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..df7a1175c8090aa10ef865d681a75579eb4a1925 |
--- /dev/null |
+++ b/base/threading/sequenced_task_runner_handle_unittest.cc |
@@ -0,0 +1,81 @@ |
+// 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 { |
+namespace { |
+ |
+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(); |
+} |
+ |
+class ThreadRunner : public DelegateSimpleThread::Delegate { |
+ public: |
+ void Run() override { |
+ ASSERT_FALSE(SequencedTaskRunnerHandle::IsSet()); |
+ } |
+ |
+ private: |
+ Closure callback_; |
+}; |
+ |
+TEST_F(SequencedTaskRunnerHandleTest, FromSimpleThread) { |
+ ThreadRunner thread_runner; |
+ DelegateSimpleThread thread(&thread_runner, "Background thread"); |
+ thread.Start(); |
+ thread.Join(); |
+} |
+ |
+} // namespace |
+} // namespace base |