mirror of
https://github.com/curl/curl.git
synced 2026-04-13 00:31:41 +08:00
This still allows users to explictily ask for 1.0 or 1.1 as the minimum version. If the TLS library allows it. Starting with this change, the CURL_SSLVERSION_DEFAULT value is no longer used as minimum version when the TLS backend are called. This also makes curl set the minimum version to 1.2 independently of libcurl for the rare case where a newer curl tool would use an older libcurl. URL: https://curl.se/mail/lib-2025-07/0007.html Assisted-by: Stefan Eissing Closes #17894
152 lines
3.7 KiB
Plaintext
152 lines
3.7 KiB
Plaintext
<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>
|
|
<features>
|
|
--libcurl
|
|
</features>
|
|
<server>
|
|
ftp
|
|
</server>
|
|
<name>
|
|
--libcurl for FTP with quote ops
|
|
</name>
|
|
<setenv>
|
|
SSL_CERT_FILE
|
|
</setenv>
|
|
<command>
|
|
ftp://%HOSTIP:%FTPPORT/%TESTNUMBER -Q "NOOP 1" -Q "+NOOP 2" -Q "-NOOP 3" -Q "*FAIL" -Q "+*FAIL HARD" --libcurl %LOGDIR/test%TESTNUMBER.c
|
|
</command>
|
|
</client>
|
|
|
|
# Verify data after the test has been "shot"
|
|
<verify>
|
|
<strip>
|
|
QUIT
|
|
</strip>
|
|
<protocol>
|
|
USER anonymous
|
|
PASS ftp@example.com
|
|
PWD
|
|
NOOP 1
|
|
FAIL
|
|
EPSV
|
|
PASV
|
|
TYPE I
|
|
NOOP 2
|
|
FAIL HARD
|
|
SIZE %TESTNUMBER
|
|
RETR %TESTNUMBER
|
|
NOOP 3
|
|
QUIT
|
|
</protocol>
|
|
<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;
|
|
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_VERBOSE, 1L);
|
|
curl_easy_setopt(hnd, CURLOPT_BUFFERSIZE, 102400L);
|
|
curl_easy_setopt(hnd, CURLOPT_URL, "ftp://%HOSTIP:%FTPPORT/%TESTNUMBER");
|
|
curl_easy_setopt(hnd, CURLOPT_FTP_SKIP_PASV_IP, 1L);
|
|
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_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_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
|
|
# CURLOPT_INTERLEAVEDATA requires RTSP (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/
|
|
$_ = '' if /CURLOPT_HTTP09_ALLOWED/
|
|
$_ = '' if /CURLOPT_INTERLEAVEDATA/
|
|
$_ = '' if /CURLOPT_SSLVERSION/
|
|
</stripfile>
|
|
</verify>
|
|
</testcase>
|