123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141 |
- <testcase>
- # Derived from test227
- <info>
- <keywords>
- FTP
- post-quote
- pre-quote
- --libcurl
- </keywords>
- </info>
- # Server-side
- <reply>
- <data>
- data
- to
- see
- that FTP
- works
- so does it?
- </data>
- <servercmd>
- REPLY EPSV 500 no such command
- REPLY FAIL 500 this might not be a failure!
- </servercmd>
- </reply>
- # Client-side
- <client>
- <server>
- ftp
- </server>
- <name>
- --libcurl for FTP with quote ops
- </name>
- <setenv>
- SSL_CERT_FILE=
- </setenv>
- <command>
- ftp://%HOSTIP:%FTPPORT/1405 -Q "NOOP 1" -Q "+NOOP 2" -Q "-NOOP 3" -Q "*FAIL" -Q "+*FAIL HARD" --libcurl log/test1405.c
- </command>
- </client>
- # Verify data after the test has been "shot"
- <verify>
- <protocol>
- USER anonymous
- PASS ftp@example.com
- PWD
- NOOP 1
- FAIL
- EPSV
- PASV
- TYPE I
- NOOP 2
- FAIL HARD
- SIZE 1405
- RETR 1405
- NOOP 3
- QUIT
- </protocol>
- <file name="log/test1405.c" mode="text">
- /********* Sample code generated by the curl command line tool **********
- * All curl_easy_setopt() options are documented at:
- * https://curl.haxx.se/libcurl/c/curl_easy_setopt.html
- ************************************************************************/
- #include <curl/curl.h>
- int main(int argc, char *argv[])
- {
- CURLcode ret;
- CURL *hnd;
- struct curl_slist *slist1;
- struct curl_slist *slist2;
- struct curl_slist *slist3;
- slist1 = NULL;
- slist1 = curl_slist_append(slist1, "NOOP 1");
- slist1 = curl_slist_append(slist1, "*FAIL");
- slist2 = NULL;
- slist2 = curl_slist_append(slist2, "NOOP 3");
- slist3 = NULL;
- slist3 = curl_slist_append(slist3, "NOOP 2");
- slist3 = curl_slist_append(slist3, "*FAIL HARD");
- hnd = curl_easy_init();
- curl_easy_setopt(hnd, CURLOPT_BUFFERSIZE, 102400L);
- curl_easy_setopt(hnd, CURLOPT_URL, "ftp://%HOSTIP:%FTPPORT/1405");
- curl_easy_setopt(hnd, CURLOPT_QUOTE, slist1);
- curl_easy_setopt(hnd, CURLOPT_POSTQUOTE, slist2);
- curl_easy_setopt(hnd, CURLOPT_PREQUOTE, slist3);
- 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_INTERLEAVEDATA 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;
- curl_slist_free_all(slist1);
- slist1 = NULL;
- curl_slist_free_all(slist2);
- slist2 = NULL;
- curl_slist_free_all(slist3);
- slist3 = NULL;
- return (int)ret;
- }
- /**** End of sample code ****/
- </file>
- <stripfile>
- # CURLOPT_USERAGENT and CURLOPT_MAXREDIRS requires HTTP protocol
- # support, IOW depends on configuration - just ignore these.
- $_ = '' if /CURLOPT_USERAGENT/
- $_ = '' if /CURLOPT_MAXREDIRS/
- # 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/
- </stripfile>
- </verify>
- </testcase>
|