aboutsummaryrefslogtreecommitdiff
path: root/tests/libtest/lib514.c
diff options
context:
space:
mode:
authorDaniel Stenberg <daniel@haxx.se>2004-06-30 11:09:16 +0000
committerDaniel Stenberg <daniel@haxx.se>2004-06-30 11:09:16 +0000
commit185baf036b9bcfe1386a6fd1549ca5403ec66812 (patch)
treece3382929e562ad910fc6628d9e6fd14c3fa329d /tests/libtest/lib514.c
parent352361382692256dd94040ce3ba54b079658135e (diff)
NOBODY set TRUE after a POST makes a good HEAD now
Diffstat (limited to 'tests/libtest/lib514.c')
-rw-r--r--tests/libtest/lib514.c43
1 files changed, 43 insertions, 0 deletions
diff --git a/tests/libtest/lib514.c b/tests/libtest/lib514.c
new file mode 100644
index 000000000..7100fd8a5
--- /dev/null
+++ b/tests/libtest/lib514.c
@@ -0,0 +1,43 @@
+#include "test.h"
+
+int test(char *URL)
+{
+ CURL *curl;
+ CURLcode res=CURLE_OK;
+
+ curl = curl_easy_init();
+ if(curl) {
+ /* First set the URL that is about to receive our POST. */
+ curl_easy_setopt(curl, CURLOPT_URL, URL);
+
+ /* Based on a bug report by Niels van Tongeren on June 29, 2004:
+
+ A weird situation occurs when request 1 is a POST request and the request
+ 2 is a HEAD request. For the POST request we set the CURLOPT_POSTFIELDS,
+ CURLOPT_POSTFIELDSIZE and CURLOPT_POST options. For the HEAD request we
+ set the CURLOPT_NOBODY option to '1'.
+
+ */
+
+ curl_easy_setopt(curl, CURLOPT_POSTFIELDS, "moo");
+ curl_easy_setopt(curl, CURLOPT_POSTFIELDSIZE, 3);
+ curl_easy_setopt(curl, CURLOPT_POST, 1);
+
+ /* this is where transfer 1 would take place, but skip that and change
+ options right away instead */
+
+ curl_easy_setopt(curl, CURLOPT_NOBODY, 1);
+
+ curl_easy_setopt(curl, CURLOPT_VERBOSE, 1); /* show verbose for debug */
+ curl_easy_setopt(curl, CURLOPT_HEADER, 1); /* include header */
+
+ /* Now, we should be making a fine HEAD request */
+
+ /* Perform the request 2, res will get the return code */
+ res = curl_easy_perform(curl);
+
+ /* always cleanup */
+ curl_easy_cleanup(curl);
+ }
+ return (int)res;
+}