2
0
mirror of https://github.com/boostorg/fiber.git synced 2026-01-31 08:12:08 +00:00
Files
fiber/test/test_future_mt.cpp
2015-09-22 19:17:08 +02:00

50 lines
1.3 KiB
C++

// (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 <utility>
#include <memory>
#include <stdexcept>
#include <string>
#include <thread>
#include <boost/fiber/all.hpp>
#include <boost/test/unit_test.hpp>
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 -> decltype( auto) { boost::fibers::fiber( std::move( pt) ).join(); } ).detach();
return std::move( f);
}
void test_async() {
int i = 3;
boost::fibers::future< int > f = async( i);
int result = f.get();
BOOST_CHECK_EQUAL( i, 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)
for ( int i = 0; i < 50; ++i) {
test->add(BOOST_TEST_CASE(test_async));
}
#else
test->add(BOOST_TEST_CASE(test_dummy));
#endif
return test;
}