Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(645)

Side by Side Diff: base/task_scheduler/sequence_unittest.cc

Issue 2831883003: Do not inherit TaskPriority in TaskTraits. (Closed)
Patch Set: self-review Created 3 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698