| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 "cc/output/delegating_renderer.h" | 5 #include "cc/output/delegating_renderer.h" |
| 6 | 6 |
| 7 #include <stdint.h> | 7 #include <stdint.h> |
| 8 | 8 |
| 9 #include "cc/test/fake_output_surface.h" | 9 #include "cc/test/fake_output_surface.h" |
| 10 #include "cc/test/layer_tree_test.h" | 10 #include "cc/test/layer_tree_test.h" |
| 11 #include "cc/test/render_pass_test_utils.h" | 11 #include "cc/test/render_pass_test_utils.h" |
| 12 #include "testing/gtest/include/gtest/gtest.h" | 12 #include "testing/gtest/include/gtest/gtest.h" |
| 13 | 13 |
| 14 namespace cc { | 14 namespace cc { |
| 15 | 15 |
| 16 class DelegatingRendererTest : public LayerTreeTest { | 16 class DelegatingRendererTest : public LayerTreeTest {}; |
| 17 public: | |
| 18 DelegatingRendererTest() : LayerTreeTest(), output_surface_(NULL) {} | |
| 19 ~DelegatingRendererTest() override {} | |
| 20 | |
| 21 std::unique_ptr<OutputSurface> CreateOutputSurface() override { | |
| 22 std::unique_ptr<FakeOutputSurface> output_surface = | |
| 23 FakeOutputSurface::CreateDelegating3d(); | |
| 24 output_surface_ = output_surface.get(); | |
| 25 return std::move(output_surface); | |
| 26 } | |
| 27 | |
| 28 protected: | |
| 29 TestWebGraphicsContext3D* context3d_; | |
| 30 FakeOutputSurface* output_surface_; | |
| 31 }; | |
| 32 | 17 |
| 33 class DelegatingRendererTestDraw : public DelegatingRendererTest { | 18 class DelegatingRendererTestDraw : public DelegatingRendererTest { |
| 34 public: | 19 public: |
| 35 void BeginTest() override { | 20 void BeginTest() override { |
| 36 layer_tree_host()->SetPageScaleFactorAndLimits(1.f, 0.5f, 4.f); | 21 layer_tree_host()->SetPageScaleFactorAndLimits(1.f, 0.5f, 4.f); |
| 37 PostSetNeedsCommitToMainThread(); | 22 PostSetNeedsCommitToMainThread(); |
| 38 } | 23 } |
| 39 | 24 |
| 40 void AfterTest() override {} | 25 void AfterTest() override {} |
| 41 | 26 |
| 42 DrawResult PrepareToDrawOnThread(LayerTreeHostImpl* host_impl, | |
| 43 LayerTreeHostImpl::FrameData* frame, | |
| 44 DrawResult draw_result) override { | |
| 45 EXPECT_EQ(0u, output_surface_->num_sent_frames()); | |
| 46 | |
| 47 const CompositorFrame* last_frame = output_surface_->last_sent_frame(); | |
| 48 EXPECT_EQ(nullptr, last_frame); | |
| 49 return DRAW_SUCCESS; | |
| 50 } | |
| 51 | |
| 52 void DrawLayersOnThread(LayerTreeHostImpl* host_impl) override { | 27 void DrawLayersOnThread(LayerTreeHostImpl* host_impl) override { |
| 53 EXPECT_EQ(0u, output_surface_->num_sent_frames()); | 28 EXPECT_EQ(0, num_swaps_); |
| 54 drawn_viewport_ = host_impl->DeviceViewport(); | 29 drawn_viewport_ = host_impl->DeviceViewport(); |
| 55 } | 30 } |
| 56 | 31 |
| 57 void SwapBuffersCompleteOnThread() override { | 32 void DisplayReceivedCompositorFrameOnThread( |
| 58 EXPECT_EQ(1u, output_surface_->num_sent_frames()); | 33 const CompositorFrame& frame) override { |
| 34 EXPECT_EQ(1, ++num_swaps_); |
| 59 | 35 |
| 60 const CompositorFrame* last_frame = output_surface_->last_sent_frame(); | 36 DelegatedFrameData* last_frame_data = frame.delegated_frame_data.get(); |
| 61 DelegatedFrameData* last_frame_data = | 37 ASSERT_TRUE(frame.delegated_frame_data); |
| 62 last_frame->delegated_frame_data.get(); | 38 EXPECT_FALSE(frame.gl_frame_data); |
| 63 ASSERT_TRUE(last_frame->delegated_frame_data); | |
| 64 EXPECT_FALSE(last_frame->gl_frame_data); | |
| 65 EXPECT_EQ(drawn_viewport_, | 39 EXPECT_EQ(drawn_viewport_, |
| 66 last_frame_data->render_pass_list.back()->output_rect); | 40 last_frame_data->render_pass_list.back()->output_rect); |
| 67 EXPECT_EQ(0.5f, last_frame->metadata.min_page_scale_factor); | 41 EXPECT_EQ(0.5f, frame.metadata.min_page_scale_factor); |
| 68 EXPECT_EQ(4.f, last_frame->metadata.max_page_scale_factor); | 42 EXPECT_EQ(4.f, frame.metadata.max_page_scale_factor); |
| 69 | 43 |
| 70 EXPECT_EQ(0u, last_frame->delegated_frame_data->resource_list.size()); | 44 EXPECT_EQ(0u, frame.delegated_frame_data->resource_list.size()); |
| 71 EXPECT_EQ(1u, last_frame->delegated_frame_data->render_pass_list.size()); | 45 EXPECT_EQ(1u, frame.delegated_frame_data->render_pass_list.size()); |
| 72 | 46 |
| 73 EndTest(); | 47 EndTest(); |
| 74 } | 48 } |
| 75 | 49 |
| 50 int num_swaps_ = 0; |
| 76 gfx::Rect drawn_viewport_; | 51 gfx::Rect drawn_viewport_; |
| 77 }; | 52 }; |
| 78 | 53 |
| 79 SINGLE_AND_MULTI_THREAD_TEST_F(DelegatingRendererTestDraw); | 54 SINGLE_AND_MULTI_THREAD_TEST_F(DelegatingRendererTestDraw); |
| 80 | 55 |
| 81 class DelegatingRendererTestResources : public DelegatingRendererTest { | 56 class DelegatingRendererTestResources : public DelegatingRendererTest { |
| 82 public: | 57 public: |
| 83 void BeginTest() override { PostSetNeedsCommitToMainThread(); } | 58 void BeginTest() override { PostSetNeedsCommitToMainThread(); } |
| 84 | 59 |
| 85 void AfterTest() override {} | 60 void AfterTest() override {} |
| (...skipping 10 matching lines...) Expand all Loading... |
| 96 AddOneOfEveryQuadType(child_pass, host_impl->resource_provider(), | 71 AddOneOfEveryQuadType(child_pass, host_impl->resource_provider(), |
| 97 RenderPassId(0, 0), &mailbox_sync_token); | 72 RenderPassId(0, 0), &mailbox_sync_token); |
| 98 | 73 |
| 99 RenderPass* pass = AddRenderPass(&frame->render_passes, RenderPassId(1, 1), | 74 RenderPass* pass = AddRenderPass(&frame->render_passes, RenderPassId(1, 1), |
| 100 gfx::Rect(3, 3, 10, 10), gfx::Transform()); | 75 gfx::Rect(3, 3, 10, 10), gfx::Transform()); |
| 101 AddOneOfEveryQuadType(pass, host_impl->resource_provider(), child_pass->id, | 76 AddOneOfEveryQuadType(pass, host_impl->resource_provider(), child_pass->id, |
| 102 &mailbox_sync_token); | 77 &mailbox_sync_token); |
| 103 return draw_result; | 78 return draw_result; |
| 104 } | 79 } |
| 105 | 80 |
| 106 void DrawLayersOnThread(LayerTreeHostImpl* host_impl) override { | 81 void DisplayReceivedCompositorFrameOnThread( |
| 107 EXPECT_EQ(0u, output_surface_->num_sent_frames()); | 82 const CompositorFrame& frame) override { |
| 108 } | 83 ASSERT_TRUE(frame.delegated_frame_data); |
| 109 | 84 |
| 110 void SwapBuffersCompleteOnThread() override { | 85 EXPECT_EQ(2u, frame.delegated_frame_data->render_pass_list.size()); |
| 111 EXPECT_EQ(1u, output_surface_->num_sent_frames()); | |
| 112 | |
| 113 const CompositorFrame* last_frame = output_surface_->last_sent_frame(); | |
| 114 ASSERT_TRUE(last_frame->delegated_frame_data); | |
| 115 | |
| 116 EXPECT_EQ(2u, last_frame->delegated_frame_data->render_pass_list.size()); | |
| 117 // Each render pass has 10 resources in it. And the root render pass has a | 86 // Each render pass has 10 resources in it. And the root render pass has a |
| 118 // mask resource used when drawing the child render pass, as well as its | 87 // mask resource used when drawing the child render pass, as well as its |
| 119 // replica (it's added twice). The number 10 may change if | 88 // replica (it's added twice). The number 10 may change if |
| 120 // AppendOneOfEveryQuadType() is updated, and the value here should be | 89 // AppendOneOfEveryQuadType() is updated, and the value here should be |
| 121 // updated accordingly. | 90 // updated accordingly. |
| 122 EXPECT_EQ(22u, last_frame->delegated_frame_data->resource_list.size()); | 91 EXPECT_EQ(22u, frame.delegated_frame_data->resource_list.size()); |
| 123 | 92 |
| 124 EndTest(); | 93 EndTest(); |
| 125 } | 94 } |
| 126 }; | 95 }; |
| 127 | 96 |
| 128 SINGLE_AND_MULTI_THREAD_TEST_F(DelegatingRendererTestResources); | 97 SINGLE_AND_MULTI_THREAD_TEST_F(DelegatingRendererTestResources); |
| 129 | 98 |
| 130 } // namespace cc | 99 } // namespace cc |
| OLD | NEW |