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

Side by Side Diff: components/scheduler/renderer/auto_advancing_virtual_time_domain_unittest.cc

Issue 1898233002: Report expected task queueing time via UMA (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Remove export. Fix windows. Created 4 years, 5 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 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
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
OLDNEW
« no previous file with comments | « components/scheduler/child/scheduler_helper.cc ('k') | components/scheduler/renderer/idle_time_estimator_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698