// 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_TIMEOUTS_H_ #define BASE_TEST_TEST_TIMEOUTS_H_ #include "base/logging.h" #include "base/macros.h" #include "base/time/time.h" // Returns common timeouts to use in tests. Makes it possible to adjust // the timeouts for different environments (like Valgrind). class TestTimeouts { public: // Argument that can be passed on the command line to indicate "no timeout". static constexpr const char kNoTimeoutSwitchValue[] = "-1"; // Initializes the timeouts. Non thread-safe. Should be called exactly once // by the test suite. static void Initialize(); // Timeout for actions that are expected to finish "almost instantly". static base::TimeDelta tiny_timeout() { DCHECK(initialized_); return base::TimeDelta::FromMilliseconds(tiny_timeout_ms_); } // Timeout to wait for something to happen. If you are not sure // which timeout to use, this is the one you want. static base::TimeDelta action_timeout() { DCHECK(initialized_); return base::TimeDelta::FromMilliseconds(action_timeout_ms_); } // Timeout longer than the above, but still suitable to use // multiple times in a single test. Use if the timeout above // is not sufficient. static base::TimeDelta action_max_timeout() { DCHECK(initialized_); return base::TimeDelta::FromMilliseconds(action_max_timeout_ms_); } // Timeout for a single test launched used built-in test launcher. // Do not use outside of the test launcher. static base::TimeDelta test_launcher_timeout() { DCHECK(initialized_); return base::TimeDelta::FromMilliseconds(test_launcher_timeout_ms_); } private: static bool initialized_; static int tiny_timeout_ms_; static int action_timeout_ms_; static int action_max_timeout_ms_; static int test_launcher_timeout_ms_; DISALLOW_IMPLICIT_CONSTRUCTORS(TestTimeouts); }; #endif // BASE_TEST_TEST_TIMEOUTS_H_