X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FPPI%2FSocketSink.test.cc;h=3f424faf1d9b11108f8e50ad9c9c9d986e70de3b;hb=f7f08ce8a2ffd9a8004ab04a22a8ed434c0812f7;hp=5b7f420ec67de23312a6bb7809782976173e6373;hpb=601d1f509f5bb24df167a4dd5a20da67a0af9af8;p=senf.git diff --git a/senf/PPI/SocketSink.test.cc b/senf/PPI/SocketSink.test.cc index 5b7f420..3f424fa 100644 --- a/senf/PPI/SocketSink.test.cc +++ b/senf/PPI/SocketSink.test.cc @@ -27,14 +27,14 @@ //#include "SocketSink.test.ih" // Custom includes -#include "../Socket/Protocols/INet/UDPSocketHandle.hh" -#include "../Socket/Protocols/INet/ConnectedUDPSocketHandle.hh" +#include +#include #include "SocketSource.hh" #include "DebugModules.hh" #include "SocketSink.hh" #include "Setup.hh" -#include "../Utils/auto_unit_test.hh" +#include #include #define prefix_ @@ -47,12 +47,31 @@ namespace { void timeout() { senf::scheduler::terminate(); } + + int base_pid = 0; + + unsigned port(unsigned i) + { + if (! base_pid) + base_pid = ::getpid(); + return 23456u + (((base_pid^(base_pid>>8)^(base_pid>>16)^(base_pid>>24))&0xff)<<2) + i; + } + + std::string localhost4str(unsigned i) + { + return (boost::format("localhost:%d") % port(i)).str(); + } + + std::string localhost6str(unsigned i) + { + return (boost::format("[::1]:%d") % port(i)).str(); + } } BOOST_AUTO_UNIT_TEST(passiveSocketSink) { senf::ConnectedUDPv4ClientSocketHandle outputSocket ( - senf::INet4SocketAddress("localhost:44344")); + senf::INet4SocketAddress(localhost4str(0))); module::PassiveSocketSink<> udpSink(outputSocket); debug::ActiveSource source; ppi::connect(source, udpSink); @@ -61,7 +80,7 @@ BOOST_AUTO_UNIT_TEST(passiveSocketSink) senf::Packet p (senf::DataPacket::create(data)); senf::UDPv4ClientSocketHandle inputSocket; - inputSocket.bind(senf::INet4SocketAddress("localhost:44344")); + inputSocket.bind(senf::INet4SocketAddress(localhost4str(0))); senf::ppi::init(); source.submit(p); @@ -72,7 +91,7 @@ BOOST_AUTO_UNIT_TEST(passiveSocketSink) BOOST_AUTO_UNIT_TEST(activeSocketSink) { senf::ConnectedUDPv4ClientSocketHandle outputSocket ( - senf::INet4SocketAddress("localhost:44344")); + senf::INet4SocketAddress(localhost4str(0))); module::ActiveSocketSink<> udpSink(outputSocket); debug::PassiveSource source; ppi::connect(source, udpSink); @@ -81,7 +100,7 @@ BOOST_AUTO_UNIT_TEST(activeSocketSink) senf::Packet p (senf::DataPacket::create(data)); senf::UDPv4ClientSocketHandle inputSocket; - inputSocket.bind(senf::INet4SocketAddress("localhost:44344")); + inputSocket.bind(senf::INet4SocketAddress(localhost4str(0))); senf::scheduler::TimerEvent timer ( "activeSocketSink test timer", &timeout, senf::ClockService::now() + senf::ClockService::milliseconds(100));