diff options
author | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2017-09-10 17:41:03 +0200 |
---|---|---|
committer | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2017-09-25 01:11:43 +0200 |
commit | 6174537c24cfe324d6e8f5a2a421883df12b8b6a (patch) | |
tree | 59fac1472c1608c97e3b1fefea6a5eb019d0f0f4 /support/resolv_test.c | |
parent | b38a42a098664a96842a23ef480d4b8c69ecd05c (diff) | |
download | glibc-6174537c24cfe324d6e8f5a2a421883df12b8b6a.tar.gz |
resolv_test.c: also cope with CONNREFUSED errors returned by recvfrom
server_thread_udp_process_one already takes care of calling sendto()
instead of xsendto to be able to ignore the case where the client has
closed the socket. Depending on the TCP/IP stack behavior, this error
could be notified later through recvfrom(), so we need to ignore it
there too.
* support/resolv_test.c (server_thread_udp_process_one): Call recvfrom
instead of xrecvfrom, and ignore ECONNREFUSED errors.
Diffstat (limited to 'support/resolv_test.c')
-rw-r--r-- | support/resolv_test.c | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/support/resolv_test.c b/support/resolv_test.c index 1625dcf43a..c3325b89b1 100644 --- a/support/resolv_test.c +++ b/support/resolv_test.c @@ -600,7 +600,7 @@ server_thread_udp_process_one (struct resolv_test *obj, int server_index) unsigned char query[512]; struct sockaddr_storage peer; socklen_t peerlen = sizeof (peer); - size_t length = xrecvfrom (obj->servers[server_index].socket_udp, + ssize_t length = recvfrom (obj->servers[server_index].socket_udp, query, sizeof (query), 0, (struct sockaddr *) &peer, &peerlen); /* Check for termination. */ @@ -613,6 +613,12 @@ server_thread_udp_process_one (struct resolv_test *obj, int server_index) return false; } + if (length < 0) + { + /* The other end had closed the socket, and we are notified only now. */ + TEST_VERIFY_EXIT (errno == ECONNREFUSED); + return true; + } struct query_info qinfo; parse_query (&qinfo, query, length); |