test_condition_timed_wait_times_out.cpp
来自「Boost provides free peer-reviewed portab」· C++ 代码 · 共 174 行
CPP
174 行
// Copyright (C) 2007-8 Anthony Williams//// Distributed under the Boost Software License, Version 1.0. (See accompanying // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)#include <boost/thread/detail/config.hpp>#include <boost/thread/condition.hpp>#include <boost/thread/thread.hpp>#include <boost/test/unit_test.hpp>#include "util.inl"bool fake_predicate(){ return false;}unsigned const timeout_seconds=2;unsigned const timeout_grace=1;boost::posix_time::milliseconds const timeout_resolution(100);void do_test_timed_wait_times_out(){ boost::condition_variable cond; boost::mutex m; boost::posix_time::seconds const delay(timeout_seconds); boost::mutex::scoped_lock lock(m); boost::system_time const start=boost::get_system_time(); boost::system_time const timeout=start+delay; while(cond.timed_wait(lock,timeout)); boost::system_time const end=boost::get_system_time(); BOOST_CHECK((delay-timeout_resolution)<=(end-start));}void do_test_timed_wait_with_predicate_times_out(){ boost::condition_variable cond; boost::mutex m; boost::posix_time::seconds const delay(timeout_seconds); boost::mutex::scoped_lock lock(m); boost::system_time const start=boost::get_system_time(); boost::system_time const timeout=start+delay; bool const res=cond.timed_wait(lock,timeout,fake_predicate); boost::system_time const end=boost::get_system_time(); BOOST_CHECK(!res); BOOST_CHECK((delay-timeout_resolution)<=(end-start));}void do_test_relative_timed_wait_with_predicate_times_out(){ boost::condition_variable cond; boost::mutex m; boost::posix_time::seconds const delay(timeout_seconds); boost::mutex::scoped_lock lock(m); boost::system_time const start=boost::get_system_time(); bool const res=cond.timed_wait(lock,delay,fake_predicate); boost::system_time const end=boost::get_system_time(); BOOST_CHECK(!res); BOOST_CHECK((delay-timeout_resolution)<=(end-start));}void do_test_timed_wait_relative_times_out(){ boost::condition_variable cond; boost::mutex m; boost::posix_time::seconds const delay(timeout_seconds); boost::mutex::scoped_lock lock(m); boost::system_time const start=boost::get_system_time(); while(cond.timed_wait(lock,delay)); boost::system_time const end=boost::get_system_time(); BOOST_CHECK((delay-timeout_resolution)<=(end-start));}void do_test_cv_any_timed_wait_times_out(){ boost::condition_variable_any cond; boost::mutex m; boost::posix_time::seconds const delay(timeout_seconds); boost::mutex::scoped_lock lock(m); boost::system_time const start=boost::get_system_time(); boost::system_time const timeout=start+delay; while(cond.timed_wait(lock,timeout)); boost::system_time const end=boost::get_system_time(); BOOST_CHECK((delay-timeout_resolution)<=(end-start));}void do_test_cv_any_timed_wait_with_predicate_times_out(){ boost::condition_variable_any cond; boost::mutex m; boost::posix_time::seconds const delay(timeout_seconds); boost::mutex::scoped_lock lock(m); boost::system_time const start=boost::get_system_time(); boost::system_time const timeout=start+delay; bool const res=cond.timed_wait(lock,timeout,fake_predicate); boost::system_time const end=boost::get_system_time(); BOOST_CHECK(!res); BOOST_CHECK((delay-timeout_resolution)<=(end-start));}void do_test_cv_any_relative_timed_wait_with_predicate_times_out(){ boost::condition_variable_any cond; boost::mutex m; boost::posix_time::seconds const delay(timeout_seconds); boost::mutex::scoped_lock lock(m); boost::system_time const start=boost::get_system_time(); bool const res=cond.timed_wait(lock,delay,fake_predicate); boost::system_time const end=boost::get_system_time(); BOOST_CHECK(!res); BOOST_CHECK((delay-timeout_resolution)<=(end-start));}void do_test_cv_any_timed_wait_relative_times_out(){ boost::condition_variable_any cond; boost::mutex m; boost::posix_time::seconds const delay(timeout_seconds); boost::mutex::scoped_lock lock(m); boost::system_time const start=boost::get_system_time(); while(cond.timed_wait(lock,delay)); boost::system_time const end=boost::get_system_time(); BOOST_CHECK((delay-timeout_resolution)<=(end-start));}void test_timed_wait_times_out(){ timed_test(&do_test_timed_wait_times_out, timeout_seconds+timeout_grace, execution_monitor::use_mutex); timed_test(&do_test_timed_wait_with_predicate_times_out, timeout_seconds+timeout_grace, execution_monitor::use_mutex); timed_test(&do_test_relative_timed_wait_with_predicate_times_out, timeout_seconds+timeout_grace, execution_monitor::use_mutex); timed_test(&do_test_timed_wait_relative_times_out, timeout_seconds+timeout_grace, execution_monitor::use_mutex); timed_test(&do_test_cv_any_timed_wait_times_out, timeout_seconds+timeout_grace, execution_monitor::use_mutex); timed_test(&do_test_cv_any_timed_wait_with_predicate_times_out, timeout_seconds+timeout_grace, execution_monitor::use_mutex); timed_test(&do_test_cv_any_relative_timed_wait_with_predicate_times_out, timeout_seconds+timeout_grace, execution_monitor::use_mutex); timed_test(&do_test_cv_any_timed_wait_relative_times_out, timeout_seconds+timeout_grace, execution_monitor::use_mutex);}boost::unit_test_framework::test_suite* init_unit_test_suite(int, char*[]){ boost::unit_test_framework::test_suite* test = BOOST_TEST_SUITE("Boost.Threads: condition test suite"); test->add(BOOST_TEST_CASE(&test_timed_wait_times_out)); return test;}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?