tests: add test for bug #1303 (dns cache timeout)
Test-case 1515 reproduces bug #1303, where libcurl would incorrectly prune DNS entries added via CURLOPT_RESOLVE after the DNS_CACHE_TIMEOUT had expired.
This commit is contained in:
		 Romulo A. Ceccon
					Romulo A. Ceccon
				
			
				
					committed by
					
						 Daniel Stenberg
						Daniel Stenberg
					
				
			
			
				
	
			
			
			 Daniel Stenberg
						Daniel Stenberg
					
				
			
						parent
						
							b93755df37
						
					
				
				
					commit
					1505e4612b
				
			| @@ -123,7 +123,7 @@ test1408 test1409 test1410          test1412 test1413 test1414 test1415 \ | |||||||
| test1416 test1417 \ | test1416 test1417 \ | ||||||
| \ | \ | ||||||
| test1500 test1501 test1502 test1503 test1504 test1505 test1506 test1507 \ | test1500 test1501 test1502 test1503 test1504 test1505 test1506 test1507 \ | ||||||
| test1508 test1509 test1510 test1511 test1512 test1513 test1514 \ | test1508 test1509 test1510 test1511 test1512 test1513 test1514 test1515 \ | ||||||
| \ | \ | ||||||
| test1900 test1901 test1902 test1903 \ | test1900 test1901 test1902 test1903 \ | ||||||
| \ | \ | ||||||
|   | |||||||
							
								
								
									
										58
									
								
								tests/data/test1515
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								tests/data/test1515
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,58 @@ | |||||||
|  | <testcase> | ||||||
|  |  | ||||||
|  | <info> | ||||||
|  | <keywords> | ||||||
|  | HTTP | ||||||
|  | multi | ||||||
|  | FAILURE | ||||||
|  | resolve | ||||||
|  | </keywords> | ||||||
|  | </info> | ||||||
|  |  | ||||||
|  | <reply> | ||||||
|  | # Close the connection after the first request. Second request will happen after | ||||||
|  | # the DNS cache timeout elapses and must succeed exactly like the first one. | ||||||
|  | <data1> | ||||||
|  | HTTP/1.1 200 OK | ||||||
|  | Date: Thu, 03 Feb 2014 17:04:00 GMT | ||||||
|  | Server: test-server/fake swsclose | ||||||
|  | Connection: close | ||||||
|  | Content-Type: text/html | ||||||
|  | Content-Length: 6 | ||||||
|  |  | ||||||
|  | hello | ||||||
|  | </data1> | ||||||
|  | <data2> | ||||||
|  | HTTP/1.1 200 OK | ||||||
|  | Date: Thu, 03 Feb 2014 17:04:02 GMT | ||||||
|  | Server: test-server/fake swsclose | ||||||
|  | Connection: close | ||||||
|  | Content-Type: text/html | ||||||
|  | Content-Length: 6 | ||||||
|  |  | ||||||
|  | hello | ||||||
|  | </data2> | ||||||
|  | </reply> | ||||||
|  |  | ||||||
|  | <client> | ||||||
|  | <server> | ||||||
|  | http | ||||||
|  | </server> | ||||||
|  | <tool> | ||||||
|  | lib1515 | ||||||
|  | </tool> | ||||||
|  | <name> | ||||||
|  | caching of manual libcurl DNS entries after DNS cache timeout | ||||||
|  | </name> | ||||||
|  | <command> | ||||||
|  | /path/1515 %HOSTIP %HTTPPORT | ||||||
|  | </command> | ||||||
|  | </client> | ||||||
|  |  | ||||||
|  | <verify> | ||||||
|  | <errorcode> | ||||||
|  | 0 | ||||||
|  | </errorcode> | ||||||
|  | </verify> | ||||||
|  |  | ||||||
|  | </testcase> | ||||||
| @@ -21,7 +21,7 @@ noinst_PROGRAMS = chkhostname libauthretry libntlmconnect                \ | |||||||
|  lib571 lib572 lib573 lib574 lib575 lib576        lib578 lib579 lib582   \ |  lib571 lib572 lib573 lib574 lib575 lib576        lib578 lib579 lib582   \ | ||||||
|  lib583 lib585 lib586 lib587        lib590 lib591 lib597 lib598 lib599   \ |  lib583 lib585 lib586 lib587        lib590 lib591 lib597 lib598 lib599   \ | ||||||
|  lib1500 lib1501 lib1502 lib1503 lib1504 lib1505 lib1506 lib1507 lib1508 \ |  lib1500 lib1501 lib1502 lib1503 lib1504 lib1505 lib1506 lib1507 lib1508 \ | ||||||
|  lib1509 lib1510 lib1511 lib1512 lib1513 lib1514 \ |  lib1509 lib1510 lib1511 lib1512 lib1513 lib1514 lib1515 \ | ||||||
|  lib1900 \ |  lib1900 \ | ||||||
|  lib2033 |  lib2033 | ||||||
|  |  | ||||||
| @@ -351,6 +351,10 @@ lib1514_SOURCES = lib1514.c $(SUPPORTFILES) $(TESTUTIL) $(WARNLESS) | |||||||
| lib1514_LDADD = $(TESTUTIL_LIBS) | lib1514_LDADD = $(TESTUTIL_LIBS) | ||||||
| lib1514_CPPFLAGS = $(AM_CPPFLAGS) -DLIB1514 | lib1514_CPPFLAGS = $(AM_CPPFLAGS) -DLIB1514 | ||||||
|  |  | ||||||
|  | lib1515_SOURCES = lib1515.c $(SUPPORTFILES) $(TESTUTIL) $(WARNLESS) | ||||||
|  | lib1515_LDADD = $(TESTUTIL_LIBS) | ||||||
|  | lib1515_CPPFLAGS = $(AM_CPPFLAGS) | ||||||
|  |  | ||||||
| lib1900_SOURCES = lib1900.c $(SUPPORTFILES) $(TESTUTIL) $(WARNLESS) | lib1900_SOURCES = lib1900.c $(SUPPORTFILES) $(TESTUTIL) $(WARNLESS) | ||||||
| lib1900_LDADD = $(TESTUTIL_LIBS) | lib1900_LDADD = $(TESTUTIL_LIBS) | ||||||
| lib1900_CPPFLAGS = $(AM_CPPFLAGS) | lib1900_CPPFLAGS = $(AM_CPPFLAGS) | ||||||
|   | |||||||
							
								
								
									
										141
									
								
								tests/libtest/lib1515.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										141
									
								
								tests/libtest/lib1515.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,141 @@ | |||||||
