| 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/sequence.h" | 5 #include "base/task_scheduler/sequence.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/bind_helpers.h" | 10 #include "base/bind_helpers.h" |
| 11 #include "base/macros.h" | 11 #include "base/macros.h" |
| 12 #include "base/memory/ptr_util.h" | 12 #include "base/memory/ptr_util.h" |
| 13 #include "base/task_scheduler/test_utils.h" |
| 13 #include "base/test/gtest_util.h" | 14 #include "base/test/gtest_util.h" |
| 14 #include "base/time/time.h" | 15 #include "base/time/time.h" |
| 15 #include "testing/gtest/include/gtest/gtest.h" | 16 #include "testing/gtest/include/gtest/gtest.h" |
| 16 | 17 |
| 17 namespace base { | 18 namespace base { |
| 18 namespace internal { | 19 namespace internal { |
| 19 | 20 |
| 20 namespace { | 21 namespace { |
| 21 | 22 |
| 22 | |
| 23 class TaskSchedulerSequenceTest : public testing::Test { | 23 class TaskSchedulerSequenceTest : public testing::Test { |
| 24 public: | 24 public: |
| 25 TaskSchedulerSequenceTest() | 25 TaskSchedulerSequenceTest() |
| 26 : task_a_owned_( | 26 : task_a_owned_(new Task( |
| 27 new Task(FROM_HERE, | 27 FROM_HERE, |
| 28 Bind(&DoNothing), | 28 Bind(&DoNothing), |
| 29 TaskTraits().WithPriority(TaskPriority::BACKGROUND), | 29 test::CreateTaskTraits().WithPriority(TaskPriority::BACKGROUND), |
| 30 TimeDelta())), | 30 TimeDelta())), |
| 31 task_b_owned_( | 31 task_b_owned_(new Task( |
| 32 new Task(FROM_HERE, | 32 FROM_HERE, |
| 33 Bind(&DoNothing), | 33 Bind(&DoNothing), |
| 34 TaskTraits().WithPriority(TaskPriority::USER_VISIBLE), | 34 test::CreateTaskTraits().WithPriority(TaskPriority::USER_VISIBLE), |
| 35 TimeDelta())), | 35 TimeDelta())), |
| 36 task_c_owned_( | 36 task_c_owned_(new Task( |
| 37 new Task(FROM_HERE, | 37 FROM_HERE, |
| 38 Bind(&DoNothing), | 38 Bind(&DoNothing), |
| 39 TaskTraits().WithPriority(TaskPriority::USER_BLOCKING), | 39 test::CreateTaskTraits().WithPriority(TaskPriority::USER_BLOCKING), |
| 40 TimeDelta())), | 40 TimeDelta())), |
| 41 task_d_owned_( | 41 task_d_owned_(new Task( |
| 42 new Task(FROM_HERE, | 42 FROM_HERE, |
| 43 Bind(&DoNothing), | 43 Bind(&DoNothing), |
| 44 TaskTraits().WithPriority(TaskPriority::USER_BLOCKING), | 44 test::CreateTaskTraits().WithPriority(TaskPriority::USER_BLOCKING), |
| 45 TimeDelta())), | 45 TimeDelta())), |
| 46 task_e_owned_( | 46 task_e_owned_(new Task( |
| 47 new Task(FROM_HERE, | 47 FROM_HERE, |
| 48 Bind(&DoNothing), | 48 Bind(&DoNothing), |
| 49 TaskTraits().WithPriority(TaskPriority::BACKGROUND), | 49 test::CreateTaskTraits().WithPriority(TaskPriority::BACKGROUND), |
| 50 TimeDelta())), | 50 TimeDelta())), |
| 51 task_a_(task_a_owned_.get()), | 51 task_a_(task_a_owned_.get()), |
| 52 task_b_(task_b_owned_.get()), | 52 task_b_(task_b_owned_.get()), |
| 53 task_c_(task_c_owned_.get()), | 53 task_c_(task_c_owned_.get()), |
| 54 task_d_(task_d_owned_.get()), | 54 task_d_(task_d_owned_.get()), |
| 55 task_e_(task_e_owned_.get()) {} | 55 task_e_(task_e_owned_.get()) {} |
| 56 | 56 |
| 57 protected: | 57 protected: |
| 58 // Tasks to be handed off to a Sequence for testing. | 58 // Tasks to be handed off to a Sequence for testing. |
| 59 std::unique_ptr<Task> task_a_owned_; | 59 std::unique_ptr<Task> task_a_owned_; |
| 60 std::unique_ptr<Task> task_b_owned_; | 60 std::unique_ptr<Task> task_b_owned_; |
| (...skipping 132 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 193 sequence->TakeTask(); | 193 sequence->TakeTask(); |
| 194 sequence->Pop(); | 194 sequence->Pop(); |
| 195 EXPECT_EQ(SequenceSortKey(TaskPriority::BACKGROUND, task_e_->sequenced_time), | 195 EXPECT_EQ(SequenceSortKey(TaskPriority::BACKGROUND, task_e_->sequenced_time), |
| 196 sequence->GetSortKey()); | 196 sequence->GetSortKey()); |
| 197 } | 197 } |
| 198 | 198 |
| 199 // Verify that a DCHECK fires if Pop() is called on a sequence whose front slot | 199 // Verify that a DCHECK fires if Pop() is called on a sequence whose front slot |
| 200 // isn't empty. | 200 // isn't empty. |
| 201 TEST_F(TaskSchedulerSequenceTest, PopNonEmptyFrontSlot) { | 201 TEST_F(TaskSchedulerSequenceTest, PopNonEmptyFrontSlot) { |
| 202 scoped_refptr<Sequence> sequence(new Sequence); | 202 scoped_refptr<Sequence> sequence(new Sequence); |
| 203 sequence->PushTask( | 203 sequence->PushTask(MakeUnique<Task>(FROM_HERE, Bind(&DoNothing), |
| 204 MakeUnique<Task>(FROM_HERE, Bind(&DoNothing), TaskTraits(), TimeDelta())); | 204 test::CreateTaskTraits(), TimeDelta())); |
| 205 | 205 |
| 206 EXPECT_DCHECK_DEATH({ sequence->Pop(); }); | 206 EXPECT_DCHECK_DEATH({ sequence->Pop(); }); |
| 207 } | 207 } |
| 208 | 208 |
| 209 // Verify that a DCHECK fires if TakeTask() is called on a sequence whose front | 209 // Verify that a DCHECK fires if TakeTask() is called on a sequence whose front |
| 210 // slot is empty. | 210 // slot is empty. |
| 211 TEST_F(TaskSchedulerSequenceTest, TakeEmptyFrontSlot) { | 211 TEST_F(TaskSchedulerSequenceTest, TakeEmptyFrontSlot) { |
| 212 scoped_refptr<Sequence> sequence(new Sequence); | 212 scoped_refptr<Sequence> sequence(new Sequence); |
| 213 sequence->PushTask( | 213 sequence->PushTask(MakeUnique<Task>(FROM_HERE, Bind(&DoNothing), |
| 214 MakeUnique<Task>(FROM_HERE, Bind(&DoNothing), TaskTraits(), TimeDelta())); | 214 test::CreateTaskTraits(), TimeDelta())); |
| 215 | 215 |
| 216 EXPECT_TRUE(sequence->TakeTask()); | 216 EXPECT_TRUE(sequence->TakeTask()); |
| 217 EXPECT_DCHECK_DEATH({ sequence->TakeTask(); }); | 217 EXPECT_DCHECK_DEATH({ sequence->TakeTask(); }); |
| 218 } | 218 } |
| 219 | 219 |
| 220 // Verify that a DCHECK fires if TakeTask() is called on an empty sequence. | 220 // Verify that a DCHECK fires if TakeTask() is called on an empty sequence. |
| 221 TEST_F(TaskSchedulerSequenceTest, TakeEmptySequence) { | 221 TEST_F(TaskSchedulerSequenceTest, TakeEmptySequence) { |
| 222 scoped_refptr<Sequence> sequence(new Sequence); | 222 scoped_refptr<Sequence> sequence(new Sequence); |
| 223 EXPECT_DCHECK_DEATH({ sequence->TakeTask(); }); | 223 EXPECT_DCHECK_DEATH({ sequence->TakeTask(); }); |
| 224 } | 224 } |
| 225 | 225 |
| 226 } // namespace internal | 226 } // namespace internal |
| 227 } // namespace base | 227 } // namespace base |
| OLD | NEW |