diff options
| author | Andreas Schneider <asn@samba.org> | 2013-12-23 10:59:59 +0100 |
|---|---|---|
| committer | Andreas Schneider <asn@samba.org> | 2013-12-23 10:59:59 +0100 |
| commit | 6876e0ca0906c6438bd2eb6d6b64e28372359e40 (patch) | |
| tree | d6830a462bc15c8561325b207a0d88917ef0b913 /tests | |
| parent | 8c561dd419a414cd50d4a63fa988fd1162042e47 (diff) | |
| download | socket_wrapper-6876e0ca0906c6438bd2eb6d6b64e28372359e40.tar.gz socket_wrapper-6876e0ca0906c6438bd2eb6d6b64e28372359e40.tar.xz socket_wrapper-6876e0ca0906c6438bd2eb6d6b64e28372359e40.zip | |
tests: Add test_echo_tcp_connect test.
This tests some corner cases we fixed in the past.
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/CMakeLists.txt | 8 | ||||
| -rw-r--r-- | tests/test_echo_tcp_connect.c | 95 |
2 files changed, 102 insertions, 1 deletions
diff --git a/tests/CMakeLists.txt b/tests/CMakeLists.txt index 23f362d..71acff5 100644 --- a/tests/CMakeLists.txt +++ b/tests/CMakeLists.txt @@ -17,7 +17,13 @@ target_link_libraries(${TORTURE_LIBRARY} ${CMOCKA_LIBRARY} ${SWRAP_REQUIRED_LIBRARIES}) -set(SWRAP_TESTS test_ioctl test_echo_udp_sendto_recvfrom test_echo_udp_send_recv test_echo_tcp_write_read test_echo_tcp_writev_readv) +set(SWRAP_TESTS + test_ioctl + test_echo_tcp_connect + test_echo_tcp_write_read + test_echo_tcp_writev_readv + test_echo_udp_sendto_recvfrom + test_echo_udp_send_recv) foreach(_SWRAP_TEST ${SWRAP_TESTS}) add_cmocka_test(${_SWRAP_TEST} ${_SWRAP_TEST}.c ${TORTURE_LIBRARY}) diff --git a/tests/test_echo_tcp_connect.c b/tests/test_echo_tcp_connect.c new file mode 100644 index 0000000..b20e453 --- /dev/null +++ b/tests/test_echo_tcp_connect.c @@ -0,0 +1,95 @@ +#include <stdarg.h> +#include <stddef.h> +#include <setjmp.h> +#include <cmocka.h> + +#include "config.h" +#include "torture.h" + +#include <errno.h> +#include <sys/types.h> +#include <sys/socket.h> +#include <netinet/in.h> +#include <arpa/inet.h> +#include <stdlib.h> +#include <stdio.h> +#include <unistd.h> + +static void setup_echo_srv_tcp_ipv4(void **state) +{ + torture_setup_echo_srv_tcp_ipv4(state); +} + +static void teardown(void **state) +{ + torture_teardown_echo_srv(state); +} + +static void test_connect_broadcast_ipv4(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); + sin.sin_family = AF_INET; + sin.sin_port = htons(torture_server_port()); + sin.sin_addr.s_addr = INADDR_BROADCAST; + + /* We don't allow connect to broadcast addresses */ + rc = connect(s, (struct sockaddr *)&sin, slen); + assert_int_equal(rc, -1); + + close(s); +} + +#ifdef HAVE_IPV6 +static void test_connect_downgrade_ipv6(void **state) +{ + struct sockaddr_in sin; + socklen_t slen = sizeof(struct sockaddr_in); + int rc; + int s; + + (void) state; /* unused */ + + s = socket(AF_INET6, SOCK_STREAM, IPPROTO_TCP); + assert_int_not_equal(s, -1); + + ZERO_STRUCT(sin); + sin.sin_family = AF_INET; + sin.sin_port = htons(torture_server_port()); + + rc = inet_pton(sin.sin_family, + torture_server_address(AF_INET), + &sin.sin_addr); + assert_int_equal(rc, 1); + + /* Connect should downgrade to IPv4 and allow the connect */ + rc = connect(s, (struct sockaddr *)&sin, slen); + assert_int_equal(rc, 0); + + close(s); +} +#endif + +int main(void) { + int rc; + + const UnitTest tests[] = { + unit_test_setup_teardown(test_connect_broadcast_ipv4, setup_echo_srv_tcp_ipv4, teardown), +#ifdef HAVE_IPV6 + unit_test_setup_teardown(test_connect_downgrade_ipv6, setup_echo_srv_tcp_ipv4, teardown), +#endif + }; + + rc = run_tests(tests); + + return rc; +} |
