test1403 2.8 KB

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