2
0
mirror of https://github.com/boostorg/sync.git synced 2026-01-19 04:42:12 +00:00
Files
sync/test/run/condition_variable_timed_wait_times_out.cpp
Andrey Semashev ffd2a86d5f Ported tests to lightweight_test.hpp.
This will allow to work around compilation warnings and errors on
MinGW coming from Boost.Test.
2019-01-03 21:22:44 +03:00

208 lines
6.7 KiB
C++

// Copyright (C) 2007-8 Anthony Williams
// Copyright (C) 2013 Andrey Semashev
//
// 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/thread.hpp>
#include <boost/thread/thread_time.hpp>
#include <boost/date_time/posix_time/posix_time_types.hpp>
#include <boost/sync/locks/unique_lock.hpp>
#include <boost/sync/mutexes/mutex.hpp>
#include <boost/sync/condition_variables/condition_variable.hpp>
#include <boost/sync/condition_variables/condition_variable_any.hpp>
#include <boost/sync/support/boost_date_time.hpp>
#include <boost/core/lightweight_test.hpp>
#include "utils.hpp"
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::sync::condition_variable cond;
boost::sync::mutex m;
boost::posix_time::seconds const delay(timeout_seconds);
boost::sync::unique_lock<boost::sync::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_TEST((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);
}
void do_test_timed_wait_with_predicate_times_out()
{
boost::sync::condition_variable cond;
boost::sync::mutex m;
boost::posix_time::seconds const delay(timeout_seconds);
boost::sync::unique_lock<boost::sync::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_TEST(!res);
BOOST_TEST((delay-timeout_resolution)<=(end-start));
}
void test_timed_wait_with_predicate_times_out()
{
timed_test(&do_test_timed_wait_with_predicate_times_out, timeout_seconds+timeout_grace, execution_monitor::use_mutex);
}
void do_test_relative_timed_wait_with_predicate_times_out()
{
boost::sync::condition_variable cond;
boost::sync::mutex m;
boost::posix_time::seconds const delay(timeout_seconds);
boost::sync::unique_lock<boost::sync::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_TEST(!res);
BOOST_TEST((delay-timeout_resolution)<=(end-start));
}
void test_relative_timed_wait_with_predicate_times_out()
{
timed_test(&do_test_relative_timed_wait_with_predicate_times_out, timeout_seconds+timeout_grace, execution_monitor::use_mutex);
}
void do_test_timed_wait_relative_times_out()
{
boost::sync::condition_variable cond;
boost::sync::mutex m;
boost::posix_time::seconds const delay(timeout_seconds);
boost::sync::unique_lock<boost::sync::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_TEST((delay-timeout_resolution)<=(end-start));
}
void test_timed_wait_relative_times_out()
{
timed_test(&do_test_timed_wait_relative_times_out, timeout_seconds+timeout_grace, execution_monitor::use_mutex);
}
void do_test_cv_any_timed_wait_times_out()
{
boost::sync::condition_variable_any cond;
boost::sync::mutex m;
boost::posix_time::seconds const delay(timeout_seconds);
boost::sync::unique_lock<boost::sync::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_TEST((delay-timeout_resolution)<=(end-start));
}
void test_cv_any_timed_wait_times_out()
{
timed_test(&do_test_cv_any_timed_wait_times_out, timeout_seconds+timeout_grace, execution_monitor::use_mutex);
}
void do_test_cv_any_timed_wait_with_predicate_times_out()
{
boost::sync::condition_variable_any cond;
boost::sync::mutex m;
boost::posix_time::seconds const delay(timeout_seconds);
boost::sync::unique_lock<boost::sync::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_TEST(!res);
BOOST_TEST((delay-timeout_resolution)<=(end-start));
}
void test_cv_any_timed_wait_with_predicate_times_out()
{
timed_test(&do_test_cv_any_timed_wait_with_predicate_times_out, timeout_seconds+timeout_grace, execution_monitor::use_mutex);
}
void do_test_cv_any_relative_timed_wait_with_predicate_times_out()
{
boost::sync::condition_variable_any cond;
boost::sync::mutex m;
boost::posix_time::seconds const delay(timeout_seconds);
boost::sync::unique_lock<boost::sync::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_TEST(!res);
BOOST_TEST((delay-timeout_resolution)<=(end-start));
}
void test_cv_any_relative_timed_wait_with_predicate_times_out()
{
timed_test(&do_test_cv_any_relative_timed_wait_with_predicate_times_out, timeout_seconds+timeout_grace, execution_monitor::use_mutex);
}
void do_test_cv_any_timed_wait_relative_times_out()
{
boost::sync::condition_variable_any cond;
boost::sync::mutex m;
boost::posix_time::seconds const delay(timeout_seconds);
boost::sync::unique_lock<boost::sync::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_TEST((delay-timeout_resolution)<=(end-start));
}
void test_cv_any_timed_wait_relative_times_out()
{
timed_test(&do_test_cv_any_timed_wait_relative_times_out, timeout_seconds+timeout_grace, execution_monitor::use_mutex);
}
int main()
{
test_timed_wait_times_out();
test_timed_wait_with_predicate_times_out();
test_relative_timed_wait_with_predicate_times_out();
test_timed_wait_relative_times_out();
test_cv_any_timed_wait_times_out();
test_cv_any_timed_wait_with_predicate_times_out();
test_cv_any_relative_timed_wait_with_predicate_times_out();
test_cv_any_timed_wait_relative_times_out();
return boost::report_errors();
}