// (C) Copyright 2008-10 Anthony Williams // // Distributed under the Boost Software License, Version 1.0. (See // accompanying file LICENSE_1_0.txt or copy at // http://www.boost.org/LICENSE_1_0.txt) #include #include #include #include #include #include #include int fn( int i) { return i; } boost::fibers::future< int > async( int i) { boost::fibers::packaged_task< int() > pt( std::bind( fn, i) ); boost::fibers::future< int > f( pt.get_future() ); std::thread([pt=std::move( pt)] () mutable -> void { boost::fibers::fiber f( std::move( pt) ); boost::this_fiber::yield(); f.join(); //pt(); }).detach(); return f; } void test_async() { for ( int i = 0; i < 100; ++i) { int n = 3; boost::fibers::future< int > f = async( n); int result = f.get(); BOOST_CHECK_EQUAL( n, result); } } void test_dummy() {} boost::unit_test_framework::test_suite* init_unit_test_suite(int, char*[]) { boost::unit_test_framework::test_suite* test = BOOST_TEST_SUITE("Boost.Fiber: futures-mt test suite"); #if ! defined(BOOST_FIBERS_NO_ATOMICS) test->add(BOOST_TEST_CASE(test_async)); #else test->add(BOOST_TEST_CASE(test_dummy)); #endif return test; }