Chromium Code Reviews| Index: base/threading/sequenced_task_runner_handle_unittest.cc |
| diff --git a/base/threading/sequenced_task_runner_handle_unittest.cc b/base/threading/sequenced_task_runner_handle_unittest.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..c8ac5a93af0bbe2e42a3aec5a2f8e68406347596 |
| --- /dev/null |
| +++ b/base/threading/sequenced_task_runner_handle_unittest.cc |
| @@ -0,0 +1,83 @@ |
| +// Copyright 2015 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/bind.h" |
| +#include "base/callback.h" |
| +#include "base/location.h" |
| +#include "base/memory/ref_counted.h" |
| +#include "base/memory/scoped_ptr.h" |
| +#include "base/message_loop/message_loop.h" |
| +#include "base/run_loop.h" |
| +#include "base/sequence_checker_impl.h" |
| +#include "base/sequenced_task_runner.h" |
| +#include "base/synchronization/waitable_event.h" |
| +#include "base/threading/sequenced_task_runner_handle.h" |
| +#include "base/threading/sequenced_worker_pool.h" |
| +#include "base/threading/simple_thread.h" |
| +#include "testing/gtest/include/gtest/gtest.h" |
| + |
| +namespace base { |
| + |
| +class SequencedTaskRunnerHandleTest : public ::testing::Test { |
| + protected: |
| + static void GetTaskRunner(const Closure& callback) { |
| + // Use SequenceCheckerImpl to make sure it's not a no-op in Release builds. |
| + scoped_ptr<SequenceCheckerImpl> sequence_checker(new SequenceCheckerImpl); |
| + ASSERT_TRUE(SequencedTaskRunnerHandle::IsSet()); |
| + scoped_refptr<SequencedTaskRunner> task_runner = |
| + SequencedTaskRunnerHandle::Get(); |
| + ASSERT_TRUE(task_runner); |
| + task_runner->PostTask( |
| + FROM_HERE, base::Bind(&SequencedTaskRunnerHandleTest::CheckValidThread, |
| + base::Passed(&sequence_checker), callback)); |
| + } |
| + |
| + private: |
| + static void CheckValidThread(scoped_ptr<SequenceCheckerImpl> sequence_checker, |
| + const Closure& callback) { |
| + EXPECT_TRUE(sequence_checker->CalledOnValidSequencedThread()); |
| + callback.Run(); |
| + } |
| + |
| + MessageLoop message_loop_; |
| +}; |
| + |
| +TEST_F(SequencedTaskRunnerHandleTest, FromMessageLoop) { |
| + RunLoop run_loop; |
| + GetTaskRunner(run_loop.QuitClosure()); |
| + run_loop.Run(); |
| +} |
| + |
| +TEST_F(SequencedTaskRunnerHandleTest, FromSequencedWorkerPool) { |
| + scoped_refptr<SequencedWorkerPool> pool(new SequencedWorkerPool(3, "Test")); |
| + WaitableEvent event(false, false); |
| + pool->PostSequencedWorkerTask( |
| + pool->GetSequenceToken(), FROM_HERE, |
| + base::Bind(&SequencedTaskRunnerHandleTest::GetTaskRunner, |
| + base::Bind(&WaitableEvent::Signal, base::Unretained(&event)))); |
| + event.Wait(); |
| +} |
| + |
| +namespace { |
|
danakj
2015/10/27 20:03:20
nit: you could wrap the whole file in anon to make
Bernhard Bauer
2015/10/28 13:36:28
Done.
|
| + |
| +class ThreadRunner : public DelegateSimpleThread::Delegate { |
| + public: |
| + void Run() override { |
| + ASSERT_FALSE(SequencedTaskRunnerHandle::IsSet()); |
| + } |
| + |
| + private: |
| + Closure callback_; |
| +}; |
| + |
| +} // namespace |
| + |
| +TEST_F(SequencedTaskRunnerHandleTest, FromSimpleThread) { |
| + ThreadRunner thread_runner; |
| + DelegateSimpleThread thread(&thread_runner, "Background thread"); |
| + thread.Start(); |
| + thread.Join(); |
| +} |
| + |
| +} // namespace base |
|
danakj
2015/10/27 20:03:20
2 spaces before //
Bernhard Bauer
2015/10/28 13:36:28
Done.
|