OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/surfaces/surface_display_output_surface.h" | 5 #include "cc/surfaces/surface_display_output_surface.h" |
6 | 6 |
7 #include "cc/surfaces/onscreen_display_client.h" | 7 #include "cc/surfaces/onscreen_display_client.h" |
8 #include "cc/surfaces/surface_id_allocator.h" | 8 #include "cc/surfaces/surface_id_allocator.h" |
9 #include "cc/surfaces/surface_manager.h" | 9 #include "cc/surfaces/surface_manager.h" |
10 #include "cc/test/fake_output_surface.h" | 10 #include "cc/test/fake_output_surface.h" |
11 #include "cc/test/fake_output_surface_client.h" | 11 #include "cc/test/fake_output_surface_client.h" |
12 #include "cc/test/ordered_simple_task_runner.h" | 12 #include "cc/test/ordered_simple_task_runner.h" |
13 #include "cc/test/test_context_provider.h" | 13 #include "cc/test/test_context_provider.h" |
14 #include "cc/test/test_gpu_memory_buffer_manager.h" | 14 #include "cc/test/test_gpu_memory_buffer_manager.h" |
15 #include "cc/test/test_shared_bitmap_manager.h" | 15 #include "cc/test/test_shared_bitmap_manager.h" |
16 #include "testing/gtest/include/gtest/gtest.h" | 16 #include "testing/gtest/include/gtest/gtest.h" |
17 | 17 |
18 namespace cc { | 18 namespace cc { |
19 namespace { | 19 namespace { |
20 | 20 |
21 class FakeOnscreenDisplayClient : public OnscreenDisplayClient { | 21 class FakeOnscreenDisplayClient : public OnscreenDisplayClient { |
22 public: | 22 public: |
23 FakeOnscreenDisplayClient( | 23 FakeOnscreenDisplayClient( |
24 SurfaceManager* manager, | 24 SurfaceManager* manager, |
25 SharedBitmapManager* bitmap_manager, | 25 SharedBitmapManager* bitmap_manager, |
26 gpu::GpuMemoryBufferManager* gpu_memory_buffer_manager, | 26 gpu::GpuMemoryBufferManager* gpu_memory_buffer_manager, |
27 const RendererSettings& settings, | 27 const RendererSettings& settings, |
28 scoped_refptr<base::SingleThreadTaskRunner> task_runner) | 28 scoped_refptr<base::SingleThreadTaskRunner> task_runner, |
| 29 uint32_t compositor_surface_namespace) |
29 : OnscreenDisplayClient(FakeOutputSurface::Create3d(), | 30 : OnscreenDisplayClient(FakeOutputSurface::Create3d(), |
30 manager, | 31 manager, |
31 bitmap_manager, | 32 bitmap_manager, |
32 gpu_memory_buffer_manager, | 33 gpu_memory_buffer_manager, |
33 settings, | 34 settings, |
34 task_runner) { | 35 task_runner, |
| 36 compositor_surface_namespace) { |
35 // Ownership is passed to another object later, store a pointer | 37 // Ownership is passed to another object later, store a pointer |
36 // to it now for future reference. | 38 // to it now for future reference. |
37 fake_output_surface_ = | 39 fake_output_surface_ = |
38 static_cast<FakeOutputSurface*>(output_surface_.get()); | 40 static_cast<FakeOutputSurface*>(output_surface_.get()); |
39 fake_output_surface_->set_max_frames_pending(2); | 41 fake_output_surface_->set_max_frames_pending(2); |
40 } | 42 } |
41 | 43 |
42 FakeOutputSurface* output_surface() { return fake_output_surface_; } | 44 FakeOutputSurface* output_surface() { return fake_output_surface_; } |
43 | 45 |
44 protected: | 46 protected: |
45 FakeOutputSurface* fake_output_surface_; | 47 FakeOutputSurface* fake_output_surface_; |
46 }; | 48 }; |
47 | 49 |
48 class SurfaceDisplayOutputSurfaceTest : public testing::Test { | 50 class SurfaceDisplayOutputSurfaceTest : public testing::Test { |
49 public: | 51 public: |
50 SurfaceDisplayOutputSurfaceTest() | 52 SurfaceDisplayOutputSurfaceTest() |
51 : now_src_(new base::SimpleTestTickClock()), | 53 : now_src_(new base::SimpleTestTickClock()), |
52 task_runner_(new OrderedSimpleTaskRunner(now_src_.get(), true)), | 54 task_runner_(new OrderedSimpleTaskRunner(now_src_.get(), true)), |
53 allocator_(0), | 55 allocator_(0), |
54 display_size_(1920, 1080), | 56 display_size_(1920, 1080), |
55 display_rect_(display_size_), | 57 display_rect_(display_size_), |
56 display_client_(&surface_manager_, | 58 display_client_(&surface_manager_, |
57 &bitmap_manager_, | 59 &bitmap_manager_, |
58 &gpu_memory_buffer_manager_, | 60 &gpu_memory_buffer_manager_, |
59 renderer_settings_, | 61 renderer_settings_, |
60 task_runner_), | 62 task_runner_, |
| 63 allocator_.id_namespace()), |
61 context_provider_(TestContextProvider::Create()), | 64 context_provider_(TestContextProvider::Create()), |
62 surface_display_output_surface_(&surface_manager_, | 65 surface_display_output_surface_(&surface_manager_, |
63 &allocator_, | 66 &allocator_, |
64 context_provider_, | 67 context_provider_, |
65 nullptr) { | 68 nullptr) { |
66 surface_manager_.RegisterSurfaceIdNamespace(allocator_.id_namespace()); | 69 surface_manager_.RegisterSurfaceIdNamespace(allocator_.id_namespace()); |
67 output_surface_ = display_client_.output_surface(); | 70 output_surface_ = display_client_.output_surface(); |
68 display_client_.set_surface_output_surface( | 71 display_client_.set_surface_output_surface( |
69 &surface_display_output_surface_); | 72 &surface_display_output_surface_); |
70 surface_display_output_surface_.set_display_client(&display_client_); | 73 surface_display_output_surface_.set_display_client(&display_client_); |
| 74 |
| 75 // Set the Display's begin frame source like a real browser compositor |
| 76 // output surface would. |
| 77 begin_frame_source_.reset( |
| 78 new BackToBackBeginFrameSource(task_runner_.get())); |
| 79 display_client_.display()->SetBeginFrameSource(begin_frame_source_.get()); |
| 80 |
71 surface_display_output_surface_.BindToClient( | 81 surface_display_output_surface_.BindToClient( |
72 &surface_display_output_surface_client_); | 82 &surface_display_output_surface_client_); |
| 83 |
73 display_client_.display()->Resize(display_size_); | 84 display_client_.display()->Resize(display_size_); |
74 | 85 |
75 EXPECT_FALSE(surface_display_output_surface_client_ | 86 EXPECT_FALSE(surface_display_output_surface_client_ |
76 .did_lose_output_surface_called()); | 87 .did_lose_output_surface_called()); |
77 } | 88 } |
78 | 89 |
79 ~SurfaceDisplayOutputSurfaceTest() override {} | 90 ~SurfaceDisplayOutputSurfaceTest() override {} |
80 | 91 |
81 void SwapBuffersWithDamage(const gfx::Rect& damage_rect_) { | 92 void SwapBuffersWithDamage(const gfx::Rect& damage_rect_) { |
82 std::unique_ptr<RenderPass> render_pass(RenderPass::Create()); | 93 std::unique_ptr<RenderPass> render_pass(RenderPass::Create()); |
(...skipping 14 matching lines...) Expand all Loading... |
97 SwapBuffersWithDamage(display_rect_); | 108 SwapBuffersWithDamage(display_rect_); |
98 | 109 |
99 EXPECT_EQ(0u, output_surface_->num_sent_frames()); | 110 EXPECT_EQ(0u, output_surface_->num_sent_frames()); |
100 task_runner_->RunUntilIdle(); | 111 task_runner_->RunUntilIdle(); |
101 EXPECT_EQ(1u, output_surface_->num_sent_frames()); | 112 EXPECT_EQ(1u, output_surface_->num_sent_frames()); |
102 } | 113 } |
103 | 114 |
104 protected: | 115 protected: |
105 std::unique_ptr<base::SimpleTestTickClock> now_src_; | 116 std::unique_ptr<base::SimpleTestTickClock> now_src_; |
106 scoped_refptr<OrderedSimpleTaskRunner> task_runner_; | 117 scoped_refptr<OrderedSimpleTaskRunner> task_runner_; |
| 118 scoped_ptr<BackToBackBeginFrameSource> begin_frame_source_; |
107 SurfaceIdAllocator allocator_; | 119 SurfaceIdAllocator allocator_; |
108 | 120 |
109 const gfx::Size display_size_; | 121 const gfx::Size display_size_; |
110 const gfx::Rect display_rect_; | 122 const gfx::Rect display_rect_; |
111 FakeOutputSurface* output_surface_; | 123 FakeOutputSurface* output_surface_; |
112 SurfaceManager surface_manager_; | 124 SurfaceManager surface_manager_; |
113 TestSharedBitmapManager bitmap_manager_; | 125 TestSharedBitmapManager bitmap_manager_; |
114 TestGpuMemoryBufferManager gpu_memory_buffer_manager_; | 126 TestGpuMemoryBufferManager gpu_memory_buffer_manager_; |
115 RendererSettings renderer_settings_; | 127 RendererSettings renderer_settings_; |
116 FakeOnscreenDisplayClient display_client_; | 128 FakeOnscreenDisplayClient display_client_; |
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
158 EXPECT_EQ(1u, output_surface_->num_sent_frames()); | 170 EXPECT_EQ(1u, output_surface_->num_sent_frames()); |
159 | 171 |
160 SwapBuffersWithDamage(gfx::Rect()); | 172 SwapBuffersWithDamage(gfx::Rect()); |
161 EXPECT_EQ(1u, output_surface_->num_sent_frames()); | 173 EXPECT_EQ(1u, output_surface_->num_sent_frames()); |
162 task_runner_->RunUntilIdle(); | 174 task_runner_->RunUntilIdle(); |
163 EXPECT_EQ(1u, output_surface_->num_sent_frames()); | 175 EXPECT_EQ(1u, output_surface_->num_sent_frames()); |
164 } | 176 } |
165 | 177 |
166 } // namespace | 178 } // namespace |
167 } // namespace cc | 179 } // namespace cc |
OLD | NEW |