OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 "components/scheduler/renderer/auto_advancing_virtual_time_domain.h" | 5 #include "components/scheduler/renderer/auto_advancing_virtual_time_domain.h" |
6 | 6 |
7 #include "base/memory/ptr_util.h" | 7 #include "base/memory/ptr_util.h" |
8 #include "base/test/simple_test_tick_clock.h" | 8 #include "base/test/simple_test_tick_clock.h" |
9 #include "cc/test/ordered_simple_task_runner.h" | 9 #include "cc/test/ordered_simple_task_runner.h" |
10 #include "components/scheduler/base/task_queue_manager.h" | 10 #include "components/scheduler/base/task_queue_manager.h" |
| 11 #include "components/scheduler/base/test_task_time_tracker.h" |
11 #include "components/scheduler/base/test_time_source.h" | 12 #include "components/scheduler/base/test_time_source.h" |
12 #include "components/scheduler/child/scheduler_tqm_delegate_for_test.h" | 13 #include "components/scheduler/child/scheduler_tqm_delegate_for_test.h" |
13 #include "testing/gmock/include/gmock/gmock.h" | 14 #include "testing/gmock/include/gmock/gmock.h" |
14 #include "testing/gtest/include/gtest/gtest.h" | 15 #include "testing/gtest/include/gtest/gtest.h" |
15 | 16 |
16 namespace scheduler { | 17 namespace scheduler { |
17 | 18 |
18 class AutoAdvancingVirtualTimeDomainTest : public testing::Test { | 19 class AutoAdvancingVirtualTimeDomainTest : public testing::Test { |
19 public: | 20 public: |
20 AutoAdvancingVirtualTimeDomainTest() {} | 21 AutoAdvancingVirtualTimeDomainTest() {} |
21 ~AutoAdvancingVirtualTimeDomainTest() override {} | 22 ~AutoAdvancingVirtualTimeDomainTest() override {} |
22 | 23 |
23 void SetUp() override { | 24 void SetUp() override { |
24 clock_.reset(new base::SimpleTestTickClock()); | 25 clock_.reset(new base::SimpleTestTickClock()); |
25 clock_->Advance(base::TimeDelta::FromMicroseconds(5000)); | 26 clock_->Advance(base::TimeDelta::FromMicroseconds(5000)); |
26 | 27 |
27 test_time_source_.reset(new TestTimeSource(clock_.get())); | 28 test_time_source_.reset(new TestTimeSource(clock_.get())); |
28 mock_task_runner_ = make_scoped_refptr( | 29 mock_task_runner_ = make_scoped_refptr( |
29 new cc::OrderedSimpleTaskRunner(clock_.get(), false)); | 30 new cc::OrderedSimpleTaskRunner(clock_.get(), false)); |
30 main_task_runner_ = SchedulerTqmDelegateForTest::Create( | 31 main_task_runner_ = SchedulerTqmDelegateForTest::Create( |
31 mock_task_runner_, base::WrapUnique(new TestTimeSource(clock_.get()))); | 32 mock_task_runner_, base::WrapUnique(new TestTimeSource(clock_.get()))); |
32 manager_ = base::WrapUnique( | 33 |
33 new TaskQueueManager(main_task_runner_, "test.scheduler", | 34 manager_ = base::WrapUnique(new TaskQueueManager( |
34 "test.scheduler", "test.scheduler.debug")); | 35 main_task_runner_, "test.scheduler", "test.scheduler", |
| 36 "test.scheduler.debug")); |
| 37 manager_->SetTaskTimeTracker(&test_task_time_tracker_); |
35 task_runner_ = | 38 task_runner_ = |
36 manager_->NewTaskQueue(TaskQueue::Spec("test_task_queue")); | 39 manager_->NewTaskQueue(TaskQueue::Spec("test_task_queue")); |
37 initial_time_= clock_->NowTicks(); | 40 initial_time_= clock_->NowTicks(); |
38 auto_advancing_time_domain_.reset( | 41 auto_advancing_time_domain_.reset( |
39 new AutoAdvancingVirtualTimeDomain(initial_time_)); | 42 new AutoAdvancingVirtualTimeDomain(initial_time_)); |
40 manager_->RegisterTimeDomain(auto_advancing_time_domain_.get()); | 43 manager_->RegisterTimeDomain(auto_advancing_time_domain_.get()); |
41 task_runner_->SetTimeDomain(auto_advancing_time_domain_.get()); | 44 task_runner_->SetTimeDomain(auto_advancing_time_domain_.get()); |
42 } | 45 } |
43 | 46 |
44 void TearDown() override { | 47 void TearDown() override { |
45 task_runner_->UnregisterTaskQueue(); | 48 task_runner_->UnregisterTaskQueue(); |
46 manager_->UnregisterTimeDomain(auto_advancing_time_domain_.get()); | 49 manager_->UnregisterTimeDomain(auto_advancing_time_domain_.get()); |
47 } | 50 } |
48 | 51 |
49 base::TimeTicks initial_time_; | 52 base::TimeTicks initial_time_; |
50 std::unique_ptr<base::SimpleTestTickClock> clock_; | 53 std::unique_ptr<base::SimpleTestTickClock> clock_; |
51 std::unique_ptr<TestTimeSource> test_time_source_; | 54 std::unique_ptr<TestTimeSource> test_time_source_; |
52 scoped_refptr<cc::OrderedSimpleTaskRunner> mock_task_runner_; | 55 scoped_refptr<cc::OrderedSimpleTaskRunner> mock_task_runner_; |
53 scoped_refptr<SchedulerTqmDelegate> main_task_runner_; | 56 scoped_refptr<SchedulerTqmDelegate> main_task_runner_; |
54 std::unique_ptr<TaskQueueManager> manager_; | 57 std::unique_ptr<TaskQueueManager> manager_; |
55 scoped_refptr<TaskQueue> task_runner_; | 58 scoped_refptr<TaskQueue> task_runner_; |
56 std::unique_ptr<AutoAdvancingVirtualTimeDomain> auto_advancing_time_domain_; | 59 std::unique_ptr<AutoAdvancingVirtualTimeDomain> auto_advancing_time_domain_; |
| 60 TestTaskTimeTracker test_task_time_tracker_; |
57 }; | 61 }; |
58 | 62 |
59 namespace { | 63 namespace { |
60 void NopTask(bool* task_run) { | 64 void NopTask(bool* task_run) { |
61 *task_run = true; | 65 *task_run = true; |
62 } | 66 } |
63 } // namesapce | 67 } // namesapce |
64 | 68 |
65 TEST_F(AutoAdvancingVirtualTimeDomainTest, VirtualTimeAdvances) { | 69 TEST_F(AutoAdvancingVirtualTimeDomainTest, VirtualTimeAdvances) { |
66 base::TimeDelta delay = base::TimeDelta::FromMilliseconds(10); | 70 base::TimeDelta delay = base::TimeDelta::FromMilliseconds(10); |
(...skipping 18 matching lines...) Expand all Loading... |
85 auto_advancing_time_domain_->SetCanAdvanceVirtualTime(false); | 89 auto_advancing_time_domain_->SetCanAdvanceVirtualTime(false); |
86 | 90 |
87 mock_task_runner_->RunUntilIdle(); | 91 mock_task_runner_->RunUntilIdle(); |
88 | 92 |
89 EXPECT_EQ(initial_time_, clock_->NowTicks()); | 93 EXPECT_EQ(initial_time_, clock_->NowTicks()); |
90 EXPECT_EQ(initial_time_, auto_advancing_time_domain_->CreateLazyNow().Now()); | 94 EXPECT_EQ(initial_time_, auto_advancing_time_domain_->CreateLazyNow().Now()); |
91 EXPECT_FALSE(task_run); | 95 EXPECT_FALSE(task_run); |
92 } | 96 } |
93 | 97 |
94 } // namespace scheduler | 98 } // namespace scheduler |
OLD | NEW |