170 lines
5.5 KiB
C++
170 lines
5.5 KiB
C++
|
// 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)
|
||
|
|
||
|
#define BOOST_THREAD_VERSION 2
|
||
|
|
||
|
#define BOOST_TEST_MODULE Boost.Threads: condition_variable test suite
|
||
|
|
||
|
#include <boost/thread/detail/config.hpp>
|
||
|
|
||
|
#include <boost/thread/condition.hpp>
|
||
|
#include <boost/thread/thread_only.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::unique_lock<boost::mutex> 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::unique_lock<boost::mutex> 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::unique_lock<boost::mutex> 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::unique_lock<boost::mutex> 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::unique_lock<boost::mutex> 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::unique_lock<boost::mutex> 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::unique_lock<boost::mutex> 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::unique_lock<boost::mutex> 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));
|
||
|
}
|
||
|
|
||
|
|
||
|
BOOST_AUTO_TEST_CASE(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);
|
||
|
}
|
||
|
|
||
|
|