]>
git.proxmox.com Git - ceph.git/blob - ceph/src/boost/libs/thread/test/sync/mutual_exclusion/locks/shared_lock/cons/duration_pass.cpp
1 //===----------------------------------------------------------------------===//
3 // The LLVM Compiler Infrastructure
5 // This file is dual licensed under the MIT and the University of Illinois Open
6 // Source Licenses. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 // Copyright (C) 2011 Vicente J. Botet Escriba
12 // Distributed under the Boost Software License, Version 1.0. (See accompanying
13 // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
15 // <boost/thread/locks.hpp>
17 // template <class Mutex> class shared_lock;
19 // template <class Rep, class Period>
20 // shared_lock(mutex_type& m, const chrono::duration<Rep, Period>& rel_time);
22 #include <boost/thread/lock_types.hpp>
23 #include <boost/thread/shared_mutex.hpp>
24 #include <boost/thread/thread.hpp>
25 #include <boost/detail/lightweight_test.hpp>
26 #include <boost/chrono/chrono_io.hpp>
28 boost::shared_mutex m
;
30 typedef boost::chrono::steady_clock Clock
;
31 typedef Clock::time_point time_point
;
32 typedef Clock::duration duration
;
33 typedef boost::chrono::milliseconds ms
;
34 typedef boost::chrono::nanoseconds ns
;
38 time_point t0
= Clock::now();
39 // This test is spurious as it depends on the time the thread system switches the threads
40 boost::shared_lock
<boost::shared_mutex
> lk(m
, ms(300)+ms(1000));
41 BOOST_TEST(lk
.owns_lock() == true);
42 time_point t1
= Clock::now();
43 ns d
= t1
- t0
- ms(250);
44 // This test is spurious as it depends on the time the thread system switches the threads
45 BOOST_TEST(d
< ns(5000000)+ms(1000)); // within 5ms
50 time_point t0
= Clock::now();
51 boost::shared_lock
<boost::shared_mutex
> lk(m
, ms(250));
52 BOOST_TEST(lk
.owns_lock() == false);
53 time_point t1
= Clock::now();
54 ns d
= t1
- t0
- ms(250);
55 // This test is spurious as it depends on the time the thread system switches the threads
56 BOOST_TEST(d
< ns(5000000)+ms(1000)); // within 5ms
64 boost::this_thread::sleep_for(ms(250));
71 // This test is spurious as it depends on the time the thread system switches the threads
72 boost::this_thread::sleep_for(ms(300)+ms(1000));
77 return boost::report_errors();