// 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 MOJO_SYSTEM_TEST_UTILS_H_ #define MOJO_SYSTEM_TEST_UTILS_H_ #include #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 tracked_objects { class Location; } namespace mojo { namespace system { namespace test { // Posts the given task (to the given task runner) and waits for it to complete. // (Note: Doesn't spin the current thread's message loop, so if you're careless // this could easily deadlock.) void PostTaskAndWait(scoped_refptr task_runner, const tracked_objects::Location& from_here, const base::Closure& task); // A timeout smaller than |TestTimeouts::tiny_timeout()|. Warning: This may lead // to flakiness, but this is unavoidable if, e.g., you're trying to ensure that // functions with timeouts are reasonably accurate. We want this to be as small // as possible without causing too much flakiness. base::TimeDelta EpsilonTimeout(); // Stopwatch ------------------------------------------------------------------- // A simple "stopwatch" for measuring time elapsed from a given starting point. class Stopwatch { public: Stopwatch() {} ~Stopwatch() {} void Start() { start_time_ = base::TimeTicks::Now(); } base::TimeDelta Elapsed() { return base::TimeTicks::Now() - start_time_; } private: base::TimeTicks start_time_; DISALLOW_COPY_AND_ASSIGN(Stopwatch); }; // TestIOThread ---------------------------------------------------------------- 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(); void PostTask(const tracked_objects::Location& from_here, const base::Closure& task); void PostTaskAndWait(const tracked_objects::Location& from_here, const base::Closure& task); base::MessageLoopForIO* message_loop() { return static_cast(io_thread_.message_loop()); } scoped_refptr task_runner() { return message_loop()->message_loop_proxy(); } private: base::Thread io_thread_; bool io_thread_started_; DISALLOW_COPY_AND_ASSIGN(TestIOThread); }; } // namespace test } // namespace system } // namespace mojo #endif // MOJO_SYSTEM_TEST_UTILS_H_