1 // Copyright 2011 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.
8 #include "base/basictypes.h"
9 #include "base/gtest_prod_util.h"
10 #include "base/test/test_simple_task_runner.h"
11 #include "cc/scheduler/begin_frame_source.h"
12 #include "cc/test/begin_frame_args_test.h"
13 #include "cc/test/scheduler_test_common.h"
14 #include "testing/gmock/include/gmock/gmock.h"
15 #include "testing/gtest/include/gtest/gtest.h"
17 // Macros to help set up expected calls on the MockBeginFrameObserver.
18 #define EXPECT_BEGIN_FRAME_DROP(obs, frame_time, deadline, interval) \
20 ::testing::Expectation exp = \
22 OnBeginFrame(CreateBeginFrameArgsForTesting( \
23 frame_time, deadline, interval))) \
24 .InSequence((obs).sequence); \
27 #define EXPECT_BEGIN_FRAME_USED(obs, frame_time, deadline, interval) \
29 BeginFrameArgs args = \
30 CreateBeginFrameArgsForTesting(frame_time, deadline, interval); \
31 ::testing::Expectation exp = \
32 EXPECT_CALL((obs), OnBeginFrame(args)).InSequence((obs).sequence); \
33 EXPECT_CALL((obs), LastUsedBeginFrameArgs()) \
34 .Times(::testing::AnyNumber()) \
36 .WillRepeatedly(::testing::Return(args)); \
39 // Macros to send BeginFrameArgs on a FakeBeginFrameSink (and verify resulting
40 // observer behaviour).
41 #define SEND_BEGIN_FRAME( \
42 args_equal_to, source, frame_time, deadline, interval) \
44 BeginFrameArgs old_args = (source).TestLastUsedBeginFrameArgs(); \
45 BeginFrameArgs new_args = \
46 CreateBeginFrameArgsForTesting(frame_time, deadline, interval); \
47 ASSERT_TRUE(!(old_args == new_args)); \
48 (source).TestOnBeginFrame(new_args); \
49 EXPECT_EQ(args_equal_to, (source).TestLastUsedBeginFrameArgs()); \
52 // When dropping LastUsedBeginFrameArgs **shouldn't** change.
53 #define SEND_BEGIN_FRAME_DROP(source, frame_time, deadline, interval) \
54 SEND_BEGIN_FRAME(old_args, source, frame_time, deadline, interval);
56 // When used LastUsedBeginFrameArgs **should** be updated.
57 #define SEND_BEGIN_FRAME_USED(source, frame_time, deadline, interval) \
58 SEND_BEGIN_FRAME(new_args, source, frame_time, deadline, interval);
63 class MockBeginFrameObserver
: public BeginFrameObserver
{
65 MOCK_METHOD1(OnBeginFrame
, void(const BeginFrameArgs
&));
66 MOCK_CONST_METHOD0(LastUsedBeginFrameArgs
, const BeginFrameArgs());
68 virtual void AsValueInto(base::debug::TracedValue
* dict
) const {
69 dict
->SetString("type", "MockBeginFrameObserver");
70 dict
->BeginDictionary("last_begin_frame_args");
71 LastUsedBeginFrameArgs().AsValueInto(dict
);
72 dict
->EndDictionary();
75 // A value different from the normal default returned by a BeginFrameObserver
76 // so it is easiable traced back here.
77 static const BeginFrameArgs kDefaultBeginFrameArgs
;
79 MockBeginFrameObserver() {
80 // Set a "default" value returned by LastUsedBeginFrameArgs so that gMock
81 // doesn't fail an assert and instead returns useful information.
82 EXPECT_CALL(*this, LastUsedBeginFrameArgs())
83 .Times(::testing::AnyNumber())
85 .WillRepeatedly(::testing::Return(kDefaultBeginFrameArgs
));
87 virtual ~MockBeginFrameObserver() {}
89 ::testing::Sequence sequence
;
92 TEST(MockBeginFrameObserverTest
, ExpectOnBeginFrame
) {
93 ::testing::NiceMock
<MockBeginFrameObserver
> obs
;
94 EXPECT_BEGIN_FRAME_USED(obs
, 100, 200, 300);
95 EXPECT_BEGIN_FRAME_USED(obs
, 400, 600, 300);
96 EXPECT_BEGIN_FRAME_USED(obs
, 700, 900, 300);
98 EXPECT_EQ(obs
.LastUsedBeginFrameArgs(),
99 MockBeginFrameObserver::kDefaultBeginFrameArgs
);
101 obs
.OnBeginFrame(CreateBeginFrameArgsForTesting(
102 100, 200, 300)); // One call to LastUsedBeginFrameArgs
103 EXPECT_EQ(obs
.LastUsedBeginFrameArgs(),
104 CreateBeginFrameArgsForTesting(100, 200, 300));
106 obs
.OnBeginFrame(CreateBeginFrameArgsForTesting(
107 400, 600, 300)); // Multiple calls to LastUsedBeginFrameArgs
108 EXPECT_EQ(obs
.LastUsedBeginFrameArgs(),
109 CreateBeginFrameArgsForTesting(400, 600, 300));
110 EXPECT_EQ(obs
.LastUsedBeginFrameArgs(),
111 CreateBeginFrameArgsForTesting(400, 600, 300));
113 obs
.OnBeginFrame(CreateBeginFrameArgsForTesting(
114 700, 900, 300)); // No calls to LastUsedBeginFrameArgs
117 TEST(MockBeginFrameObserverTest
, ExpectOnBeginFrameStatus
) {
118 ::testing::NiceMock
<MockBeginFrameObserver
> obs
;
119 EXPECT_BEGIN_FRAME_USED(obs
, 100, 200, 300);
120 EXPECT_BEGIN_FRAME_DROP(obs
, 400, 600, 300);
121 EXPECT_BEGIN_FRAME_DROP(obs
, 450, 650, 300);
122 EXPECT_BEGIN_FRAME_USED(obs
, 700, 900, 300);
124 EXPECT_EQ(obs
.LastUsedBeginFrameArgs(),
125 MockBeginFrameObserver::kDefaultBeginFrameArgs
);
128 obs
.OnBeginFrame(CreateBeginFrameArgsForTesting(100, 200, 300));
129 EXPECT_EQ(obs
.LastUsedBeginFrameArgs(),
130 CreateBeginFrameArgsForTesting(100, 200, 300));
133 obs
.OnBeginFrame(CreateBeginFrameArgsForTesting(400, 600, 300));
134 EXPECT_EQ(obs
.LastUsedBeginFrameArgs(),
135 CreateBeginFrameArgsForTesting(100, 200, 300));
138 obs
.OnBeginFrame(CreateBeginFrameArgsForTesting(450, 650, 300));
139 EXPECT_EQ(obs
.LastUsedBeginFrameArgs(),
140 CreateBeginFrameArgsForTesting(100, 200, 300));
143 obs
.OnBeginFrame(CreateBeginFrameArgsForTesting(700, 900, 300));
144 EXPECT_EQ(obs
.LastUsedBeginFrameArgs(),
145 CreateBeginFrameArgsForTesting(700, 900, 300));
148 const BeginFrameArgs
MockBeginFrameObserver::kDefaultBeginFrameArgs
=
149 CreateBeginFrameArgsForTesting(-1, -1, -1);
151 // BeginFrameObserverMixIn testing ---------------------------------------
152 class MockMinimalBeginFrameObserverMixIn
: public BeginFrameObserverMixIn
{
154 MOCK_METHOD1(OnBeginFrameMixInDelegate
, bool(const BeginFrameArgs
&));
155 int64_t dropped_begin_frame_args() const { return dropped_begin_frame_args_
; }
158 TEST(BeginFrameObserverMixInTest
, OnBeginFrameImplementation
) {
159 using ::testing::Return
;
160 MockMinimalBeginFrameObserverMixIn obs
;
161 ::testing::InSequence ordered
; // These calls should be ordered
163 // Initial conditions
164 EXPECT_EQ(BeginFrameArgs(), obs
.LastUsedBeginFrameArgs());
165 EXPECT_EQ(0, obs
.dropped_begin_frame_args());
168 EXPECT_DEATH({ obs
.OnBeginFrame(BeginFrameArgs()); }, "");
171 BeginFrameArgs args1
= CreateBeginFrameArgsForTesting(100, 200, 300);
172 EXPECT_CALL(obs
, OnBeginFrameMixInDelegate(args1
)).WillOnce(Return(true));
173 obs
.OnBeginFrame(args1
);
174 EXPECT_EQ(args1
, obs
.LastUsedBeginFrameArgs());
175 EXPECT_EQ(0, obs
.dropped_begin_frame_args());
179 { obs
.OnBeginFrame(CreateBeginFrameArgsForTesting(50, 200, 300)); }, "");
182 // Returning false shouldn't update the LastUsedBeginFrameArgs value.
183 BeginFrameArgs args2
= CreateBeginFrameArgsForTesting(200, 300, 400);
184 EXPECT_CALL(obs
, OnBeginFrameMixInDelegate(args2
)).WillOnce(Return(false));
185 obs
.OnBeginFrame(args2
);
186 EXPECT_EQ(args1
, obs
.LastUsedBeginFrameArgs());
187 EXPECT_EQ(1, obs
.dropped_begin_frame_args());
189 BeginFrameArgs args3
= CreateBeginFrameArgsForTesting(150, 300, 400);
190 EXPECT_CALL(obs
, OnBeginFrameMixInDelegate(args3
)).WillOnce(Return(true));
191 obs
.OnBeginFrame(args3
);
192 EXPECT_EQ(args3
, obs
.LastUsedBeginFrameArgs());
193 EXPECT_EQ(1, obs
.dropped_begin_frame_args());
196 // BeginFrameSource testing ----------------------------------------------
197 TEST(BeginFrameSourceMixInTest
, ObserverManipulation
) {
198 MockBeginFrameObserver obs
;
199 MockBeginFrameObserver otherObs
;
200 FakeBeginFrameSource source
;
202 source
.AddObserver(&obs
);
203 EXPECT_EQ(&obs
, source
.GetObserver());
206 // Adding an observer when an observer already exists should DCHECK fail.
207 EXPECT_DEATH({ source
.AddObserver(&otherObs
); }, "");
209 // Removing wrong observer should DCHECK fail.
210 EXPECT_DEATH({ source
.RemoveObserver(&otherObs
); }, "");
212 // Removing an observer when there is no observer should DCHECK fail.
214 source
.RemoveObserver(&obs
);
215 source
.RemoveObserver(&obs
);
219 source
.RemoveObserver(&obs
);
221 source
.AddObserver(&otherObs
);
222 EXPECT_EQ(&otherObs
, source
.GetObserver());
223 source
.RemoveObserver(&otherObs
);
226 TEST(BeginFrameSourceMixInTest
, Observer
) {
227 FakeBeginFrameSource source
;
228 MockBeginFrameObserver obs
;
229 source
.AddObserver(&obs
);
230 EXPECT_BEGIN_FRAME_USED(obs
, 100, 200, 300);
231 EXPECT_BEGIN_FRAME_DROP(obs
, 400, 600, 300);
232 EXPECT_BEGIN_FRAME_DROP(obs
, 450, 650, 300);
233 EXPECT_BEGIN_FRAME_USED(obs
, 700, 900, 300);
235 SEND_BEGIN_FRAME_USED(source
, 100, 200, 300);
236 SEND_BEGIN_FRAME_DROP(source
, 400, 600, 300);
237 SEND_BEGIN_FRAME_DROP(source
, 450, 650, 300);
238 SEND_BEGIN_FRAME_USED(source
, 700, 900, 300);
241 TEST(BeginFrameSourceMixInTest
, NoObserver
) {
242 FakeBeginFrameSource source
;
243 SEND_BEGIN_FRAME_DROP(source
, 100, 200, 300);
246 TEST(BeginFrameSourceMixInTest
, NeedsBeginFrames
) {
247 FakeBeginFrameSource source
;
248 EXPECT_FALSE(source
.NeedsBeginFrames());
249 source
.SetNeedsBeginFrames(true);
250 EXPECT_TRUE(source
.NeedsBeginFrames());
251 source
.SetNeedsBeginFrames(false);
252 EXPECT_FALSE(source
.NeedsBeginFrames());
255 class LoopingBeginFrameObserver
: public BeginFrameObserverMixIn
{
257 BeginFrameSource
* source_
;
259 void AsValueInto(base::debug::TracedValue
* dict
) const override
{
260 dict
->SetString("type", "LoopingBeginFrameObserver");
261 dict
->BeginDictionary("source");
262 source_
->AsValueInto(dict
);
263 dict
->EndDictionary();
267 // BeginFrameObserverMixIn
268 bool OnBeginFrameMixInDelegate(const BeginFrameArgs
& args
) override
{
273 TEST(BeginFrameSourceMixInTest
, DetectAsValueIntoLoop
) {
274 LoopingBeginFrameObserver obs
;
275 FakeBeginFrameSource source
;
277 obs
.source_
= &source
;
278 source
.AddObserver(&obs
);
280 scoped_refptr
<base::debug::TracedValue
> state
=
281 new base::debug::TracedValue();
282 source
.AsValueInto(state
.get());
285 // BackToBackBeginFrameSource testing -----------------------------------------
286 class TestBackToBackBeginFrameSource
: public BackToBackBeginFrameSource
{
288 static scoped_ptr
<TestBackToBackBeginFrameSource
> Create(
289 scoped_refptr
<TestNowSource
> now_src
,
290 base::SingleThreadTaskRunner
* task_runner
) {
291 return make_scoped_ptr(
292 new TestBackToBackBeginFrameSource(now_src
, task_runner
));
296 TestBackToBackBeginFrameSource(scoped_refptr
<TestNowSource
> now_src
,
297 base::SingleThreadTaskRunner
* task_runner
)
298 : BackToBackBeginFrameSource(task_runner
), now_src_(now_src
) {}
300 base::TimeTicks
Now() override
{ return now_src_
->Now(); }
302 scoped_refptr
<TestNowSource
> now_src_
;
305 class BackToBackBeginFrameSourceTest
: public ::testing::Test
{
307 static const int64_t kDeadline
;
308 static const int64_t kInterval
;
310 scoped_refptr
<TestNowSource
> now_src_
;
311 scoped_refptr
<OrderedSimpleTaskRunner
> task_runner_
;
312 scoped_ptr
<TestBackToBackBeginFrameSource
> source_
;
313 scoped_ptr
<MockBeginFrameObserver
> obs_
;
315 void SetUp() override
{
316 now_src_
= TestNowSource::Create(1000);
318 make_scoped_refptr(new OrderedSimpleTaskRunner(now_src_
, false));
319 task_runner_
->SetRunTaskLimit(1);
321 TestBackToBackBeginFrameSource::Create(now_src_
, task_runner_
.get());
322 obs_
= make_scoped_ptr(new ::testing::StrictMock
<MockBeginFrameObserver
>());
323 source_
->AddObserver(obs_
.get());
326 void TearDown() override
{ obs_
.reset(); }
329 const int64_t BackToBackBeginFrameSourceTest::kDeadline
=
330 BeginFrameArgs::DefaultInterval().ToInternalValue();
332 const int64_t BackToBackBeginFrameSourceTest::kInterval
=
333 BeginFrameArgs::DefaultInterval().ToInternalValue();
335 TEST_F(BackToBackBeginFrameSourceTest
, SetNeedsBeginFramesSendsBeginFrame
) {
336 EXPECT_BEGIN_FRAME_USED(*obs_
, 1000, 1000 + kDeadline
, kInterval
);
337 source_
->SetNeedsBeginFrames(true);
338 EXPECT_TRUE(task_runner_
->HasPendingTasks());
339 task_runner_
->RunUntilIdle();
341 EXPECT_BEGIN_FRAME_USED(*obs_
, 1100, 1100 + kDeadline
, kInterval
);
342 now_src_
->AdvanceNowMicroseconds(100);
343 source_
->DidFinishFrame(0);
344 task_runner_
->RunUntilIdle();
347 TEST_F(BackToBackBeginFrameSourceTest
,
348 DidFinishFrameThenSetNeedsBeginFramesProducesNoFrame
) {
349 EXPECT_BEGIN_FRAME_USED(*obs_
, 1000, 1000 + kDeadline
, kInterval
);
350 source_
->SetNeedsBeginFrames(true);
351 task_runner_
->RunUntilIdle();
353 source_
->SetNeedsBeginFrames(false);
354 source_
->DidFinishFrame(0);
356 EXPECT_FALSE(task_runner_
->HasPendingTasks());
359 TEST_F(BackToBackBeginFrameSourceTest
,
360 SetNeedsBeginFramesThenDidFinishFrameProducesNoFrame
) {
361 EXPECT_BEGIN_FRAME_USED(*obs_
, 1000, 1000 + kDeadline
, kInterval
);
362 source_
->SetNeedsBeginFrames(true);
363 task_runner_
->RunUntilIdle();
365 now_src_
->AdvanceNowMicroseconds(100);
366 source_
->DidFinishFrame(0);
367 source_
->SetNeedsBeginFrames(false);
369 EXPECT_TRUE(task_runner_
->HasPendingTasks());
370 task_runner_
->RunUntilIdle();
373 TEST_F(BackToBackBeginFrameSourceTest
,
374 DidFinishFrameThenTogglingSetNeedsBeginFramesProducesCorrectFrame
) {
375 EXPECT_BEGIN_FRAME_USED(*obs_
, 1000, 1000 + kDeadline
, kInterval
);
376 source_
->SetNeedsBeginFrames(true);
377 task_runner_
->RunUntilIdle();
379 now_src_
->AdvanceNowMicroseconds(100);
381 source_
->SetNeedsBeginFrames(false);
382 now_src_
->AdvanceNowMicroseconds(10);
383 source_
->DidFinishFrame(0);
384 now_src_
->AdvanceNowMicroseconds(10);
385 source_
->SetNeedsBeginFrames(false);
386 now_src_
->AdvanceNowMicroseconds(10);
387 source_
->SetNeedsBeginFrames(true);
389 EXPECT_BEGIN_FRAME_USED(*obs_
, 1130, 1130 + kDeadline
, kInterval
);
390 EXPECT_TRUE(task_runner_
->HasPendingTasks());
391 task_runner_
->RunUntilIdle();
394 TEST_F(BackToBackBeginFrameSourceTest
,
395 TogglingSetNeedsBeginFramesThenDidFinishFrameProducesCorrectFrame
) {
396 EXPECT_BEGIN_FRAME_USED(*obs_
, 1000, 1000 + kDeadline
, kInterval
);
397 source_
->SetNeedsBeginFrames(true);
398 task_runner_
->RunUntilIdle();
400 now_src_
->AdvanceNowMicroseconds(100);
401 source_
->DidFinishFrame(0);
402 now_src_
->AdvanceNowMicroseconds(10);
403 source_
->SetNeedsBeginFrames(false);
404 now_src_
->AdvanceNowMicroseconds(10);
405 source_
->SetNeedsBeginFrames(true);
406 now_src_
->AdvanceNowMicroseconds(10);
408 EXPECT_BEGIN_FRAME_USED(*obs_
, 1130, 1130 + kDeadline
, kInterval
);
409 EXPECT_TRUE(task_runner_
->HasPendingTasks());
410 task_runner_
->RunUntilIdle();
413 TEST_F(BackToBackBeginFrameSourceTest
, DidFinishFrameNeedsBeginFrameFalse
) {
414 source_
->SetNeedsBeginFrames(false);
415 source_
->DidFinishFrame(0);
416 EXPECT_FALSE(task_runner_
->RunPendingTasks());
419 TEST_F(BackToBackBeginFrameSourceTest
, DidFinishFrameRemainingFrames
) {
420 EXPECT_BEGIN_FRAME_USED(*obs_
, 1000, 1000 + kDeadline
, kInterval
);
421 source_
->SetNeedsBeginFrames(true);
422 task_runner_
->RunUntilIdle();
424 now_src_
->AdvanceNowMicroseconds(100);
426 source_
->DidFinishFrame(3);
427 EXPECT_FALSE(task_runner_
->HasPendingTasks());
428 source_
->DidFinishFrame(2);
429 EXPECT_FALSE(task_runner_
->HasPendingTasks());
430 source_
->DidFinishFrame(1);
431 EXPECT_FALSE(task_runner_
->HasPendingTasks());
433 EXPECT_BEGIN_FRAME_USED(*obs_
, 1100, 1100 + kDeadline
, kInterval
);
434 source_
->DidFinishFrame(0);
435 EXPECT_EQ(base::TimeDelta(), task_runner_
->DelayToNextTaskTime());
436 task_runner_
->RunUntilIdle();
439 TEST_F(BackToBackBeginFrameSourceTest
, DidFinishFrameMultipleCallsIdempotent
) {
440 source_
->SetNeedsBeginFrames(true);
441 EXPECT_BEGIN_FRAME_USED(*obs_
, 1000, 1000 + kDeadline
, kInterval
);
442 task_runner_
->RunUntilIdle();
444 now_src_
->AdvanceNowMicroseconds(100);
445 source_
->DidFinishFrame(0);
446 source_
->DidFinishFrame(0);
447 source_
->DidFinishFrame(0);
448 EXPECT_BEGIN_FRAME_USED(*obs_
, 1100, 1100 + kDeadline
, kInterval
);
449 task_runner_
->RunUntilIdle();
451 now_src_
->AdvanceNowMicroseconds(100);
452 source_
->DidFinishFrame(0);
453 source_
->DidFinishFrame(0);
454 source_
->DidFinishFrame(0);
455 EXPECT_BEGIN_FRAME_USED(*obs_
, 1200, 1200 + kDeadline
, kInterval
);
456 task_runner_
->RunUntilIdle();
459 TEST_F(BackToBackBeginFrameSourceTest
, DelayInPostedTaskProducesCorrectFrame
) {
460 EXPECT_BEGIN_FRAME_USED(*obs_
, 1000, 1000 + kDeadline
, kInterval
);
461 source_
->SetNeedsBeginFrames(true);
462 task_runner_
->RunUntilIdle();
464 now_src_
->AdvanceNowMicroseconds(100);
465 source_
->DidFinishFrame(0);
466 now_src_
->AdvanceNowMicroseconds(50);
467 EXPECT_BEGIN_FRAME_USED(*obs_
, 1150, 1150 + kDeadline
, kInterval
);
469 EXPECT_TRUE(task_runner_
->HasPendingTasks());
470 task_runner_
->RunUntilIdle();
473 // SyntheticBeginFrameSource testing ------------------------------------------
474 class SyntheticBeginFrameSourceTest
: public ::testing::Test
{
476 scoped_refptr
<TestNowSource
> now_src_
;
477 scoped_refptr
<OrderedSimpleTaskRunner
> task_runner_
;
478 scoped_ptr
<TestSyntheticBeginFrameSource
> source_
;
479 scoped_ptr
<MockBeginFrameObserver
> obs_
;
481 void SetUp() override
{
482 now_src_
= TestNowSource::Create(1000);
484 make_scoped_refptr(new OrderedSimpleTaskRunner(now_src_
, false));
485 source_
= TestSyntheticBeginFrameSource::Create(
486 now_src_
, task_runner_
.get(), base::TimeDelta::FromMicroseconds(10000));
487 obs_
= make_scoped_ptr(new MockBeginFrameObserver());
488 source_
->AddObserver(obs_
.get());
491 void TearDown() override
{ obs_
.reset(); }
494 TEST_F(SyntheticBeginFrameSourceTest
,
495 SetNeedsBeginFramesCallsOnBeginFrameWithMissedTick
) {
496 now_src_
->SetNowMicroseconds(10010);
498 OnBeginFrame(CreateTypedBeginFrameArgsForTesting(
499 10000, 20000, 10000, BeginFrameArgs::MISSED
)));
500 source_
->SetNeedsBeginFrames(true); // Should cause the last tick to be sent
501 // No tasks should need to be run for this to occur.
504 TEST_F(SyntheticBeginFrameSourceTest
,
505 SetNeedsBeginFramesCallsCausesOnBeginFrame
) {
506 source_
->SetNeedsBeginFrames(true);
507 EXPECT_EQ(10000, task_runner_
->NextTaskTime().ToInternalValue());
509 EXPECT_BEGIN_FRAME_USED(*obs_
, 10000, 20000, 10000);
510 now_src_
->SetNowMicroseconds(10010);
511 task_runner_
->RunPendingTasks();
514 TEST_F(SyntheticBeginFrameSourceTest
, BasicOperation
) {
515 task_runner_
->SetAutoAdvanceNowToPendingTasks(true);
517 source_
->SetNeedsBeginFrames(true);
518 EXPECT_BEGIN_FRAME_USED(*obs_
, 10000, 20000, 10000);
519 EXPECT_BEGIN_FRAME_USED(*obs_
, 20000, 30000, 10000);
520 EXPECT_BEGIN_FRAME_USED(*obs_
, 30000, 40000, 10000);
521 task_runner_
->RunUntilTime(base::TimeTicks::FromInternalValue(30001));
523 source_
->SetNeedsBeginFrames(false);
525 task_runner_
->RunUntilTime(base::TimeTicks::FromInternalValue(60000));
528 TEST_F(SyntheticBeginFrameSourceTest
, VSyncChanges
) {
529 task_runner_
->SetAutoAdvanceNowToPendingTasks(true);
530 source_
->SetNeedsBeginFrames(true);
532 EXPECT_BEGIN_FRAME_USED(*obs_
, 10000, 20000, 10000);
533 EXPECT_BEGIN_FRAME_USED(*obs_
, 20000, 30000, 10000);
534 EXPECT_BEGIN_FRAME_USED(*obs_
, 30000, 40000, 10000);
535 task_runner_
->RunUntilTime(base::TimeTicks::FromInternalValue(30001));
537 // Update the vsync information
538 source_
->OnUpdateVSyncParameters(base::TimeTicks::FromInternalValue(27500),
539 base::TimeDelta::FromMicroseconds(10001));
541 EXPECT_BEGIN_FRAME_USED(*obs_
, 40000, 47502, 10001);
542 EXPECT_BEGIN_FRAME_USED(*obs_
, 47502, 57503, 10001);
543 EXPECT_BEGIN_FRAME_USED(*obs_
, 57503, 67504, 10001);
544 task_runner_
->RunUntilTime(base::TimeTicks::FromInternalValue(60000));
547 // BeginFrameSourceMultiplexer testing -----------------------------------
548 class BeginFrameSourceMultiplexerTest
: public ::testing::Test
{
550 void SetUp() override
{
551 mux_
= BeginFrameSourceMultiplexer::Create();
553 source1_store_
= make_scoped_ptr(new FakeBeginFrameSource());
554 source2_store_
= make_scoped_ptr(new FakeBeginFrameSource());
555 source3_store_
= make_scoped_ptr(new FakeBeginFrameSource());
557 source1_
= source1_store_
.get();
558 source2_
= source2_store_
.get();
559 source3_
= source3_store_
.get();
562 void TearDown() override
{
563 // Make sure the mux is torn down before the sources.
567 scoped_ptr
<BeginFrameSourceMultiplexer
> mux_
;
568 FakeBeginFrameSource
* source1_
;
569 FakeBeginFrameSource
* source2_
;
570 FakeBeginFrameSource
* source3_
;
573 scoped_ptr
<FakeBeginFrameSource
> source1_store_
;
574 scoped_ptr
<FakeBeginFrameSource
> source2_store_
;
575 scoped_ptr
<FakeBeginFrameSource
> source3_store_
;
578 TEST_F(BeginFrameSourceMultiplexerTest
, SourcesManipulation
) {
579 EXPECT_EQ(NULL
, mux_
->ActiveSource());
581 mux_
->AddSource(source1_
);
582 EXPECT_EQ(source1_
, mux_
->ActiveSource());
584 mux_
->SetActiveSource(NULL
);
585 EXPECT_EQ(NULL
, mux_
->ActiveSource());
587 mux_
->SetActiveSource(source1_
);
590 // Setting a source which isn't in the mux as active should DCHECK fail.
591 EXPECT_DEATH({ mux_
->SetActiveSource(source2_
); }, "");
593 // Adding a source which is already added should DCHECK fail.
594 EXPECT_DEATH({ mux_
->AddSource(source1_
); }, "");
596 // Removing a source which isn't in the mux should DCHECK fail.
597 EXPECT_DEATH({ mux_
->RemoveSource(source2_
); }, "");
599 // Removing the active source fails
600 EXPECT_DEATH({ mux_
->RemoveSource(source1_
); }, "");
603 // Test manipulation doesn't segfault.
604 mux_
->AddSource(source2_
);
605 mux_
->RemoveSource(source2_
);
607 mux_
->AddSource(source2_
);
608 mux_
->SetActiveSource(source2_
);
609 EXPECT_EQ(source2_
, mux_
->ActiveSource());
611 mux_
->RemoveSource(source1_
);
614 TEST_F(BeginFrameSourceMultiplexerTest
, NeedsBeginFrames
) {
615 mux_
->AddSource(source1_
);
616 mux_
->AddSource(source2_
);
617 mux_
->SetActiveSource(source1_
);
618 EXPECT_EQ(source1_
->NeedsBeginFrames(), false);
619 EXPECT_EQ(source2_
->NeedsBeginFrames(), false);
621 // Check SetNeedsFrames works
622 mux_
->SetNeedsBeginFrames(true);
623 EXPECT_EQ(source1_
->NeedsBeginFrames(), true);
624 EXPECT_EQ(source2_
->NeedsBeginFrames(), false);
626 mux_
->SetNeedsBeginFrames(false);
627 EXPECT_EQ(source1_
->NeedsBeginFrames(), false);
628 EXPECT_EQ(source2_
->NeedsBeginFrames(), false);
630 // Checking that switching the source makes SetNeedsFrames on the
631 // subsources correctly.
632 mux_
->SetNeedsBeginFrames(true);
634 mux_
->SetActiveSource(source1_
);
635 EXPECT_EQ(source1_
->NeedsBeginFrames(), true);
636 EXPECT_EQ(source2_
->NeedsBeginFrames(), false);
638 mux_
->SetActiveSource(source2_
);
639 EXPECT_EQ(source1_
->NeedsBeginFrames(), false);
640 EXPECT_EQ(source2_
->NeedsBeginFrames(), true);
643 TEST_F(BeginFrameSourceMultiplexerTest
, BeginFramesSimple
) {
644 mux_
->AddSource(source1_
);
645 mux_
->AddSource(source2_
);
646 mux_
->SetActiveSource(source1_
);
648 MockBeginFrameObserver obs
;
649 mux_
->AddObserver(&obs
);
650 EXPECT_BEGIN_FRAME_USED(obs
, 100, 200, 300);
651 EXPECT_BEGIN_FRAME_USED(obs
, 400, 600, 300);
653 mux_
->SetActiveSource(source1_
);
655 SEND_BEGIN_FRAME_USED(*source1_
, 100, 200, 300);
656 SEND_BEGIN_FRAME_DROP(*source2_
, 200, 500, 300);
658 mux_
->SetActiveSource(source2_
);
659 SEND_BEGIN_FRAME_USED(*source2_
, 400, 600, 300);
660 SEND_BEGIN_FRAME_DROP(*source1_
, 500, 700, 300);
663 TEST_F(BeginFrameSourceMultiplexerTest
, BeginFramesBackwardsProtection
) {
664 mux_
->AddSource(source1_
);
665 mux_
->AddSource(source2_
);
667 MockBeginFrameObserver obs
;
668 mux_
->AddObserver(&obs
);
669 EXPECT_BEGIN_FRAME_USED(obs
, 400, 600, 300);
670 EXPECT_BEGIN_FRAME_USED(obs
, 700, 900, 300);
671 EXPECT_BEGIN_FRAME_USED(obs
, 1000, 1200, 300);
672 EXPECT_BEGIN_FRAME_USED(obs
, 1001, 1201, 301);
674 mux_
->SetActiveSource(source1_
);
675 SEND_BEGIN_FRAME_USED(*source1_
, 400, 600, 300);
676 SEND_BEGIN_FRAME_USED(*source1_
, 700, 900, 300);
678 mux_
->SetActiveSource(source2_
);
679 SEND_BEGIN_FRAME_DROP(*source2_
, 699, 899, 300);
680 SEND_BEGIN_FRAME_USED(*source2_
, 1000, 1200, 300);
682 mux_
->SetActiveSource(source1_
);
683 SEND_BEGIN_FRAME_USED(*source1_
, 1001, 1201, 301);
686 TEST_F(BeginFrameSourceMultiplexerTest
, MinimumIntervalNegativeFails
) {
689 { mux_
->SetMinimumInterval(base::TimeDelta::FromInternalValue(-100)); },
694 TEST_F(BeginFrameSourceMultiplexerTest
, MinimumIntervalZero
) {
695 mux_
->SetMinimumInterval(base::TimeDelta());
696 mux_
->AddSource(source1_
);
698 MockBeginFrameObserver obs
;
699 mux_
->AddObserver(&obs
);
700 EXPECT_BEGIN_FRAME_USED(obs
, 100, 200, 300);
701 EXPECT_BEGIN_FRAME_USED(obs
, 400, 600, 300);
702 EXPECT_BEGIN_FRAME_USED(obs
, 700, 900, 300);
704 SEND_BEGIN_FRAME_USED(*source1_
, 100, 200, 300);
705 SEND_BEGIN_FRAME_USED(*source1_
, 400, 600, 300);
706 SEND_BEGIN_FRAME_USED(*source1_
, 700, 900, 300);
709 TEST_F(BeginFrameSourceMultiplexerTest
, MinimumIntervalBasic
) {
710 mux_
->SetMinimumInterval(base::TimeDelta::FromInternalValue(600));
711 mux_
->AddSource(source1_
);
713 MockBeginFrameObserver obs
;
714 mux_
->AddObserver(&obs
);
715 EXPECT_BEGIN_FRAME_USED(obs
, 100, 200, 300);
716 EXPECT_BEGIN_FRAME_USED(obs
, 700, 900, 300);
718 SEND_BEGIN_FRAME_USED(*source1_
, 100, 200, 300);
719 SEND_BEGIN_FRAME_DROP(*source1_
, 400, 600, 300);
720 SEND_BEGIN_FRAME_USED(*source1_
, 700, 900, 300);
723 TEST_F(BeginFrameSourceMultiplexerTest
, MinimumIntervalWithMultipleSources
) {
724 mux_
->SetMinimumInterval(base::TimeDelta::FromMicroseconds(150));
725 mux_
->AddSource(source1_
);
726 mux_
->AddSource(source2_
);
728 MockBeginFrameObserver obs
;
729 mux_
->AddObserver(&obs
);
730 EXPECT_BEGIN_FRAME_USED(obs
, 400, 600, 300);
731 EXPECT_BEGIN_FRAME_USED(obs
, 700, 900, 300);
732 EXPECT_BEGIN_FRAME_USED(obs
, 1050, 1250, 300);
734 mux_
->SetActiveSource(source1_
);
735 SEND_BEGIN_FRAME_USED(*source1_
, 400, 600, 300);
736 SEND_BEGIN_FRAME_USED(*source1_
, 700, 900, 300);
738 mux_
->SetActiveSource(source2_
);
739 SEND_BEGIN_FRAME_DROP(*source2_
, 750, 1050, 300);
740 SEND_BEGIN_FRAME_USED(*source2_
, 1050, 1250, 300);
742 mux_
->SetActiveSource(source1_
);
743 SEND_BEGIN_FRAME_DROP(*source2_
, 1100, 1400, 300);