1 <testcase> 2 <info> 3 <keywords> 4 HTTP 5 HTTP GET 6 --libcurl 7 </keywords> 8 </info> 9 10 # Server-side 11 <reply> 12 <data> 13 HTTP/1.1 200 OK 14 Date: Thu, 29 Jul 2008 14:49:00 GMT 15 Server: test-server/fake 16 Content-Length: 0 17 Content-Type: text/plain 18 Connection: close 19 20 </data> 21 </reply> 22 23 # Client-side 24 <client> 25 <server> 26 http 27 </server> 28 <name> 29 --libcurl for GET with query 30 </name> 31 <command> 32 http://%HOSTIP:%HTTPPORT/we/want/1403 --libcurl log/test1403.c -G -d "foo=bar" -d "baz=quux" 33 </command> 34 </client> 35 36 # Verify data after the test has been "shot" 37 <verify> 38 <strip> 39 ^User-Agent:.* 40 </strip> 41 <protocol> 42 GET /we/want/1403?foo=bar&baz=quux HTTP/1.1 43 User-Agent: curl/7.18.2 (i686-pc-linux-gnu) libcurl/7.18.2 OpenSSL/0.9.7a ipv6 zlib/1.1.4 44 Host: %HOSTIP:%HTTPPORT 45 Accept: */* 46 47 </protocol> 48 <stripfile> 49 # curl's default user-agent varies with version, libraries etc. 50 s/(USERAGENT, \")[^\"]+/${1}stripped/ 51 # CURLOPT_SSL_VERIFYPEER, SSH_KNOWNHOSTS and HTTP_VERSION vary with 52 # configurations - just ignore them 53 $_ = '' if /CURLOPT_SSL_VERIFYPEER/ 54 $_ = '' if /CURLOPT_SSH_KNOWNHOSTS/ 55 $_ = '' if /CURLOPT_HTTP_VERSION/ 56 </stripfile> 57 <file name="log/test1403.c" mode="text"> 58 /********* Sample code generated by the curl command line tool ********** 59 * All curl_easy_setopt() options are documented at: 60 * https://curl.haxx.se/libcurl/c/curl_easy_setopt.html 61 ************************************************************************/ 62 #include <curl/curl.h> 63 64 int main(int argc, char *argv[]) 65 { 66 CURLcode ret; 67 CURL *hnd; 68 69 hnd = curl_easy_init(); 70 curl_easy_setopt(hnd, CURLOPT_URL, "http://%HOSTIP:%HTTPPORT/we/want/1403?foo=bar&baz=quux"); 71 curl_easy_setopt(hnd, CURLOPT_HEADER, 1L); 72 curl_easy_setopt(hnd, CURLOPT_USERAGENT, "stripped"); 73 curl_easy_setopt(hnd, CURLOPT_MAXREDIRS, 50L); 74 curl_easy_setopt(hnd, CURLOPT_VERBOSE, 1L); 75 curl_easy_setopt(hnd, CURLOPT_TCP_KEEPALIVE, 1L); 76 77 /* Here is a list of options the curl code used that cannot get generated 78 as source easily. You may select to either not use them or implement 79 them yourself. 80 81 CURLOPT_WRITEDATA set to a objectpointer 82 CURLOPT_WRITEFUNCTION set to a functionpointer 83 CURLOPT_READDATA set to a objectpointer 84 CURLOPT_READFUNCTION set to a functionpointer 85 CURLOPT_SEEKDATA set to a objectpointer 86 CURLOPT_SEEKFUNCTION set to a functionpointer 87 CURLOPT_ERRORBUFFER set to a objectpointer 88 CURLOPT_STDERR set to a objectpointer 89 CURLOPT_DEBUGFUNCTION set to a functionpointer 90 CURLOPT_DEBUGDATA set to a objectpointer 91 CURLOPT_HEADERFUNCTION set to a functionpointer 92 CURLOPT_HEADERDATA set to a objectpointer 93 94 */ 95 96 ret = curl_easy_perform(hnd); 97 98 curl_easy_cleanup(hnd); 99 hnd = NULL; 100 101 return (int)ret; 102 } 103 /**** End of sample code ****/ 104 </file> 105 <stdout> 106 </stdout> 107 </verify> 108 </testcase> 109