// // set_error.cpp // ~~~~~~~~~~~~~ // // Copyright (c) 2003-2021 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) // Test that header file is self-contained. #include #include #include "../unit_test.hpp" namespace exec = boost::asio::execution; static int call_count = 0; struct no_set_error { }; struct const_member_set_error { template void set_error(BOOST_ASIO_MOVE_ARG(E) e) const BOOST_ASIO_NOEXCEPT { typename boost::asio::decay::type tmp(BOOST_ASIO_MOVE_CAST(E)(e)); (void)tmp; ++call_count; } }; #if !defined(BOOST_ASIO_HAS_DEDUCED_SET_ERROR_MEMBER_TRAIT) namespace boost { namespace asio { namespace traits { template struct set_error_member { BOOST_ASIO_STATIC_CONSTEXPR(bool, is_valid = true); BOOST_ASIO_STATIC_CONSTEXPR(bool, is_noexcept = true); typedef void result_type; }; } // namespace traits } // namespace asio } // namespace boost #endif // !defined(BOOST_ASIO_HAS_DEDUCED_SET_ERROR_MEMBER_TRAIT) struct free_set_error_const_receiver { template friend void set_error(const free_set_error_const_receiver&, BOOST_ASIO_MOVE_ARG(E) e) BOOST_ASIO_NOEXCEPT { typename boost::asio::decay::type tmp(BOOST_ASIO_MOVE_CAST(E)(e)); (void)tmp; ++call_count; } }; #if !defined(BOOST_ASIO_HAS_DEDUCED_SET_ERROR_FREE_TRAIT) namespace boost { namespace asio { namespace traits { template struct set_error_free { BOOST_ASIO_STATIC_CONSTEXPR(bool, is_valid = true); BOOST_ASIO_STATIC_CONSTEXPR(bool, is_noexcept = true); typedef void result_type; }; } // namespace traits } // namespace asio } // namespace boost #endif // !defined(BOOST_ASIO_HAS_DEDUCED_SET_ERROR_FREE_TRAIT) struct non_const_member_set_error { template void set_error(BOOST_ASIO_MOVE_ARG(E) e) BOOST_ASIO_NOEXCEPT { typename boost::asio::decay::type tmp(BOOST_ASIO_MOVE_CAST(E)(e)); (void)tmp; ++call_count; } }; #if !defined(BOOST_ASIO_HAS_DEDUCED_SET_ERROR_MEMBER_TRAIT) namespace boost { namespace asio { namespace traits { template struct set_error_member { BOOST_ASIO_STATIC_CONSTEXPR(bool, is_valid = true); BOOST_ASIO_STATIC_CONSTEXPR(bool, is_noexcept = true); typedef void result_type; }; } // namespace traits } // namespace asio } // namespace boost #endif // !defined(BOOST_ASIO_HAS_DEDUCED_SET_ERROR_MEMBER_TRAIT) struct free_set_error_non_const_receiver { template friend void set_error(free_set_error_non_const_receiver&, BOOST_ASIO_MOVE_ARG(E) e) BOOST_ASIO_NOEXCEPT { typename boost::asio::decay::type tmp(BOOST_ASIO_MOVE_CAST(E)(e)); (void)tmp; ++call_count; } }; #if !defined(BOOST_ASIO_HAS_DEDUCED_SET_ERROR_FREE_TRAIT) namespace boost { namespace asio { namespace traits { template struct set_error_free { BOOST_ASIO_STATIC_CONSTEXPR(bool, is_valid = true); BOOST_ASIO_STATIC_CONSTEXPR(bool, is_noexcept = true); typedef void result_type; }; } // namespace traits } // namespace asio } // namespace boost #endif // !defined(BOOST_ASIO_HAS_DEDUCED_SET_ERROR_FREE_TRAIT) void test_can_set_error() { BOOST_ASIO_CONSTEXPR bool b1 = exec::can_set_error< no_set_error&, boost::system::error_code>::value; BOOST_ASIO_CHECK(b1 == false); BOOST_ASIO_CONSTEXPR bool b2 = exec::can_set_error< const no_set_error&, boost::system::error_code>::value; BOOST_ASIO_CHECK(b2 == false); BOOST_ASIO_CONSTEXPR bool b3 = exec::can_set_error< const_member_set_error&, boost::system::error_code>::value; BOOST_ASIO_CHECK(b3 == true); BOOST_ASIO_CONSTEXPR bool b4 = exec::can_set_error< const const_member_set_error&, boost::system::error_code>::value; BOOST_ASIO_CHECK(b4 == true); BOOST_ASIO_CONSTEXPR bool b5 = exec::can_set_error< free_set_error_const_receiver&, boost::system::error_code>::value; BOOST_ASIO_CHECK(b5 == true); BOOST_ASIO_CONSTEXPR bool b6 = exec::can_set_error< const free_set_error_const_receiver&, boost::system::error_code>::value; BOOST_ASIO_CHECK(b6 == true); BOOST_ASIO_CONSTEXPR bool b7 = exec::can_set_error< non_const_member_set_error&, boost::system::error_code>::value; BOOST_ASIO_CHECK(b7 == true); BOOST_ASIO_CONSTEXPR bool b8 = exec::can_set_error< const non_const_member_set_error&, boost::system::error_code>::value; BOOST_ASIO_CHECK(b8 == false); BOOST_ASIO_CONSTEXPR bool b9 = exec::can_set_error< free_set_error_non_const_receiver&, boost::system::error_code>::value; BOOST_ASIO_CHECK(b9 == true); BOOST_ASIO_CONSTEXPR bool b10 = exec::can_set_error< const free_set_error_non_const_receiver&, boost::system::error_code>::value; BOOST_ASIO_CHECK(b10 == false); } void increment(int* count) { ++(*count); } void test_set_error() { boost::system::error_code ec; call_count = 0; const_member_set_error ex1 = {}; exec::set_error(ex1, ec); BOOST_ASIO_CHECK(call_count == 1); call_count = 0; const const_member_set_error ex2 = {}; exec::set_error(ex2, ec); BOOST_ASIO_CHECK(call_count == 1); call_count = 0; exec::set_error(const_member_set_error(), ec); BOOST_ASIO_CHECK(call_count == 1); call_count = 0; free_set_error_const_receiver ex3 = {}; exec::set_error(ex3, ec); BOOST_ASIO_CHECK(call_count == 1); call_count = 0; const free_set_error_const_receiver ex4 = {}; exec::set_error(ex4, ec); BOOST_ASIO_CHECK(call_count == 1); call_count = 0; exec::set_error(free_set_error_const_receiver(), ec); BOOST_ASIO_CHECK(call_count == 1); call_count = 0; non_const_member_set_error ex5 = {}; exec::set_error(ex5, ec); BOOST_ASIO_CHECK(call_count == 1); call_count = 0; free_set_error_non_const_receiver ex6 = {}; exec::set_error(ex6, ec); BOOST_ASIO_CHECK(call_count == 1); } BOOST_ASIO_TEST_SUITE ( "set_error", BOOST_ASIO_TEST_CASE(test_can_set_error) BOOST_ASIO_TEST_CASE(test_set_error) )