| 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 "base/task_scheduler/scheduler_worker_thread.h" | 5 #include "base/task_scheduler/scheduler_worker_thread.h" |
| 6 | 6 |
| 7 #include <stddef.h> | 7 #include <stddef.h> |
| 8 | 8 |
| 9 #include <memory> | 9 #include <memory> |
| 10 #include <vector> | 10 #include <vector> |
| (...skipping 13 matching lines...) Expand all Loading... |
| 24 namespace internal { | 24 namespace internal { |
| 25 namespace { | 25 namespace { |
| 26 | 26 |
| 27 const size_t kNumSequencesPerTest = 150; | 27 const size_t kNumSequencesPerTest = 150; |
| 28 | 28 |
| 29 // The test parameter is the number of Tasks per Sequence returned by GetWork(). | 29 // The test parameter is the number of Tasks per Sequence returned by GetWork(). |
| 30 class TaskSchedulerWorkerThreadTest : public testing::TestWithParam<size_t> { | 30 class TaskSchedulerWorkerThreadTest : public testing::TestWithParam<size_t> { |
| 31 protected: | 31 protected: |
| 32 TaskSchedulerWorkerThreadTest() | 32 TaskSchedulerWorkerThreadTest() |
| 33 : main_entry_called_(true, false), | 33 : main_entry_called_(true, false), |
| 34 num_get_work_cv_(lock_.CreateConditionVariable()) {} | 34 num_get_work_cv_(lock_.CreateConditionVariable()), |
| 35 worker_thread_set_(true, false) {} |
| 35 | 36 |
| 36 void SetUp() override { | 37 void SetUp() override { |
| 37 worker_thread_ = SchedulerWorkerThread::Create( | 38 worker_thread_ = SchedulerWorkerThread::Create( |
| 38 ThreadPriority::NORMAL, | 39 ThreadPriority::NORMAL, |
| 39 WrapUnique(new TestSchedulerWorkerThreadDelegate(this)), | 40 WrapUnique(new TestSchedulerWorkerThreadDelegate(this)), |
| 40 &task_tracker_); | 41 &task_tracker_); |
| 41 ASSERT_TRUE(worker_thread_); | 42 ASSERT_TRUE(worker_thread_); |
| 43 worker_thread_set_.Signal(); |
| 42 main_entry_called_.Wait(); | 44 main_entry_called_.Wait(); |
| 43 } | 45 } |
| 44 | 46 |
| 45 void TearDown() override { | 47 void TearDown() override { |
| 46 worker_thread_->JoinForTesting(); | 48 worker_thread_->JoinForTesting(); |
| 47 } | 49 } |
| 48 | 50 |
| 49 size_t TasksPerSequence() const { return GetParam(); } | 51 size_t TasksPerSequence() const { return GetParam(); } |
| 50 | 52 |
| 51 // Wait until GetWork() has been called |num_get_work| times. | 53 // Wait until GetWork() has been called |num_get_work| times. |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 84 std::unique_ptr<SchedulerWorkerThread> worker_thread_; | 86 std::unique_ptr<SchedulerWorkerThread> worker_thread_; |
| 85 | 87 |
| 86 private: | 88 private: |
| 87 class TestSchedulerWorkerThreadDelegate | 89 class TestSchedulerWorkerThreadDelegate |
| 88 : public SchedulerWorkerThread::Delegate { | 90 : public SchedulerWorkerThread::Delegate { |
| 89 public: | 91 public: |
| 90 TestSchedulerWorkerThreadDelegate(TaskSchedulerWorkerThreadTest* outer) | 92 TestSchedulerWorkerThreadDelegate(TaskSchedulerWorkerThreadTest* outer) |
| 91 : outer_(outer) {} | 93 : outer_(outer) {} |
| 92 | 94 |
| 93 // SchedulerWorkerThread::Delegate: | 95 // SchedulerWorkerThread::Delegate: |
| 94 void OnMainEntry() override { | 96 void OnMainEntry(SchedulerWorkerThread* worker_thread) override { |
| 97 outer_->worker_thread_set_.Wait(); |
| 98 EXPECT_EQ(outer_->worker_thread_.get(), worker_thread); |
| 99 |
| 95 // Without synchronization, OnMainEntry() could be called twice without | 100 // Without synchronization, OnMainEntry() could be called twice without |
| 96 // generating an error. | 101 // generating an error. |
| 97 AutoSchedulerLock auto_lock(outer_->lock_); | 102 AutoSchedulerLock auto_lock(outer_->lock_); |
| 98 EXPECT_FALSE(outer_->main_entry_called_.IsSignaled()); | 103 EXPECT_FALSE(outer_->main_entry_called_.IsSignaled()); |
| 99 outer_->main_entry_called_.Signal(); | 104 outer_->main_entry_called_.Signal(); |
| 100 } | 105 } |
| 101 | 106 |
| 102 scoped_refptr<Sequence> GetWork( | 107 scoped_refptr<Sequence> GetWork( |
| 103 SchedulerWorkerThread* worker_thread) override { | 108 SchedulerWorkerThread* worker_thread) override { |
| 104 EXPECT_EQ(outer_->worker_thread_.get(), worker_thread); | 109 EXPECT_EQ(outer_->worker_thread_.get(), worker_thread); |
| (...skipping 88 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 193 | 198 |
| 194 // Sequences created by GetWork(). | 199 // Sequences created by GetWork(). |
| 195 std::vector<scoped_refptr<Sequence>> created_sequences_; | 200 std::vector<scoped_refptr<Sequence>> created_sequences_; |
| 196 | 201 |
| 197 // Sequences passed to EnqueueSequence(). | 202 // Sequences passed to EnqueueSequence(). |
| 198 std::vector<scoped_refptr<Sequence>> re_enqueued_sequences_; | 203 std::vector<scoped_refptr<Sequence>> re_enqueued_sequences_; |
| 199 | 204 |
| 200 // Number of times that RunTaskCallback() has been called. | 205 // Number of times that RunTaskCallback() has been called. |
| 201 size_t num_run_tasks_ = 0; | 206 size_t num_run_tasks_ = 0; |
| 202 | 207 |
| 208 // Signaled after |worker_thread_| is set. |
| 209 WaitableEvent worker_thread_set_; |
| 210 |
| 203 DISALLOW_COPY_AND_ASSIGN(TaskSchedulerWorkerThreadTest); | 211 DISALLOW_COPY_AND_ASSIGN(TaskSchedulerWorkerThreadTest); |
| 204 }; | 212 }; |
| 205 | 213 |
| 206 // Verify that when GetWork() continuously returns Sequences, all Tasks in these | 214 // Verify that when GetWork() continuously returns Sequences, all Tasks in these |
| 207 // Sequences run successfully. The test wakes up the SchedulerWorkerThread once. | 215 // Sequences run successfully. The test wakes up the SchedulerWorkerThread once. |
| 208 TEST_P(TaskSchedulerWorkerThreadTest, ContinuousWork) { | 216 TEST_P(TaskSchedulerWorkerThreadTest, ContinuousWork) { |
| 209 // Set GetWork() to return |kNumSequencesPerTest| Sequences before starting to | 217 // Set GetWork() to return |kNumSequencesPerTest| Sequences before starting to |
| 210 // return nullptr. | 218 // return nullptr. |
| 211 SetNumSequencesToCreate(kNumSequencesPerTest); | 219 SetNumSequencesToCreate(kNumSequencesPerTest); |
| 212 | 220 |
| (...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 267 INSTANTIATE_TEST_CASE_P(OneTaskPerSequence, | 275 INSTANTIATE_TEST_CASE_P(OneTaskPerSequence, |
| 268 TaskSchedulerWorkerThreadTest, | 276 TaskSchedulerWorkerThreadTest, |
| 269 ::testing::Values(1)); | 277 ::testing::Values(1)); |
| 270 INSTANTIATE_TEST_CASE_P(TwoTasksPerSequence, | 278 INSTANTIATE_TEST_CASE_P(TwoTasksPerSequence, |
| 271 TaskSchedulerWorkerThreadTest, | 279 TaskSchedulerWorkerThreadTest, |
| 272 ::testing::Values(2)); | 280 ::testing::Values(2)); |
| 273 | 281 |
| 274 } // namespace | 282 } // namespace |
| 275 } // namespace internal | 283 } // namespace internal |
| 276 } // namespace base | 284 } // namespace base |
| OLD | NEW |