| // Copyright 2013 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. |
| |
| #ifndef BASE_TEST_TEST_IO_THREAD_H_ |
| #define BASE_TEST_TEST_IO_THREAD_H_ |
| |
| #include "base/callback_forward.h" |
| #include "base/compiler_specific.h" |
| #include "base/macros.h" |
| #include "base/memory/ref_counted.h" |
| #include "base/task_runner.h" |
| #include "base/threading/thread.h" |
| #include "base/time/time.h" |
| |
| namespace base { |
| |
| // Create and run an IO thread with a MessageLoop, and |
| // making the MessageLoop accessible from its client. |
| // It also provides some ideomatic API like PostTaskAndWait(). |
| // |
| // This API is not thread-safe: |
| // - Start()/Stop() should only be called from the main (creation) thread. |
| // - PostTask()/message_loop()/task_runner() are also safe to call from the |
| // underlying thread itself (to post tasks from other threads: get the |
| // task_runner() from the main thread first, it is then safe to pass _it_ |
| // around). |
| class TestIOThread { |
| public: |
| enum Mode { kAutoStart, kManualStart }; |
| explicit TestIOThread(Mode mode); |
| // Stops the I/O thread if necessary. |
| ~TestIOThread(); |
| |
| // After Stop(), Start() may be called again to start a new I/O thread. |
| // Stop() may be called even when the I/O thread is not started. |
| void Start(); |
| void Stop(); |
| |
| // Post |task| to the IO thread. |
| void PostTask(const Location& from_here, base::OnceClosure task); |
| |
| base::MessageLoopForIO* message_loop() { |
| return static_cast<base::MessageLoopForIO*>(io_thread_.message_loop()); |
| } |
| |
| scoped_refptr<SingleThreadTaskRunner> task_runner() { |
| return message_loop()->task_runner(); |
| } |
| |
| private: |
| base::Thread io_thread_; |
| bool io_thread_started_; |
| |
| DISALLOW_COPY_AND_ASSIGN(TestIOThread); |
| }; |
| |
| } // namespace base |
| |
| #endif // BASE_TEST_TEST_IO_THREAD_H_ |