// 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(). class TestIOThread { public: enum Mode { kAutoStart, kManualStart }; explicit TestIOThread(Mode mode); // Stops the I/O thread if necessary. ~TestIOThread(); // |Start()|/|Stop()| should only be called from the main (creation) thread. // 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 tracked_objects::Location& from_here, const base::Closure& task); // Posts |task| to the IO-thread with an WaitableEvent associated blocks on // it until the posted |task| is executed, then returns. void PostTaskAndWait(const tracked_objects::Location& from_here, const base::Closure& 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_