diff options
| author | Daniel Stenberg <daniel@haxx.se> | 2008-11-11 21:59:25 +0000 | 
|---|---|---|
| committer | Daniel Stenberg <daniel@haxx.se> | 2008-11-11 21:59:25 +0000 | 
| commit | d07d1a6ef85d6e42d3e376935cdede698c968556 (patch) | |
| tree | 4856cc9450f40a1863ff23462711a043e6391f19 /tests/libtest/lib560.c | |
| parent | 8bdd60fa71c369ea45b9a5d173d0de23a576ac68 (diff) | |
Added test case 560:
This test was added after the HTTPS-using-multi-interface with OpenSSL
regression of 7.19.1 to hopefully prevent this embarassing mistake from
appearing again... Unfortunately the bug wasn't triggered by this test, which
presumably is because the connect to a local server is too fast/different
compared to the real/distant servers we saw the bug happen with.
Diffstat (limited to 'tests/libtest/lib560.c')
| -rw-r--r-- | tests/libtest/lib560.c | 92 | 
1 files changed, 92 insertions, 0 deletions
| diff --git a/tests/libtest/lib560.c b/tests/libtest/lib560.c new file mode 100644 index 000000000..e9d51c4d1 --- /dev/null +++ b/tests/libtest/lib560.c @@ -0,0 +1,92 @@ +/***************************************************************************** + *                                  _   _ ____  _ + *  Project                     ___| | | |  _ \| | + *                             / __| | | | |_) | | + *                            | (__| |_| |  _ <| |___ + *                             \___|\___/|_| \_\_____| + * + * $Id$ + * + */ +#include "test.h" + +/* + * Simply download a HTTPS file! + * + * This test was added after the HTTPS-using-multi-interface with OpenSSL + * regression of 7.19.1 to hopefully prevent this embarassing mistake from + * appearing again... Unfortunately the bug wasn't triggered by this test, + * which presumably is because the connect to a local server is too + * fast/different compared to the real/distant servers we saw the bug happen + * with. + */ +int test(char *URL) +{ +  CURL *http_handle; +  CURLM *multi_handle; + +  int still_running; /* keep number of running handles */ + +  http_handle = curl_easy_init(); + +  /* set options */ +  curl_easy_setopt(http_handle, CURLOPT_URL, URL); +  curl_easy_setopt(http_handle, CURLOPT_HEADER, 1L); +  curl_easy_setopt(http_handle, CURLOPT_SSL_VERIFYPEER, 0L); +  curl_easy_setopt(http_handle, CURLOPT_SSL_VERIFYHOST, 0L); + +  /* init a multi stack */ +  multi_handle = curl_multi_init(); + +  /* add the individual transfers */ +  curl_multi_add_handle(multi_handle, http_handle); + +  /* we start some action by calling perform right away */ +  while(CURLM_CALL_MULTI_PERFORM == +        curl_multi_perform(multi_handle, &still_running)); + +  while(still_running) { +    struct timeval timeout; +    int rc; /* select() return code */ + +    fd_set fdread; +    fd_set fdwrite; +    fd_set fdexcep; +    int maxfd; + +    FD_ZERO(&fdread); +    FD_ZERO(&fdwrite); +    FD_ZERO(&fdexcep); + +    /* set a suitable timeout to play around with */ +    timeout.tv_sec = 1; +    timeout.tv_usec = 0; + +    /* get file descriptors from the transfers */ +    curl_multi_fdset(multi_handle, &fdread, &fdwrite, &fdexcep, &maxfd); + +    /* In a real-world program you OF COURSE check the return code of the +       function calls, *and* you make sure that maxfd is bigger than -1 so +       that the call to select() below makes sense! */ + +    rc = select(maxfd+1, &fdread, &fdwrite, &fdexcep, &timeout); + +    switch(rc) { +    case -1: +      /* select error */ +      break; +    case 0: +    default: +      /* timeout or readable/writable sockets */ +      while(CURLM_CALL_MULTI_PERFORM == +            curl_multi_perform(multi_handle, &still_running)); +      break; +    } +  } + +  curl_multi_cleanup(multi_handle); + +  curl_easy_cleanup(http_handle); + +  return 0; +} | 
