test1402 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. <testcase>
  2. <info>
  3. <keywords>
  4. HTTP
  5. HTTP POST
  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 simple POST
  27. </name>
  28. <command>
  29. http://%HOSTIP:%HTTPPORT/we/want/1402 --libcurl log/test1402.c -d "foo=bar" -d "baz=quux"
  30. </command>
  31. </client>
  32. # Verify data after the test has been "shot"
  33. <verify>
  34. <strip>
  35. ^User-Agent:.*
  36. </strip>
  37. <protocol nonewline="yes">
  38. POST /we/want/1402 HTTP/1.1
  39. User-Agent: curl/7.18.2 (i686-pc-linux-gnu) libcurl/7.18.2 OpenSSL/0.9.7a ipv6 zlib/1.1.4
  40. Host: %HOSTIP:%HTTPPORT
  41. Accept: */*
  42. Content-Length: 16
  43. Content-Type: application/x-www-form-urlencoded
  44. foo=bar&baz=quux
  45. </protocol>
  46. <stripfile>
  47. # curl's default user-agent varies with version, libraries etc.
  48. s/(USERAGENT, \")[^\"]+/${1}stripped/
  49. # CURLOPT_SSL_VERIFYPEER and SSH_KNOWNHOSTS vary with configurations - just
  50. # ignore them
  51. $_ = '' if /CURLOPT_SSL_VERIFYPEER/
  52. $_ = '' if /CURLOPT_SSH_KNOWNHOSTS/
  53. </stripfile>
  54. <file name="log/test1402.c" mode="text">
  55. /********* Sample code generated by the curl command line tool **********
  56. * All curl_easy_setopt() options are documented at:
  57. * http://curl.haxx.se/libcurl/c/curl_easy_setopt.html
  58. ************************************************************************/
  59. #include <curl/curl.h>
  60. int main(int argc, char *argv[])
  61. {
  62. CURLcode ret;
  63. CURL *hnd;
  64. hnd = curl_easy_init();
  65. curl_easy_setopt(hnd, CURLOPT_URL, "http://%HOSTIP:%HTTPPORT/we/want/1402");
  66. curl_easy_setopt(hnd, CURLOPT_HEADER, 1L);
  67. curl_easy_setopt(hnd, CURLOPT_POSTFIELDS, "foo=bar&baz=quux");
  68. curl_easy_setopt(hnd, CURLOPT_POSTFIELDSIZE_LARGE, (curl_off_t)16);
  69. curl_easy_setopt(hnd, CURLOPT_USERAGENT, "stripped");
  70. curl_easy_setopt(hnd, CURLOPT_MAXREDIRS, 50L);
  71. curl_easy_setopt(hnd, CURLOPT_VERBOSE, 1L);
  72. curl_easy_setopt(hnd, CURLOPT_TCP_KEEPALIVE, 1L);
  73. /* Here is a list of options the curl code used that cannot get generated
  74. as source easily. You may select to either not use them or implement
  75. them yourself.
  76. CURLOPT_WRITEDATA 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. <stdout>
  97. </stdout>
  98. </verify>
  99. </testcase>