Chromium Code Reviews| Index: base/task_scheduler/utils_unittest.cc |
| diff --git a/base/task_scheduler/utils_unittest.cc b/base/task_scheduler/utils_unittest.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..a1e79f3a159289394fd78eecc398359c447151ef |
| --- /dev/null |
| +++ b/base/task_scheduler/utils_unittest.cc |
| @@ -0,0 +1,77 @@ |
| +// Copyright 2016 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "base/task_scheduler/utils.h" |
| + |
| +#include <memory> |
| + |
| +#include "base/bind.h" |
| +#include "base/bind_helpers.h" |
| +#include "base/memory/ptr_util.h" |
| +#include "base/memory/ref_counted.h" |
| +#include "base/task_scheduler/priority_queue.h" |
| +#include "base/task_scheduler/sequence.h" |
| +#include "base/task_scheduler/task.h" |
| +#include "base/task_scheduler/task_tracker.h" |
| +#include "testing/gtest/include/gtest/gtest.h" |
| + |
| +namespace base { |
| +namespace internal { |
| +namespace { |
| + |
|
gab
2016/04/14 16:11:35
Can we also test PostTaskHelper?
fdoray
2016/04/14 18:41:12
Done.
|
| +// Checks that when PostTaskWithSequenceHelper is called with an empty sequence, |
| +// the task is added to the sequence and the sequence is added to the priority |
| +// queue. |
| +TEST(TaskSchedulerPostTaskWithSequenceHelperTest, PostTaskInEmptySequence) { |
| + std::unique_ptr<Task> task( |
| + new Task(FROM_HERE, Bind(&DoNothing), TaskTraits())); |
| + const Task* task_raw = task.get(); |
| + scoped_refptr<Sequence> sequence(new Sequence); |
| + PriorityQueue priority_queue; |
| + |
| + // Post |task|. |
| + EXPECT_TRUE( |
| + PostTaskWithSequenceHelper(std::move(task), sequence, &priority_queue)); |
| + |
| + // Expect to find the sequence in the priority queue. |
| + EXPECT_EQ(sequence, priority_queue.BeginTransaction()->Peek().sequence); |
| + |
| + // Expect to find |task| alone in |sequence|. |
| + EXPECT_EQ(task_raw, sequence->PeekTask()); |
| + sequence->PopTask(); |
| + EXPECT_EQ(nullptr, sequence->PeekTask()); |
| +} |
| + |
| +// Checks that when PostTaskWithSequenceHelper is called with a sequence that |
| +// already contains a task, the task is added to the sequence but the sequence |
| +// is not added to the priority queue. |
| +TEST(TaskSchedulerPostTaskWithSequenceHelperTest, PostTaskInNonEmptySequence) { |
| + std::unique_ptr<Task> task( |
| + new Task(FROM_HERE, Bind(&DoNothing), TaskTraits())); |
| + const Task* task_raw = task.get(); |
| + scoped_refptr<Sequence> sequence(new Sequence); |
| + PriorityQueue priority_queue; |
| + |
| + // Add an initial task in |sequence|. |
| + sequence->PushTask( |
| + WrapUnique(new Task(FROM_HERE, Bind(&DoNothing), TaskTraits()))); |
| + |
| + // Post |task|. |
| + EXPECT_FALSE( |
| + PostTaskWithSequenceHelper(std::move(task), sequence, &priority_queue)); |
| + |
| + // Expect to find the priority queue empty. |
| + EXPECT_TRUE(priority_queue.BeginTransaction()->Peek().is_null()); |
| + |
| + // Expect to find |task| in |sequence| behind the initial task. |
| + EXPECT_NE(task_raw, sequence->PeekTask()); |
| + sequence->PopTask(); |
| + EXPECT_EQ(task_raw, sequence->PeekTask()); |
| + sequence->PopTask(); |
| + EXPECT_EQ(nullptr, sequence->PeekTask()); |
| +} |
| + |
| +} // namespace |
| +} // namespace internal |
| +} // namespace base |