Blob Blame History Raw
 CHANGES                |    3 +++
 tests/libtest/lib575.c |   10 +++-------
 2 files changed, 6 insertions(+), 7 deletions(-)

diff --git a/CHANGES b/CHANGES
index b432038..9efe768 100644
--- a/CHANGES
+++ b/CHANGES
@@ -59,6 +59,9 @@ Kamil Dudka (28 Jun 2010)
   initialized as soon as any SSL or NTLM is required, while the PEM module
   is prevented from being loaded until the SSL is actually required.
 
+Kamil Dudka (17 June 2010)
+- Improve test575 in order to not fail with threaded DNS resolver.
+
 Version 7.21.0 (16 June 2010)
 
 Daniel Stenberg (5 June 2010)
diff --git a/tests/libtest/lib575.c b/tests/libtest/lib575.c
index 49a379e..521720e 100644
--- a/tests/libtest/lib575.c
+++ b/tests/libtest/lib575.c
@@ -71,7 +71,7 @@ int test(char *URL)
         curl_multi_perform(mhandle, &still_running));
 
   while(still_running) {
-    struct timeval timeout;
+    static struct timeval timeout = /* 100 ms */ { 0, 100000L };
     int rc;
     fd_set fdread;
     fd_set fdwrite;
@@ -80,23 +80,19 @@ int test(char *URL)
     FD_ZERO(&fdread);
     FD_ZERO(&fdwrite);
     FD_ZERO(&fdexcep);
-    timeout.tv_sec = 3;
-    timeout.tv_usec = 0;
 
     m = curl_multi_fdset(mhandle, &fdread, &fdwrite, &fdexcep, &max_fdset);
     if(m != CURLM_OK) {
       fprintf(stderr, "curl_multi_fdset() error\n");
       goto test_cleanup;
     }
+    /* We call select(max_fdset + 1, ...), specially in case of (maxfd == -1),
+     * we call select(0, ...), which is basically equal to sleep. */
     rc = select(max_fdset + 1, &fdread, &fdwrite, &fdexcep, &timeout);
     if(rc == -1) {
       fprintf(stderr, "select() error\n");
       goto test_cleanup;
     }
-    else if(rc == 0) {
-      fprintf(stderr, "select() timeout!\n");
-      goto test_cleanup;
-    }
     else {
       while(CURLM_CALL_MULTI_PERFORM ==
           curl_multi_perform(mhandle, &still_running));