Annotation of embedaddon/curl/tests/libtest/lib1515.c, revision 1.1.1.1

1.1       misho       1: /***************************************************************************
                      2:  *                                  _   _ ____  _
                      3:  *  Project                     ___| | | |  _ \| |
                      4:  *                             / __| | | | |_) | |
                      5:  *                            | (__| |_| |  _ <| |___
                      6:  *                             \___|\___/|_| \_\_____|
                      7:  *
                      8:  * Copyright (C) 1998 - 2020, Daniel Stenberg, <daniel@haxx.se>, et al.
                      9:  *
                     10:  * This software is licensed as described in the file COPYING, which
                     11:  * you should have received as part of this distribution. The terms
                     12:  * are also available at https://curl.haxx.se/docs/copyright.html.
                     13:  *
                     14:  * You may opt to use, copy, modify, merge, publish, distribute and/or sell
                     15:  * copies of the Software, and permit persons to whom the Software is
                     16:  * furnished to do so, under the terms of the COPYING file.
                     17:  *
                     18:  * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
                     19:  * KIND, either express or implied.
                     20:  *
                     21:  ***************************************************************************/
                     22: 
                     23: /*
                     24:  * Check for bugs #1303 and #1327: libcurl should never remove DNS entries
                     25:  * created via CURLOPT_RESOLVE, neither after DNS_CACHE_TIMEOUT elapses
                     26:  * (test1515) nor a dead connection is detected (test1616).
                     27:  */
                     28: 
                     29: #include "test.h"
                     30: #include "testutil.h"
                     31: #include "warnless.h"
                     32: #include "memdebug.h"
                     33: 
                     34: #define TEST_HANG_TIMEOUT 60 * 1000
                     35: 
                     36: #define DNS_TIMEOUT 1
                     37: 
                     38: #if defined(WIN32) || defined(_WIN32)
                     39: #define sleep(sec) Sleep ((sec)*1000)
                     40: #endif
                     41: 
                     42: static int debug_callback(CURL *curl, curl_infotype info, char *msg,
                     43:                           size_t len, void *ptr)
                     44: {
                     45:   (void)curl;
                     46:   (void)ptr;
                     47: 
                     48:   if(info == CURLINFO_TEXT)
                     49:     fprintf(stderr, "debug: %.*s", (int) len, msg);
                     50: 
                     51:   return 0;
                     52: }
                     53: 
                     54: static int do_one_request(CURLM *m, char *URL, char *resolve)
                     55: {
                     56:   CURL *curls;
                     57:   struct curl_slist *resolve_list = NULL;
                     58:   int still_running;
                     59:   int res = 0;
                     60:   CURLMsg *msg;
                     61:   int msgs_left;
                     62: 
                     63:   resolve_list = curl_slist_append(resolve_list, resolve);
                     64: 
                     65:   easy_init(curls);
                     66: 
                     67:   easy_setopt(curls, CURLOPT_URL, URL);
                     68:   easy_setopt(curls, CURLOPT_RESOLVE, resolve_list);
                     69:   easy_setopt(curls, CURLOPT_DEBUGFUNCTION, debug_callback);
                     70:   easy_setopt(curls, CURLOPT_VERBOSE, 1);
                     71:   easy_setopt(curls, CURLOPT_DNS_CACHE_TIMEOUT, DNS_TIMEOUT);
                     72: 
                     73:   multi_add_handle(m, curls);
                     74:   multi_perform(m, &still_running);
                     75: 
                     76:   abort_on_test_timeout();
                     77: 
                     78:   while(still_running) {
                     79:     struct timeval timeout;
                     80:     fd_set fdread, fdwrite, fdexcep;
                     81:     int maxfd = -99;
                     82: 
                     83:     FD_ZERO(&fdread);
                     84:     FD_ZERO(&fdwrite);
                     85:     FD_ZERO(&fdexcep);
                     86:     timeout.tv_sec = 1;
                     87:     timeout.tv_usec = 0;
                     88: 
                     89:     multi_fdset(m, &fdread, &fdwrite, &fdexcep, &maxfd);
                     90:     select_test(maxfd + 1, &fdread, &fdwrite, &fdexcep, &timeout);
                     91: 
                     92:     abort_on_test_timeout();
                     93:     multi_perform(m, &still_running);
                     94: 
                     95:     abort_on_test_timeout();
                     96:   }
                     97: 
                     98:   do {
                     99:     msg = curl_multi_info_read(m, &msgs_left);
                    100:     if(msg && msg->msg == CURLMSG_DONE && msg->easy_handle == curls) {
                    101:       res = msg->data.result;
                    102:       break;
                    103:     }
                    104:   } while(msg);
                    105: 
                    106: test_cleanup:
                    107: 
                    108:   curl_multi_remove_handle(m, curls);
                    109:   curl_easy_cleanup(curls);
                    110:   curl_slist_free_all(resolve_list);
                    111: 
                    112:   return res;
                    113: }
                    114: 
                    115: int test(char *URL)
                    116: {
                    117:   CURLM *multi = NULL;
                    118:   int res = 0;
                    119:   char *address = libtest_arg2;
                    120:   char *port = libtest_arg3;
                    121:   char *path = URL;
                    122:   char dns_entry[256];
                    123:   int i;
                    124:   int count = 2;
                    125: 
                    126:   msnprintf(dns_entry, sizeof(dns_entry), "testserver.example.com:%s:%s",
                    127:             port, address);
                    128: 
                    129:   start_test_timing();
                    130: 
                    131:   global_init(CURL_GLOBAL_ALL);
                    132:   multi_init(multi);
                    133: 
                    134:   for(i = 1; i <= count; i++) {
                    135:     char target_url[256];
                    136:     msnprintf(target_url, sizeof(target_url),
                    137:               "http://testserver.example.com:%s/%s%04d", port, path, i);
                    138: 
                    139:     /* second request must succeed like the first one */
                    140:     res = do_one_request(multi, target_url, dns_entry);
                    141:     if(res)
                    142:       goto test_cleanup;
                    143: 
                    144:     if(i < count)
                    145:       sleep(DNS_TIMEOUT + 1);
                    146:   }
                    147: 
                    148: test_cleanup:
                    149: 
                    150:   curl_multi_cleanup(multi);
                    151:   curl_global_cleanup();
                    152: 
                    153:   return (int) res;
                    154: }

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>