OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/compositor_frame.h" | 5 #include "cc/output/compositor_frame.h" |
6 #include "cc/quads/render_pass.h" | 6 #include "cc/quads/render_pass.h" |
7 #include "cc/quads/solid_color_draw_quad.h" | 7 #include "cc/quads/solid_color_draw_quad.h" |
8 #include "cc/quads/surface_draw_quad.h" | 8 #include "cc/quads/surface_draw_quad.h" |
9 #include "cc/surfaces/surface.h" | 9 #include "cc/surfaces/surface.h" |
10 #include "cc/surfaces/surface_aggregator.h" | 10 #include "cc/surfaces/surface_aggregator.h" |
11 #include "cc/surfaces/surface_factory.h" | 11 #include "cc/surfaces/surface_factory.h" |
12 #include "cc/surfaces/surface_factory_client.h" | 12 #include "cc/surfaces/surface_factory_client.h" |
13 #include "cc/surfaces/surface_id_allocator.h" | 13 #include "cc/surfaces/surface_id_allocator.h" |
14 #include "cc/surfaces/surface_manager.h" | 14 #include "cc/surfaces/surface_manager.h" |
15 #include "cc/test/pixel_comparator.h" | 15 #include "cc/test/pixel_comparator.h" |
16 #include "cc/test/pixel_test.h" | 16 #include "cc/test/pixel_test.h" |
17 #include "testing/gtest/include/gtest/gtest.h" | 17 #include "testing/gtest/include/gtest/gtest.h" |
18 | 18 |
19 #if !defined(OS_ANDROID) | 19 #if !defined(OS_ANDROID) |
20 | 20 |
21 namespace cc { | 21 namespace cc { |
22 namespace { | 22 namespace { |
23 | 23 |
24 class EmptySurfaceFactoryClient : public SurfaceFactoryClient { | 24 class EmptySurfaceFactoryClient : public SurfaceFactoryClient { |
25 public: | 25 public: |
26 void ReturnResources(const ReturnedResourceArray& resources) override {} | 26 void ReturnResources(const ReturnedResourceArray& resources) override {} |
27 void SetBeginFrameSource(SurfaceId surface_id, | 27 void SetBeginFrameSource(BeginFrameSource* begin_frame_source) override {} |
28 BeginFrameSource* begin_frame_source) override {} | |
29 }; | |
30 | |
31 class EmptySurfaceAggregatorClient : public SurfaceAggregatorClient { | |
32 public: | |
33 void AddSurface(Surface* surface) override {} | |
34 void RemoveSurface(Surface* surface) override {} | |
35 }; | 28 }; |
36 | 29 |
37 class SurfacesPixelTest : public RendererPixelTest<GLRenderer> { | 30 class SurfacesPixelTest : public RendererPixelTest<GLRenderer> { |
38 public: | 31 public: |
39 SurfacesPixelTest() : allocator_(1u), factory_(&manager_, &client_) {} | 32 SurfacesPixelTest() : allocator_(1u), factory_(&manager_, &client_) {} |
40 | 33 |
41 protected: | 34 protected: |
42 SurfaceManager manager_; | 35 SurfaceManager manager_; |
43 SurfaceIdAllocator allocator_; | 36 SurfaceIdAllocator allocator_; |
44 EmptySurfaceFactoryClient client_; | 37 EmptySurfaceFactoryClient client_; |
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
84 delegated_frame_data->render_pass_list.push_back(std::move(pass)); | 77 delegated_frame_data->render_pass_list.push_back(std::move(pass)); |
85 | 78 |
86 scoped_ptr<CompositorFrame> root_frame(new CompositorFrame); | 79 scoped_ptr<CompositorFrame> root_frame(new CompositorFrame); |
87 root_frame->delegated_frame_data = std::move(delegated_frame_data); | 80 root_frame->delegated_frame_data = std::move(delegated_frame_data); |
88 | 81 |
89 SurfaceId root_surface_id = allocator_.GenerateId(); | 82 SurfaceId root_surface_id = allocator_.GenerateId(); |
90 factory_.Create(root_surface_id); | 83 factory_.Create(root_surface_id); |
91 factory_.SubmitCompositorFrame(root_surface_id, std::move(root_frame), | 84 factory_.SubmitCompositorFrame(root_surface_id, std::move(root_frame), |
92 SurfaceFactory::DrawCallback()); | 85 SurfaceFactory::DrawCallback()); |
93 | 86 |
94 EmptySurfaceAggregatorClient surface_aggregator_client; | 87 SurfaceAggregator aggregator(&manager_, resource_provider_.get(), true); |
95 SurfaceAggregator aggregator(&surface_aggregator_client, &manager_, | |
96 resource_provider_.get(), true); | |
97 scoped_ptr<CompositorFrame> aggregated_frame = | 88 scoped_ptr<CompositorFrame> aggregated_frame = |
98 aggregator.Aggregate(root_surface_id); | 89 aggregator.Aggregate(root_surface_id); |
99 factory_.Destroy(root_surface_id); | 90 factory_.Destroy(root_surface_id); |
100 | 91 |
101 bool discard_alpha = false; | 92 bool discard_alpha = false; |
102 ExactPixelComparator pixel_comparator(discard_alpha); | 93 ExactPixelComparator pixel_comparator(discard_alpha); |
103 RenderPassList* pass_list = | 94 RenderPassList* pass_list = |
104 &aggregated_frame->delegated_frame_data->render_pass_list; | 95 &aggregated_frame->delegated_frame_data->render_pass_list; |
105 EXPECT_TRUE(RunPixelTest(pass_list, | 96 EXPECT_TRUE(RunPixelTest(pass_list, |
106 base::FilePath(FILE_PATH_LITERAL("green.png")), | 97 base::FilePath(FILE_PATH_LITERAL("green.png")), |
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
170 scoped_ptr<DelegatedFrameData> delegated_frame_data(new DelegatedFrameData); | 161 scoped_ptr<DelegatedFrameData> delegated_frame_data(new DelegatedFrameData); |
171 delegated_frame_data->render_pass_list.push_back(std::move(pass)); | 162 delegated_frame_data->render_pass_list.push_back(std::move(pass)); |
172 | 163 |
173 scoped_ptr<CompositorFrame> child_frame(new CompositorFrame); | 164 scoped_ptr<CompositorFrame> child_frame(new CompositorFrame); |
174 child_frame->delegated_frame_data = std::move(delegated_frame_data); | 165 child_frame->delegated_frame_data = std::move(delegated_frame_data); |
175 | 166 |
176 factory_.SubmitCompositorFrame(child_surface_id, std::move(child_frame), | 167 factory_.SubmitCompositorFrame(child_surface_id, std::move(child_frame), |
177 SurfaceFactory::DrawCallback()); | 168 SurfaceFactory::DrawCallback()); |
178 } | 169 } |
179 | 170 |
180 EmptySurfaceAggregatorClient surface_aggregator_client; | 171 SurfaceAggregator aggregator(&manager_, resource_provider_.get(), true); |
181 SurfaceAggregator aggregator(&surface_aggregator_client, &manager_, | |
182 resource_provider_.get(), true); | |
183 scoped_ptr<CompositorFrame> aggregated_frame = | 172 scoped_ptr<CompositorFrame> aggregated_frame = |
184 aggregator.Aggregate(root_surface_id); | 173 aggregator.Aggregate(root_surface_id); |
185 | 174 |
186 bool discard_alpha = false; | 175 bool discard_alpha = false; |
187 ExactPixelComparator pixel_comparator(discard_alpha); | 176 ExactPixelComparator pixel_comparator(discard_alpha); |
188 RenderPassList* pass_list = | 177 RenderPassList* pass_list = |
189 &aggregated_frame->delegated_frame_data->render_pass_list; | 178 &aggregated_frame->delegated_frame_data->render_pass_list; |
190 EXPECT_TRUE(RunPixelTest(pass_list, | 179 EXPECT_TRUE(RunPixelTest(pass_list, |
191 base::FilePath(FILE_PATH_LITERAL("blue_yellow.png")), | 180 base::FilePath(FILE_PATH_LITERAL("blue_yellow.png")), |
192 pixel_comparator)); | 181 pixel_comparator)); |
(...skipping 122 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
315 scoped_ptr<DelegatedFrameData> delegated_frame_data(new DelegatedFrameData); | 304 scoped_ptr<DelegatedFrameData> delegated_frame_data(new DelegatedFrameData); |
316 delegated_frame_data->render_pass_list.push_back(std::move(pass)); | 305 delegated_frame_data->render_pass_list.push_back(std::move(pass)); |
317 | 306 |
318 scoped_ptr<CompositorFrame> child_frame(new CompositorFrame); | 307 scoped_ptr<CompositorFrame> child_frame(new CompositorFrame); |
319 child_frame->delegated_frame_data = std::move(delegated_frame_data); | 308 child_frame->delegated_frame_data = std::move(delegated_frame_data); |
320 | 309 |
321 factory_.SubmitCompositorFrame(right_child_id, std::move(child_frame), | 310 factory_.SubmitCompositorFrame(right_child_id, std::move(child_frame), |
322 SurfaceFactory::DrawCallback()); | 311 SurfaceFactory::DrawCallback()); |
323 } | 312 } |
324 | 313 |
325 EmptySurfaceAggregatorClient surface_aggregator_client; | 314 SurfaceAggregator aggregator(&manager_, resource_provider_.get(), true); |
326 SurfaceAggregator aggregator(&surface_aggregator_client, &manager_, | |
327 resource_provider_.get(), true); | |
328 scoped_ptr<CompositorFrame> aggregated_frame = | 315 scoped_ptr<CompositorFrame> aggregated_frame = |
329 aggregator.Aggregate(root_surface_id); | 316 aggregator.Aggregate(root_surface_id); |
330 | 317 |
331 bool discard_alpha = false; | 318 bool discard_alpha = false; |
332 ExactPixelComparator pixel_comparator(discard_alpha); | 319 ExactPixelComparator pixel_comparator(discard_alpha); |
333 RenderPassList* pass_list = | 320 RenderPassList* pass_list = |
334 &aggregated_frame->delegated_frame_data->render_pass_list; | 321 &aggregated_frame->delegated_frame_data->render_pass_list; |
335 EXPECT_TRUE(RunPixelTest( | 322 EXPECT_TRUE(RunPixelTest( |
336 pass_list, | 323 pass_list, |
337 base::FilePath(FILE_PATH_LITERAL("four_blue_green_checkers.png")), | 324 base::FilePath(FILE_PATH_LITERAL("four_blue_green_checkers.png")), |
338 pixel_comparator)); | 325 pixel_comparator)); |
339 | 326 |
340 factory_.Destroy(root_surface_id); | 327 factory_.Destroy(root_surface_id); |
341 factory_.Destroy(left_child_id); | 328 factory_.Destroy(left_child_id); |
342 factory_.Destroy(right_child_id); | 329 factory_.Destroy(right_child_id); |
343 } | 330 } |
344 | 331 |
345 } // namespace | 332 } // namespace |
346 } // namespace cc | 333 } // namespace cc |
347 | 334 |
348 #endif // !defined(OS_ANDROID) | 335 #endif // !defined(OS_ANDROID) |
OLD | NEW |