1 // Copyright (C) 2012 Vicente J. Botet Escriba
3 // Distributed under the Boost Software License, Version 1.0. (See accompanying
4 // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
6 // <boost/thread/locks.hpp>
8 // template <class Mutex> class nested_strict_lock;
10 // nested_strict_lock(Mutex &);
12 #include <boost/thread/lock_types.hpp>
13 #include <boost/thread/strict_lock.hpp>
14 #include <boost/thread/mutex.hpp>
15 #include <boost/thread/thread.hpp>
16 #include <boost/detail/lightweight_test.hpp>
18 #ifdef BOOST_THREAD_USES_CHRONO
19 typedef boost::chrono::high_resolution_clock Clock
;
20 typedef Clock::time_point time_point
;
21 typedef Clock::duration duration
;
22 typedef boost::chrono::milliseconds ms
;
23 typedef boost::chrono::nanoseconds ns
;
30 #ifdef BOOST_THREAD_USES_CHRONO
31 time_point t0
= Clock::now();
33 boost::unique_lock
<boost::mutex
> lg(m
);
35 boost::nested_strict_lock
<boost::unique_lock
<boost::mutex
> > nlg(lg
);
38 ns d
= t1
- t0
- ms(250);
39 // This test is spurious as it depends on the time the thread system switches the threads
40 BOOST_TEST(d
< ns(2500000)+ms(1000)); // within 2.5ms
42 //time_point t0 = Clock::now();
44 boost::unique_lock
<boost::mutex
> lg(m
);
46 boost::nested_strict_lock
<boost::unique_lock
<boost::mutex
> > nlg(lg
);
49 //ns d = t1 - t0 - ms(250);
50 // This test is spurious as it depends on the time the thread system switches the threads
51 //BOOST_TEST(d < ns(2500000)+ms(1000)); // within 2.5ms
60 #ifdef BOOST_THREAD_USES_CHRONO
61 boost::this_thread::sleep_for(ms(250));
67 return boost::report_errors();