#if !defined(BOOST_ALL_NO_LIB)
#define BOOST_ALL_NO_LIB 1
#endif
#include "asio/ip/multicast.hpp"
#include "asio/io_context.hpp"
#include "asio/ip/udp.hpp"
#include "../unit_test.hpp"
namespace ip_multicast_compile {
void test()
{
using namespace asio;
namespace ip = asio::ip;
try
{
io_context ioc;
ip::udp::socket sock(ioc);
const ip::address address;
const ip::address_v4 address_v4;
const ip::address_v6 address_v6;
ip::multicast::join_group join_group1;
ip::multicast::join_group join_group2(address);
ip::multicast::join_group join_group3(address_v4);
ip::multicast::join_group join_group4(address_v4, address_v4);
ip::multicast::join_group join_group5(address_v6);
ip::multicast::join_group join_group6(address_v6, 1);
sock.set_option(join_group6);
ip::multicast::leave_group leave_group1;
ip::multicast::leave_group leave_group2(address);
ip::multicast::leave_group leave_group3(address_v4);
ip::multicast::leave_group leave_group4(address_v4, address_v4);
ip::multicast::leave_group leave_group5(address_v6);
ip::multicast::leave_group leave_group6(address_v6, 1);
sock.set_option(leave_group6);
ip::multicast::outbound_interface outbound_interface1;
ip::multicast::outbound_interface outbound_interface2(address_v4);
ip::multicast::outbound_interface outbound_interface3(1);
sock.set_option(outbound_interface3);
ip::multicast::hops hops1(1024);
sock.set_option(hops1);
ip::multicast::hops hops2;
sock.get_option(hops2);
hops1 = 1;
(void)static_cast<int>(hops1.value());
ip::multicast::enable_loopback enable_loopback1(true);
sock.set_option(enable_loopback1);
ip::multicast::enable_loopback enable_loopback2;
sock.get_option(enable_loopback2);
enable_loopback1 = true;
(void)static_cast<bool>(enable_loopback1);
(void)static_cast<bool>(!enable_loopback1);
(void)static_cast<bool>(enable_loopback1.value());
}
catch (std::exception&)
{
}
}
}
namespace ip_multicast_runtime {
#if defined(__hpux)
extern "C" unsigned int if_nametoindex(const char*);
#endif
void test()
{
using namespace asio;
namespace ip = asio::ip;
io_context ioc;
asio::error_code ec;
ip::udp::endpoint ep_v4(ip::address_v4::loopback(), 0);
ip::udp::socket sock_v4(ioc);
sock_v4.open(ep_v4.protocol(), ec);
sock_v4.bind(ep_v4, ec);
bool have_v4 = !ec;
ip::udp::endpoint ep_v6(ip::address_v6::loopback(), 0);
ip::udp::socket sock_v6(ioc);
sock_v6.open(ep_v6.protocol(), ec);
sock_v6.bind(ep_v6, ec);
bool have_v6 = !ec;
ASIO_CHECK(have_v4 || have_v6);
#if defined(ASIO_WINDOWS) && defined(UNDER_CE)
const ip::address multicast_address_v4 = ip::make_address("239.0.0.4", ec);
#else
const ip::address multicast_address_v4 = ip::make_address("239.255.0.1", ec);
#endif ASIO_CHECK(!have_v4 || !ec);
#if (defined(__MACH__) && defined(__APPLE__)) \
|| defined(__FreeBSD__) \
|| defined(__NetBSD__) \
|| defined(__OpenBSD__)
const ip::address multicast_address_v6 = ip::make_address("ff02::1%lo0", ec);
#else
const ip::address multicast_address_v6 = ip::make_address("ff01::1", ec);
#endif ASIO_CHECK(!have_v6 || !ec);
if (have_v4)
{
ip::multicast::join_group join_group(multicast_address_v4);
sock_v4.set_option(join_group, ec);
ASIO_CHECK_MESSAGE(!ec || ec == error::no_such_device,
ec.value() << ", " << ec.message());
if (!ec)
{
ip::multicast::leave_group leave_group(multicast_address_v4);
sock_v4.set_option(leave_group, ec);
ASIO_CHECK_MESSAGE(!ec, ec.value() << ", " << ec.message());
}
}
if (have_v6)
{
ip::multicast::join_group join_group(multicast_address_v6);
sock_v6.set_option(join_group, ec);
ASIO_CHECK_MESSAGE(!ec || ec == error::no_such_device,
ec.value() << ", " << ec.message());
if (!ec)
{
ip::multicast::leave_group leave_group(multicast_address_v6);
sock_v6.set_option(leave_group, ec);
ASIO_CHECK_MESSAGE(!ec, ec.value() << ", " << ec.message());
}
}
if (have_v4)
{
ip::multicast::outbound_interface outbound_interface(
ip::address_v4::loopback());
sock_v4.set_option(outbound_interface, ec);
ASIO_CHECK_MESSAGE(!ec, ec.value() << ", " << ec.message());
}
if (have_v6)
{
#if defined(__hpux)
ip::multicast::outbound_interface outbound_interface(if_nametoindex("lo0"));
#else
ip::multicast::outbound_interface outbound_interface(1);
#endif
sock_v6.set_option(outbound_interface, ec);
ASIO_CHECK_MESSAGE(!ec, ec.value() << ", " << ec.message());
}
if (have_v4)
{
ip::multicast::hops hops1(1);
ASIO_CHECK(hops1.value() == 1);
sock_v4.set_option(hops1, ec);
ASIO_CHECK_MESSAGE(!ec, ec.value() << ", " << ec.message());
ip::multicast::hops hops2;
sock_v4.get_option(hops2, ec);
ASIO_CHECK_MESSAGE(!ec, ec.value() << ", " << ec.message());
ASIO_CHECK(hops2.value() == 1);
ip::multicast::hops hops3(0);
ASIO_CHECK(hops3.value() == 0);
sock_v4.set_option(hops3, ec);
ASIO_CHECK_MESSAGE(!ec, ec.value() << ", " << ec.message());
ip::multicast::hops hops4;
sock_v4.get_option(hops4, ec);
ASIO_CHECK_MESSAGE(!ec, ec.value() << ", " << ec.message());
ASIO_CHECK(hops4.value() == 0);
}
if (have_v6)
{
ip::multicast::hops hops1(1);
ASIO_CHECK(hops1.value() == 1);
sock_v6.set_option(hops1, ec);
ASIO_CHECK_MESSAGE(!ec, ec.value() << ", " << ec.message());
ip::multicast::hops hops2;
sock_v6.get_option(hops2, ec);
ASIO_CHECK_MESSAGE(!ec, ec.value() << ", " << ec.message());
ASIO_CHECK(hops2.value() == 1);
ip::multicast::hops hops3(0);
ASIO_CHECK(hops3.value() == 0);
sock_v6.set_option(hops3, ec);
ASIO_CHECK_MESSAGE(!ec, ec.value() << ", " << ec.message());
ip::multicast::hops hops4;
sock_v6.get_option(hops4, ec);
ASIO_CHECK_MESSAGE(!ec, ec.value() << ", " << ec.message());
ASIO_CHECK(hops4.value() == 0);
}
if (have_v4)
{
ip::multicast::enable_loopback enable_loopback1(true);
ASIO_CHECK(enable_loopback1.value());
ASIO_CHECK(static_cast<bool>(enable_loopback1));
ASIO_CHECK(!!enable_loopback1);
sock_v4.set_option(enable_loopback1, ec);
#if defined(ASIO_WINDOWS) && defined(UNDER_CE)
ASIO_CHECK_MESSAGE(ec == asio::error::no_protocol_option,
ec.value() << ", " << ec.message());
#else
ASIO_CHECK_MESSAGE(!ec, ec.value() << ", " << ec.message());
#endif
ip::multicast::enable_loopback enable_loopback2;
sock_v4.get_option(enable_loopback2, ec);
#if defined(ASIO_WINDOWS) && defined(UNDER_CE)
ASIO_CHECK_MESSAGE(!ec, ec.value() << ", " << ec.message());
#else
ASIO_CHECK_MESSAGE(!ec, ec.value() << ", " << ec.message());
ASIO_CHECK(enable_loopback2.value());
ASIO_CHECK(static_cast<bool>(enable_loopback2));
ASIO_CHECK(!!enable_loopback2);
#endif
ip::multicast::enable_loopback enable_loopback3(false);
ASIO_CHECK(!enable_loopback3.value());
ASIO_CHECK(!static_cast<bool>(enable_loopback3));
ASIO_CHECK(!enable_loopback3);
sock_v4.set_option(enable_loopback3, ec);
#if defined(ASIO_WINDOWS) && defined(UNDER_CE)
ASIO_CHECK_MESSAGE(ec == asio::error::no_protocol_option,
ec.value() << ", " << ec.message());
#else
ASIO_CHECK_MESSAGE(!ec, ec.value() << ", " << ec.message());
#endif
ip::multicast::enable_loopback enable_loopback4;
sock_v4.get_option(enable_loopback4, ec);
#if defined(ASIO_WINDOWS) && defined(UNDER_CE)
ASIO_CHECK_MESSAGE(!ec, ec.value() << ", " << ec.message());
#else
ASIO_CHECK_MESSAGE(!ec, ec.value() << ", " << ec.message());
ASIO_CHECK(!enable_loopback4.value());
ASIO_CHECK(!static_cast<bool>(enable_loopback4));
ASIO_CHECK(!enable_loopback4);
#endif }
if (have_v6)
{
ip::multicast::enable_loopback enable_loopback1(true);
ASIO_CHECK(enable_loopback1.value());
ASIO_CHECK(static_cast<bool>(enable_loopback1));
ASIO_CHECK(!!enable_loopback1);
sock_v6.set_option(enable_loopback1, ec);
ASIO_CHECK_MESSAGE(!ec, ec.value() << ", " << ec.message());
ip::multicast::enable_loopback enable_loopback2;
sock_v6.get_option(enable_loopback2, ec);
ASIO_CHECK_MESSAGE(!ec, ec.value() << ", " << ec.message());
ASIO_CHECK(enable_loopback2.value());
ASIO_CHECK(static_cast<bool>(enable_loopback2));
ASIO_CHECK(!!enable_loopback2);
ip::multicast::enable_loopback enable_loopback3(false);
ASIO_CHECK(!enable_loopback3.value());
ASIO_CHECK(!static_cast<bool>(enable_loopback3));
ASIO_CHECK(!enable_loopback3);
sock_v6.set_option(enable_loopback3, ec);
ASIO_CHECK_MESSAGE(!ec, ec.value() << ", " << ec.message());
ip::multicast::enable_loopback enable_loopback4;
sock_v6.get_option(enable_loopback4, ec);
ASIO_CHECK_MESSAGE(!ec, ec.value() << ", " << ec.message());
ASIO_CHECK(!enable_loopback4.value());
ASIO_CHECK(!static_cast<bool>(enable_loopback4));
ASIO_CHECK(!enable_loopback4);
}
}
}
ASIO_TEST_SUITE
(
"ip/multicast",
ASIO_COMPILE_TEST_CASE(ip_multicast_compile::test)
ASIO_TEST_CASE(ip_multicast_runtime::test)
)