Return to lib1500.c CVS log | Up to [ELWIX - Embedded LightWeight unIX -] / embedaddon / curl / tests / libtest |
1.1 ! misho 1: /*************************************************************************** ! 2: * _ _ ____ _ ! 3: * Project ___| | | | _ \| | ! 4: * / __| | | | |_) | | ! 5: * | (__| |_| | _ <| |___ ! 6: * \___|\___/|_| \_\_____| ! 7: * ! 8: * Copyright (C) 1998 - 2016, 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: #include "test.h" ! 23: ! 24: #include "testutil.h" ! 25: #include "warnless.h" ! 26: #include "memdebug.h" ! 27: ! 28: #define TEST_HANG_TIMEOUT 60 * 1000 ! 29: ! 30: int test(char *URL) ! 31: { ! 32: CURL *curls = NULL; ! 33: CURLM *multi = NULL; ! 34: int still_running; ! 35: int i = TEST_ERR_FAILURE; ! 36: int res = 0; ! 37: CURLMsg *msg; ! 38: ! 39: start_test_timing(); ! 40: ! 41: global_init(CURL_GLOBAL_ALL); ! 42: ! 43: multi_init(multi); ! 44: ! 45: easy_init(curls); ! 46: ! 47: easy_setopt(curls, CURLOPT_URL, URL); ! 48: easy_setopt(curls, CURLOPT_HEADER, 1L); ! 49: ! 50: multi_add_handle(multi, curls); ! 51: ! 52: multi_perform(multi, &still_running); ! 53: ! 54: abort_on_test_timeout(); ! 55: ! 56: while(still_running) { ! 57: int num; ! 58: res = curl_multi_wait(multi, NULL, 0, TEST_HANG_TIMEOUT, &num); ! 59: if(res != CURLM_OK) { ! 60: printf("curl_multi_wait() returned %d\n", res); ! 61: res = TEST_ERR_MAJOR_BAD; ! 62: goto test_cleanup; ! 63: } ! 64: ! 65: abort_on_test_timeout(); ! 66: ! 67: multi_perform(multi, &still_running); ! 68: ! 69: abort_on_test_timeout(); ! 70: } ! 71: ! 72: msg = curl_multi_info_read(multi, &still_running); ! 73: if(msg) ! 74: /* this should now contain a result code from the easy handle, ! 75: get it */ ! 76: i = msg->data.result; ! 77: ! 78: test_cleanup: ! 79: ! 80: /* undocumented cleanup sequence - type UA */ ! 81: ! 82: curl_multi_cleanup(multi); ! 83: curl_easy_cleanup(curls); ! 84: curl_global_cleanup(); ! 85: ! 86: if(res) ! 87: i = res; ! 88: ! 89: return i; /* return the final return code */ ! 90: }