mirror of
https://github.com/boostorg/thread.git
synced 2026-02-10 11:52:10 +00:00
merged from trunk
[SVN r46303]
This commit is contained in:
@@ -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