Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "components/html_viewer/layout_test_content_handler_impl.h" | 5 #include "components/html_viewer/layout_test_content_handler_impl.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "components/html_viewer/html_document_application_delegate.h" | 8 #include "components/html_viewer/html_document_application_delegate.h" |
| 9 #include "components/html_viewer/web_test_delegate_impl.h" | 9 #include "components/html_viewer/web_test_delegate_impl.h" |
| 10 #include "components/test_runner/web_frame_test_proxy.h" | 10 #include "components/test_runner/web_frame_test_proxy.h" |
| 11 #include "components/test_runner/web_test_proxy.h" | 11 #include "components/test_runner/web_test_proxy.h" |
| 12 #include "third_party/WebKit/public/web/WebTestingSupport.h" | 12 #include "third_party/WebKit/public/web/WebTestingSupport.h" |
| 13 #include "third_party/WebKit/public/web/WebView.h" | 13 #include "third_party/WebKit/public/web/WebView.h" |
| 14 | 14 |
| 15 namespace html_viewer { | 15 namespace html_viewer { |
| 16 | 16 |
| 17 class TestHTMLFrame : public HTMLFrame { | |
| 18 public: | |
| 19 explicit TestHTMLFrame(HTMLFrame::CreateParams* params) : HTMLFrame(params) {} | |
| 20 | |
| 21 ~TestHTMLFrame() override {} | |
| 22 | |
| 23 private: | |
| 24 // blink::WebFrameClient:: | |
| 25 void didClearWindowObject(blink::WebLocalFrame* frame) override { | |
| 26 blink::WebTestingSupport::injectInternalsObject(frame); | |
|
sky
2015/08/18 18:13:57
Should you call through to the base class?
sadrul
2015/08/18 20:06:34
Done.
| |
| 27 } | |
| 28 | |
| 29 DISALLOW_COPY_AND_ASSIGN(TestHTMLFrame); | |
| 30 }; | |
| 31 | |
| 17 LayoutTestContentHandlerImpl::LayoutTestContentHandlerImpl( | 32 LayoutTestContentHandlerImpl::LayoutTestContentHandlerImpl( |
| 18 GlobalState* global_state, | 33 GlobalState* global_state, |
| 19 mojo::ApplicationImpl* app, | 34 mojo::ApplicationImpl* app, |
| 20 mojo::InterfaceRequest<mojo::ContentHandler> request, | 35 mojo::InterfaceRequest<mojo::ContentHandler> request, |
| 21 test_runner::WebTestInterfaces* test_interfaces, | 36 test_runner::WebTestInterfaces* test_interfaces, |
| 22 WebTestDelegateImpl* test_delegate) | 37 WebTestDelegateImpl* test_delegate) |
| 23 : ContentHandlerImpl(global_state, app, request.Pass()), | 38 : ContentHandlerImpl(global_state, app, request.Pass()), |
| 24 test_interfaces_(test_interfaces), | 39 test_interfaces_(test_interfaces), |
| 25 test_delegate_(test_delegate) { | 40 test_delegate_(test_delegate) { |
| 26 } | 41 } |
| (...skipping 13 matching lines...) Expand all Loading... | |
| 40 request.Pass(), response.Pass(), global_state(), | 55 request.Pass(), response.Pass(), global_state(), |
| 41 app()->app_lifetime_helper()->CreateAppRefCount()); | 56 app()->app_lifetime_helper()->CreateAppRefCount()); |
| 42 | 57 |
| 43 delegate->SetHTMLFrameCreationCallback(base::Bind( | 58 delegate->SetHTMLFrameCreationCallback(base::Bind( |
| 44 &LayoutTestContentHandlerImpl::CreateHTMLFrame, base::Unretained(this))); | 59 &LayoutTestContentHandlerImpl::CreateHTMLFrame, base::Unretained(this))); |
| 45 } | 60 } |
| 46 | 61 |
| 47 HTMLFrame* LayoutTestContentHandlerImpl::CreateHTMLFrame( | 62 HTMLFrame* LayoutTestContentHandlerImpl::CreateHTMLFrame( |
| 48 HTMLFrame::CreateParams* params) { | 63 HTMLFrame::CreateParams* params) { |
| 49 using ProxyType = test_runner::WebTestProxy< | 64 using ProxyType = test_runner::WebTestProxy< |
| 50 test_runner::WebFrameTestProxy<HTMLFrame, HTMLFrame::CreateParams*>, | 65 test_runner::WebFrameTestProxy<TestHTMLFrame, HTMLFrame::CreateParams*>, |
| 51 HTMLFrame::CreateParams*>; | 66 HTMLFrame::CreateParams*>; |
| 52 // TODO(sky): this isn't right for all frame types, eg remote frames. | 67 // TODO(sky): this isn't right for all frame types, eg remote frames. |
| 53 ProxyType* proxy = new ProxyType(params); | 68 ProxyType* proxy = new ProxyType(params); |
| 69 blink::WebView* web_view = proxy->web_view(); | |
| 70 if (!web_view) | |
| 71 web_view = params->manager->GetWebView(); | |
|
sadrul
2015/08/18 08:00:13
This does avoid a crash on start-up below (line ~7
sky
2015/08/18 18:13:57
Are you trying to run a test that creates multiple
sadrul
2015/08/18 20:06:34
Indeed, the test this was failing on did have an i
| |
| 72 CHECK(web_view); | |
| 54 proxy->SetInterfaces(test_interfaces_); | 73 proxy->SetInterfaces(test_interfaces_); |
| 55 proxy->SetDelegate(test_delegate_); | 74 proxy->SetDelegate(test_delegate_); |
| 56 proxy->set_base_proxy(proxy); | 75 proxy->set_base_proxy(proxy); |
| 57 test_delegate_->set_test_proxy(proxy); | 76 test_delegate_->set_test_proxy(proxy); |
| 58 test_interfaces_->SetWebView(proxy->web_view(), proxy); | 77 test_interfaces_->SetWebView(web_view, proxy); |
| 59 proxy->set_widget(proxy->web_view()); | 78 proxy->set_widget(web_view); |
| 60 blink::WebTestingSupport::injectInternalsObject( | 79 test_interfaces_->BindTo(web_view->mainFrame()); |
| 61 proxy->web_view()->mainFrame()->toWebLocalFrame()); | |
| 62 test_interfaces_->BindTo(proxy->web_view()->mainFrame()); | |
| 63 return proxy; | 80 return proxy; |
| 64 } | 81 } |
| 65 | 82 |
| 66 } // namespace html_viewer | 83 } // namespace html_viewer |
| OLD | NEW |