mirror of
https://github.com/boostorg/thread.git
synced 2026-02-13 00:42:09 +00:00
merged from trunk
[SVN r46303]
This commit is contained in:
@@ -1,4 +1,4 @@
|
||||
// (C) Copyright 2006-7 Anthony Williams
|
||||
// (C) Copyright 2006-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)
|
||||
@@ -196,6 +196,35 @@ struct test_default_constructed_has_no_mutex_and_unlocked
|
||||
};
|
||||
};
|
||||
|
||||
|
||||
template<typename Mutex,typename Lock>
|
||||
struct test_locks_can_be_swapped
|
||||
{
|
||||
void operator()() const
|
||||
{
|
||||
Mutex m1;
|
||||
Mutex m2;
|
||||
Lock l1(m1);
|
||||
Lock l2(m2);
|
||||
|
||||
BOOST_CHECK_EQUAL(l1.mutex(),&m1);
|
||||
BOOST_CHECK_EQUAL(l2.mutex(),&m2);
|
||||
|
||||
l1.swap(l2);
|
||||
|
||||
BOOST_CHECK_EQUAL(l1.mutex(),&m2);
|
||||
BOOST_CHECK_EQUAL(l2.mutex(),&m1);
|
||||
|
||||
swap(l1,l2);
|
||||
|
||||
BOOST_CHECK_EQUAL(l1.mutex(),&m1);
|
||||
BOOST_CHECK_EQUAL(l2.mutex(),&m2);
|
||||
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
|
||||
BOOST_TEST_CASE_TEMPLATE_FUNCTION(test_scoped_lock_concept,Mutex)
|
||||
{
|
||||
typedef typename Mutex::scoped_lock Lock;
|
||||
@@ -208,6 +237,7 @@ BOOST_TEST_CASE_TEMPLATE_FUNCTION(test_scoped_lock_concept,Mutex)
|
||||
test_locked_after_lock_called<Mutex,Lock>()();
|
||||
test_throws_if_lock_called_when_already_locked<Mutex,Lock>()();
|
||||
test_throws_if_unlock_called_when_already_unlocked<Mutex,Lock>()();
|
||||
test_locks_can_be_swapped<Mutex,Lock>()();
|
||||
}
|
||||
|
||||
BOOST_TEST_CASE_TEMPLATE_FUNCTION(test_scoped_try_lock_concept,Mutex)
|
||||
@@ -225,6 +255,7 @@ BOOST_TEST_CASE_TEMPLATE_FUNCTION(test_scoped_try_lock_concept,Mutex)
|
||||
test_throws_if_lock_called_when_already_locked<Mutex,Lock>()();
|
||||
test_throws_if_try_lock_called_when_already_locked<Mutex,Lock>()();
|
||||
test_throws_if_unlock_called_when_already_unlocked<Mutex,Lock>()();
|
||||
test_locks_can_be_swapped<Mutex,Lock>()();
|
||||
}
|
||||
|
||||
boost::unit_test_framework::test_suite* init_unit_test_suite(int, char*[])
|
||||
|
||||
@@ -258,11 +258,58 @@ void do_test_tss_does_no_cleanup_after_release()
|
||||
}
|
||||
}
|
||||
|
||||
struct dummy_class_tracks_deletions
|
||||
{
|
||||
static unsigned deletions;
|
||||
|
||||
~dummy_class_tracks_deletions()
|
||||
{
|
||||
++deletions;
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
unsigned dummy_class_tracks_deletions::deletions=0;
|
||||
|
||||
boost::thread_specific_ptr<dummy_class_tracks_deletions> tss_with_null_cleanup(NULL);
|
||||
|
||||
void tss_thread_with_null_cleanup(dummy_class_tracks_deletions* delete_tracker)
|
||||
{
|
||||
tss_with_null_cleanup.reset(delete_tracker);
|
||||
}
|
||||
|
||||
void do_test_tss_does_no_cleanup_with_null_cleanup_function()
|
||||
{
|
||||
dummy_class_tracks_deletions* delete_tracker=new dummy_class_tracks_deletions;
|
||||
boost::thread t(tss_thread_with_null_cleanup,delete_tracker);
|
||||
try
|
||||
{
|
||||
t.join();
|
||||
}
|
||||
catch(...)
|
||||
{
|
||||
t.interrupt();
|
||||
t.join();
|
||||
throw;
|
||||
}
|
||||
|
||||
BOOST_CHECK(!dummy_class_tracks_deletions::deletions);
|
||||
if(!dummy_class_tracks_deletions::deletions)
|
||||
{
|
||||
delete delete_tracker;
|
||||
}
|
||||
}
|
||||
|
||||
void test_tss_does_no_cleanup_after_release()
|
||||
{
|
||||
timed_test(&do_test_tss_does_no_cleanup_after_release, 2);
|
||||
}
|
||||
|
||||
void test_tss_does_no_cleanup_with_null_cleanup_function()
|
||||
{
|
||||
timed_test(&do_test_tss_does_no_cleanup_with_null_cleanup_function, 2);
|
||||
}
|
||||
|
||||
boost::unit_test_framework::test_suite* init_unit_test_suite(int, char*[])
|
||||
{
|
||||
boost::unit_test_framework::test_suite* test =
|
||||
@@ -271,6 +318,7 @@ boost::unit_test_framework::test_suite* init_unit_test_suite(int, char*[])
|
||||
test->add(BOOST_TEST_CASE(test_tss));
|
||||
test->add(BOOST_TEST_CASE(test_tss_with_custom_cleanup));
|
||||
test->add(BOOST_TEST_CASE(test_tss_does_no_cleanup_after_release));
|
||||
test->add(BOOST_TEST_CASE(test_tss_does_no_cleanup_with_null_cleanup_function));
|
||||
|
||||
return test;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user