// 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 "base/callback.h" #include "base/location.h" #include "base/time.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(const tracked_objects::Location& location, const Closure& task, TimeTicks post_time, TimeDelta delay, TestNestability nestability); ~TestPendingTask(); // 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; tracked_objects::Location location; Closure task; TimeTicks post_time; TimeDelta delay; TestNestability nestability; }; } // namespace base #endif // BASE_TEST_TEST_TASK_RUNNER_H_