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

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

Issue 2208693003: Revert of cc: Make LayerTreeTests use a DelegatingRenderer and Display. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: 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 };
17 32
18 class DelegatingRendererTestDraw : public DelegatingRendererTest { 33 class DelegatingRendererTestDraw : public DelegatingRendererTest {
19 public: 34 public:
20 void BeginTest() override { 35 void BeginTest() override {
21 layer_tree_host()->SetPageScaleFactorAndLimits(1.f, 0.5f, 4.f); 36 layer_tree_host()->SetPageScaleFactorAndLimits(1.f, 0.5f, 4.f);
22 PostSetNeedsCommitToMainThread(); 37 PostSetNeedsCommitToMainThread();
23 } 38 }
24 39
25 void AfterTest() override {} 40 void AfterTest() override {}
26 41
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
27 void DrawLayersOnThread(LayerTreeHostImpl* host_impl) override { 52 void DrawLayersOnThread(LayerTreeHostImpl* host_impl) override {
28 EXPECT_EQ(0, num_swaps_); 53 EXPECT_EQ(0u, output_surface_->num_sent_frames());
29 drawn_viewport_ = host_impl->DeviceViewport(); 54 drawn_viewport_ = host_impl->DeviceViewport();
30 } 55 }
31 56
32 void DisplayReceivedCompositorFrameOnThread( 57 void SwapBuffersCompleteOnThread() override {
33 const CompositorFrame& frame) override { 58 EXPECT_EQ(1u, output_surface_->num_sent_frames());
34 EXPECT_EQ(1, ++num_swaps_);
35 59
36 DelegatedFrameData* last_frame_data = frame.delegated_frame_data.get(); 60 const CompositorFrame* last_frame = output_surface_->last_sent_frame();
37 ASSERT_TRUE(frame.delegated_frame_data); 61 DelegatedFrameData* last_frame_data =
38 EXPECT_FALSE(frame.gl_frame_data); 62 last_frame->delegated_frame_data.get();
63 ASSERT_TRUE(last_frame->delegated_frame_data);
64 EXPECT_FALSE(last_frame->gl_frame_data);
39 EXPECT_EQ(drawn_viewport_, 65 EXPECT_EQ(drawn_viewport_,
40 last_frame_data->render_pass_list.back()->output_rect); 66 last_frame_data->render_pass_list.back()->output_rect);
41 EXPECT_EQ(0.5f, frame.metadata.min_page_scale_factor); 67 EXPECT_EQ(0.5f, last_frame->metadata.min_page_scale_factor);
42 EXPECT_EQ(4.f, frame.metadata.max_page_scale_factor); 68 EXPECT_EQ(4.f, last_frame->metadata.max_page_scale_factor);
43 69
44 EXPECT_EQ(0u, frame.delegated_frame_data->resource_list.size()); 70 EXPECT_EQ(0u, last_frame->delegated_frame_data->resource_list.size());
45 EXPECT_EQ(1u, frame.delegated_frame_data->render_pass_list.size()); 71 EXPECT_EQ(1u, last_frame->delegated_frame_data->render_pass_list.size());
46 72
47 EndTest(); 73 EndTest();
48 } 74 }
49 75
50 int num_swaps_ = 0;
51 gfx::Rect drawn_viewport_; 76 gfx::Rect drawn_viewport_;
52 }; 77 };
53 78
54 SINGLE_AND_MULTI_THREAD_TEST_F(DelegatingRendererTestDraw); 79 SINGLE_AND_MULTI_THREAD_TEST_F(DelegatingRendererTestDraw);
55 80
56 class DelegatingRendererTestResources : public DelegatingRendererTest { 81 class DelegatingRendererTestResources : public DelegatingRendererTest {
57 public: 82 public:
58 void BeginTest() override { PostSetNeedsCommitToMainThread(); } 83 void BeginTest() override { PostSetNeedsCommitToMainThread(); }
59 84
60 void AfterTest() override {} 85 void AfterTest() override {}
(...skipping 10 matching lines...) Expand all
71 AddOneOfEveryQuadType(child_pass, host_impl->resource_provider(), 96 AddOneOfEveryQuadType(child_pass, host_impl->resource_provider(),
72 RenderPassId(0, 0), &mailbox_sync_token); 97 RenderPassId(0, 0), &mailbox_sync_token);
73 98
74 RenderPass* pass = AddRenderPass(&frame->render_passes, RenderPassId(1, 1), 99 RenderPass* pass = AddRenderPass(&frame->render_passes, RenderPassId(1, 1),
75 gfx::Rect(3, 3, 10, 10), gfx::Transform()); 100 gfx::Rect(3, 3, 10, 10), gfx::Transform());
76 AddOneOfEveryQuadType(pass, host_impl->resource_provider(), child_pass->id, 101 AddOneOfEveryQuadType(pass, host_impl->resource_provider(), child_pass->id,
77 &mailbox_sync_token); 102 &mailbox_sync_token);
78 return draw_result; 103 return draw_result;
79 } 104 }
80 105
81 void DisplayReceivedCompositorFrameOnThread( 106 void DrawLayersOnThread(LayerTreeHostImpl* host_impl) override {
82 const CompositorFrame& frame) override { 107 EXPECT_EQ(0u, output_surface_->num_sent_frames());
83 ASSERT_TRUE(frame.delegated_frame_data); 108 }
84 109
85 EXPECT_EQ(2u, frame.delegated_frame_data->render_pass_list.size()); 110 void SwapBuffersCompleteOnThread() override {
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());
86 // Each render pass has 10 resources in it. And the root render pass has a 117 // Each render pass has 10 resources in it. And the root render pass has a
87 // mask resource used when drawing the child render pass, as well as its 118 // mask resource used when drawing the child render pass, as well as its
88 // replica (it's added twice). The number 10 may change if 119 // replica (it's added twice). The number 10 may change if
89 // AppendOneOfEveryQuadType() is updated, and the value here should be 120 // AppendOneOfEveryQuadType() is updated, and the value here should be
90 // updated accordingly. 121 // updated accordingly.
91 EXPECT_EQ(22u, frame.delegated_frame_data->resource_list.size()); 122 EXPECT_EQ(22u, last_frame->delegated_frame_data->resource_list.size());
92 123
93 EndTest(); 124 EndTest();
94 } 125 }
95 }; 126 };
96 127
97 SINGLE_AND_MULTI_THREAD_TEST_F(DelegatingRendererTestResources); 128 SINGLE_AND_MULTI_THREAD_TEST_F(DelegatingRendererTestResources);
98 129
99 } // namespace cc 130 } // 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