then_pass.cpp 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. // Copyright (C) 2012-2013 Vicente Botet
  2. //
  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)
  5. // <boost/thread/future.hpp>
  6. // class future<R>
  7. // template<typename F>
  8. // auto then(F&& func) -> future<decltype(func(*this))>;
  9. #define BOOST_THREAD_VERSION 4
  10. //#define BOOST_THREAD_USES_LOG
  11. #define BOOST_THREAD_USES_LOG_THREAD_ID
  12. #include <boost/thread/detail/log.hpp>
  13. #include <boost/thread/future.hpp>
  14. #include <boost/detail/lightweight_test.hpp>
  15. #if defined BOOST_THREAD_PROVIDES_FUTURE_CONTINUATION
  16. #ifdef BOOST_MSVC
  17. #pragma warning(disable: 4127) // conditional expression is constant
  18. #endif
  19. int p1()
  20. {
  21. BOOST_THREAD_LOG << "p1 < " << BOOST_THREAD_END_LOG;
  22. boost::this_thread::sleep_for(boost::chrono::milliseconds(500));
  23. BOOST_THREAD_LOG << "p1 >" << BOOST_THREAD_END_LOG;
  24. return 1;
  25. }
  26. int p2(boost::shared_future<int> f)
  27. {
  28. BOOST_THREAD_LOG << "p2 <" << &f << BOOST_THREAD_END_LOG;
  29. BOOST_TEST(f.valid());
  30. int i = f.get();
  31. boost::this_thread::sleep_for(boost::chrono::milliseconds(500));
  32. BOOST_THREAD_LOG << "p2 <" << &f << BOOST_THREAD_END_LOG;
  33. return 2 * i;
  34. }
  35. void p3(boost::shared_future<int> f)
  36. {
  37. BOOST_THREAD_LOG << "p3 <" << &f << BOOST_THREAD_END_LOG;
  38. BOOST_TEST(f.valid());
  39. int i = f.get();
  40. boost::this_thread::sleep_for(boost::chrono::milliseconds(500));
  41. BOOST_THREAD_LOG << "p3 <" << &f << " " << i << BOOST_THREAD_END_LOG;
  42. return ;
  43. }
  44. int main()
  45. {
  46. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  47. {
  48. boost::shared_future<int> f1 = boost::async(boost::launch::async, &p1).share();
  49. BOOST_TEST(f1.valid());
  50. boost::future<int> f2 = f1.then(&p2);
  51. BOOST_TEST(f2.valid());
  52. try
  53. {
  54. BOOST_TEST(f2.get()==2);
  55. }
  56. catch (std::exception& ex)
  57. {
  58. BOOST_THREAD_LOG << "ERRORRRRR "<<ex.what() << "" << BOOST_THREAD_END_LOG;
  59. BOOST_TEST(false);
  60. }
  61. catch (...)
  62. {
  63. BOOST_THREAD_LOG << " ERRORRRRR exception thrown" << BOOST_THREAD_END_LOG;
  64. BOOST_TEST(false);
  65. }
  66. }
  67. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  68. {
  69. boost::shared_future<int> f1 = boost::async(boost::launch::async, &p1).share();
  70. BOOST_TEST(f1.valid());
  71. boost::future<int> f2 = f1.then(&p2);
  72. boost::future<int> f3 = f1.then(&p2);
  73. BOOST_TEST(f2.valid());
  74. BOOST_TEST(f3.valid());
  75. try
  76. {
  77. BOOST_TEST(f2.get()==2);
  78. BOOST_TEST(f3.get()==2);
  79. }
  80. catch (std::exception& ex)
  81. {
  82. BOOST_THREAD_LOG << "ERRORRRRR "<<ex.what() << "" << BOOST_THREAD_END_LOG;
  83. BOOST_TEST(false);
  84. }
  85. catch (...)
  86. {
  87. BOOST_THREAD_LOG << " ERRORRRRR exception thrown" << BOOST_THREAD_END_LOG;
  88. BOOST_TEST(false);
  89. }
  90. }
  91. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  92. {
  93. boost::shared_future<int> f1 = boost::async(boost::launch::async, &p1).share();
  94. BOOST_TEST(f1.valid());
  95. boost::future<void> f2 = f1.then(&p3);
  96. BOOST_TEST(f2.valid());
  97. try
  98. {
  99. f2.wait();
  100. }
  101. catch (std::exception& ex)
  102. {
  103. BOOST_THREAD_LOG << "ERRORRRRR "<<ex.what() << "" << BOOST_THREAD_END_LOG;
  104. BOOST_TEST(false);
  105. }
  106. catch (...)
  107. {
  108. BOOST_THREAD_LOG << " ERRORRRRR exception thrown" << BOOST_THREAD_END_LOG;
  109. BOOST_TEST(false);
  110. }
  111. }
  112. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  113. {
  114. boost::future<int> f2 = boost::async(p1).share().then(&p2);
  115. BOOST_TEST(f2.get()==2);
  116. }
  117. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  118. {
  119. boost::shared_future<int> f1 = boost::async(p1).share();
  120. boost::shared_future<int> f21 = f1.then(&p2).share();
  121. boost::future<int> f2= f21.then(&p2);
  122. BOOST_TEST(f2.get()==4);
  123. }
  124. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  125. {
  126. boost::shared_future<int> f1 = boost::async(p1).share();
  127. boost::future<int> f2= f1.then(&p2).share().then(&p2);
  128. BOOST_TEST(f2.get()==4);
  129. }
  130. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  131. {
  132. boost::future<int> f2 = boost::async(p1).share().then(&p2).share().then(&p2);
  133. BOOST_TEST(f2.get()==4);
  134. }
  135. return boost::report_errors();
  136. }
  137. #else
  138. int main()
  139. {
  140. return 0;
  141. }
  142. #endif