X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FSocket%2FProtocols%2FINet%2FTCPSocketHandle.test.cc;h=e19e967d67cf27ef0865e1f685934b6e9768312a;hb=a1c37005ec4c281f6a76c07070a943cd1e36b6af;hp=8a0038590ec6407cc55839e93b5fb01f7cd4a74d;hpb=26610f603ebdd465307b9621f532c1fe19fd5571;p=senf.git diff --git a/senf/Socket/Protocols/INet/TCPSocketHandle.test.cc b/senf/Socket/Protocols/INet/TCPSocketHandle.test.cc index 8a00385..e19e967 100644 --- a/senf/Socket/Protocols/INet/TCPSocketHandle.test.cc +++ b/senf/Socket/Protocols/INet/TCPSocketHandle.test.cc @@ -35,6 +35,7 @@ #include #include #include "TCPSocketHandle.hh" +#include "net.test.hh" #include #include @@ -42,53 +43,6 @@ #define prefix_ ///////////////////////////////cc.p//////////////////////////////////////// -namespace { - - void error(char const * fn, char const * proc="") - { - std::cerr << "\n" << proc << ((*proc)?": ":"") << fn << ": " << strerror(errno) << std::endl; - } - - void fail(char const * proc, char const * fn) - { - error(fn,proc); - _exit(1); - } - - int server_pid = 0; - - void start(void (*fn)()) - { - server_pid = ::fork(); - if (server_pid < 0) BOOST_FAIL("fork()"); - if (server_pid == 0) { - signal(SIGCHLD, SIG_IGN); - (*fn)(); - _exit(0); - } - signal(SIGCHLD, SIG_DFL); - ::sleep(1); - } - - void wait() - { - int status; - if (waitpid(server_pid,&status,0)<0) - BOOST_FAIL("waitpid()"); - BOOST_CHECK_EQUAL( status , 0 ); - } - - void stop() - { - if (server_pid) { - kill(server_pid,9); - wait(); - server_pid = 0; - } - } - -} - /////////////////////////////////////////////////////////////////////////// namespace { @@ -103,7 +57,7 @@ namespace { struct sockaddr_in sin; ::memset(&sin,0,sizeof(sin)); sin.sin_family = AF_INET; - sin.sin_port = htons(12345); + sin.sin_port = htons(port(0)); sin.sin_addr.s_addr = htonl(INADDR_LOOPBACK); if (bind(serv,(struct sockaddr *)&sin,sizeof(sin))<0) fail("server_v4","bind()"); if (listen(serv,1)<0) fail("server_v4","listen()"); @@ -115,7 +69,7 @@ namespace { int n = read(sock,buffer,1024); if (n == 4 && strncmp(buffer,"QUIT",4) == 0) break; - write(sock,buffer,n); + senf::IGNORE( write(sock,buffer,n) ); } if (shutdown(sock, SHUT_RDWR) < 0) fail("server_v4","shutdown()"); @@ -133,7 +87,7 @@ namespace { struct sockaddr_in6 sin; ::memset(&sin,0,sizeof(sin)); sin.sin6_family = AF_INET6; - sin.sin6_port = htons(12345); + sin.sin6_port = htons(port(0)); sin.sin6_addr = in6addr_loopback; if (bind(serv,(struct sockaddr *)&sin,sizeof(sin))<0) fail("server_v6","bind()"); if (listen(serv,1)<0) fail("server_v6","listen()"); @@ -145,7 +99,7 @@ namespace { int n = read(sock,buffer,1024); if (n == 4 && strncmp(buffer,"QUIT",4) == 0) break; - write(sock,buffer,n); + senf::IGNORE( write(sock,buffer,n) ); } if (shutdown(sock, SHUT_RDWR) < 0) fail("server_v6","shutdown()"); @@ -155,12 +109,12 @@ namespace { } -BOOST_AUTO_UNIT_TEST(tcpv4ClientSocketHandle) +SENF_AUTO_UNIT_TEST(tcpv4ClientSocketHandle) { { senf::TCPv4ClientSocketHandle sock; - BOOST_CHECK_THROW( sock.connect(senf::INet4SocketAddress("127.0.0.1:12345")), + BOOST_CHECK_THROW( sock.connect(senf::INet4SocketAddress(localhost4str(0))), senf::SystemException ); } @@ -168,10 +122,10 @@ BOOST_AUTO_UNIT_TEST(tcpv4ClientSocketHandle) alarm(10); start(server_v4); senf::TCPv4ClientSocketHandle sock; - SENF_CHECK_NO_THROW( sock.bind(senf::INet4SocketAddress("127.0.0.1:23456")) ); - SENF_CHECK_NO_THROW( sock.connect(senf::INet4SocketAddress("127.0.0.1:12345")) ); - BOOST_CHECK( sock.peer() == senf::INet4SocketAddress("127.0.0.1:12345") ); - BOOST_CHECK( sock.local() == senf::INet4SocketAddress("127.0.0.1:23456") ); + SENF_CHECK_NO_THROW( sock.bind(senf::INet4SocketAddress(localhost4str(1))) ); + SENF_CHECK_NO_THROW( sock.connect(senf::INet4SocketAddress(localhost4str(0))) ); + BOOST_CHECK( sock.peer() == senf::INet4SocketAddress(localhost4str(0)) ); + BOOST_CHECK( sock.local() == senf::INet4SocketAddress(localhost4str(1)) ); BOOST_CHECK( sock.blocking() ); SENF_CHECK_NO_THROW( sock.protocol().rcvbuf(2048) ); BOOST_CHECK_EQUAL( sock.protocol().rcvbuf(), 2048u ); @@ -226,12 +180,12 @@ BOOST_AUTO_UNIT_TEST(tcpv4ClientSocketHandle) } } -BOOST_AUTO_UNIT_TEST(tcpv6ClientSocketHandle) +SENF_AUTO_UNIT_TEST(tcpv6ClientSocketHandle) { { senf::TCPv6ClientSocketHandle sock; - BOOST_CHECK_THROW( sock.connect(senf::INet6SocketAddress("[::1]:12345")), + BOOST_CHECK_THROW( sock.connect(senf::INet6SocketAddress(localhost6str(0))), senf::SystemException ); } @@ -239,10 +193,10 @@ BOOST_AUTO_UNIT_TEST(tcpv6ClientSocketHandle) alarm(10); start(server_v6); senf::TCPv6ClientSocketHandle sock; - SENF_CHECK_NO_THROW( sock.bind(senf::INet6SocketAddress("[::1]:23456")) ); - SENF_CHECK_NO_THROW( sock.connect(senf::INet6SocketAddress("[::1]:12345")) ); - BOOST_CHECK( sock.peer() == senf::INet6SocketAddress("[::1]:12345") ); - BOOST_CHECK( sock.local() == senf::INet6SocketAddress("[::1]:23456") ); + SENF_CHECK_NO_THROW( sock.bind(senf::INet6SocketAddress(localhost6str(1))) ); + SENF_CHECK_NO_THROW( sock.connect(senf::INet6SocketAddress(localhost6str(0))) ); + BOOST_CHECK( sock.peer() == senf::INet6SocketAddress(localhost6str(0)) ); + BOOST_CHECK( sock.local() == senf::INet6SocketAddress(localhost6str(1)) ); BOOST_CHECK( sock.blocking() ); SENF_CHECK_NO_THROW( sock.protocol().rcvbuf(2048) ); BOOST_CHECK_EQUAL( sock.protocol().rcvbuf(), 2048u ); @@ -296,7 +250,7 @@ namespace { struct sockaddr_in sin; ::memset(&sin,0,sizeof(sin)); sin.sin_family = AF_INET; - sin.sin_port = htons(12346); + sin.sin_port = htons(port(2)); sin.sin_addr.s_addr = htonl(INADDR_LOOPBACK); if (connect(sock,(struct sockaddr *)&sin,sizeof(sin)) < 0) fail("client_v4","connect()"); @@ -306,7 +260,7 @@ namespace { int n = read(sock,buffer,1024); if (n == 4 && strncmp(buffer,"QUIT",4) == 0) break; - write(sock,buffer,n); + senf::IGNORE( write(sock,buffer,n) ); } if (shutdown(sock, SHUT_RDWR) < 0) fail("client_v4","shutdown()"); @@ -320,7 +274,7 @@ namespace { struct sockaddr_in6 sin; ::memset(&sin,0,sizeof(sin)); sin.sin6_family = AF_INET6; - sin.sin6_port = htons(12347); + sin.sin6_port = htons(port(3)); sin.sin6_addr = in6addr_loopback; if (connect(sock,(struct sockaddr *)&sin,sizeof(sin)) < 0) fail("client_v6","connect()"); @@ -330,7 +284,7 @@ namespace { int n = read(sock,buffer,1024); if (n == 4 && strncmp(buffer,"QUIT",4) == 0) break; - write(sock,buffer,n); + senf::IGNORE( write(sock,buffer,n) ); } if (shutdown(sock, SHUT_RDWR) < 0) fail("client_v6","shutdown()"); @@ -339,12 +293,12 @@ namespace { } -BOOST_AUTO_UNIT_TEST(tcpv4ServerSocketHandle) +SENF_AUTO_UNIT_TEST(tcpv4ServerSocketHandle) { try { alarm(10); BOOST_CHECKPOINT("Opening server socket"); - senf::TCPv4ServerSocketHandle server (senf::INet4SocketAddress("127.0.0.1:12346")); + senf::TCPv4ServerSocketHandle server (senf::INet4SocketAddress(localhost4str(2))); BOOST_CHECKPOINT("Starting client"); start(client_v4); @@ -365,12 +319,12 @@ BOOST_AUTO_UNIT_TEST(tcpv4ServerSocketHandle) } } -BOOST_AUTO_UNIT_TEST(tcpv6ServerSocketHandle) +SENF_AUTO_UNIT_TEST(tcpv6ServerSocketHandle) { try { alarm(10); BOOST_CHECKPOINT("Opening server socket"); - senf::TCPv6ServerSocketHandle server (senf::INet6SocketAddress("[::1]:12347")); + senf::TCPv6ServerSocketHandle server (senf::INet6SocketAddress(localhost6str(3))); BOOST_CHECKPOINT("Starting client"); start(client_v6);