diff options
author | Nick Mathewson <nickm@torproject.org> | 2016-09-11 17:28:29 -0400 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2016-09-11 17:28:29 -0400 |
commit | c6e70dacb8e53f28b7e926de81edaf4b25b48848 (patch) | |
tree | 1163d7ad627988d43513bfa3ba80b73b17ea71b1 /src/test/test_util.c | |
parent | a671a1c9d632242662bf9fd8b37b63ccefd8a3bf (diff) | |
download | tor-c6e70dacb8e53f28b7e926de81edaf4b25b48848.tar.gz tor-c6e70dacb8e53f28b7e926de81edaf4b25b48848.zip |
Try to make our ersatz-socketpair test work better on FreeBSD jails
Diffstat (limited to 'src/test/test_util.c')
-rw-r--r-- | src/test/test_util.c | 42 |
1 files changed, 40 insertions, 2 deletions
diff --git a/src/test/test_util.c b/src/test/test_util.c index 38f23027c0..cb523cf350 100644 --- a/src/test/test_util.c +++ b/src/test/test_util.c @@ -5090,6 +5090,44 @@ test_util_socket(void *arg) tor_close_socket(fd4); } +static int +is_there_a_localhost(void) +{ + tor_socket_t s; + s = tor_open_socket(AF_INET, SOCK_STREAM, IPPROTO_TCP); + tor_assert(SOCKET_OK(s)); + + struct sockaddr_in sin; + memset(&sin, 0, sizeof(sin)); + sin.sin_family = AF_INET; + sin.sin_addr.s_addr = htonl(0x7f000001); + sin.sin_port = 0; + + int result = 0; + if (bind(s, (void*)&sin, sizeof(sin)) == 0) { + result = 1; + } + tor_close_socket(s); + if (result) + return result; + + s = tor_open_socket(AF_INET, SOCK_STREAM, IPPROTO_TCP); + tor_assert(SOCKET_OK(s)); + + struct sockaddr_in6 sin6; + memset(&sin6, 0, sizeof(sin6)); + sin6.sin6_family = AF_INET6; + sin6.sin6_addr.s6_addr[15] = 1; + sin6.sin6_port = 0; + + if (bind(s, (void*)&sin6, sizeof(sin6)) == 0) { + result = 1; + } + tor_close_socket(s); + + return result; +} + /* Test for socketpair and ersatz_socketpair(). We test them both, since * the latter is a tolerably good way to exersize tor_accept_socket(). */ static void @@ -5108,10 +5146,10 @@ test_util_socketpair(void *arg) * Otherwise, we risk exposing a socketpair on a routable IP address. (Some * BSD jails use a routable address for localhost. Fortunately, they have * the real AF_UNIX socketpair.) */ - if (ersatz && ERRNO_IS_EPROTO(-socketpair_result)) { + if (ersatz && socketpair_result < 0 && !is_there_a_localhost()) { /* In my testing, an IPv6-only FreeBSD jail without ::1 returned EINVAL. * Assume we're on a machine without 127.0.0.1 or ::1 and give up now. */ - goto done; + tt_skip(); } tt_int_op(0, OP_EQ, socketpair_result); |