|  | /*************************************************************************** | ||||||
|  |  *                                  _   _ ____  _ | ||||||
|  |  *  Project                     ___| | | |  _ \| | | ||||||
|  |  *                             / __| | | | |_) | | | ||||||
|  |  *                            | (__| |_| |  _ <| |___ | ||||||
|  |  *                             \___|\___/|_| \_\_____| | ||||||
|  |  * | ||||||
|  |  * Copyright (C) 1998 - 2011, 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 | ||||||
|  |  * are also available at http://curl.haxx.se/docs/copyright.html. | ||||||
|  |  * | ||||||
|  |  * You may opt to use, copy, modify, merge, publish, distribute and/or sell | ||||||
|  |  * copies of the Software, and permit persons to whom the Software is | ||||||
|  |  * furnished to do so, under the terms of the COPYING file. | ||||||
|  |  * | ||||||
|  |  * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY | ||||||
|  |  * KIND, either express or implied. | ||||||
|  |  * | ||||||
|  |  ***************************************************************************/ | ||||||
|  |   | ||||||
|  | /* | ||||||
|  |  * Check for bugs #1303 and #1327: libcurl should never remove DNS entries | ||||||
|  |  * created via CURLOPT_RESOLVE, neither after DNS_CACHE_TIMEOUT elapses | ||||||
|  |  * (test1515) nor a dead connection is detected (test1616). | ||||||
|  |  */ | ||||||
|  |   | ||||||
|  | #include "test.h" | ||||||
|  | #include "testutil.h" | ||||||
|  | #include "warnless.h" | ||||||
|  | #include "memdebug.h" | ||||||
|  |  | ||||||
|  | #define TEST_HANG_TIMEOUT 60 * 1000 | ||||||
|  |  | ||||||
|  | #define DNS_TIMEOUT 1 | ||||||
|  |  | ||||||
|  | int debug_callback(CURL *curl, curl_infotype info, char *msg, size_t len, void *ptr) | ||||||
|  | { | ||||||
|  |   if (info == CURLINFO_TEXT) | ||||||
|  |     fprintf(stderr, "debug: %.*s", (int) len, msg); | ||||||
|  |  | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | int do_one_request(CURLM *m, char *URL, char *resolve) | ||||||
|  | { | ||||||
|  |   CURL *curls; | ||||||
|  |   struct curl_slist *resolve_list = NULL; | ||||||
|  |   int still_running; | ||||||
|  |   int res = 0; | ||||||
|  |   CURLMsg *msg; | ||||||
|  |   int msgs_left; | ||||||
|  |    | ||||||
|  |   resolve_list = curl_slist_append(resolve_list, resolve); | ||||||
|  |    | ||||||
|  |   easy_init(curls); | ||||||
|  |    | ||||||
|  |   easy_setopt(curls, CURLOPT_URL, URL); | ||||||
|  |   easy_setopt(curls, CURLOPT_RESOLVE, resolve_list); | ||||||
|  |   easy_setopt(curls, CURLOPT_DEBUGFUNCTION, debug_callback); | ||||||
|  |   easy_setopt(curls, CURLOPT_VERBOSE, 1); | ||||||
|  |   easy_setopt(curls, CURLOPT_DNS_CACHE_TIMEOUT, DNS_TIMEOUT); | ||||||
|  |    | ||||||
|  |   multi_add_handle(m, curls); | ||||||
|  |   multi_perform(m, &still_running); | ||||||
|  |    | ||||||
|  |   abort_on_test_timeout(); | ||||||
|  |  | ||||||
|  |   while (still_running) | ||||||
|  |   { | ||||||
|  |     struct timeval timeout; | ||||||
|  |     fd_set fdread, fdwrite, fdexcep; | ||||||
|  |     int maxfd = -99; | ||||||
|  |  | ||||||
|  |     FD_ZERO(&fdread); | ||||||
|  |     FD_ZERO(&fdwrite); | ||||||
|  |     FD_ZERO(&fdexcep); | ||||||
|  |     timeout.tv_sec = 1; | ||||||
|  |     timeout.tv_usec = 0; | ||||||
|  |  | ||||||
|  |     multi_fdset(m, &fdread, &fdwrite, &fdexcep, &maxfd); | ||||||
|  |     select_test(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout); | ||||||
|  |  | ||||||
|  |     abort_on_test_timeout(); | ||||||
|  |     multi_perform(m, &still_running); | ||||||
|  |  | ||||||
|  |     abort_on_test_timeout(); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   while ((msg = curl_multi_info_read(m, &msgs_left))) | ||||||
|  |   { | ||||||
|  |     if (msg->msg == CURLMSG_DONE && msg->easy_handle == curls) | ||||||
|  |     { | ||||||
|  |       res = msg->data.result; | ||||||
|  |       break; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |    | ||||||
|  | test_cleanup: | ||||||
|  |   curl_multi_remove_handle(m, curls); | ||||||
|  |   curl_easy_cleanup(curls); | ||||||
|  |   curl_slist_free_all(resolve_list); | ||||||
|  |    | ||||||
|  |   return res; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | int test(char *URL) | ||||||
|  | { | ||||||
|  |   CURLM* multi = NULL; | ||||||
|  |   int res = 0; | ||||||
|  |   char *address = libtest_arg2; | ||||||
|  |   char *port = libtest_arg3; | ||||||
|  |   char *path = URL; | ||||||
|  |   char dns_entry[256]; | ||||||
|  |   int i; | ||||||
|  |   int count = 2; | ||||||
|  |  | ||||||
|  |   snprintf(dns_entry, sizeof(dns_entry), "testserver.example.com:%s:%s", port, address); | ||||||
|  |   char target_url[256]; | ||||||
|  |    | ||||||
|  |   start_test_timing(); | ||||||
|  |    | ||||||
|  |   global_init(CURL_GLOBAL_ALL); | ||||||
|  |   multi_init(multi); | ||||||
|  |    | ||||||
|  |   for (i = 1; i <= count; i++) | ||||||
|  |   { | ||||||
|  |     snprintf(target_url, sizeof(target_url), "http://testserver.example.com:%s%s%04d", port, path, i); | ||||||
|  |     /* second request must succeed like the first one */ | ||||||
|  |     if ((res = do_one_request(multi, target_url, dns_entry))) | ||||||
|  |       goto test_cleanup; | ||||||
|  |     if (i < count) | ||||||
|  |       sleep(DNS_TIMEOUT + 1); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  | test_cleanup: | ||||||
|  |   curl_multi_cleanup(multi); | ||||||
|  |  | ||||||
|  |   return (int) res; | ||||||
|  | } | ||||||
		Reference in New Issue
	
	Block a user