OLD | NEW |
| (Empty) |
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 | |
3 // found in the LICENSE file. | |
4 | |
5 #include "content/renderer/scheduler/deadline_task_runner.h" | |
6 | |
7 #include "cc/test/ordered_simple_task_runner.h" | |
8 #include "cc/test/test_now_source.h" | |
9 #include "testing/gmock/include/gmock/gmock.h" | |
10 #include "testing/gtest/include/gtest/gtest.h" | |
11 | |
12 namespace content { | |
13 | |
14 class DeadlineTaskRunnerTest : public testing::Test { | |
15 public: | |
16 DeadlineTaskRunnerTest() {} | |
17 ~DeadlineTaskRunnerTest() override {} | |
18 | |
19 void SetUp() override { | |
20 clock_ = cc::TestNowSource::Create(5000); | |
21 mock_task_runner_ = new cc::OrderedSimpleTaskRunner(clock_, true); | |
22 deadline_task_runner_.reset(new DeadlineTaskRunner( | |
23 base::Bind(&DeadlineTaskRunnerTest::TestTask, base::Unretained(this)), | |
24 mock_task_runner_)); | |
25 run_times_.clear(); | |
26 } | |
27 | |
28 bool RunUntilIdle() { return mock_task_runner_->RunUntilIdle(); } | |
29 | |
30 void TestTask() { run_times_.push_back(clock_->Now()); } | |
31 | |
32 scoped_refptr<cc::TestNowSource> clock_; | |
33 scoped_refptr<cc::OrderedSimpleTaskRunner> mock_task_runner_; | |
34 scoped_ptr<DeadlineTaskRunner> deadline_task_runner_; | |
35 std::vector<base::TimeTicks> run_times_; | |
36 }; | |
37 | |
38 TEST_F(DeadlineTaskRunnerTest, RunOnce) { | |
39 base::TimeTicks start_time = clock_->Now(); | |
40 base::TimeDelta delay = base::TimeDelta::FromMilliseconds(10); | |
41 deadline_task_runner_->SetDeadline(FROM_HERE, delay, clock_->Now()); | |
42 RunUntilIdle(); | |
43 | |
44 EXPECT_THAT(run_times_, testing::ElementsAre(start_time + delay)); | |
45 }; | |
46 | |
47 TEST_F(DeadlineTaskRunnerTest, RunTwice) { | |
48 base::TimeDelta delay1 = base::TimeDelta::FromMilliseconds(10); | |
49 base::TimeTicks deadline1 = clock_->Now() + delay1; | |
50 deadline_task_runner_->SetDeadline(FROM_HERE, delay1, clock_->Now()); | |
51 RunUntilIdle(); | |
52 | |
53 base::TimeDelta delay2 = base::TimeDelta::FromMilliseconds(100); | |
54 base::TimeTicks deadline2 = clock_->Now() + delay2; | |
55 deadline_task_runner_->SetDeadline(FROM_HERE, delay2, clock_->Now()); | |
56 RunUntilIdle(); | |
57 | |
58 EXPECT_THAT(run_times_, testing::ElementsAre(deadline1, deadline2)); | |
59 }; | |
60 | |
61 TEST_F(DeadlineTaskRunnerTest, EarlierDeadlinesTakePrecidence) { | |
62 base::TimeTicks start_time = clock_->Now(); | |
63 base::TimeDelta delay1 = base::TimeDelta::FromMilliseconds(1); | |
64 base::TimeDelta delay10 = base::TimeDelta::FromMilliseconds(10); | |
65 base::TimeDelta delay100 = base::TimeDelta::FromMilliseconds(100); | |
66 deadline_task_runner_->SetDeadline(FROM_HERE, delay100, clock_->Now()); | |
67 deadline_task_runner_->SetDeadline(FROM_HERE, delay10, clock_->Now()); | |
68 deadline_task_runner_->SetDeadline(FROM_HERE, delay1, clock_->Now()); | |
69 | |
70 RunUntilIdle(); | |
71 | |
72 EXPECT_THAT(run_times_, testing::ElementsAre(start_time + delay1)); | |
73 }; | |
74 | |
75 TEST_F(DeadlineTaskRunnerTest, LaterDeadlinesIgnored) { | |
76 base::TimeTicks start_time = clock_->Now(); | |
77 base::TimeDelta delay100 = base::TimeDelta::FromMilliseconds(100); | |
78 base::TimeDelta delay10000 = base::TimeDelta::FromMilliseconds(10000); | |
79 deadline_task_runner_->SetDeadline(FROM_HERE, delay100, clock_->Now()); | |
80 deadline_task_runner_->SetDeadline(FROM_HERE, delay10000, clock_->Now()); | |
81 | |
82 RunUntilIdle(); | |
83 | |
84 EXPECT_THAT(run_times_, testing::ElementsAre(start_time + delay100)); | |
85 }; | |
86 | |
87 TEST_F(DeadlineTaskRunnerTest, DeleteDeadlineTaskRunnerAfterPosting) { | |
88 deadline_task_runner_->SetDeadline( | |
89 FROM_HERE, base::TimeDelta::FromMilliseconds(10), clock_->Now()); | |
90 | |
91 // Deleting the pending task should cancel it. | |
92 deadline_task_runner_.reset(nullptr); | |
93 RunUntilIdle(); | |
94 | |
95 EXPECT_TRUE(run_times_.empty()); | |
96 }; | |
97 | |
98 } // namespace content | |
OLD | NEW |