// Copyright (c) 2012 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_PENDING_TASK_H_ #define BASE_TEST_TEST_PENDING_TASK_H_ #include <string> #include "base/callback.h" #include "base/location.h" #include "base/time/time.h" // Unsupported in libchrome. // #include "base/trace_event/trace_event_argument.h" namespace base { // TestPendingTask is a helper class for test TaskRunner // implementations. See test_simple_task_runner.h for example usage. struct TestPendingTask { enum TestNestability { NESTABLE, NON_NESTABLE }; TestPendingTask(); TestPendingTask(TestPendingTask&& other); TestPendingTask(const Location& location, OnceClosure task, TimeTicks post_time, TimeDelta delay, TestNestability nestability); ~TestPendingTask(); TestPendingTask& operator=(TestPendingTask&& other); // Returns post_time + delay. TimeTicks GetTimeToRun() const; // Returns true if this task is nestable and |other| isn't, or if // this task's time to run is strictly earlier than |other|'s time // to run. // // Note that two tasks may both have the same nestability and delay. // In that case, the caller must use some other criterion (probably // the position in some queue) to break the tie. Conveniently, the // following STL functions already do so: // // - std::min_element // - std::stable_sort // // but the following STL functions don't: // // - std::max_element // - std::sort. bool ShouldRunBefore(const TestPendingTask& other) const; Location location; OnceClosure task; TimeTicks post_time; TimeDelta delay; TestNestability nestability; // Unsupported in libchrome. #if 0 // Functions for using test pending task with tracing, useful in unit // testing. void AsValueInto(base::trace_event::TracedValue* state) const; std::unique_ptr<base::trace_event::ConvertableToTraceFormat> AsValue() const; #endif std::string ToString() const; private: DISALLOW_COPY_AND_ASSIGN(TestPendingTask); }; // gtest helpers which allow pretty printing of the tasks, very useful in unit // testing. std::ostream& operator<<(std::ostream& os, const TestPendingTask& task); void PrintTo(const TestPendingTask& task, std::ostream* os); } // namespace base #endif // BASE_TEST_TEST_PENDING_TASK_H_