From: Lennart Poettering Date: Mon, 27 Nov 2017 15:29:41 +0000 (+0100) Subject: test-resolve: make sure we don't hang forever X-Git-Tag: v236~104^2 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=5bf5510b8f1637c64638000f09ca9b5123046d26;p=platform%2Fupstream%2Fsystemd.git test-resolve: make sure we don't hang forever If test-resolve is running in some CI environment that doesn't have reliably working DNS, it's a good idea not to hang forever, let's time-out after 20s --- diff --git a/src/libsystemd/sd-resolve/test-resolve.c b/src/libsystemd/sd-resolve/test-resolve.c index 93083f8..752eb15 100644 --- a/src/libsystemd/sd-resolve/test-resolve.c +++ b/src/libsystemd/sd-resolve/test-resolve.c @@ -34,6 +34,8 @@ #include "socket-util.h" #include "string-util.h" +#define TEST_TIMEOUT_USEC (20*USEC_PER_SEC) + static int getaddrinfo_handler(sd_resolve_query *q, int ret, const struct addrinfo *ai, void *userdata) { const struct addrinfo *i; @@ -102,9 +104,18 @@ int main(int argc, char *argv[]) { /* Wait until all queries are completed */ for (;;) { - r = sd_resolve_wait(resolve, (uint64_t) -1); + r = sd_resolve_wait(resolve, TEST_TIMEOUT_USEC); if (r == 0) break; + if (r == -ETIMEDOUT) { + /* Let's catch time-outs here, so that we can run safely in a CI that has no reliable DNS. Note + * that we invoke exit() directly here, as the stuck NSS call will not allow us to exit + * cleanly. */ + + log_notice_errno(r, "sd_resolve_wait() timed out, but that's OK"); + exit(EXIT_SUCCESS); + break; + } if (r < 0) { log_error_errno(r, "sd_resolve_wait(): %m"); assert_not_reached("sd_resolve_wait() failed");