Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(190)

Side by Side Diff: cc/output/delegating_renderer_unittest.cc

Issue 2193293004: cc: Make LayerTreeTests use a DelegatingRenderer and Display. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: display-layertreetest: withperftestsfix Created 4 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « cc/layers/texture_layer_unittest.cc ('k') | cc/output/renderer_unittest.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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
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
OLDNEW
« no previous file with comments | « cc/layers/texture_layer_unittest.cc ('k') | cc/output/renderer_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698