OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 "content/public/test/layouttest_support.h" | 5 #include "content/public/test/layouttest_support.h" |
6 | 6 |
7 #include <stddef.h> | 7 #include <stddef.h> |
8 #include <utility> | 8 #include <utility> |
9 | 9 |
10 #include "base/callback.h" | 10 #include "base/callback.h" |
11 #include "base/lazy_instance.h" | 11 #include "base/lazy_instance.h" |
12 #include "base/memory/ptr_util.h" | 12 #include "base/memory/ptr_util.h" |
13 #include "base/strings/string_util.h" | 13 #include "base/strings/string_util.h" |
14 #include "build/build_config.h" | 14 #include "build/build_config.h" |
15 #include "cc/output/copy_output_request.h" | 15 #include "cc/output/copy_output_request.h" |
16 #include "cc/test/pixel_test_output_surface.h" | 16 #include "cc/test/pixel_test_output_surface.h" |
17 #include "cc/test/test_delegating_output_surface.h" | 17 #include "cc/test/test_delegating_output_surface.h" |
18 #include "components/scheduler/test/renderer_scheduler_test_support.h" | 18 #include "components/scheduler/test/renderer_scheduler_test_support.h" |
19 #include "components/test_runner/test_common.h" | 19 #include "components/test_runner/test_common.h" |
20 #include "components/test_runner/web_frame_test_proxy.h" | 20 #include "components/test_runner/web_frame_test_proxy.h" |
21 #include "components/test_runner/web_view_test_proxy.h" | 21 #include "components/test_runner/web_view_test_proxy.h" |
22 #include "components/test_runner/web_widget_test_proxy.h" | |
22 #include "content/browser/bluetooth/bluetooth_device_chooser_controller.h" | 23 #include "content/browser/bluetooth/bluetooth_device_chooser_controller.h" |
23 #include "content/browser/renderer_host/render_process_host_impl.h" | 24 #include "content/browser/renderer_host/render_process_host_impl.h" |
24 #include "content/browser/renderer_host/render_widget_host_impl.h" | 25 #include "content/browser/renderer_host/render_widget_host_impl.h" |
25 #include "content/common/gpu/client/context_provider_command_buffer.h" | 26 #include "content/common/gpu/client/context_provider_command_buffer.h" |
26 #include "content/common/site_isolation_policy.h" | 27 #include "content/common/site_isolation_policy.h" |
27 #include "content/public/common/page_state.h" | 28 #include "content/public/common/page_state.h" |
28 #include "content/public/renderer/renderer_gamepad_provider.h" | 29 #include "content/public/renderer/renderer_gamepad_provider.h" |
29 #include "content/renderer/fetchers/manifest_fetcher.h" | 30 #include "content/renderer/fetchers/manifest_fetcher.h" |
30 #include "content/renderer/gpu/render_widget_compositor.h" | 31 #include "content/renderer/gpu/render_widget_compositor.h" |
31 #include "content/renderer/history_entry.h" | 32 #include "content/renderer/history_entry.h" |
32 #include "content/renderer/history_serialization.h" | 33 #include "content/renderer/history_serialization.h" |
33 #include "content/renderer/layout_test_dependencies.h" | 34 #include "content/renderer/layout_test_dependencies.h" |
34 #include "content/renderer/render_frame_impl.h" | 35 #include "content/renderer/render_frame_impl.h" |
35 #include "content/renderer/render_thread_impl.h" | 36 #include "content/renderer/render_thread_impl.h" |
36 #include "content/renderer/render_view_impl.h" | 37 #include "content/renderer/render_view_impl.h" |
38 #include "content/renderer/render_widget.h" | |
37 #include "content/renderer/renderer_blink_platform_impl.h" | 39 #include "content/renderer/renderer_blink_platform_impl.h" |
38 #include "content/shell/common/shell_switches.h" | 40 #include "content/shell/common/shell_switches.h" |
39 #include "gpu/ipc/service/image_transport_surface.h" | 41 #include "gpu/ipc/service/image_transport_surface.h" |
40 #include "third_party/WebKit/public/platform/WebFloatRect.h" | 42 #include "third_party/WebKit/public/platform/WebFloatRect.h" |
41 #include "third_party/WebKit/public/platform/WebGamepads.h" | 43 #include "third_party/WebKit/public/platform/WebGamepads.h" |
42 #include "third_party/WebKit/public/platform/modules/device_orientation/WebDevic eMotionData.h" | 44 #include "third_party/WebKit/public/platform/modules/device_orientation/WebDevic eMotionData.h" |
43 #include "third_party/WebKit/public/platform/modules/device_orientation/WebDevic eOrientationData.h" | 45 #include "third_party/WebKit/public/platform/modules/device_orientation/WebDevic eOrientationData.h" |
44 #include "third_party/WebKit/public/web/WebHistoryItem.h" | 46 #include "third_party/WebKit/public/web/WebHistoryItem.h" |
45 #include "third_party/WebKit/public/web/WebView.h" | 47 #include "third_party/WebKit/public/web/WebView.h" |
46 | 48 |
(...skipping 14 matching lines...) Expand all Loading... | |
61 using blink::WebRect; | 63 using blink::WebRect; |
62 using blink::WebSize; | 64 using blink::WebSize; |
63 | 65 |
64 namespace content { | 66 namespace content { |
65 | 67 |
66 namespace { | 68 namespace { |
67 | 69 |
68 base::LazyInstance<ViewProxyCreationCallback>::Leaky | 70 base::LazyInstance<ViewProxyCreationCallback>::Leaky |
69 g_view_test_proxy_callback = LAZY_INSTANCE_INITIALIZER; | 71 g_view_test_proxy_callback = LAZY_INSTANCE_INITIALIZER; |
70 | 72 |
73 base::LazyInstance<WidgetProxyCreationCallback>::Leaky | |
74 g_widget_test_proxy_callback = LAZY_INSTANCE_INITIALIZER; | |
75 | |
71 base::LazyInstance<FrameProxyCreationCallback>::Leaky | 76 base::LazyInstance<FrameProxyCreationCallback>::Leaky |
72 g_frame_test_proxy_callback = LAZY_INSTANCE_INITIALIZER; | 77 g_frame_test_proxy_callback = LAZY_INSTANCE_INITIALIZER; |
73 | 78 |
74 using WebViewTestProxyType = | 79 using WebViewTestProxyType = |
75 test_runner::WebViewTestProxy<RenderViewImpl, | 80 test_runner::WebViewTestProxy<RenderViewImpl, |
76 CompositorDependencies*, | 81 CompositorDependencies*, |
77 const ViewMsg_New_Params&>; | 82 const ViewMsg_New_Params&>; |
83 using WebWidgetTestProxyType = | |
84 test_runner::WebWidgetTestProxy<RenderWidget, | |
85 CompositorDependencies*, | |
86 blink::WebPopupType, | |
87 const blink::WebScreenInfo&, | |
88 bool, | |
89 bool, | |
90 bool>; | |
78 using WebFrameTestProxyType = | 91 using WebFrameTestProxyType = |
79 test_runner::WebFrameTestProxy<RenderFrameImpl, | 92 test_runner::WebFrameTestProxy<RenderFrameImpl, |
80 const RenderFrameImpl::CreateParams&>; | 93 const RenderFrameImpl::CreateParams&>; |
81 | 94 |
82 RenderViewImpl* CreateWebViewTestProxy(CompositorDependencies* compositor_deps, | 95 RenderViewImpl* CreateWebViewTestProxy(CompositorDependencies* compositor_deps, |
83 const ViewMsg_New_Params& params) { | 96 const ViewMsg_New_Params& params) { |
84 WebViewTestProxyType* render_view_proxy = | 97 WebViewTestProxyType* render_view_proxy = |
85 new WebViewTestProxyType(compositor_deps, params); | 98 new WebViewTestProxyType(compositor_deps, params); |
86 if (g_view_test_proxy_callback == 0) | 99 if (g_view_test_proxy_callback == 0) |
87 return render_view_proxy; | 100 return render_view_proxy; |
88 g_view_test_proxy_callback.Get().Run(render_view_proxy, render_view_proxy); | 101 g_view_test_proxy_callback.Get().Run(render_view_proxy, render_view_proxy); |
89 return render_view_proxy; | 102 return render_view_proxy; |
90 } | 103 } |
91 | 104 |
105 RenderWidget* CreateWebWidgetTestProxy(CompositorDependencies* compositor_deps, | |
106 blink::WebPopupType popup_type, | |
107 const blink::WebScreenInfo& screen_info, | |
108 bool swapped_out, | |
109 bool hidden, | |
110 bool never_visible) { | |
111 WebWidgetTestProxyType* render_widget_proxy = | |
112 new WebWidgetTestProxyType(compositor_deps, popup_type, screen_info, | |
113 swapped_out, hidden, never_visible); | |
114 return render_widget_proxy; | |
115 } | |
116 | |
117 void RenderWidgetCreated(RenderWidget* render_widget) { | |
118 WebWidgetTestProxyType* render_widget_proxy = | |
119 static_cast<WebWidgetTestProxyType*>(render_widget); | |
120 if (!(g_widget_test_proxy_callback == 0)) { | |
Łukasz Anforowicz
2016/08/11 17:19:28
nit: I found the code for this condition a bit wei
lfg
2016/08/11 19:49:39
I agree that this isn't very nice. Looking at this
jam
2016/08/15 20:07:44
if (!g_widget_test_proxy_callback.Get().is_null())
| |
121 g_widget_test_proxy_callback.Get().Run(render_widget->webwidget(), | |
122 render_widget_proxy); | |
123 } | |
124 } | |
125 | |
92 RenderFrameImpl* CreateWebFrameTestProxy( | 126 RenderFrameImpl* CreateWebFrameTestProxy( |
93 const RenderFrameImpl::CreateParams& params) { | 127 const RenderFrameImpl::CreateParams& params) { |
94 WebFrameTestProxyType* render_frame_proxy = new WebFrameTestProxyType(params); | 128 WebFrameTestProxyType* render_frame_proxy = new WebFrameTestProxyType(params); |
95 if (g_frame_test_proxy_callback == 0) | 129 if (g_frame_test_proxy_callback == 0) |
96 return render_frame_proxy; | 130 return render_frame_proxy; |
97 g_frame_test_proxy_callback.Get().Run(render_frame_proxy, render_frame_proxy); | 131 g_frame_test_proxy_callback.Get().Run(render_frame_proxy, render_frame_proxy); |
98 return render_frame_proxy; | 132 return render_frame_proxy; |
99 } | 133 } |
100 | 134 |
101 #if defined(OS_WIN) | 135 #if defined(OS_WIN) |
(...skipping 21 matching lines...) Expand all Loading... | |
123 | 157 |
124 test_runner::WebFrameTestProxyBase* GetWebFrameTestProxyBase( | 158 test_runner::WebFrameTestProxyBase* GetWebFrameTestProxyBase( |
125 RenderFrame* render_frame) { | 159 RenderFrame* render_frame) { |
126 WebFrameTestProxyType* render_frame_proxy = | 160 WebFrameTestProxyType* render_frame_proxy = |
127 static_cast<WebFrameTestProxyType*>(render_frame); | 161 static_cast<WebFrameTestProxyType*>(render_frame); |
128 return static_cast<test_runner::WebFrameTestProxyBase*>(render_frame_proxy); | 162 return static_cast<test_runner::WebFrameTestProxyBase*>(render_frame_proxy); |
129 } | 163 } |
130 | 164 |
131 void EnableWebTestProxyCreation( | 165 void EnableWebTestProxyCreation( |
132 const ViewProxyCreationCallback& view_proxy_creation_callback, | 166 const ViewProxyCreationCallback& view_proxy_creation_callback, |
167 const WidgetProxyCreationCallback& widget_proxy_creation_callback, | |
133 const FrameProxyCreationCallback& frame_proxy_creation_callback) { | 168 const FrameProxyCreationCallback& frame_proxy_creation_callback) { |
134 g_view_test_proxy_callback.Get() = view_proxy_creation_callback; | 169 g_view_test_proxy_callback.Get() = view_proxy_creation_callback; |
170 g_widget_test_proxy_callback.Get() = widget_proxy_creation_callback; | |
135 g_frame_test_proxy_callback.Get() = frame_proxy_creation_callback; | 171 g_frame_test_proxy_callback.Get() = frame_proxy_creation_callback; |
136 RenderViewImpl::InstallCreateHook(CreateWebViewTestProxy); | 172 RenderViewImpl::InstallCreateHook(CreateWebViewTestProxy); |
173 RenderWidget::InstallCreateHook(CreateWebWidgetTestProxy, | |
174 RenderWidgetCreated); | |
137 RenderFrameImpl::InstallCreateHook(CreateWebFrameTestProxy); | 175 RenderFrameImpl::InstallCreateHook(CreateWebFrameTestProxy); |
138 } | 176 } |
139 | 177 |
140 void FetchManifestDoneCallback(std::unique_ptr<ManifestFetcher> fetcher, | 178 void FetchManifestDoneCallback(std::unique_ptr<ManifestFetcher> fetcher, |
141 const FetchManifestCallback& callback, | 179 const FetchManifestCallback& callback, |
142 const blink::WebURLResponse& response, | 180 const blink::WebURLResponse& response, |
143 const std::string& data) { | 181 const std::string& data) { |
144 // |fetcher| will be autodeleted here as it is going out of scope. | 182 // |fetcher| will be autodeleted here as it is going out of scope. |
145 callback.Run(response, data); | 183 callback.Run(response, data); |
146 } | 184 } |
(...skipping 423 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
570 return result; | 608 return result; |
571 } | 609 } |
572 | 610 |
573 void SchedulerRunIdleTasks(const base::Closure& callback) { | 611 void SchedulerRunIdleTasks(const base::Closure& callback) { |
574 scheduler::RendererScheduler* scheduler = | 612 scheduler::RendererScheduler* scheduler = |
575 content::RenderThreadImpl::current()->GetRendererScheduler(); | 613 content::RenderThreadImpl::current()->GetRendererScheduler(); |
576 scheduler::RunIdleTasksForTesting(scheduler, callback); | 614 scheduler::RunIdleTasksForTesting(scheduler, callback); |
577 } | 615 } |
578 | 616 |
579 } // namespace content | 617 } // namespace content |
OLD | NEW |