| 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_info.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 // Pops a task from the front of |pending_tasks| and returns it. | 29 void RecordTrue(bool* b) { |
| 30 TestPendingTask PopFront(std::deque<TestPendingTask>* pending_tasks) { | 30 *b = true; |
| 31 TestPendingTask task = pending_tasks->front(); | |
| 32 pending_tasks->pop_front(); | |
| 33 return task; | |
| 34 } | 31 } |
| 35 | 32 |
| 36 class ScopedMockTimeMessageLoopTaskRunnerTest : public testing::Test { | 33 class ScopedMockTimeMessageLoopTaskRunnerTest : public testing::Test { |
| 37 public: | 34 public: |
| 38 ScopedMockTimeMessageLoopTaskRunnerTest() | 35 ScopedMockTimeMessageLoopTaskRunnerTest() |
| 39 : original_task_runner_(new TestMockTimeTaskRunner()) { | 36 : original_task_runner_(new TestMockTimeTaskRunner()) { |
| 40 MessageLoop::current()->SetTaskRunner(original_task_runner_); | 37 MessageLoop::current()->SetTaskRunner(original_task_runner_); |
| 41 } | 38 } |
| 42 | 39 |
| 43 protected: | 40 protected: |
| (...skipping 18 matching lines...) Expand all Loading... |
| 62 EXPECT_EQ(scoped_task_runner_->task_runner(), GetCurrentTaskRunner()); | 59 EXPECT_EQ(scoped_task_runner_->task_runner(), GetCurrentTaskRunner()); |
| 63 scoped_task_runner_.reset(); | 60 scoped_task_runner_.reset(); |
| 64 EXPECT_EQ(original_task_runner(), GetCurrentTaskRunner()); | 61 EXPECT_EQ(original_task_runner(), GetCurrentTaskRunner()); |
| 65 } | 62 } |
| 66 | 63 |
| 67 TEST_F(ScopedMockTimeMessageLoopTaskRunnerTest, | 64 TEST_F(ScopedMockTimeMessageLoopTaskRunnerTest, |
| 68 IncompleteTasksAreCopiedToPreviousTaskRunnerAfterDestruction) { | 65 IncompleteTasksAreCopiedToPreviousTaskRunnerAfterDestruction) { |
| 69 auto scoped_task_runner_ = | 66 auto scoped_task_runner_ = |
| 70 base::MakeUnique<ScopedMockTimeMessageLoopTaskRunner>(); | 67 base::MakeUnique<ScopedMockTimeMessageLoopTaskRunner>(); |
| 71 | 68 |
| 69 bool has_task_10_run = false; |
| 70 bool has_task_11_run = false; |
| 71 |
| 72 Closure task_1 = Bind(&DoNothing); | 72 Closure task_1 = Bind(&DoNothing); |
| 73 Closure task_2 = Bind(&DoNothing); | 73 Closure task_2 = Bind(&DoNothing); |
| 74 Closure task_10 = Bind(&DoNothing); | 74 Closure task_10 = Bind(&RecordTrue, &has_task_10_run); |
| 75 Closure task_11 = Bind(&DoNothing); | 75 Closure task_11 = Bind(&RecordTrue, &has_task_11_run); |
| 76 | 76 |
| 77 constexpr TimeDelta task_1_delay = TimeDelta::FromSeconds(1); | 77 constexpr TimeDelta task_1_delay = TimeDelta::FromSeconds(1); |
| 78 constexpr TimeDelta task_2_delay = TimeDelta::FromSeconds(2); | 78 constexpr TimeDelta task_2_delay = TimeDelta::FromSeconds(2); |
| 79 constexpr TimeDelta task_10_delay = TimeDelta::FromSeconds(10); | 79 constexpr TimeDelta task_10_delay = TimeDelta::FromSeconds(10); |
| 80 constexpr TimeDelta task_11_delay = TimeDelta::FromSeconds(11); | 80 constexpr TimeDelta task_11_delay = TimeDelta::FromSeconds(11); |
| 81 | 81 |
| 82 constexpr TimeDelta step_time_by = TimeDelta::FromSeconds(5); | 82 constexpr TimeDelta step_time_by = TimeDelta::FromSeconds(5); |
| 83 | 83 |
| 84 GetCurrentTaskRunner()->PostDelayedTask(FROM_HERE, task_1, task_1_delay); | 84 GetCurrentTaskRunner()->PostDelayedTask(FROM_HERE, task_1, task_1_delay); |
| 85 GetCurrentTaskRunner()->PostDelayedTask(FROM_HERE, task_2, task_2_delay); | 85 GetCurrentTaskRunner()->PostDelayedTask(FROM_HERE, task_2, task_2_delay); |
| 86 GetCurrentTaskRunner()->PostDelayedTask(FROM_HERE, task_10, task_10_delay); | 86 GetCurrentTaskRunner()->PostDelayedTask(FROM_HERE, task_10, task_10_delay); |
| 87 GetCurrentTaskRunner()->PostDelayedTask(FROM_HERE, task_11, task_11_delay); | 87 GetCurrentTaskRunner()->PostDelayedTask(FROM_HERE, task_11, task_11_delay); |
| 88 | 88 |
| 89 scoped_task_runner_->task_runner()->FastForwardBy(step_time_by); | 89 scoped_task_runner_->task_runner()->FastForwardBy(step_time_by); |
| 90 | 90 |
| 91 scoped_task_runner_.reset(); | 91 scoped_task_runner_.reset(); |
| 92 | 92 |
| 93 std::deque<TestPendingTask> pending_tasks = | 93 TestPendingTaskQueue pending_tasks = |
| 94 original_task_runner()->TakePendingTasks(); | 94 original_task_runner()->TakePendingTasks(); |
| 95 | |
| 96 EXPECT_EQ(2U, pending_tasks.size()); | 95 EXPECT_EQ(2U, pending_tasks.size()); |
| 97 | 96 |
| 98 TestPendingTask pending_task = PopFront(&pending_tasks); | 97 TestPendingTaskInfo task_info = pending_tasks.front().first; |
| 99 EXPECT_TRUE(task_10.Equals(pending_task.task)); | 98 OnceClosure task = std::move(pending_tasks.front().second); |
| 100 EXPECT_EQ(task_10_delay - step_time_by, pending_task.delay); | 99 pending_tasks.pop_front(); |
| 101 | 100 |
| 102 pending_task = PopFront(&pending_tasks); | 101 EXPECT_FALSE(has_task_10_run); |
| 103 EXPECT_TRUE(task_11.Equals(pending_task.task)); | 102 std::move(task).Run(); |
| 104 EXPECT_EQ(task_11_delay - step_time_by, pending_task.delay); | 103 EXPECT_TRUE(has_task_10_run); |
| 104 EXPECT_EQ(task_10_delay - step_time_by, task_info.delay); |
| 105 |
| 106 task_info = pending_tasks.front().first; |
| 107 task = std::move(pending_tasks.front().second); |
| 108 pending_tasks.pop_front(); |
| 109 EXPECT_FALSE(has_task_11_run); |
| 110 std::move(task).Run(); |
| 111 EXPECT_TRUE(has_task_11_run); |
| 112 EXPECT_EQ(task_11_delay - step_time_by, task_info.delay); |
| 105 } | 113 } |
| 106 | 114 |
| 107 } // namespace | 115 } // namespace |
| 108 } // namespace base | 116 } // namespace base |
| OLD | NEW |