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

Side by Side Diff: cc/surfaces/direct_compositor_frame_sink_unittest.cc

Issue 2854163003: [cc] Plumb BeginFrameAcks through SurfaceManager to DisplayScheduler. (Closed)
Patch Set: Pass ack via SurfaceDamaged, add back tests. Created 3 years, 7 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
OLDNEW
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/direct_compositor_frame_sink.h" 5 #include "cc/surfaces/direct_compositor_frame_sink.h"
6 6
7 #include <memory> 7 #include <memory>
8 8
9 #include "base/memory/ptr_util.h" 9 #include "base/memory/ptr_util.h"
10 #include "cc/output/renderer_settings.h" 10 #include "cc/output/renderer_settings.h"
11 #include "cc/output/texture_mailbox_deleter.h" 11 #include "cc/output/texture_mailbox_deleter.h"
12 #include "cc/scheduler/begin_frame_source.h" 12 #include "cc/scheduler/begin_frame_source.h"
13 #include "cc/scheduler/delay_based_time_source.h" 13 #include "cc/scheduler/delay_based_time_source.h"
14 #include "cc/surfaces/display.h" 14 #include "cc/surfaces/display.h"
15 #include "cc/surfaces/display_scheduler.h" 15 #include "cc/surfaces/display_scheduler.h"
16 #include "cc/surfaces/frame_sink_id.h" 16 #include "cc/surfaces/frame_sink_id.h"
17 #include "cc/surfaces/local_surface_id_allocator.h" 17 #include "cc/surfaces/local_surface_id_allocator.h"
18 #include "cc/surfaces/surface_manager.h" 18 #include "cc/surfaces/surface_manager.h"
19 #include "cc/test/begin_frame_args_test.h" 19 #include "cc/test/begin_frame_args_test.h"
20 #include "cc/test/compositor_frame_helpers.h" 20 #include "cc/test/compositor_frame_helpers.h"
21 #include "cc/test/fake_compositor_frame_sink_client.h" 21 #include "cc/test/fake_compositor_frame_sink_client.h"
22 #include "cc/test/fake_output_surface.h" 22 #include "cc/test/fake_output_surface.h"
23 #include "cc/test/ordered_simple_task_runner.h" 23 #include "cc/test/ordered_simple_task_runner.h"
24 #include "cc/test/test_begin_frame_ack_tracker.h"
24 #include "cc/test/test_context_provider.h" 25 #include "cc/test/test_context_provider.h"
25 #include "cc/test/test_gpu_memory_buffer_manager.h" 26 #include "cc/test/test_gpu_memory_buffer_manager.h"
26 #include "cc/test/test_shared_bitmap_manager.h" 27 #include "cc/test/test_shared_bitmap_manager.h"
27 #include "testing/gtest/include/gtest/gtest.h" 28 #include "testing/gtest/include/gtest/gtest.h"
28 29
29 namespace cc { 30 namespace cc {
30 namespace { 31 namespace {
31 32
32 static constexpr FrameSinkId kArbitraryFrameSinkId(1, 1); 33 static constexpr FrameSinkId kArbitraryFrameSinkId(1, 1);
33 34
34 class TestDirectCompositorFrameSink : public DirectCompositorFrameSink { 35 class TestDirectCompositorFrameSink : public DirectCompositorFrameSink {
35 public: 36 public:
36 using DirectCompositorFrameSink::DirectCompositorFrameSink; 37 using DirectCompositorFrameSink::DirectCompositorFrameSink;
37 38
38 CompositorFrameSinkSupport* support() const { return support_.get(); } 39 CompositorFrameSinkSupport* support() const { return support_.get(); }
39 }; 40 };
40 41
41 class DirectCompositorFrameSinkTest : public testing::Test { 42 class DirectCompositorFrameSinkTest : public testing::Test {
42 public: 43 public:
43 DirectCompositorFrameSinkTest() 44 DirectCompositorFrameSinkTest()
44 : now_src_(new base::SimpleTestTickClock()), 45 : now_src_(new base::SimpleTestTickClock()),
45 task_runner_(new OrderedSimpleTaskRunner(now_src_.get(), true)), 46 task_runner_(new OrderedSimpleTaskRunner(now_src_.get(), true)),
46 display_size_(1920, 1080), 47 display_size_(1920, 1080),
47 display_rect_(display_size_), 48 display_rect_(display_size_),
48 context_provider_(TestContextProvider::Create()) { 49 context_provider_(TestContextProvider::Create()) {
49 surface_manager_.RegisterFrameSinkId(kArbitraryFrameSinkId); 50 surface_manager_.RegisterFrameSinkId(kArbitraryFrameSinkId);
51 surface_manager_.AddObserver(&ack_tracker_);
50 52
51 std::unique_ptr<FakeOutputSurface> display_output_surface = 53 std::unique_ptr<FakeOutputSurface> display_output_surface =
52 FakeOutputSurface::Create3d(); 54 FakeOutputSurface::Create3d();
53 display_output_surface_ = display_output_surface.get(); 55 display_output_surface_ = display_output_surface.get();
54 56
55 begin_frame_source_.reset(new BackToBackBeginFrameSource( 57 begin_frame_source_.reset(new BackToBackBeginFrameSource(
56 base::MakeUnique<DelayBasedTimeSource>(task_runner_.get()))); 58 base::MakeUnique<DelayBasedTimeSource>(task_runner_.get())));
57 59
58 int max_frames_pending = 2; 60 int max_frames_pending = 2;
59 std::unique_ptr<DisplayScheduler> scheduler( 61 std::unique_ptr<DisplayScheduler> scheduler(
(...skipping 12 matching lines...) Expand all
72 compositor_frame_sink_->BindToClient(&compositor_frame_sink_client_); 74 compositor_frame_sink_->BindToClient(&compositor_frame_sink_client_);
73 display_->Resize(display_size_); 75 display_->Resize(display_size_);
74 display_->SetVisible(true); 76 display_->SetVisible(true);
75 77
76 EXPECT_FALSE( 78 EXPECT_FALSE(
77 compositor_frame_sink_client_.did_lose_compositor_frame_sink_called()); 79 compositor_frame_sink_client_.did_lose_compositor_frame_sink_called());
78 } 80 }
79 81
80 ~DirectCompositorFrameSinkTest() override { 82 ~DirectCompositorFrameSinkTest() override {
81 compositor_frame_sink_->DetachFromClient(); 83 compositor_frame_sink_->DetachFromClient();
84 surface_manager_.RemoveObserver(&ack_tracker_);
82 } 85 }
83 86
84 void SwapBuffersWithDamage(const gfx::Rect& damage_rect) { 87 void SwapBuffersWithDamage(const gfx::Rect& damage_rect) {
85 std::unique_ptr<RenderPass> render_pass(RenderPass::Create()); 88 std::unique_ptr<RenderPass> render_pass(RenderPass::Create());
86 render_pass->SetNew(1, display_rect_, damage_rect, gfx::Transform()); 89 render_pass->SetNew(1, display_rect_, damage_rect, gfx::Transform());
87 90
88 CompositorFrame frame = test::MakeEmptyCompositorFrame(); 91 CompositorFrame frame = test::MakeEmptyCompositorFrame();
89 frame.metadata.begin_frame_ack = BeginFrameAck(0, 1, 1, true); 92 frame.metadata.begin_frame_ack = BeginFrameAck(0, 1, 1, true);
90 frame.render_pass_list.push_back(std::move(render_pass)); 93 frame.render_pass_list.push_back(std::move(render_pass));
91 94
(...skipping 18 matching lines...) Expand all
110 SurfaceManager surface_manager_; 113 SurfaceManager surface_manager_;
111 TestSharedBitmapManager bitmap_manager_; 114 TestSharedBitmapManager bitmap_manager_;
112 TestGpuMemoryBufferManager gpu_memory_buffer_manager_; 115 TestGpuMemoryBufferManager gpu_memory_buffer_manager_;
113 116
114 scoped_refptr<TestContextProvider> context_provider_; 117 scoped_refptr<TestContextProvider> context_provider_;
115 FakeOutputSurface* display_output_surface_ = nullptr; 118 FakeOutputSurface* display_output_surface_ = nullptr;
116 std::unique_ptr<BackToBackBeginFrameSource> begin_frame_source_; 119 std::unique_ptr<BackToBackBeginFrameSource> begin_frame_source_;
117 std::unique_ptr<Display> display_; 120 std::unique_ptr<Display> display_;
118 FakeCompositorFrameSinkClient compositor_frame_sink_client_; 121 FakeCompositorFrameSinkClient compositor_frame_sink_client_;
119 std::unique_ptr<TestDirectCompositorFrameSink> compositor_frame_sink_; 122 std::unique_ptr<TestDirectCompositorFrameSink> compositor_frame_sink_;
123 TestBeginFrameAckTracker ack_tracker_;
120 }; 124 };
121 125
122 TEST_F(DirectCompositorFrameSinkTest, DamageTriggersSwapBuffers) { 126 TEST_F(DirectCompositorFrameSinkTest, DamageTriggersSwapBuffers) {
123 SwapBuffersWithDamage(display_rect_); 127 SwapBuffersWithDamage(display_rect_);
124 EXPECT_EQ(1u, display_output_surface_->num_sent_frames()); 128 EXPECT_EQ(1u, display_output_surface_->num_sent_frames());
125 task_runner_->RunUntilIdle(); 129 task_runner_->RunUntilIdle();
126 EXPECT_EQ(2u, display_output_surface_->num_sent_frames()); 130 EXPECT_EQ(2u, display_output_surface_->num_sent_frames());
127 } 131 }
128 132
129 TEST_F(DirectCompositorFrameSinkTest, NoDamageDoesNotTriggerSwapBuffers) { 133 TEST_F(DirectCompositorFrameSinkTest, NoDamageDoesNotTriggerSwapBuffers) {
(...skipping 11 matching lines...) Expand all
141 EXPECT_EQ(1u, display_output_surface_->num_sent_frames()); 145 EXPECT_EQ(1u, display_output_surface_->num_sent_frames());
142 SwapBuffersWithDamage(display_rect_); 146 SwapBuffersWithDamage(display_rect_);
143 task_runner_->RunUntilIdle(); 147 task_runner_->RunUntilIdle();
144 EXPECT_EQ(1u, display_output_surface_->num_sent_frames()); 148 EXPECT_EQ(1u, display_output_surface_->num_sent_frames());
145 display_output_surface_->set_suspended_for_recycle(false); 149 display_output_surface_->set_suspended_for_recycle(false);
146 SwapBuffersWithDamage(display_rect_); 150 SwapBuffersWithDamage(display_rect_);
147 task_runner_->RunUntilIdle(); 151 task_runner_->RunUntilIdle();
148 EXPECT_EQ(2u, display_output_surface_->num_sent_frames()); 152 EXPECT_EQ(2u, display_output_surface_->num_sent_frames());
149 } 153 }
150 154
151 // TODO(eseckler): Add back tests for BeginFrameAck forwarding through 155 TEST_F(DirectCompositorFrameSinkTest, AcknowledgesBeginFramesWithDamage) {
sunnyps 2017/05/25 20:49:13 nit: I don't think we need this test here because
Eric Seckler 2017/05/26 10:57:52 Done. (You're right, the only additional behavior
152 // DirectCompositorFrameSink and CompositorFrameSinkSupport when we add plumbing 156 // Verify that the frame sink forwards the BeginFrameAck attached to
153 // of BeginFrameAcks through SurfaceObservers. 157 // CompositorFrame submitted during SetUp().
158 EXPECT_EQ(BeginFrameAck(0, 1, 1, true), ack_tracker_.last_ack());
159 }
160
161 TEST_F(DirectCompositorFrameSinkTest, AcknowledgesBeginFramesWithoutDamage) {
162 // Verify that the frame sink forwards the BeginFrameAck from
163 // DidNotProduceFrame().
164 BeginFrameAck ack(0, 2, 2, false);
165 compositor_frame_sink_->DidNotProduceFrame(ack);
166 EXPECT_EQ(ack, ack_tracker_.last_ack());
167 }
154 168
155 } // namespace 169 } // namespace
156 } // namespace cc 170 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698