async_deferred_then_pass.cpp 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  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 && defined(BOOST_THREAD_PROVIDES_VARIADIC_THREAD)
  16. int p1()
  17. {
  18. BOOST_THREAD_LOG << "p1 < " << BOOST_THREAD_END_LOG;
  19. boost::this_thread::sleep_for(boost::chrono::milliseconds(500));
  20. BOOST_THREAD_LOG << "p1 >" << BOOST_THREAD_END_LOG;
  21. return 1;
  22. }
  23. int p2(boost::future<int> f)
  24. {
  25. BOOST_THREAD_LOG << "p2 <" << &f << BOOST_THREAD_END_LOG;
  26. BOOST_TEST(f.valid());
  27. int i = f.get();
  28. boost::this_thread::sleep_for(boost::chrono::milliseconds(500));
  29. BOOST_THREAD_LOG << "p2 <" << &f << BOOST_THREAD_END_LOG;
  30. return 2 * i;
  31. }
  32. void p3(boost::future<int> f)
  33. {
  34. BOOST_THREAD_LOG << "p3 <" << &f << BOOST_THREAD_END_LOG;
  35. BOOST_TEST(f.valid());
  36. int i = f.get();
  37. boost::this_thread::sleep_for(boost::chrono::milliseconds(500));
  38. BOOST_THREAD_LOG << "p3 <" << &f << " " <<i << BOOST_THREAD_END_LOG;
  39. return;
  40. }
  41. int main()
  42. {
  43. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  44. {
  45. try
  46. {
  47. boost::future<int> f1 = boost::async(boost::launch::deferred, &p1);
  48. BOOST_TEST(f1.valid());
  49. {
  50. boost::future<int> f2 = f1.then(&p2);
  51. BOOST_TEST(f2.valid());
  52. }
  53. BOOST_TEST(! f1.valid());
  54. }
  55. catch (std::exception& ex)
  56. {
  57. BOOST_THREAD_LOG << "ERRORRRRR "<<ex.what() << "" << BOOST_THREAD_END_LOG;
  58. BOOST_TEST(false);
  59. }
  60. catch (...)
  61. {
  62. BOOST_THREAD_LOG << " ERRORRRRR exception thrown" << BOOST_THREAD_END_LOG;
  63. BOOST_TEST(false);
  64. }
  65. }
  66. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  67. {
  68. boost::future<int> f1 = boost::async(boost::launch::deferred, &p1);
  69. BOOST_TEST(f1.valid());
  70. boost::future<int> f2 = f1.then(&p2);
  71. BOOST_TEST(f2.valid());
  72. BOOST_TEST(! f1.valid());
  73. try
  74. {
  75. BOOST_TEST(f2.get()==2);
  76. }
  77. catch (std::exception& ex)
  78. {
  79. BOOST_THREAD_LOG << "ERRORRRRR "<<ex.what() << "" << BOOST_THREAD_END_LOG;
  80. BOOST_TEST(false);
  81. }
  82. catch (...)
  83. {
  84. BOOST_THREAD_LOG << " ERRORRRRR exception thrown" << BOOST_THREAD_END_LOG;
  85. BOOST_TEST(false);
  86. }
  87. }
  88. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  89. {
  90. boost::future<int> f1 = boost::async(boost::launch::deferred, &p1);
  91. BOOST_TEST(f1.valid());
  92. boost::future<void> f2 = f1.then(&p3);
  93. BOOST_TEST(f2.valid());
  94. try
  95. {
  96. f2.wait();
  97. }
  98. catch (std::exception& ex)
  99. {
  100. BOOST_THREAD_LOG << "ERRORRRRR "<<ex.what() << "" << BOOST_THREAD_END_LOG;
  101. BOOST_TEST(false);
  102. }
  103. catch (...)
  104. {
  105. BOOST_THREAD_LOG << " ERRORRRRR exception thrown" << BOOST_THREAD_END_LOG;
  106. BOOST_TEST(false);
  107. }
  108. }
  109. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  110. {
  111. boost::future<int> f2 = boost::async(boost::launch::deferred, p1).then(&p2);
  112. BOOST_TEST(f2.get()==2);
  113. }
  114. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  115. {
  116. boost::future<int> f1 = boost::async(boost::launch::deferred, p1);
  117. boost::future<int> f21 = f1.then(&p2);
  118. boost::future<int> f2= f21.then(&p2);
  119. BOOST_TEST(f2.get()==4);
  120. }
  121. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  122. {
  123. boost::future<int> f1 = boost::async(boost::launch::deferred, p1);
  124. boost::future<int> f2= f1.then(&p2).then(&p2);
  125. BOOST_TEST(f2.get()==4);
  126. }
  127. BOOST_THREAD_LOG << BOOST_THREAD_END_LOG;
  128. {
  129. boost::future<int> f2 = boost::async(boost::launch::deferred, p1).then(&p2).then(&p2);
  130. BOOST_TEST(f2.get()==4);
  131. }
  132. return boost::report_errors();
  133. }
  134. #else
  135. int main()
  136. {
  137. return 0;
  138. }
  139. #endif