OLD | NEW |
1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 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 "config.h" | 5 #include "config.h" |
6 | 6 |
7 #include "cc/delegated_renderer_layer_impl.h" | 7 #include "cc/delegated_renderer_layer_impl.h" |
8 | 8 |
9 #include "cc/append_quads_data.h" | 9 #include "cc/append_quads_data.h" |
10 #include "cc/layer_tree_host_impl.h" | 10 #include "cc/layer_tree_host_impl.h" |
11 #include "cc/quad_sink.h" | 11 #include "cc/quad_sink.h" |
12 #include "cc/render_pass_draw_quad.h" | 12 #include "cc/render_pass_draw_quad.h" |
13 #include "cc/scoped_ptr_vector.h" | 13 #include "cc/scoped_ptr_vector.h" |
14 #include "cc/single_thread_proxy.h" | 14 #include "cc/single_thread_proxy.h" |
15 #include "cc/solid_color_draw_quad.h" | 15 #include "cc/solid_color_draw_quad.h" |
16 #include "cc/solid_color_layer_impl.h" | 16 #include "cc/solid_color_layer_impl.h" |
| 17 #include "cc/test/fake_proxy.h" |
17 #include "cc/test/fake_web_compositor_output_surface.h" | 18 #include "cc/test/fake_web_compositor_output_surface.h" |
18 #include "cc/test/fake_web_graphics_context_3d.h" | 19 #include "cc/test/fake_web_graphics_context_3d.h" |
19 #include "cc/test/geometry_test_utils.h" | 20 #include "cc/test/geometry_test_utils.h" |
20 #include "cc/test/mock_quad_culler.h" | 21 #include "cc/test/mock_quad_culler.h" |
21 #include "cc/test/render_pass_test_common.h" | 22 #include "cc/test/render_pass_test_common.h" |
22 #include "testing/gtest/include/gtest/gtest.h" | 23 #include "testing/gtest/include/gtest/gtest.h" |
23 #include <public/WebTransformationMatrix.h> | 24 #include <public/WebTransformationMatrix.h> |
24 | 25 |
25 using WebKit::FakeWebCompositorOutputSurface; | 26 using WebKit::FakeWebCompositorOutputSurface; |
26 using WebKit::FakeWebGraphicsContext3D; | 27 using WebKit::FakeWebGraphicsContext3D; |
27 using WebKit::WebTransformationMatrix; | 28 using WebKit::WebTransformationMatrix; |
28 | 29 |
29 using namespace cc; | 30 using namespace cc; |
30 using namespace WebKitTests; | 31 using namespace WebKitTests; |
31 | 32 |
32 namespace { | 33 namespace { |
33 | 34 |
34 class DelegatedRendererLayerImplTest : public testing::Test, public LayerTreeHos
tImplClient { | 35 class DelegatedRendererLayerImplTest : public testing::Test, public LayerTreeHos
tImplClient { |
35 public: | 36 public: |
36 DelegatedRendererLayerImplTest() | 37 DelegatedRendererLayerImplTest() |
| 38 : m_proxy(scoped_ptr<Thread>(NULL)) |
| 39 , m_alwaysImplThreadAndMainThreadBlocked(&m_proxy) |
37 { | 40 { |
38 LayerTreeSettings settings; | 41 LayerTreeSettings settings; |
39 settings.minimumOcclusionTrackingSize = gfx::Size(); | 42 settings.minimumOcclusionTrackingSize = gfx::Size(); |
40 | 43 |
41 m_hostImpl = LayerTreeHostImpl::create(settings, this); | 44 m_hostImpl = LayerTreeHostImpl::create(settings, this, &m_proxy); |
42 m_hostImpl->initializeRenderer(createContext()); | 45 m_hostImpl->initializeRenderer(createContext()); |
43 m_hostImpl->setViewportSize(gfx::Size(10, 10), gfx::Size(10, 10)); | 46 m_hostImpl->setViewportSize(gfx::Size(10, 10), gfx::Size(10, 10)); |
44 } | 47 } |
45 | 48 |
46 // LayerTreeHostImplClient implementation. | 49 // LayerTreeHostImplClient implementation. |
47 virtual void didLoseContextOnImplThread() OVERRIDE { } | 50 virtual void didLoseContextOnImplThread() OVERRIDE { } |
48 virtual void onSwapBuffersCompleteOnImplThread() OVERRIDE { } | 51 virtual void onSwapBuffersCompleteOnImplThread() OVERRIDE { } |
49 virtual void onVSyncParametersChanged(base::TimeTicks, base::TimeDelta) OVER
RIDE { } | 52 virtual void onVSyncParametersChanged(base::TimeTicks, base::TimeDelta) OVER
RIDE { } |
50 virtual void onCanDrawStateChanged(bool) OVERRIDE { } | 53 virtual void onCanDrawStateChanged(bool) OVERRIDE { } |
51 virtual void setNeedsRedrawOnImplThread() OVERRIDE { } | 54 virtual void setNeedsRedrawOnImplThread() OVERRIDE { } |
52 virtual void setNeedsCommitOnImplThread() OVERRIDE { } | 55 virtual void setNeedsCommitOnImplThread() OVERRIDE { } |
53 virtual void postAnimationEventsToMainThreadOnImplThread(scoped_ptr<Animatio
nEventsVector>, base::Time wallClockTime) OVERRIDE { } | 56 virtual void postAnimationEventsToMainThreadOnImplThread(scoped_ptr<Animatio
nEventsVector>, base::Time wallClockTime) OVERRIDE { } |
54 virtual bool reduceContentsTextureMemoryOnImplThread(size_t limitBytes, int
priorityCutoff) OVERRIDE { return true; } | 57 virtual bool reduceContentsTextureMemoryOnImplThread(size_t limitBytes, int
priorityCutoff) OVERRIDE { return true; } |
55 virtual void sendManagedMemoryStats() OVERRIDE { } | 58 virtual void sendManagedMemoryStats() OVERRIDE { } |
56 | 59 |
57 protected: | 60 protected: |
58 scoped_ptr<GraphicsContext> createContext() | 61 scoped_ptr<GraphicsContext> createContext() |
59 { | 62 { |
60 return FakeWebCompositorOutputSurface::create(scoped_ptr<WebKit::WebGrap
hicsContext3D>(new FakeWebGraphicsContext3D)).PassAs<GraphicsContext>(); | 63 return FakeWebCompositorOutputSurface::create(scoped_ptr<WebKit::WebGrap
hicsContext3D>(new FakeWebGraphicsContext3D)).PassAs<GraphicsContext>(); |
61 } | 64 } |
62 | 65 |
63 DebugScopedSetImplThread m_alwaysImplThread; | 66 FakeProxy m_proxy; |
64 DebugScopedSetMainThreadBlocked m_alwaysMainThreadBlocked; | 67 DebugScopedSetImplThreadAndMainThreadBlocked m_alwaysImplThreadAndMainThread
Blocked; |
65 | |
66 scoped_ptr<LayerTreeHostImpl> m_hostImpl; | 68 scoped_ptr<LayerTreeHostImpl> m_hostImpl; |
67 }; | 69 }; |
68 | 70 |
69 static TestRenderPass* addRenderPass(ScopedPtrVector<RenderPass>& passList, Rend
erPass::Id id, gfx::Rect outputRect, WebTransformationMatrix rootTransform) | 71 static TestRenderPass* addRenderPass(ScopedPtrVector<RenderPass>& passList, Rend
erPass::Id id, gfx::Rect outputRect, WebTransformationMatrix rootTransform) |
70 { | 72 { |
71 scoped_ptr<TestRenderPass> pass(TestRenderPass::create(id, outputRect, rootT
ransform)); | 73 scoped_ptr<TestRenderPass> pass(TestRenderPass::create(id, outputRect, rootT
ransform)); |
72 TestRenderPass* saved = pass.get(); | 74 TestRenderPass* saved = pass.get(); |
73 passList.append(pass.PassAs<RenderPass>()); | 75 passList.append(pass.PassAs<RenderPass>()); |
74 return saved; | 76 return saved; |
75 } | 77 } |
(...skipping 370 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
446 EXPECT_EQ(sharedState, quadList[3]->sharedQuadState()); | 448 EXPECT_EQ(sharedState, quadList[3]->sharedQuadState()); |
447 | 449 |
448 // The state should be transformed only once. | 450 // The state should be transformed only once. |
449 EXPECT_RECT_EQ(gfx::Rect(30, 30, 50, 50), sharedState->clippedRectInTarget); | 451 EXPECT_RECT_EQ(gfx::Rect(30, 30, 50, 50), sharedState->clippedRectInTarget); |
450 WebTransformationMatrix expected; | 452 WebTransformationMatrix expected; |
451 expected.translate(30, 30); | 453 expected.translate(30, 30); |
452 EXPECT_TRANSFORMATION_MATRIX_EQ(expected, sharedState->quadTransform); | 454 EXPECT_TRANSFORMATION_MATRIX_EQ(expected, sharedState->quadTransform); |
453 } | 455 } |
454 | 456 |
455 } // annonymous namespace | 457 } // annonymous namespace |
OLD | NEW |