]>
git.proxmox.com Git - ceph.git/blob - ceph/src/boost/libs/thread/test/sync/futures/future/then_executor_pass.cpp
1 // Copyright (C) 2014 Vicente Botet
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/future.hpp>
10 // template<typename F>
11 // auto then(F&& func) -> future<decltype(func(*this))>;
13 #define BOOST_THREAD_VERSION 4
14 #define BOOST_THREAD_PROVIDES_EXECUTORS
15 //#define BOOST_THREAD_USES_LOG
16 #define BOOST_THREAD_USES_LOG_THREAD_ID
17 #include <boost/thread/detail/log.hpp>
19 #include <boost/thread/future.hpp>
20 #include <boost/thread/executors/basic_thread_pool.hpp>
21 #include <boost/thread/executor.hpp>
22 #include <boost/detail/lightweight_test.hpp>
25 #if defined BOOST_THREAD_PROVIDES_FUTURE_CONTINUATION
30 BOOST_THREAD_LOG
<< "p1 < " << BOOST_THREAD_END_LOG
;
31 boost::this_thread::sleep_for(boost::chrono::milliseconds(500));
32 BOOST_THREAD_LOG
<< "p1 >" << BOOST_THREAD_END_LOG
;
36 int p2(boost::future
<int> f
)
39 BOOST_THREAD_LOG
<< "p2 <" << &f
<< BOOST_THREAD_END_LOG
;
40 BOOST_TEST(f
.valid());
42 boost::this_thread::sleep_for(boost::chrono::milliseconds(500));
43 BOOST_THREAD_LOG
<< "p2 <" << &f
<< BOOST_THREAD_END_LOG
;
47 void p3(boost::future
<int> f
)
50 BOOST_THREAD_LOG
<< "p3 <" << &f
<< BOOST_THREAD_END_LOG
;
51 BOOST_TEST(f
.valid());
53 boost::this_thread::sleep_for(boost::chrono::milliseconds(500));
54 BOOST_THREAD_LOG
<< "p3 <" << &f
<< " " <<i
<< BOOST_THREAD_END_LOG
;
60 BOOST_THREAD_LOG
<< BOOST_THREAD_END_LOG
;
62 boost::basic_thread_pool
ex(1);
63 boost::future
<int> f1
= boost::async(boost::launch::async
, &p1
);
64 BOOST_TEST(f1
.valid());
65 boost::future
<int> f2
= f1
.then(ex
, &p2
);
66 BOOST_TEST(f2
.valid());
67 BOOST_TEST(! f1
.valid());
70 BOOST_TEST(f2
.get()==2);
72 catch (std::exception
& ex
)
74 BOOST_THREAD_LOG
<< "ERRORRRRR "<<ex
.what() << "" << BOOST_THREAD_END_LOG
;
79 BOOST_THREAD_LOG
<< " ERRORRRRR exception thrown" << BOOST_THREAD_END_LOG
;
83 BOOST_THREAD_LOG
<< BOOST_THREAD_END_LOG
;
85 boost::basic_thread_pool
ex(1);
86 boost::future
<int> f1
= boost::async(boost::launch::async
, &p1
);
87 BOOST_TEST(f1
.valid());
88 boost::future
<void> f2
= f1
.then(ex
, &p3
);
89 BOOST_TEST(f2
.valid());
94 catch (std::exception
& ex
)
96 BOOST_THREAD_LOG
<< "ERRORRRRR "<<ex
.what() << "" << BOOST_THREAD_END_LOG
;
101 BOOST_THREAD_LOG
<< " ERRORRRRR exception thrown" << BOOST_THREAD_END_LOG
;
105 BOOST_THREAD_LOG
<< BOOST_THREAD_END_LOG
;
107 boost::basic_thread_pool
ex(1);
108 boost::future
<int> f2
= boost::async(p1
).then(ex
, &p2
);
109 BOOST_TEST(f2
.get()==2);
111 BOOST_THREAD_LOG
<< BOOST_THREAD_END_LOG
;
113 boost::basic_thread_pool
ex(1);
114 boost::future
<int> f1
= boost::async(p1
);
115 boost::future
<int> f21
= f1
.then(ex
, &p2
);
116 boost::future
<int> f2
= f21
.then(ex
, &p2
);
117 BOOST_TEST(f2
.get()==4);
119 BOOST_THREAD_LOG
<< BOOST_THREAD_END_LOG
;
121 boost::basic_thread_pool
ex(1);
122 boost::future
<int> f1
= boost::async(p1
);
123 boost::future
<int> f21
= f1
.then(ex
, &p2
);
124 boost::future
<int> f2
= f21
.then(&p2
);
125 BOOST_TEST(f2
.get()==4);
127 BOOST_THREAD_LOG
<< BOOST_THREAD_END_LOG
;
129 boost::basic_thread_pool
ex(1);
130 boost::future
<int> f1
= boost::async(p1
);
131 boost::future
<int> f2
= f1
.then(&p2
).then(ex
, &p2
);
132 BOOST_TEST(f2
.get()==4);
134 BOOST_THREAD_LOG
<< BOOST_THREAD_END_LOG
;
136 boost::basic_thread_pool
ex(1);
137 boost::future
<int> f2
= boost::async(p1
).then(ex
, &p2
).then(ex
, &p2
);
138 BOOST_TEST(f2
.get()==4);
141 return boost::report_errors();