OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 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 | 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 "base/test/scoped_mock_time_message_loop_task_runner.h" | 5 #include "base/test/scoped_mock_time_message_loop_task_runner.h" |
6 | 6 |
7 #include <deque> | 7 #include <deque> |
8 #include <memory> | 8 #include <memory> |
9 | 9 |
10 #include "base/bind.h" | 10 #include "base/bind.h" |
11 #include "base/bind_helpers.h" | 11 #include "base/bind_helpers.h" |
12 #include "base/callback_forward.h" | 12 #include "base/callback_forward.h" |
13 #include "base/macros.h" | 13 #include "base/macros.h" |
14 #include "base/memory/ptr_util.h" | 14 #include "base/memory/ptr_util.h" |
15 #include "base/memory/ref_counted.h" | 15 #include "base/memory/ref_counted.h" |
16 #include "base/message_loop/message_loop.h" | 16 #include "base/message_loop/message_loop.h" |
17 #include "base/test/test_mock_time_task_runner.h" | 17 #include "base/test/test_mock_time_task_runner.h" |
18 #include "base/test/test_pending_task.h" | 18 #include "base/test/test_pending_task.h" |
19 #include "base/time/time.h" | 19 #include "base/time/time.h" |
20 #include "testing/gtest/include/gtest/gtest.h" | 20 #include "testing/gtest/include/gtest/gtest.h" |
21 | 21 |
22 namespace base { | 22 namespace base { |
23 namespace { | 23 namespace { |
24 | 24 |
25 TaskRunner* GetCurrentTaskRunner() { | 25 TaskRunner* GetCurrentTaskRunner() { |
26 return MessageLoop::current()->task_runner().get(); | 26 return MessageLoop::current()->task_runner().get(); |
27 } | 27 } |
28 | 28 |
| 29 void AssignTrue(bool* out) { |
| 30 *out = true; |
| 31 } |
| 32 |
29 // Pops a task from the front of |pending_tasks| and returns it. | 33 // Pops a task from the front of |pending_tasks| and returns it. |
30 TestPendingTask PopFront(std::deque<TestPendingTask>* pending_tasks) { | 34 TestPendingTask PopFront(std::deque<TestPendingTask>* pending_tasks) { |
31 TestPendingTask task = pending_tasks->front(); | 35 TestPendingTask task = std::move(pending_tasks->front()); |
32 pending_tasks->pop_front(); | 36 pending_tasks->pop_front(); |
33 return task; | 37 return task; |
34 } | 38 } |
35 | 39 |
36 class ScopedMockTimeMessageLoopTaskRunnerTest : public testing::Test { | 40 class ScopedMockTimeMessageLoopTaskRunnerTest : public testing::Test { |
37 public: | 41 public: |
38 ScopedMockTimeMessageLoopTaskRunnerTest() | 42 ScopedMockTimeMessageLoopTaskRunnerTest() |
39 : original_task_runner_(new TestMockTimeTaskRunner()) { | 43 : original_task_runner_(new TestMockTimeTaskRunner()) { |
40 MessageLoop::current()->SetTaskRunner(original_task_runner_); | 44 MessageLoop::current()->SetTaskRunner(original_task_runner_); |
41 } | 45 } |
(...skipping 20 matching lines...) Expand all Loading... |
62 EXPECT_EQ(scoped_task_runner_->task_runner(), GetCurrentTaskRunner()); | 66 EXPECT_EQ(scoped_task_runner_->task_runner(), GetCurrentTaskRunner()); |
63 scoped_task_runner_.reset(); | 67 scoped_task_runner_.reset(); |
64 EXPECT_EQ(original_task_runner(), GetCurrentTaskRunner()); | 68 EXPECT_EQ(original_task_runner(), GetCurrentTaskRunner()); |
65 } | 69 } |
66 | 70 |
67 TEST_F(ScopedMockTimeMessageLoopTaskRunnerTest, | 71 TEST_F(ScopedMockTimeMessageLoopTaskRunnerTest, |
68 IncompleteTasksAreCopiedToPreviousTaskRunnerAfterDestruction) { | 72 IncompleteTasksAreCopiedToPreviousTaskRunnerAfterDestruction) { |
69 auto scoped_task_runner_ = | 73 auto scoped_task_runner_ = |
70 base::MakeUnique<ScopedMockTimeMessageLoopTaskRunner>(); | 74 base::MakeUnique<ScopedMockTimeMessageLoopTaskRunner>(); |
71 | 75 |
| 76 bool task_10_has_run = false; |
| 77 bool task_11_has_run = false; |
| 78 |
72 Closure task_1 = Bind(&DoNothing); | 79 Closure task_1 = Bind(&DoNothing); |
73 Closure task_2 = Bind(&DoNothing); | 80 Closure task_2 = Bind(&DoNothing); |
74 Closure task_10 = Bind(&DoNothing); | 81 Closure task_10 = Bind(&AssignTrue, &task_10_has_run); |
75 Closure task_11 = Bind(&DoNothing); | 82 Closure task_11 = Bind(&AssignTrue, &task_11_has_run); |
76 | 83 |
77 constexpr TimeDelta task_1_delay = TimeDelta::FromSeconds(1); | 84 constexpr TimeDelta task_1_delay = TimeDelta::FromSeconds(1); |
78 constexpr TimeDelta task_2_delay = TimeDelta::FromSeconds(2); | 85 constexpr TimeDelta task_2_delay = TimeDelta::FromSeconds(2); |
79 constexpr TimeDelta task_10_delay = TimeDelta::FromSeconds(10); | 86 constexpr TimeDelta task_10_delay = TimeDelta::FromSeconds(10); |
80 constexpr TimeDelta task_11_delay = TimeDelta::FromSeconds(11); | 87 constexpr TimeDelta task_11_delay = TimeDelta::FromSeconds(11); |
81 | 88 |
82 constexpr TimeDelta step_time_by = TimeDelta::FromSeconds(5); | 89 constexpr TimeDelta step_time_by = TimeDelta::FromSeconds(5); |
83 | 90 |
84 GetCurrentTaskRunner()->PostDelayedTask(FROM_HERE, task_1, task_1_delay); | 91 GetCurrentTaskRunner()->PostDelayedTask(FROM_HERE, task_1, task_1_delay); |
85 GetCurrentTaskRunner()->PostDelayedTask(FROM_HERE, task_2, task_2_delay); | 92 GetCurrentTaskRunner()->PostDelayedTask(FROM_HERE, task_2, task_2_delay); |
86 GetCurrentTaskRunner()->PostDelayedTask(FROM_HERE, task_10, task_10_delay); | 93 GetCurrentTaskRunner()->PostDelayedTask(FROM_HERE, task_10, task_10_delay); |
87 GetCurrentTaskRunner()->PostDelayedTask(FROM_HERE, task_11, task_11_delay); | 94 GetCurrentTaskRunner()->PostDelayedTask(FROM_HERE, task_11, task_11_delay); |
88 | 95 |
89 scoped_task_runner_->task_runner()->FastForwardBy(step_time_by); | 96 scoped_task_runner_->task_runner()->FastForwardBy(step_time_by); |
90 | 97 |
91 scoped_task_runner_.reset(); | 98 scoped_task_runner_.reset(); |
92 | 99 |
93 std::deque<TestPendingTask> pending_tasks = | 100 std::deque<TestPendingTask> pending_tasks = |
94 original_task_runner()->TakePendingTasks(); | 101 original_task_runner()->TakePendingTasks(); |
95 | 102 |
96 EXPECT_EQ(2U, pending_tasks.size()); | 103 EXPECT_EQ(2U, pending_tasks.size()); |
97 | 104 |
98 TestPendingTask pending_task = PopFront(&pending_tasks); | 105 TestPendingTask pending_task = PopFront(&pending_tasks); |
99 EXPECT_TRUE(task_10.Equals(pending_task.task)); | 106 EXPECT_FALSE(task_10_has_run); |
| 107 std::move(pending_task.task).Run(); |
| 108 EXPECT_TRUE(task_10_has_run); |
100 EXPECT_EQ(task_10_delay - step_time_by, pending_task.delay); | 109 EXPECT_EQ(task_10_delay - step_time_by, pending_task.delay); |
101 | 110 |
102 pending_task = PopFront(&pending_tasks); | 111 pending_task = PopFront(&pending_tasks); |
103 EXPECT_TRUE(task_11.Equals(pending_task.task)); | 112 EXPECT_FALSE(task_11_has_run); |
| 113 std::move(pending_task.task).Run(); |
| 114 EXPECT_TRUE(task_11_has_run); |
104 EXPECT_EQ(task_11_delay - step_time_by, pending_task.delay); | 115 EXPECT_EQ(task_11_delay - step_time_by, pending_task.delay); |
105 } | 116 } |
106 | 117 |
107 } // namespace | 118 } // namespace |
108 } // namespace base | 119 } // namespace base |
OLD | NEW |