9756d1da76
- Add new option CURLOPT_DEFAULT_PROTOCOL to allow specifying a default protocol for schemeless URLs. - Add new tool option --proto-default to expose CURLOPT_DEFAULT_PROTOCOL. In the case of schemeless URLs libcurl will behave in this way: When the option is used libcurl will use the supplied default. When the option is not used, libcurl will follow its usual plan of guessing from the hostname and falling back to 'http'.
55 lines
1.2 KiB
Plaintext
55 lines
1.2 KiB
Plaintext
<testcase>
|
|
<info>
|
|
<keywords>
|
|
FTP
|
|
--proto-default
|
|
</keywords>
|
|
</info>
|
|
|
|
|
|
#
|
|
# Server-side
|
|
<reply>
|
|
<!--
|
|
The purpose of this test is to make sure the --proto-default option works
|
|
properly. We specify a default protocol of FTP and if the option works properly
|
|
curl will use the FTP protocol. If the option is broken however curl will use
|
|
the HTTP protocol.
|
|
In the broken scenario curl would use HTTP to talk to our FTP server. We handle
|
|
that by replying with something that both protocols can understand. Our FTP
|
|
server allows a custom welcome message, so we use that feature to make an HTTP
|
|
reply that contains an FTP reply (think polyglot). In the case of FTP we expect
|
|
curl will return CURLE_FTP_WEIRD_SERVER_REPLY so we test for that return code.
|
|
-->
|
|
<servercmd>
|
|
REPLY welcome HTTP/1.1 200 OK\r\nContent-Length: 21\r\n\r\n500 Weird FTP Reply
|
|
</servercmd>
|
|
</reply>
|
|
|
|
#
|
|
# Client-side
|
|
<client>
|
|
<features>
|
|
none
|
|
</features>
|
|
<server>
|
|
ftp
|
|
</server>
|
|
<name>
|
|
Set the default protocol to ftp for a schemeless URL
|
|
</name>
|
|
<command>
|
|
-H "User-Agent:" -H "Host:" -H "Accept:" --proto-default ftp %HOSTIP:%FTPPORT
|
|
</command>
|
|
</client>
|
|
|
|
#
|
|
# Verify data after the test has been "shot"
|
|
<verify>
|
|
# CURLE_FTP_WEIRD_SERVER_REPLY is error code 8
|
|
<errorcode>
|
|
8
|
|
</errorcode>
|
|
</verify>
|
|
</testcase>
|