]> granicus.if.org Git - curl/commitdiff
ares: return error at once if timed out before name resolve starts
authorDaniel Stenberg <daniel@haxx.se>
Mon, 6 Mar 2017 08:21:01 +0000 (09:21 +0100)
committerDaniel Stenberg <daniel@haxx.se>
Mon, 6 Mar 2017 08:21:01 +0000 (09:21 +0100)
Pointed-out-by: Ray Satiro
Bug: https://curl.haxx.se/mail/lib-2017-03/0004.html

lib/asyn-ares.c

index c038c2a3f157b6a7b7d203c2e5cc6eebe7ec83c5..ae73d05024d869209f299cdac68c0ec5ec6b8d33 100644 (file)
@@ -5,7 +5,7 @@
  *                            | (__| |_| |  _ <| |___
  *                             \___|\___/|_| \_\_____|
  *
- * Copyright (C) 1998 - 2016, Daniel Stenberg, <daniel@haxx.se>, et al.
+ * Copyright (C) 1998 - 2017, Daniel Stenberg, <daniel@haxx.se>, et al.
  *
  * This software is licensed as described in the file COPYING, which
  * you should have received as part of this distribution. The terms
@@ -359,6 +359,11 @@ CURLcode Curl_resolver_wait_resolv(struct connectdata *conn,
   struct Curl_dns_entry *temp_entry;
 
   timeout = Curl_timeleft(data, &now, TRUE);
+  if(timeout < 0) {
+    /* already expired! */
+    connclose(conn, "Timed out before name resolve started");
+    return CURLE_OPERATION_TIMEDOUT;
+  }
   if(!timeout)
     timeout = CURL_TIMEOUT_RESOLVE * 1000; /* default name resolve timeout */