From 37b472d7972f0d18bd343137d4991f5e091a2ed7 Mon Sep 17 00:00:00 2001 From: Andreas Schneider Date: Tue, 27 May 2014 20:53:51 +0200 Subject: tests: Add test that getsockname is correct after socket(). Signed-off-by: Andreas Schneider Reviewed-by: Michael Adam --- tests/CMakeLists.txt | 1 + tests/test_echo_tcp_socket.c | 69 ++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 70 insertions(+) create mode 100644 tests/test_echo_tcp_socket.c diff --git a/tests/CMakeLists.txt b/tests/CMakeLists.txt index 287539b..6a5f978 100644 --- a/tests/CMakeLists.txt +++ b/tests/CMakeLists.txt @@ -20,6 +20,7 @@ target_link_libraries(${TORTURE_LIBRARY} set(SWRAP_TESTS test_ioctl + test_echo_tcp_socket test_echo_tcp_connect test_echo_tcp_socket_options test_echo_tcp_write_read diff --git a/tests/test_echo_tcp_socket.c b/tests/test_echo_tcp_socket.c new file mode 100644 index 0000000..04f15aa --- /dev/null +++ b/tests/test_echo_tcp_socket.c @@ -0,0 +1,69 @@ +#include +#include +#include +#include + +#include "config.h" +#include "torture.h" + +#include +#include +#include +#include +#include +#include +#include +#include + +static void test_socket_getsockname(void **state) +{ + struct sockaddr_in sin; + socklen_t slen = sizeof(struct sockaddr_in); + int rc; + int s; + + (void) state; /* unused */ + + s = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP); + assert_int_not_equal(s, -1); + + ZERO_STRUCT(sin); + rc = getsockname(s, (struct sockaddr *)&sin, &slen); + assert_return_code(rc, errno); + assert_int_equal(sin.sin_family, AF_INET); +} + +#ifdef HAVE_IPV6 +static void test_socket_getsockname6(void **state) +{ + struct sockaddr_in6 sin6; + socklen_t slen = sizeof(struct sockaddr_in6); + int rc; + int s; + + (void) state; /* unused */ + + s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP); + assert_int_not_equal(s, -1); + + ZERO_STRUCT(sin6); + rc = getsockname(s, (struct sockaddr *)&sin6, &slen); + assert_return_code(rc, errno); + assert_int_equal(sin6.sin6_family, AF_INET6); +} +#endif + +int main(void) { + int rc; + + const UnitTest tests[] = { + unit_test(test_socket_getsockname), +#ifdef HAVE_IPV6 + unit_test(test_socket_getsockname6), +#endif + }; + + rc = run_tests(tests); + + return rc; +} -- cgit