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

Side by Side Diff: services/ui/ws/frame_generator_unittest.cc

Issue 2755573002: Add FrameGenerator Unit Tests (Closed)
Patch Set: Added cc:test_support to pulic_deps Created 3 years, 9 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 | « services/ui/ws/frame_generator.cc ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 // Copyright 2017 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "services/ui/ws/frame_generator.h"
6
7 #include "base/macros.h"
8 #include "cc/output/compositor_frame_sink.h"
9 #include "cc/scheduler/begin_frame_source.h"
10 #include "cc/test/begin_frame_args_test.cc"
11 #include "cc/test/fake_external_begin_frame_source.h"
12 #include "services/ui/ws/frame_generator_delegate.h"
13 #include "services/ui/ws/server_window.h"
14 #include "services/ui/ws/server_window_delegate.h"
15 #include "testing/gtest/include/gtest/gtest.h"
16
17 namespace ui {
18 namespace ws {
19 namespace test {
20
21 // TestFrameGeneratorDelegate implements FrameGeneratorDelegate and returns
22 // false when IsInHighContrastMode() is called.
23 class TestFrameGeneratorDelegate : public FrameGeneratorDelegate {
Fady Samuel 2017/03/18 02:44:06 Looks like you have a name collision with this: ht
Alex Z. 2017/03/18 03:03:25 Done.
24 public:
25 TestFrameGeneratorDelegate() {}
26 ~TestFrameGeneratorDelegate() override {}
27
28 // FrameGeneratorDelegate implementation:
29 bool IsInHighContrastMode() override { return false; }
30
31 private:
32 DISALLOW_COPY_AND_ASSIGN(TestFrameGeneratorDelegate);
33 };
34
35 // TestServerWindowDelegate implements ServerWindowDelegate and returns nullptrs
36 // when either of the methods from the interface is called.
37 class TestServerWindowDelegate : public ServerWindowDelegate {
38 public:
39 TestServerWindowDelegate() {}
40 ~TestServerWindowDelegate() override {}
41
42 // ServerWindowDelegate implementation:
43 cc::mojom::DisplayCompositor* GetDisplayCompositor() override {
44 return nullptr;
45 }
46
47 ServerWindow* GetRootWindow(const ServerWindow* window) override {
48 return nullptr;
49 }
50
51 private:
52 DISALLOW_COPY_AND_ASSIGN(TestServerWindowDelegate);
53 };
54
55 // FakeCompositorFrameSink observes a FakeExternalBeginFrameSource and receives
56 // CompositorFrames from a FrameGenerator.
57 class FakeCompositorFrameSink : public cc::CompositorFrameSink,
58 public cc::BeginFrameObserver,
59 public cc::ExternalBeginFrameSourceClient {
60 public:
61 FakeCompositorFrameSink()
62 : cc::CompositorFrameSink(nullptr, nullptr, nullptr, nullptr) {}
63
64 // cc::CompositorFrameSink implementation:
65 bool BindToClient(cc::CompositorFrameSinkClient* client) override {
66 if (!cc::CompositorFrameSink::BindToClient(client))
67 return false;
68
69 external_begin_frame_source_ =
70 base::MakeUnique<cc::ExternalBeginFrameSource>(this);
71 client_->SetBeginFrameSource(external_begin_frame_source_.get());
72 return true;
73 }
74
75 void DetachFromClient() override {
76 cc::CompositorFrameSink::DetachFromClient();
77 }
78
79 void SubmitCompositorFrame(cc::CompositorFrame frame) override {
80 ++number_frames_received_;
81 last_frame_ = std::move(frame);
82 }
83
84 // cc::BeginFrameObserver implementation.
85 void OnBeginFrame(const cc::BeginFrameArgs& args) override {
86 external_begin_frame_source_->OnBeginFrame(args);
87 last_begin_frame_args_ = args;
88 }
89
90 const cc::BeginFrameArgs& LastUsedBeginFrameArgs() const override {
91 return last_begin_frame_args_;
92 }
93
94 void OnBeginFrameSourcePausedChanged(bool paused) override {}
95
96 // cc::ExternalBeginFrameSourceClient implementation:
97 void OnNeedsBeginFrames(bool needs_begin_frames) override {
98 needs_begin_frames_ = needs_begin_frames;
99 UpdateNeedsBeginFramesInternal();
100 }
101
102 void OnDidFinishFrame(const cc::BeginFrameAck& ack) override {
103 external_begin_frame_source_->DidFinishFrame(this, ack);
104 }
105
106 void SetBeginFrameSource(cc::BeginFrameSource* source) {
107 if (begin_frame_source_ && observing_begin_frames_) {
108 begin_frame_source_->RemoveObserver(this);
109 observing_begin_frames_ = false;
110 }
111 begin_frame_source_ = source;
112 UpdateNeedsBeginFramesInternal();
113 }
114
115 const cc::CompositorFrameMetadata& last_metadata() {
116 return last_frame_.metadata;
117 }
118
119 int number_frames_received() { return number_frames_received_; }
120
121 private:
122 void UpdateNeedsBeginFramesInternal() {
123 if (!begin_frame_source_)
124 return;
125
126 if (needs_begin_frames_ == observing_begin_frames_)
127 return;
128
129 observing_begin_frames_ = needs_begin_frames_;
130 if (needs_begin_frames_) {
131 begin_frame_source_->AddObserver(this);
132 } else {
133 begin_frame_source_->RemoveObserver(this);
134 }
135 }
136
137 int number_frames_received_ = 0;
138 std::unique_ptr<cc::ExternalBeginFrameSource> external_begin_frame_source_;
139 cc::BeginFrameSource* begin_frame_source_ = nullptr;
140 cc::BeginFrameArgs last_begin_frame_args_;
141 bool observing_begin_frames_ = false;
142 bool needs_begin_frames_ = false;
143 cc::CompositorFrame last_frame_;
144
145 DISALLOW_COPY_AND_ASSIGN(FakeCompositorFrameSink);
146 };
147
148 class FrameGeneratorTest : public testing::Test {
149 public:
150 FrameGeneratorTest() {}
151 ~FrameGeneratorTest() override {}
152
153 // testing::Test overrides:
154 void SetUp() override {
155 testing::Test::SetUp();
156
157 std::unique_ptr<FakeCompositorFrameSink> compositor_frame_sink =
158 base::MakeUnique<FakeCompositorFrameSink>();
159 compositor_frame_sink_ = compositor_frame_sink.get();
160
161 constexpr float kRefreshRate = 0.f;
162 constexpr bool kTickAutomatically = false;
163 begin_frame_source_ = base::MakeUnique<cc::FakeExternalBeginFrameSource>(
164 kRefreshRate, kTickAutomatically);
165 compositor_frame_sink_->SetBeginFrameSource(begin_frame_source_.get());
166 delegate_ = base::MakeUnique<TestFrameGeneratorDelegate>();
167 server_window_delegate_ = base::MakeUnique<TestServerWindowDelegate>();
168 root_window_ = base::MakeUnique<ServerWindow>(server_window_delegate_.get(),
169 WindowId());
170 root_window_->SetVisible(true);
171 frame_generator_ = base::MakeUnique<FrameGenerator>(
172 delegate_.get(), root_window_.get(), std::move(compositor_frame_sink));
173 };
174
175 int NumberOfFramesReceived() {
176 return compositor_frame_sink_->number_frames_received();
177 }
178
179 void IssueBeginFrame() {
180 begin_frame_source_->TestOnBeginFrame(cc::CreateBeginFrameArgsForTesting(
181 BEGINFRAME_FROM_HERE, 0, next_sequence_number_));
182 ++next_sequence_number_;
183 }
184
185 FrameGenerator* frame_generator() { return frame_generator_.get(); }
186
187 const cc::CompositorFrameMetadata& LastMetadata() {
188 return compositor_frame_sink_->last_metadata();
189 }
190
191 private:
192 FakeCompositorFrameSink* compositor_frame_sink_ = nullptr;
193 std::unique_ptr<cc::FakeExternalBeginFrameSource> begin_frame_source_;
194 std::unique_ptr<TestFrameGeneratorDelegate> delegate_;
195 std::unique_ptr<TestServerWindowDelegate> server_window_delegate_;
196 std::unique_ptr<ServerWindow> root_window_;
197 std::unique_ptr<FrameGenerator> frame_generator_;
198 int next_sequence_number_ = 1;
199
200 DISALLOW_COPY_AND_ASSIGN(FrameGeneratorTest);
201 };
202
203 TEST_F(FrameGeneratorTest, OnSurfaceCreated) {
204 EXPECT_EQ(0, NumberOfFramesReceived());
205
206 // FrameGenerator does not request BeginFrames upon creation.
207 IssueBeginFrame();
208 EXPECT_EQ(0, NumberOfFramesReceived());
209
210 const cc::SurfaceId kArbitrarySurfaceId(
211 cc::FrameSinkId(1, 1),
212 cc::LocalSurfaceId(1, base::UnguessableToken::Create()));
213 const cc::SurfaceInfo kArbitrarySurfaceInfo(kArbitrarySurfaceId, 1.0f,
214 gfx::Size(100, 100));
215 frame_generator()->OnSurfaceCreated(kArbitrarySurfaceInfo);
216 EXPECT_EQ(0, NumberOfFramesReceived());
217
218 IssueBeginFrame();
219 EXPECT_EQ(1, NumberOfFramesReceived());
220
221 // Verify that the CompositorFrame refers to the window manager's surface via
222 // referenced_surfaces.
223 const cc::CompositorFrameMetadata& last_metadata = LastMetadata();
224 const std::vector<cc::SurfaceId>& referenced_surfaces =
225 last_metadata.referenced_surfaces;
226 EXPECT_EQ(1lu, referenced_surfaces.size());
227 EXPECT_EQ(kArbitrarySurfaceId, referenced_surfaces.front());
228
229 // FrameGenerator stops requesting BeginFrames after submitting a
230 // CompositorFrame.
231 IssueBeginFrame();
232 EXPECT_EQ(1, NumberOfFramesReceived());
233 }
234
235 TEST_F(FrameGeneratorTest, SetDeviceScaleFactor) {
236 EXPECT_EQ(0, NumberOfFramesReceived());
237 const cc::SurfaceId kArbitrarySurfaceId(
238 cc::FrameSinkId(1, 1),
239 cc::LocalSurfaceId(1, base::UnguessableToken::Create()));
240 const cc::SurfaceInfo kArbitrarySurfaceInfo(kArbitrarySurfaceId, 1.0f,
241 gfx::Size(100, 100));
242 constexpr float kDefaultScaleFactor = 1.0f;
243 constexpr float kArbitraryScaleFactor = 0.5f;
244
245 // A valid SurfaceInfo is required before setting device scale factor.
246 frame_generator()->OnSurfaceCreated(kArbitrarySurfaceInfo);
247 IssueBeginFrame();
248 EXPECT_EQ(1, NumberOfFramesReceived());
249
250 // FrameGenerator stops requesting BeginFrames after receiving one.
251 IssueBeginFrame();
252 EXPECT_EQ(1, NumberOfFramesReceived());
253
254 // FrameGenerator does not request BeginFrames if its device scale factor
255 // remains unchanged.
256 frame_generator()->SetDeviceScaleFactor(kDefaultScaleFactor);
257 IssueBeginFrame();
258 EXPECT_EQ(1, NumberOfFramesReceived());
259 const cc::CompositorFrameMetadata& last_metadata = LastMetadata();
260 EXPECT_EQ(kDefaultScaleFactor, last_metadata.device_scale_factor);
261
262 frame_generator()->SetDeviceScaleFactor(kArbitraryScaleFactor);
263 IssueBeginFrame();
264 EXPECT_EQ(2, NumberOfFramesReceived());
265 const cc::CompositorFrameMetadata& second_last_metadata = LastMetadata();
266 EXPECT_EQ(kArbitraryScaleFactor, second_last_metadata.device_scale_factor);
267 }
268
269 } // namespace test
270 } // namespace ws
271 } // namespace ui
OLDNEW
« no previous file with comments | « services/ui/ws/frame_generator.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698