| // 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_ |