|
- <testcase>
- <info>
- <keywords>
- HTTP
- HTTP GET
- --libcurl
- </keywords>
- </info>
-
- # Server-side
- <reply>
- <data>
- HTTP/1.1 200 OK
- Date: Thu, 29 Jul 2008 14:49:00 GMT
- Server: test-server/fake
- Content-Length: 0
- Content-Type: text/plain
- Connection: close
-
- </data>
- </reply>
-
- # Client-side
- <client>
- <server>
- http
- </server>
- <name>
- --libcurl for GET with query
- </name>
- <command>
- http://%HOSTIP:%HTTPPORT/we/want/1403 --libcurl log/test1403.c -G -d "foo=bar" -d "baz=quux"
- </command>
- </client>
-
- # Verify data after the test has been "shot"
- <verify>
- <strip>
- ^User-Agent:.*
- </strip>
- <protocol>
- GET /we/want/1403?foo=bar&baz=quux HTTP/1.1
- User-Agent: curl/7.18.2 (i686-pc-linux-gnu) libcurl/7.18.2 OpenSSL/0.9.7a ipv6 zlib/1.1.4
- Host: %HOSTIP:%HTTPPORT
- Accept: */*
-
- </protocol>
- <stripfile>
- # curl's default user-agent varies with version, libraries etc.
- s/(USERAGENT, \")[^\"]+/${1}stripped/
- # CURLOPT_SSL_VERIFYPEER and SSH_KNOWNHOSTS vary with configurations - just
- # ignore them
- $_ = '' if /CURLOPT_SSL_VERIFYPEER/
- $_ = '' if /CURLOPT_SSH_KNOWNHOSTS/
- </stripfile>
- <file name="log/test1403.c" mode="text">
- /********* Sample code generated by the curl command line tool **********
- * All curl_easy_setopt() options are documented at:
- * http://curl.haxx.se/libcurl/c/curl_easy_setopt.html
- ************************************************************************/
- #include <curl/curl.h>
-
- int main(int argc, char *argv[])
- {
- CURLcode ret;
- CURL *hnd;
-
- hnd = curl_easy_init();
- curl_easy_setopt(hnd, CURLOPT_URL, "http://%HOSTIP:%HTTPPORT/we/want/1403?foo=bar&baz=quux");
- curl_easy_setopt(hnd, CURLOPT_HEADER, 1L);
- curl_easy_setopt(hnd, CURLOPT_USERAGENT, "stripped");
- curl_easy_setopt(hnd, CURLOPT_MAXREDIRS, 50L);
- curl_easy_setopt(hnd, CURLOPT_VERBOSE, 1L);
- curl_easy_setopt(hnd, CURLOPT_TCP_KEEPALIVE, 1L);
-
- /* Here is a list of options the curl code used that cannot get generated
- as source easily. You may select to either not use them or implement
- them yourself.
-
- CURLOPT_WRITEDATA set to a objectpointer
- CURLOPT_WRITEFUNCTION set to a functionpointer
- CURLOPT_READDATA set to a objectpointer
- CURLOPT_READFUNCTION set to a functionpointer
- CURLOPT_SEEKDATA set to a objectpointer
- CURLOPT_SEEKFUNCTION set to a functionpointer
- CURLOPT_ERRORBUFFER set to a objectpointer
- CURLOPT_STDERR set to a objectpointer
- CURLOPT_DEBUGFUNCTION set to a functionpointer
- CURLOPT_DEBUGDATA set to a objectpointer
- CURLOPT_HEADERFUNCTION set to a functionpointer
- CURLOPT_HEADERDATA set to a objectpointer
-
- */
-
- ret = curl_easy_perform(hnd);
-
- curl_easy_cleanup(hnd);
- hnd = NULL;
-
- return (int)ret;
- }
- /**** End of sample code ****/
- </file>
- <stdout>
- </stdout>
- </verify>
- </testcase>
|