Add per-user preferences support.
[chromium-blink-merge.git] / base / test / test_io_thread.h
blobc2ed1878d1df1355e502457788646aec230df6f7
1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef BASE_TEST_TEST_IO_THREAD_H_
6 #define BASE_TEST_TEST_IO_THREAD_H_
8 #include "base/callback_forward.h"
9 #include "base/compiler_specific.h"
10 #include "base/macros.h"
11 #include "base/memory/ref_counted.h"
12 #include "base/task_runner.h"
13 #include "base/threading/thread.h"
14 #include "base/time/time.h"
16 namespace base {
18 // Create and run an IO thread with a MessageLoop, and
19 // making the MessageLoop accessible from its client.
20 // It also provides some ideomatic API like PostTaskAndWait().
21 class TestIOThread {
22 public:
23 enum Mode { kAutoStart, kManualStart };
24 explicit TestIOThread(Mode mode);
25 // Stops the I/O thread if necessary.
26 ~TestIOThread();
28 // |Start()|/|Stop()| should only be called from the main (creation) thread.
29 // After |Stop()|, |Start()| may be called again to start a new I/O thread.
30 // |Stop()| may be called even when the I/O thread is not started.
31 void Start();
32 void Stop();
34 // Post |task| to the IO thread.
35 void PostTask(const tracked_objects::Location& from_here,
36 const base::Closure& task);
37 // Posts |task| to the IO-thread with an WaitableEvent associated blocks on
38 // it until the posted |task| is executed, then returns.
39 void PostTaskAndWait(const tracked_objects::Location& from_here,
40 const base::Closure& task);
42 base::MessageLoopForIO* message_loop() {
43 return static_cast<base::MessageLoopForIO*>(io_thread_.message_loop());
46 scoped_refptr<SingleThreadTaskRunner> task_runner() {
47 return message_loop()->task_runner();
50 private:
51 base::Thread io_thread_;
52 bool io_thread_started_;
54 DISALLOW_COPY_AND_ASSIGN(TestIOThread);
57 } // namespace base
59 #endif // BASE_TEST_TEST_IO_THREAD_H_