mirror of
https://github.com/curl/curl.git
synced 2026-04-14 00:51:42 +08:00
Some curl command-lines are long, often repetitive, and difficult to read or write: Before this patch (1 test == 1 line): - <=78 characters: 1099 tests - 79-132 characters: 500 tests - 133+ characters: 217 tests: patch meant to help with some of these. After this patch: - <=78 characters: 1288 lines - 79-132 characters: 526 lines - 133+ characters: 190 lines After this patch it's possible to fold long lines into multiple ones. Folding can reduce greppability, thus this is primarily useful for cases when the options are repetitive, e.g. a list of form options, headers, mail parameters and the like. Closes #19500
196 lines
5.4 KiB
Plaintext
196 lines
5.4 KiB
Plaintext
<testcase>
|
|
# Based on test 1315
|
|
<info>
|
|
<keywords>
|
|
HTTP
|
|
HTTP FORMPOST
|
|
HTTP file upload
|
|
--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
|
|
Connection: close
|
|
|
|
</data>
|
|
</reply>
|
|
|
|
# Client-side
|
|
<client>
|
|
<features>
|
|
Mime
|
|
--libcurl
|
|
</features>
|
|
<server>
|
|
http
|
|
</server>
|
|
<name>
|
|
--libcurl plus -F with 3 files, one with explicit type and encoder
|
|
</name>
|
|
<setenv>
|
|
SSL_CERT_FILE
|
|
</setenv>
|
|
<command>
|
|
http://%HOSTIP:%HTTPPORT/we/want/%TESTNUMBER
|
|
-F name=value
|
|
-F 'file=@%LOGDIR/test%TESTNUMBER.txt,%LOGDIR/test%TESTNUMBER.txt;type=magic/content;encoder=8bit,%LOGDIR/test%TESTNUMBER.txt;headers=X-testheader-1: header 1;headers=X-testheader-2: header 2'
|
|
--libcurl %LOGDIR/test%TESTNUMBER.c
|
|
</command>
|
|
# We create this file before the command is invoked!
|
|
<file name="%LOGDIR/test%TESTNUMBER.txt">
|
|
dummy data
|
|
</file>
|
|
</client>
|
|
|
|
# Verify data after the test has been "shot"
|
|
<verify>
|
|
<strip>
|
|
-----+\w+
|
|
</strip>
|
|
<protocol>
|
|
POST /we/want/%TESTNUMBER HTTP/1.1%CR
|
|
Host: %HOSTIP:%HTTPPORT%CR
|
|
User-Agent: curl/%VERSION%CR
|
|
Accept: */*%CR
|
|
Content-Length: 930%CR
|
|
Content-Type: multipart/form-data; boundary=----------------------------9ef8d6205763%CR
|
|
%CR
|
|
------------------------------9ef8d6205763%CR
|
|
Content-Disposition: form-data; name="name"%CR
|
|
%CR
|
|
value%CR
|
|
------------------------------9ef8d6205763%CR
|
|
Content-Disposition: form-data; name="file"%CR
|
|
Content-Type: multipart/mixed; boundary=----------------------------aaaaaaaaaaaa%CR
|
|
%CR
|
|
Content-Disposition: attachment; filename="test%TESTNUMBER.txt"%CR
|
|
Content-Type: text/plain%CR
|
|
%CR
|
|
dummy data
|
|
%CR
|
|
------------------------------9ef8d6205763%CR
|
|
Content-Disposition: attachment; filename="test%TESTNUMBER.txt"%CR
|
|
Content-Type: magic/content%CR
|
|
Content-Transfer-Encoding: 8bit%CR
|
|
%CR
|
|
dummy data
|
|
%CR
|
|
------------------------------9ef8d6205763%CR
|
|
Content-Disposition: attachment; filename="test%TESTNUMBER.txt"%CR
|
|
Content-Type: text/plain%CR
|
|
X-testheader-1: header 1%CR
|
|
X-testheader-2: header 2%CR
|
|
%CR
|
|
dummy data
|
|
%CR
|
|
------------------------------aaaaaaaaaaaa--%CR
|
|
%CR
|
|
------------------------------9ef8d6205763--%CR
|
|
</protocol>
|
|
<stripfile>
|
|
# curl's default user-agent varies with version, libraries etc.
|
|
s/(USERAGENT, \")[^\"]+/${1}stripped/
|
|
# CURLOPT_SSL_VERIFYPEER, SSH_KNOWNHOSTS and HTTP_VERSION vary with
|
|
# configurations - just ignore them
|
|
$_ = '' if /CURLOPT_SSL_VERIFYPEER/
|
|
$_ = '' if /CURLOPT_SSH_KNOWNHOSTS/
|
|
$_ = '' if /CURLOPT_HTTP_VERSION/
|
|
$_ = '' if /CURLOPT_INTERLEAVEDATA/
|
|
$_ = '' if /CURLOPT_SSLVERSION/
|
|
# CURL_DOES_CONVERSION generates an extra comment.
|
|
$_ = '' if /\/\* "value" \*\//
|
|
</stripfile>
|
|
<file name="%LOGDIR/test%TESTNUMBER.c" mode="text">
|
|
/********* Sample code generated by the curl command line tool **********
|
|
* All curl_easy_setopt() options are documented at:
|
|
* https://curl.se/libcurl/c/curl_easy_setopt.html
|
|
************************************************************************/
|
|
#include <curl/curl.h>
|
|
|
|
int main(int argc, char *argv[])
|
|
{
|
|
CURLcode ret;
|
|
CURL *hnd;
|
|
curl_mime *mime1;
|
|
curl_mimepart *part1;
|
|
curl_mime *mime2;
|
|
curl_mimepart *part2;
|
|
struct curl_slist *slist1;
|
|
|
|
mime1 = NULL;
|
|
mime2 = NULL;
|
|
slist1 = NULL;
|
|
slist1 = curl_slist_append(slist1, "X-testheader-1: header 1");
|
|
slist1 = curl_slist_append(slist1, "X-testheader-2: header 2");
|
|
|
|
hnd = curl_easy_init();
|
|
curl_easy_setopt(hnd, CURLOPT_VERBOSE, 1L);
|
|
curl_easy_setopt(hnd, CURLOPT_BUFFERSIZE, 102400L);
|
|
curl_easy_setopt(hnd, CURLOPT_URL, "http://%HOSTIP:%HTTPPORT/we/want/%TESTNUMBER");
|
|
mime1 = curl_mime_init(hnd);
|
|
part1 = curl_mime_addpart(mime1);
|
|
curl_mime_data(part1, "value", CURL_ZERO_TERMINATED);
|
|
curl_mime_name(part1, "name");
|
|
part1 = curl_mime_addpart(mime1);
|
|
mime2 = curl_mime_init(hnd);
|
|
part2 = curl_mime_addpart(mime2);
|
|
curl_mime_filedata(part2, "%LOGDIR/test%TESTNUMBER.txt");
|
|
part2 = curl_mime_addpart(mime2);
|
|
curl_mime_filedata(part2, "%LOGDIR/test%TESTNUMBER.txt");
|
|
curl_mime_encoder(part2, "8bit");
|
|
curl_mime_type(part2, "magic/content");
|
|
part2 = curl_mime_addpart(mime2);
|
|
curl_mime_filedata(part2, "%LOGDIR/test%TESTNUMBER.txt");
|
|
curl_mime_headers(part2, slist1, 1);
|
|
slist1 = NULL;
|
|
curl_mime_subparts(part1, mime2);
|
|
mime2 = NULL;
|
|
curl_mime_name(part1, "file");
|
|
curl_easy_setopt(hnd, CURLOPT_MIMEPOST, mime1);
|
|
curl_easy_setopt(hnd, CURLOPT_USERAGENT, "stripped");
|
|
curl_easy_setopt(hnd, CURLOPT_MAXREDIRS, 50L);
|
|
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 choose to either not use them or implement
|
|
them yourself.
|
|
|
|
CURLOPT_DEBUGFUNCTION was set to a function pointer
|
|
CURLOPT_DEBUGDATA was set to an object pointer
|
|
CURLOPT_WRITEDATA was set to an object pointer
|
|
CURLOPT_WRITEFUNCTION was set to a function pointer
|
|
CURLOPT_READDATA was set to an object pointer
|
|
CURLOPT_READFUNCTION was set to a function pointer
|
|
CURLOPT_SEEKDATA was set to an object pointer
|
|
CURLOPT_SEEKFUNCTION was set to a function pointer
|
|
CURLOPT_HEADERFUNCTION was set to a function pointer
|
|
CURLOPT_HEADERDATA was set to an object pointer
|
|
CURLOPT_ERRORBUFFER was set to an object pointer
|
|
CURLOPT_STDERR was set to an object pointer
|
|
|
|
*/
|
|
|
|
ret = curl_easy_perform(hnd);
|
|
|
|
curl_easy_cleanup(hnd);
|
|
hnd = NULL;
|
|
curl_mime_free(mime1);
|
|
mime1 = NULL;
|
|
curl_mime_free(mime2);
|
|
mime2 = NULL;
|
|
curl_slist_free_all(slist1);
|
|
slist1 = NULL;
|
|
|
|
return (int)ret;
|
|
}
|
|
/**** End of sample code ****/
|
|
</file>
|
|
</verify>
|
|
</testcase>
|