1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166
|
//
// inline_executor.cpp
// ~~~~~~~~~~~~~~~~~~~
//
// Copyright (c) 2003-2025 Christopher M. Kohlhoff (chris at kohlhoff dot com)
//
// 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)
//
// Disable autolinking for unit tests.
#if !defined(BOOST_ALL_NO_LIB)
#define BOOST_ALL_NO_LIB 1
#endif // !defined(BOOST_ALL_NO_LIB)
// Prevent link dependency on the Boost.System library.
#if !defined(BOOST_SYSTEM_NO_DEPRECATED)
#define BOOST_SYSTEM_NO_DEPRECATED
#endif // !defined(BOOST_SYSTEM_NO_DEPRECATED)
// Test that header file is self-contained.
#include <boost/asio/inline_executor.hpp>
#include <functional>
#include <boost/asio/any_completion_executor.hpp>
#include <boost/asio/dispatch.hpp>
#include "unit_test.hpp"
using namespace boost::asio;
namespace bindns = std;
void increment(boost::asio::detail::atomic_count* count)
{
++(*count);
}
void inline_executor_query_test()
{
BOOST_ASIO_CHECK(
boost::asio::query(inline_executor(),
boost::asio::execution::blocking)
== boost::asio::execution::blocking.always);
BOOST_ASIO_CHECK(
boost::asio::query(inline_executor(),
boost::asio::execution::blocking.possibly)
== boost::asio::execution::blocking.always);
BOOST_ASIO_CHECK(
boost::asio::query(inline_executor(),
boost::asio::execution::outstanding_work)
== boost::asio::execution::outstanding_work.untracked);
BOOST_ASIO_CHECK(
boost::asio::query(inline_executor(),
boost::asio::execution::outstanding_work.untracked)
== boost::asio::execution::outstanding_work.untracked);
BOOST_ASIO_CHECK(
boost::asio::query(inline_executor(),
boost::asio::execution::relationship)
== boost::asio::execution::relationship.fork);
BOOST_ASIO_CHECK(
boost::asio::query(inline_executor(),
boost::asio::execution::relationship.fork)
== boost::asio::execution::relationship.fork);
BOOST_ASIO_CHECK(
boost::asio::query(inline_executor(),
boost::asio::execution::mapping)
== boost::asio::execution::mapping.thread);
BOOST_ASIO_CHECK(
boost::asio::query(inline_executor(),
boost::asio::execution::inline_exception_handling)
== boost::asio::execution::inline_exception_handling.propagate);
BOOST_ASIO_CHECK(
boost::asio::query(inline_executor(),
boost::asio::execution::inline_exception_handling.propagate)
== boost::asio::execution::inline_exception_handling.propagate);
BOOST_ASIO_CHECK(
boost::asio::query(
boost::asio::require(inline_executor(),
boost::asio::execution::inline_exception_handling.terminate),
boost::asio::execution::inline_exception_handling)
== boost::asio::execution::inline_exception_handling.terminate);
BOOST_ASIO_CHECK(
boost::asio::query(
boost::asio::require(inline_executor(),
boost::asio::execution::inline_exception_handling.terminate),
boost::asio::execution::inline_exception_handling.propagate)
== boost::asio::execution::inline_exception_handling.terminate);
}
void inline_executor_execute_test()
{
boost::asio::detail::atomic_count count(0);
inline_executor().execute(bindns::bind(increment, &count));
boost::asio::require(inline_executor(),
boost::asio::execution::blocking.always
).execute(bindns::bind(increment, &count));
boost::asio::prefer(inline_executor(),
boost::asio::execution::blocking.possibly
).execute(bindns::bind(increment, &count));
boost::asio::any_completion_executor ex = inline_executor();
ex.execute(bindns::bind(increment, &count));
BOOST_ASIO_CHECK(count == 4);
}
void inline_executor_dispatch_test()
{
boost::asio::detail::atomic_count count(0);
boost::asio::dispatch(inline_executor(),
bindns::bind(increment, &count));
boost::asio::dispatch(
boost::asio::require(inline_executor(),
boost::asio::execution::inline_exception_handling.terminate),
bindns::bind(increment, &count));
BOOST_ASIO_CHECK(count == 2);
}
void throw_exception()
{
throw 42;
}
void inline_executor_exception_test()
{
#if !defined(BOOST_ASIO_NO_EXCEPTIONS)
bool caught = false;
try
{
inline_executor().execute(throw_exception);
}
catch (...)
{
caught = true;
}
BOOST_ASIO_CHECK(caught);
#endif // !defined(BOOST_ASIO_NO_EXCEPTIONS)
}
BOOST_ASIO_TEST_SUITE
(
"inline_executor",
BOOST_ASIO_TEST_CASE(inline_executor_query_test)
BOOST_ASIO_TEST_CASE(inline_executor_execute_test)
BOOST_ASIO_TEST_CASE(inline_executor_dispatch_test)
BOOST_ASIO_TEST_CASE(inline_executor_exception_test)
)
|