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/test/pixel_test_delegating_output_surface.h" | |
15 #include "components/scheduler/test/renderer_scheduler_test_support.h" | 16 #include "components/scheduler/test/renderer_scheduler_test_support.h" |
16 #include "components/test_runner/test_common.h" | 17 #include "components/test_runner/test_common.h" |
17 #include "components/test_runner/web_frame_test_proxy.h" | 18 #include "components/test_runner/web_frame_test_proxy.h" |
18 #include "components/test_runner/web_test_proxy.h" | 19 #include "components/test_runner/web_test_proxy.h" |
19 #include "content/browser/bluetooth/bluetooth_adapter_factory_wrapper.h" | 20 #include "content/browser/bluetooth/bluetooth_adapter_factory_wrapper.h" |
20 #include "content/browser/renderer_host/render_process_host_impl.h" | 21 #include "content/browser/renderer_host/render_process_host_impl.h" |
21 #include "content/browser/renderer_host/render_widget_host_impl.h" | 22 #include "content/browser/renderer_host/render_widget_host_impl.h" |
23 #include "content/common/gpu/client/context_provider_command_buffer.h" | |
22 #include "content/common/site_isolation_policy.h" | 24 #include "content/common/site_isolation_policy.h" |
23 #include "content/public/common/page_state.h" | 25 #include "content/public/common/page_state.h" |
24 #include "content/public/renderer/renderer_gamepad_provider.h" | 26 #include "content/public/renderer/renderer_gamepad_provider.h" |
25 #include "content/renderer/fetchers/manifest_fetcher.h" | 27 #include "content/renderer/fetchers/manifest_fetcher.h" |
26 #include "content/renderer/history_entry.h" | 28 #include "content/renderer/history_entry.h" |
27 #include "content/renderer/history_serialization.h" | 29 #include "content/renderer/history_serialization.h" |
28 #include "content/renderer/layout_test_dependencies.h" | 30 #include "content/renderer/layout_test_dependencies.h" |
29 #include "content/renderer/render_frame_impl.h" | 31 #include "content/renderer/render_frame_impl.h" |
30 #include "content/renderer/render_thread_impl.h" | 32 #include "content/renderer/render_thread_impl.h" |
31 #include "content/renderer/render_view_impl.h" | 33 #include "content/renderer/render_view_impl.h" |
(...skipping 138 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
170 RendererBlinkPlatformImpl::SetMockDeviceMotionDataForTesting(data); | 172 RendererBlinkPlatformImpl::SetMockDeviceMotionDataForTesting(data); |
171 } | 173 } |
172 | 174 |
173 void SetMockDeviceOrientationData(const WebDeviceOrientationData& data) { | 175 void SetMockDeviceOrientationData(const WebDeviceOrientationData& data) { |
174 RendererBlinkPlatformImpl::SetMockDeviceOrientationDataForTesting(data); | 176 RendererBlinkPlatformImpl::SetMockDeviceOrientationDataForTesting(data); |
175 } | 177 } |
176 | 178 |
177 class LayoutTestDependenciesImpl : public LayoutTestDependencies { | 179 class LayoutTestDependenciesImpl : public LayoutTestDependencies { |
178 public: | 180 public: |
179 std::unique_ptr<cc::OutputSurface> CreateOutputSurface( | 181 std::unique_ptr<cc::OutputSurface> CreateOutputSurface( |
180 uint32_t output_surface_id, | 182 scoped_refptr<gpu::GpuChannelHost> gpu_channel, |
181 scoped_refptr<cc::ContextProvider> context_provider, | 183 scoped_refptr<cc::ContextProvider> compositor_context_provider, |
182 scoped_refptr<cc::ContextProvider> worker_context_provider) override { | 184 scoped_refptr<cc::ContextProvider> worker_context_provider, |
185 CompositorDependencies* deps) override { | |
186 // This is for an offscreen context for the compositor. So the default | |
187 // framebuffer doesn't need alpha, depth, stencil, antialiasing. | |
188 gpu::gles2::ContextCreationAttribHelper attributes; | |
189 attributes.alpha_size = -1; | |
190 attributes.depth_size = 0; | |
191 attributes.stencil_size = 0; | |
192 attributes.samples = 0; | |
193 attributes.sample_buffers = 0; | |
194 attributes.bind_generates_resource = false; | |
195 attributes.lose_context_when_out_of_memory = true; | |
196 const bool automatic_flushes = false; | |
197 const bool support_locking = false; | |
198 | |
199 scoped_refptr<cc::ContextProvider> display_context_provider( | |
200 new ContextProviderCommandBuffer( | |
201 std::move(gpu_channel), gpu::GPU_STREAM_DEFAULT, | |
202 gpu::GpuStreamPriority::NORMAL, gpu::kNullSurfaceHandle, | |
203 GURL( | |
204 "chrome://gpu/LayoutTestDependenciesImpl::CreateOutputSurface"), | |
205 gl::PreferIntegratedGpu, automatic_flushes, support_locking, | |
206 gpu::SharedMemoryLimits(), attributes, nullptr, | |
207 command_buffer_metrics::OFFSCREEN_CONTEXT_FOR_TESTING)); | |
208 | |
209 return base::MakeUnique<cc::PixelTestDelegatingOutputSurface>( | |
210 std::move(compositor_context_provider), | |
211 std::move(worker_context_provider), std::move(display_context_provider), | |
212 deps->GetSharedBitmapManager(), deps->GetGpuMemoryBufferManager(), | |
213 false, !deps->GetCompositorImplThreadTaskRunner()); | |
214 /* | |
183 return base::MakeUnique<MailboxOutputSurface>( | 215 return base::MakeUnique<MailboxOutputSurface>( |
184 output_surface_id, std::move(context_provider), | 216 output_surface_id, std::move(context_provider), |
185 std::move(worker_context_provider)); | 217 std::move(worker_context_provider)); |
218 */ | |
piman
2016/06/20 16:45:07
nit: remove
danakj
2016/06/20 23:21:00
Done.
| |
186 } | 219 } |
187 }; | 220 }; |
188 | 221 |
189 void EnableRendererLayoutTestMode() { | 222 void EnableRendererLayoutTestMode() { |
190 RenderThreadImpl::current()->set_layout_test_dependencies( | 223 RenderThreadImpl::current()->set_layout_test_dependencies( |
191 base::MakeUnique<LayoutTestDependenciesImpl>()); | 224 base::MakeUnique<LayoutTestDependenciesImpl>()); |
192 | 225 |
193 #if defined(OS_WIN) | 226 #if defined(OS_WIN) |
194 RegisterSideloadedTypefaces(SkFontMgr_New_DirectWrite()); | 227 RegisterSideloadedTypefaces(SkFontMgr_New_DirectWrite()); |
195 #endif | 228 #endif |
(...skipping 257 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
453 return result; | 486 return result; |
454 } | 487 } |
455 | 488 |
456 void SchedulerRunIdleTasks(const base::Closure& callback) { | 489 void SchedulerRunIdleTasks(const base::Closure& callback) { |
457 scheduler::RendererScheduler* scheduler = | 490 scheduler::RendererScheduler* scheduler = |
458 content::RenderThreadImpl::current()->GetRendererScheduler(); | 491 content::RenderThreadImpl::current()->GetRendererScheduler(); |
459 scheduler::RunIdleTasksForTesting(scheduler, callback); | 492 scheduler::RunIdleTasksForTesting(scheduler, callback); |
460 } | 493 } |
461 | 494 |
462 } // namespace content | 495 } // namespace content |
OLD | NEW |