1<testcase>
2# Derived from test227
3<info>
4<keywords>
5FTP
6post-quote
7pre-quote
8--libcurl
9</keywords>
10</info>
11# Server-side
12<reply>
13<data>
14data
15    to
16      see
17that FTP
18works
19  so does it?
20</data>
21<servercmd>
22REPLY EPSV 500 no such command
23REPLY FAIL 500 this might not be a failure!
24</servercmd>
25</reply>
26
27# Client-side
28<client>
29<server>
30ftp
31</server>
32 <name>
33--libcurl for FTP with quote ops
34 </name>
35<setenv>
36SSL_CERT_FILE=
37</setenv>
38 <command>
39ftp://%HOSTIP:%FTPPORT/1405 -Q "NOOP 1" -Q "+NOOP 2" -Q "-NOOP 3" -Q "*FAIL" -Q "+*FAIL HARD" --libcurl log/test1405.c
40</command>
41</client>
42
43# Verify data after the test has been "shot"
44<verify>
45<protocol>
46USER anonymous
47PASS ftp@example.com
48PWD
49NOOP 1
50FAIL
51EPSV
52PASV
53TYPE I
54NOOP 2
55FAIL HARD
56SIZE 1405
57RETR 1405
58NOOP 3
59QUIT
60</protocol>
61<file name="log/test1405.c" mode="text">
62/********* Sample code generated by the curl command line tool **********
63 * All curl_easy_setopt() options are documented at:
64 * https://curl.haxx.se/libcurl/c/curl_easy_setopt.html
65 ************************************************************************/
66#include <curl/curl.h>
67
68int main(int argc, char *argv[])
69{
70  CURLcode ret;
71  CURL *hnd;
72  struct curl_slist *slist1;
73  struct curl_slist *slist2;
74  struct curl_slist *slist3;
75
76  slist1 = NULL;
77  slist1 = curl_slist_append(slist1, "NOOP 1");
78  slist1 = curl_slist_append(slist1, "*FAIL");
79  slist2 = NULL;
80  slist2 = curl_slist_append(slist2, "NOOP 3");
81  slist3 = NULL;
82  slist3 = curl_slist_append(slist3, "NOOP 2");
83  slist3 = curl_slist_append(slist3, "*FAIL HARD");
84
85  hnd = curl_easy_init();
86  curl_easy_setopt(hnd, CURLOPT_BUFFERSIZE, 102400L);
87  curl_easy_setopt(hnd, CURLOPT_URL, "ftp://%HOSTIP:%FTPPORT/1405");
88  curl_easy_setopt(hnd, CURLOPT_QUOTE, slist1);
89  curl_easy_setopt(hnd, CURLOPT_POSTQUOTE, slist2);
90  curl_easy_setopt(hnd, CURLOPT_PREQUOTE, slist3);
91  curl_easy_setopt(hnd, CURLOPT_VERBOSE, 1L);
92  curl_easy_setopt(hnd, CURLOPT_TCP_KEEPALIVE, 1L);
93
94  /* Here is a list of options the curl code used that cannot get generated
95     as source easily. You may select to either not use them or implement
96     them yourself.
97
98  CURLOPT_WRITEDATA set to a objectpointer
99  CURLOPT_WRITEFUNCTION set to a functionpointer
100  CURLOPT_READDATA set to a objectpointer
101  CURLOPT_READFUNCTION set to a functionpointer
102  CURLOPT_SEEKDATA set to a objectpointer
103  CURLOPT_SEEKFUNCTION set to a functionpointer
104  CURLOPT_ERRORBUFFER set to a objectpointer
105  CURLOPT_STDERR set to a objectpointer
106  CURLOPT_DEBUGFUNCTION set to a functionpointer
107  CURLOPT_DEBUGDATA set to a objectpointer
108  CURLOPT_HEADERFUNCTION set to a functionpointer
109  CURLOPT_HEADERDATA set to a objectpointer
110
111  */
112
113  ret = curl_easy_perform(hnd);
114
115  curl_easy_cleanup(hnd);
116  hnd = NULL;
117  curl_slist_free_all(slist1);
118  slist1 = NULL;
119  curl_slist_free_all(slist2);
120  slist2 = NULL;
121  curl_slist_free_all(slist3);
122  slist3 = NULL;
123
124  return (int)ret;
125}
126/**** End of sample code ****/
127</file>
128<stripfile>
129# CURLOPT_USERAGENT and CURLOPT_MAXREDIRS requires HTTP protocol
130# CURLOPT_INTERLEAVEDATA requires RTSP (HTTP) protocol
131# support, IOW depends on configuration - just ignore these.
132$_ = '' if /CURLOPT_USERAGENT/
133$_ = '' if /CURLOPT_MAXREDIRS/
134# CURLOPT_SSL_VERIFYPEER, SSH_KNOWNHOSTS and HTTP_VERSION vary with
135# configurations - just ignore them
136$_ = '' if /CURLOPT_SSL_VERIFYPEER/
137$_ = '' if /CURLOPT_SSH_KNOWNHOSTS/
138$_ = '' if /CURLOPT_HTTP_VERSION/
139$_ = '' if /CURLOPT_HTTP09_ALLOWED/
140$_ = '' if /CURLOPT_INTERLEAVEDATA/
141</stripfile>
142</verify>
143</testcase>
144