2022-06-14 16:22:56 +08:00
|
|
|
<!--
|
2023-01-02 20:51:48 +08:00
|
|
|
Copyright (C) Daniel Stenberg, <daniel@haxx.se>, et al.
|
2022-06-14 16:22:56 +08:00
|
|
|
|
|
|
|
SPDX-License-Identifier: curl
|
|
|
|
-->
|
|
|
|
|
2020-04-20 00:10:41 +08:00
|
|
|
# curl test suite file format
|
|
|
|
|
2022-09-19 23:30:30 +08:00
|
|
|
The curl test suite's file format is simple and extendable, closely resembling
|
|
|
|
XML. All data for a single test case resides in a single ASCII file. Labels
|
|
|
|
mark the beginning and the end of all sections, and each label must be written
|
|
|
|
in its own line. Comments are either XML-style (enclosed with `<!--` and
|
|
|
|
`-->`) or shell script style (beginning with `#`) and must appear on their own
|
|
|
|
lines and not alongside actual test data. Most test data files are
|
|
|
|
syntactically valid XML, although a few files are not (lack of support for
|
2020-04-20 00:10:41 +08:00
|
|
|
character entities and the preservation of CR/LF characters at the end of
|
|
|
|
lines are the biggest differences).
|
|
|
|
|
2020-05-12 04:44:58 +08:00
|
|
|
Each test case source exists as a file matching the format
|
2022-09-21 05:30:19 +08:00
|
|
|
`tests/data/testNUM`, where `NUM` is the unique test number, and must begin
|
|
|
|
with a `testcase` tag, which encompasses the remainder of the file.
|
2020-04-20 00:10:41 +08:00
|
|
|
|
2020-05-12 04:44:58 +08:00
|
|
|
# Preprocessing
|
|
|
|
|
|
|
|
When a test is to be executed, the source file is first preprocessed and
|
2022-10-26 14:59:35 +08:00
|
|
|
variables are substituted by their respective contents and the output
|
2023-03-29 09:20:54 +08:00
|
|
|
version of the test file is stored as `%LOGDIR/testNUM`. That version is what
|
|
|
|
will be read and used by the test servers.
|
2020-05-12 04:44:58 +08:00
|
|
|
|
2020-08-04 19:56:12 +08:00
|
|
|
## Base64 Encoding
|
|
|
|
|
|
|
|
In the preprocess stage, a special instruction can be used to have runtests.pl
|
|
|
|
base64 encode a certain section and insert in the generated output file. This
|
|
|
|
is in particular good for test cases where the test tool is expected to pass
|
|
|
|
in base64 encoded content that might use dynamic information that is unique
|
|
|
|
for this particular test invocation, like the server port number.
|
|
|
|
|
|
|
|
To insert a base64 encoded string into the output, use this syntax:
|
|
|
|
|
|
|
|
%b64[ data to encode ]b64%
|
|
|
|
|
|
|
|
The data to encode can then use any of the existing variables mentioned below,
|
|
|
|
or even percent-encoded individual bytes. As an example, insert the HTTP
|
|
|
|
server's port number (in ASCII) followed by a space and the hexadecimal byte
|
|
|
|
9a:
|
|
|
|
|
|
|
|
%b64[%HTTPPORT %9a]b64%
|
|
|
|
|
2020-10-02 06:11:13 +08:00
|
|
|
## Hexadecimal decoding
|
|
|
|
|
|
|
|
In the preprocess stage, a special instruction can be used to have runtests.pl
|
|
|
|
generate a sequence of binary bytes.
|
|
|
|
|
|
|
|
To insert a sequence of bytes from a hex encoded string, use this syntax:
|
|
|
|
|
|
|
|
%hex[ %XX-encoded data to decode ]hex%
|
|
|
|
|
|
|
|
For example, to insert the binary octets 0, 1 and 255 into the test file:
|
|
|
|
|
|
|
|
%hex[ %00%01%FF ]hex%
|
|
|
|
|
2020-10-04 06:03:02 +08:00
|
|
|
## Repeat content
|
|
|
|
|
|
|
|
In the preprocess stage, a special instruction can be used to have runtests.pl
|
2022-04-21 23:01:45 +08:00
|
|
|
generate a repetitive sequence of bytes.
|
2020-10-04 06:03:02 +08:00
|
|
|
|
|
|
|
To insert a sequence of repeat bytes, use this syntax to make the `<string>`
|
2021-01-24 01:37:37 +08:00
|
|
|
get repeated `<number>` of times. The number has to be 1 or larger and the
|
2020-10-04 06:03:02 +08:00
|
|
|
string may contain `%HH` hexadecimal codes:
|
|
|
|
|
|
|
|
%repeat[<number> x <string>]%
|
|
|
|
|
2022-10-26 14:59:35 +08:00
|
|
|
For example, to insert the word hello 100 times:
|
2020-10-04 06:03:02 +08:00
|
|
|
|
|
|
|
%repeat[100 x hello]%
|
|
|
|
|
2023-12-31 23:27:46 +08:00
|
|
|
## Include file
|
|
|
|
|
|
|
|
This instruction allows a test case to include another file. It is helpful to
|
|
|
|
remember that the ordinary variables are expanded before the include happens
|
|
|
|
so `%LOGDIR` and the others can be used in the include line.
|
|
|
|
|
|
|
|
The file name cannot contain `%` as that letter is used to end the name for
|
|
|
|
the include instruction:
|
|
|
|
|
|
|
|
%include filename%
|
|
|
|
|
2020-12-11 17:26:06 +08:00
|
|
|
## Conditional lines
|
|
|
|
|
|
|
|
Lines in the test file can be made to appear conditionally on a specific
|
|
|
|
feature (see the "features" section below) being set or not set. If the
|
|
|
|
specific feature is present, the following lines will be output, otherwise it
|
2022-09-21 05:30:19 +08:00
|
|
|
outputs nothing, until a following else or `endif` clause. Like this:
|
2020-12-11 17:26:06 +08:00
|
|
|
|
|
|
|
%if brotli
|
|
|
|
Accept-Encoding
|
|
|
|
%endif
|
|
|
|
|
2022-04-21 23:01:45 +08:00
|
|
|
It can also check for the inverse condition, so if the feature is *not* set by
|
2020-12-11 17:26:06 +08:00
|
|
|
the use of an exclamation mark:
|
|
|
|
|
|
|
|
%if !brotli
|
|
|
|
Accept-Encoding: not-brotli
|
|
|
|
%endif
|
|
|
|
|
|
|
|
You can also make an "else" clause to get output for the opposite condition,
|
|
|
|
like:
|
|
|
|
|
|
|
|
%if brotli
|
|
|
|
Accept-Encoding: brotli
|
|
|
|
%else
|
|
|
|
Accept-Encoding: nothing
|
|
|
|
%endif
|
|
|
|
|
2023-08-25 05:51:24 +08:00
|
|
|
Nested conditions are supported.
|
2020-12-11 17:26:06 +08:00
|
|
|
|
2020-05-12 04:44:58 +08:00
|
|
|
# Variables
|
|
|
|
|
|
|
|
When the test is preprocessed, a range of "variables" in the test file will be
|
|
|
|
replaced by their content at that time.
|
|
|
|
|
|
|
|
Available substitute variables include:
|
|
|
|
|
|
|
|
- `%CLIENT6IP` - IPv6 address of the client running curl
|
|
|
|
- `%CLIENTIP` - IPv4 address of the client running curl
|
|
|
|
- `%CURL` - Path to the curl executable
|
2022-10-26 14:59:35 +08:00
|
|
|
- `%FILE_PWD` - Current directory, on Windows prefixed with a slash
|
2020-05-12 04:44:58 +08:00
|
|
|
- `%FTP6PORT` - IPv6 port number of the FTP server
|
|
|
|
- `%FTPPORT` - Port number of the FTP server
|
|
|
|
- `%FTPSPORT` - Port number of the FTPS server
|
|
|
|
- `%FTPTIME2` - Timeout in seconds that should be just sufficient to receive a
|
|
|
|
response from the test FTP server
|
2022-09-21 05:30:19 +08:00
|
|
|
- `%FTPTIME3` - Even longer than `%FTPTIME2`
|
2020-05-12 04:44:58 +08:00
|
|
|
- `%GOPHER6PORT` - IPv6 port number of the Gopher server
|
|
|
|
- `%GOPHERPORT` - Port number of the Gopher server
|
2020-11-17 00:54:07 +08:00
|
|
|
- `%GOPHERSPORT` - Port number of the Gophers server
|
2020-05-12 04:44:58 +08:00
|
|
|
- `%HOST6IP` - IPv6 address of the host running this test
|
|
|
|
- `%HOSTIP` - IPv4 address of the host running this test
|
|
|
|
- `%HTTP6PORT` - IPv6 port number of the HTTP server
|
|
|
|
- `%HTTPPORT` - Port number of the HTTP server
|
2020-08-03 17:42:16 +08:00
|
|
|
- `%HTTP2PORT` - Port number of the HTTP/2 server
|
2020-05-12 04:44:58 +08:00
|
|
|
- `%HTTPSPORT` - Port number of the HTTPS server
|
2020-05-14 15:44:17 +08:00
|
|
|
- `%HTTPSPROXYPORT` - Port number of the HTTPS-proxy
|
2020-05-12 04:44:58 +08:00
|
|
|
- `%HTTPTLS6PORT` - IPv6 port number of the HTTP TLS server
|
|
|
|
- `%HTTPTLSPORT` - Port number of the HTTP TLS server
|
|
|
|
- `%HTTPUNIXPATH` - Path to the Unix socket of the HTTP server
|
2023-04-09 01:56:15 +08:00
|
|
|
- `%SOCKSUNIXPATH` - Path to the Unix socket of the SOCKS server
|
2020-05-12 04:44:58 +08:00
|
|
|
- `%IMAP6PORT` - IPv6 port number of the IMAP server
|
|
|
|
- `%IMAPPORT` - Port number of the IMAP server
|
2023-03-29 09:20:54 +08:00
|
|
|
- `%LOGDIR` - Log directory relative to %PWD
|
2020-05-12 04:44:58 +08:00
|
|
|
- `%MQTTPORT` - Port number of the MQTT server
|
2020-08-05 21:39:34 +08:00
|
|
|
- `%TELNETPORT` - Port number of the telnet server
|
2020-05-12 04:44:58 +08:00
|
|
|
- `%NOLISTENPORT` - Port number where no service is listening
|
|
|
|
- `%POP36PORT` - IPv6 port number of the POP3 server
|
|
|
|
- `%POP3PORT` - Port number of the POP3 server
|
|
|
|
- `%POSIX_PWD` - Current directory somewhat mingw friendly
|
|
|
|
- `%PROXYPORT` - Port number of the HTTP proxy
|
|
|
|
- `%PWD` - Current directory
|
|
|
|
- `%RTSP6PORT` - IPv6 port number of the RTSP server
|
|
|
|
- `%RTSPPORT` - Port number of the RTSP server
|
|
|
|
- `%SMBPORT` - Port number of the SMB server
|
|
|
|
- `%SMBSPORT` - Port number of the SMBS server
|
|
|
|
- `%SMTP6PORT` - IPv6 port number of the SMTP server
|
|
|
|
- `%SMTPPORT` - Port number of the SMTP server
|
|
|
|
- `%SOCKSPORT` - Port number of the SOCKS4/5 server
|
|
|
|
- `%SRCDIR` - Full path to the source dir
|
|
|
|
- `%SSHPORT` - Port number of the SCP/SFTP server
|
|
|
|
- `%SSHSRVMD5` - MD5 of SSH server's public key
|
2021-09-27 05:20:53 +08:00
|
|
|
- `%SSHSRVSHA256` - SHA256 of SSH server's public key
|
2020-05-12 04:44:58 +08:00
|
|
|
- `%SSH_PWD` - Current directory friendly for the SSH server
|
2014-06-16 22:03:00 +08:00
|
|
|
- `%TESTNUMBER` - Number of the test case
|
2020-05-12 04:44:58 +08:00
|
|
|
- `%TFTP6PORT` - IPv6 port number of the TFTP server
|
|
|
|
- `%TFTPPORT` - Port number of the TFTP server
|
|
|
|
- `%USER` - Login ID of the user running the test
|
2020-10-02 19:45:24 +08:00
|
|
|
- `%VERSION` - the full version number of the tested curl
|
2020-04-20 00:10:41 +08:00
|
|
|
|
|
|
|
# `<testcase>`
|
|
|
|
|
2022-09-21 05:30:19 +08:00
|
|
|
Each test is always specified entirely within the `testcase` tag. Each test
|
|
|
|
case is split up in four main sections: `info`, `reply`, `client` and
|
|
|
|
`verify`.
|
2020-04-20 00:10:41 +08:00
|
|
|
|
|
|
|
- **info** provides information about the test case
|
|
|
|
|
|
|
|
- **reply** is used for the server to know what to send as a reply for the
|
|
|
|
requests curl sends
|
|
|
|
|
|
|
|
- **client** defines how the client should behave
|
|
|
|
|
|
|
|
- **verify** defines how to verify that the data stored after a command has
|
2023-03-23 05:52:24 +08:00
|
|
|
been run ended up correct
|
2020-04-20 00:10:41 +08:00
|
|
|
|
|
|
|
Each main section has a number of available subsections that can be specified,
|
|
|
|
that will be checked/used if specified.
|
|
|
|
|
|
|
|
## `<info>`
|
|
|
|
|
|
|
|
### `<keywords>`
|
|
|
|
A newline-separated list of keywords describing what this test case uses and
|
2022-09-19 23:30:30 +08:00
|
|
|
tests. Try to use already used keywords. These keywords will be used for
|
2021-06-04 00:10:44 +08:00
|
|
|
statistical/informational purposes and for choosing or skipping classes of
|
2022-09-19 23:30:30 +08:00
|
|
|
tests. Keywords must begin with an alphabetic character, `-`, `[` or `{` and
|
|
|
|
may actually consist of multiple words separated by spaces which are treated
|
2023-09-08 14:48:33 +08:00
|
|
|
together as a single identifier. Most keywords are only there to provide a way
|
|
|
|
for users to skip certain classes of tests, if desired, but a few are treated
|
|
|
|
specially by the test harness or build system.
|
2021-06-04 00:10:44 +08:00
|
|
|
|
2023-03-23 05:52:24 +08:00
|
|
|
When using curl built with Hyper, the keywords must include `HTTP` or `HTTPS`
|
|
|
|
for 'hyper mode' to kick in and make line ending checks work for tests.
|
|
|
|
|
|
|
|
When running a unit test and the keywords include `unittest`, the `<tool>`
|
|
|
|
section can be left empty to use the standard unit test tool name `unitN` where
|
|
|
|
`N` is the test number.
|
|
|
|
|
2023-09-08 14:48:33 +08:00
|
|
|
The `text-ci` make target automatically skips test with the `flaky` keyword.
|
|
|
|
|
|
|
|
Tests that have strict timing dependencies have the `timing-dependent` keyword.
|
|
|
|
These are intended to eventually be treated specially on CI builds which are
|
|
|
|
often run on overloaded machines with unpredictable timing.
|
|
|
|
|
2020-04-20 00:10:41 +08:00
|
|
|
## `<reply>`
|
|
|
|
|
2022-12-01 16:21:04 +08:00
|
|
|
### `<data [nocheck="yes"] [sendzero="yes"] [base64="yes"] [hex="yes"] [nonewline="yes"] [crlf="yes"]>`
|
2020-04-20 00:10:41 +08:00
|
|
|
|
|
|
|
data to be sent to the client on its request and later verified that it
|
|
|
|
arrived safely. Set `nocheck="yes"` to prevent the test script from verifying
|
|
|
|
the arrival of this data.
|
|
|
|
|
|
|
|
If the data contains `swsclose` anywhere within the start and end tag, and
|
2022-10-26 14:59:35 +08:00
|
|
|
this is an HTTP test, then the connection will be closed by the server after
|
2020-04-20 00:10:41 +08:00
|
|
|
this response is sent. If not, the connection will be kept persistent.
|
|
|
|
|
|
|
|
If the data contains `swsbounce` anywhere within the start and end tag, the
|
|
|
|
HTTP server will detect if this is a second request using the same test and
|
|
|
|
part number and will then increase the part number with one. This is useful
|
|
|
|
for auth tests and similar.
|
|
|
|
|
|
|
|
`sendzero=yes` means that the (FTP) server will "send" the data even if the
|
2020-12-31 17:11:49 +08:00
|
|
|
size is zero bytes. Used to verify curl's behavior on zero bytes transfers.
|
2020-04-20 00:10:41 +08:00
|
|
|
|
|
|
|
`base64=yes` means that the data provided in the test-file is a chunk of data
|
|
|
|
encoded with base64. It is the only way a test case can contain binary
|
|
|
|
data. (This attribute can in fact be used on any section, but it doesn't make
|
|
|
|
much sense for other sections than "data").
|
|
|
|
|
|
|
|
`hex=yes` means that the data is a sequence of hex pairs. It will get decoded
|
|
|
|
and used as "raw" data.
|
|
|
|
|
2021-02-09 21:04:32 +08:00
|
|
|
`nonewline=yes` means that the last byte (the trailing newline character)
|
|
|
|
should be cut off from the data before sending or comparing it.
|
|
|
|
|
2022-12-01 16:21:04 +08:00
|
|
|
`crlf=yes` forces *header* newlines to become CRLF even if not written so in
|
|
|
|
the source file. Note that this makes runtests.pl parse and "guess" what is a
|
|
|
|
header and what is not in order to apply the CRLF line endings appropriately.
|
|
|
|
|
2020-04-20 00:10:41 +08:00
|
|
|
For FTP file listings, the `<data>` section will be used *only* if you make
|
2022-09-21 05:30:19 +08:00
|
|
|
sure that there has been a CWD done first to a directory named `test-[NUM]`
|
|
|
|
where `NUM` is the test case number. Otherwise the ftp server can't know from
|
2020-04-20 00:10:41 +08:00
|
|
|
which test file to load the list content.
|
|
|
|
|
2022-12-01 16:21:04 +08:00
|
|
|
### `<dataNUM [crlf="yes"]>`
|
2020-04-20 00:10:41 +08:00
|
|
|
|
2023-09-01 07:25:26 +08:00
|
|
|
Send back this contents instead of the `<data>` one. The `NUM` is set by:
|
2020-04-20 00:10:41 +08:00
|
|
|
|
|
|
|
- The test number in the request line is >10000 and this is the remainder
|
|
|
|
of [test case number]%10000.
|
2022-09-21 05:30:19 +08:00
|
|
|
- The request was HTTP and included digest details, which adds 1000 to `NUM`
|
2022-10-26 14:59:35 +08:00
|
|
|
- If an HTTP request is NTLM type-1, it adds 1001 to `NUM`
|
|
|
|
- If an HTTP request is NTLM type-3, it adds 1002 to `NUM`
|
|
|
|
- If an HTTP request is Basic and `NUM` is already >=1000, it adds 1 to `NUM`
|
|
|
|
- If an HTTP request is Negotiate, `NUM` gets incremented by one for each
|
2020-04-20 00:10:41 +08:00
|
|
|
request with Negotiate authorization header on the same test case.
|
|
|
|
|
2022-09-21 05:30:19 +08:00
|
|
|
Dynamically changing `NUM` in this way allows the test harness to be used to
|
2020-04-20 00:10:41 +08:00
|
|
|
test authentication negotiation where several different requests must be sent
|
|
|
|
to complete a transfer. The response to each request is found in its own data
|
2022-09-19 23:30:30 +08:00
|
|
|
section. Validating the entire negotiation sequence can be done by specifying
|
2022-09-21 05:30:19 +08:00
|
|
|
a `datacheck` section.
|
2020-04-20 00:10:41 +08:00
|
|
|
|
|
|
|
### `<connect>`
|
|
|
|
The connect section is used instead of the 'data' for all CONNECT
|
|
|
|
requests. The remainder of the rules for the data section then apply but with
|
|
|
|
a connect prefix.
|
|
|
|
|
2022-01-03 20:33:46 +08:00
|
|
|
### `<socks>`
|
|
|
|
Address type and address details as logged by the SOCKS proxy.
|
|
|
|
|
2022-12-01 16:21:04 +08:00
|
|
|
### `<datacheck [mode="text"] [nonewline="yes"] [crlf="yes"]>`
|
2020-04-20 00:10:41 +08:00
|
|
|
if the data is sent but this is what should be checked afterwards. If
|
|
|
|
`nonewline=yes` is set, runtests will cut off the trailing newline from the
|
|
|
|
data before comparing with the one actually received by the client.
|
|
|
|
|
|
|
|
Use the `mode="text"` attribute if the output is in text mode on platforms
|
|
|
|
that have a text/binary difference.
|
|
|
|
|
2022-12-01 16:21:04 +08:00
|
|
|
### `<datacheckNUM [nonewline="yes"] [mode="text"] [crlf="yes"]>`
|
2022-09-21 05:30:19 +08:00
|
|
|
The contents of numbered `datacheck` sections are appended to the non-numbered
|
2020-04-20 00:10:41 +08:00
|
|
|
one.
|
|
|
|
|
|
|
|
### `<size>`
|
|
|
|
number to return on a ftp SIZE command (set to -1 to make this command fail)
|
|
|
|
|
|
|
|
### `<mdtm>`
|
2022-09-21 05:30:19 +08:00
|
|
|
what to send back if the client sends a (FTP) `MDTM` command, set to -1 to
|
2020-04-20 00:10:41 +08:00
|
|
|
have it return that the file doesn't exist
|
|
|
|
|
|
|
|
### `<postcmd>`
|
|
|
|
special purpose server-command to control its behavior *after* the
|
|
|
|
reply is sent
|
|
|
|
For HTTP/HTTPS, these are supported:
|
|
|
|
|
|
|
|
`wait [secs]` - Pause for the given time
|
|
|
|
|
|
|
|
### `<servercmd>`
|
|
|
|
Special-commands for the server.
|
|
|
|
|
2020-04-16 20:16:22 +08:00
|
|
|
The first line of this file will always be set to `Testnum [number]` by the
|
|
|
|
test script, to allow servers to read that to know what test the client is
|
|
|
|
about to issue.
|
|
|
|
|
2020-04-20 00:10:41 +08:00
|
|
|
#### For FTP/SMTP/POP/IMAP
|
|
|
|
|
|
|
|
- `REPLY [command] [return value] [response string]` - Changes how the server
|
|
|
|
responds to the [command]. [response string] is evaluated as a perl string,
|
|
|
|
so it can contain embedded \r\n, for example. There's a special [command]
|
|
|
|
named "welcome" (without quotes) which is the string sent immediately on
|
|
|
|
connect as a welcome.
|
|
|
|
- `REPLYLF` (like above but sends the response terminated with LF-only and not
|
|
|
|
CRLF)
|
|
|
|
- `COUNT [command] [num]` - Do the `REPLY` change for `[command]` only `[num]`
|
|
|
|
times and then go back to the built-in approach
|
|
|
|
- `DELAY [command] [secs]` - Delay responding to this command for the given
|
|
|
|
time
|
|
|
|
- `RETRWEIRDO` - Enable the "weirdo" RETR case when multiple response lines
|
|
|
|
appear at once when a file is transferred
|
|
|
|
- `RETRNOSIZE` - Make sure the RETR response doesn't contain the size of the
|
|
|
|
file
|
2022-11-10 23:20:28 +08:00
|
|
|
- `RETRSIZE [size]` - Force RETR response to contain the specified size
|
2020-04-20 00:10:41 +08:00
|
|
|
- `NOSAVE` - Don't actually save what is received
|
|
|
|
- `SLOWDOWN` - Send FTP responses with 0.01 sec delay between each byte
|
|
|
|
- `PASVBADIP` - makes PASV send back an illegal IP in its 227 response
|
|
|
|
- `CAPA [capabilities]` - Enables support for and specifies a list of space
|
|
|
|
separated capabilities to return to the client for the IMAP `CAPABILITY`,
|
|
|
|
POP3 `CAPA` and SMTP `EHLO` commands
|
|
|
|
- `AUTH [mechanisms]` - Enables support for SASL authentication and specifies
|
|
|
|
a list of space separated mechanisms for IMAP, POP3 and SMTP
|
2020-09-25 23:13:42 +08:00
|
|
|
- `STOR [msg]` respond with this instead of default after `STOR`
|
2020-04-20 00:10:41 +08:00
|
|
|
|
|
|
|
#### For HTTP/HTTPS
|
|
|
|
|
|
|
|
- `auth_required` if this is set and a POST/PUT is made without auth, the
|
|
|
|
server will NOT wait for the full request body to get sent
|
2023-08-22 05:10:25 +08:00
|
|
|
- `delay: [msecs]` - delay this amount after connection
|
2020-04-20 00:10:41 +08:00
|
|
|
- `idle` - do nothing after receiving the request, just "sit idle"
|
|
|
|
- `stream` - continuously send data to the client, never-ending
|
2022-05-11 17:14:18 +08:00
|
|
|
- `writedelay: [msecs]` delay this amount between reply packets
|
2020-04-20 00:10:41 +08:00
|
|
|
- `skip: [num]` - instructs the server to ignore reading this many bytes from
|
|
|
|
a PUT or POST request
|
|
|
|
- `rtp: part [num] channel [num] size [num]` - stream a fake RTP packet for
|
|
|
|
the given part on a chosen channel with the given payload size
|
|
|
|
- `connection-monitor` - When used, this will log `[DISCONNECT]` to the
|
|
|
|
`server.input` log when the connection is disconnected.
|
|
|
|
- `upgrade` - when an HTTP upgrade header is found, the server will upgrade to
|
|
|
|
http2
|
|
|
|
- `swsclose` - instruct server to close connection after response
|
|
|
|
- `no-expect` - don't read the request body if Expect: is present
|
|
|
|
|
|
|
|
#### For TFTP
|
|
|
|
`writedelay: [secs]` delay this amount between reply packets (each packet
|
|
|
|
being 512 bytes payload)
|
|
|
|
|
|
|
|
## `<client>`
|
|
|
|
|
|
|
|
### `<server>`
|
|
|
|
What server(s) this test case requires/uses. Available servers:
|
|
|
|
|
2022-09-29 01:56:31 +08:00
|
|
|
- `dict`
|
2020-04-20 00:10:41 +08:00
|
|
|
- `file`
|
|
|
|
- `ftp`
|
2022-09-29 01:56:31 +08:00
|
|
|
- `ftp-ipv6`
|
2020-04-20 00:10:41 +08:00
|
|
|
- `ftps`
|
2020-11-17 00:54:07 +08:00
|
|
|
- `gopher`
|
2022-09-29 01:56:31 +08:00
|
|
|
- `gopher-ipv6`
|
2020-11-17 00:54:07 +08:00
|
|
|
- `gophers`
|
2022-09-29 01:56:31 +08:00
|
|
|
- `http`
|
|
|
|
- `http/2`
|
2020-04-20 00:10:41 +08:00
|
|
|
- `http-ipv6`
|
|
|
|
- `http-proxy`
|
|
|
|
- `https`
|
2022-09-29 01:56:31 +08:00
|
|
|
- `https-proxy`
|
2020-04-20 00:10:41 +08:00
|
|
|
- `httptls+srp`
|
2022-09-29 01:56:31 +08:00
|
|
|
- `httptls+srp-ipv6`
|
|
|
|
- `http-unix`
|
2020-04-20 00:10:41 +08:00
|
|
|
- `imap`
|
|
|
|
- `mqtt`
|
|
|
|
- `none`
|
|
|
|
- `pop3`
|
|
|
|
- `rtsp`
|
2022-09-29 01:56:31 +08:00
|
|
|
- `rtsp-ipv6`
|
2020-04-20 00:10:41 +08:00
|
|
|
- `scp`
|
|
|
|
- `sftp`
|
2022-09-29 01:56:31 +08:00
|
|
|
- `smb`
|
2020-04-20 00:10:41 +08:00
|
|
|
- `smtp`
|
|
|
|
- `socks4`
|
|
|
|
- `socks5`
|
2022-09-29 01:56:31 +08:00
|
|
|
- `socks5unix`
|
|
|
|
- `telnet`
|
|
|
|
- `tftp`
|
|
|
|
|
|
|
|
Give only one per line. This subsection is mandatory (use `none` if no servers
|
|
|
|
are required). Servers that require a special server certificate can have the
|
|
|
|
PEM certificate file name (found in the `certs` directory) appended to the
|
|
|
|
server name separated by a space.
|
2020-04-20 00:10:41 +08:00
|
|
|
|
|
|
|
### `<features>`
|
|
|
|
A list of features that MUST be present in the client/library for this test to
|
|
|
|
be able to run. If a required feature is not present then the test will be
|
|
|
|
SKIPPED.
|
|
|
|
|
|
|
|
Alternatively a feature can be prefixed with an exclamation mark to indicate a
|
|
|
|
feature is NOT required. If the feature is present then the test will be
|
|
|
|
SKIPPED.
|
|
|
|
|
|
|
|
Features testable here are:
|
|
|
|
|
|
|
|
- `alt-svc`
|
2022-04-07 14:36:27 +08:00
|
|
|
- `bearssl`
|
2023-03-23 05:52:24 +08:00
|
|
|
- `brotli`
|
2020-11-27 00:24:24 +08:00
|
|
|
- `c-ares`
|
2023-03-23 05:52:24 +08:00
|
|
|
- `CharConv`
|
2020-05-27 20:28:51 +08:00
|
|
|
- `cookies`
|
2020-04-20 00:10:41 +08:00
|
|
|
- `crypto`
|
|
|
|
- `debug`
|
2020-05-27 20:28:51 +08:00
|
|
|
- `DoH`
|
2020-04-20 00:10:41 +08:00
|
|
|
- `getrlimit`
|
|
|
|
- `GnuTLS`
|
|
|
|
- `GSS-API`
|
2022-03-20 06:12:03 +08:00
|
|
|
- `h2c`
|
2023-03-23 05:52:24 +08:00
|
|
|
- `headers-api`
|
2020-11-03 06:17:01 +08:00
|
|
|
- `HSTS`
|
2020-05-27 20:28:51 +08:00
|
|
|
- `HTTP-auth`
|
2020-04-20 00:10:41 +08:00
|
|
|
- `http/2`
|
2023-03-23 05:52:24 +08:00
|
|
|
- `http/3`
|
|
|
|
- `https-proxy`
|
2020-12-11 17:26:06 +08:00
|
|
|
- `hyper`
|
2020-04-20 00:10:41 +08:00
|
|
|
- `idn`
|
|
|
|
- `ipv6`
|
|
|
|
- `Kerberos`
|
|
|
|
- `large_file`
|
2023-08-20 03:20:03 +08:00
|
|
|
- `large-time` (time_t is larger than 32 bit)
|
2020-04-20 00:10:41 +08:00
|
|
|
- `ld_preload`
|
2021-11-14 06:08:35 +08:00
|
|
|
- `libssh2`
|
|
|
|
- `libssh`
|
2022-03-06 21:13:34 +08:00
|
|
|
- `oldlibssh` (versions before 0.9.4)
|
2020-04-20 00:10:41 +08:00
|
|
|
- `libz`
|
|
|
|
- `manual`
|
2022-12-27 19:00:13 +08:00
|
|
|
- `mbedtls`
|
2020-05-27 20:28:51 +08:00
|
|
|
- `Mime`
|
|
|
|
- `netrc`
|
2023-03-23 05:52:24 +08:00
|
|
|
- `nghttpx`
|
|
|
|
- `nghttpx-h3`
|
2020-04-20 00:10:41 +08:00
|
|
|
- `NTLM`
|
2023-03-23 05:52:24 +08:00
|
|
|
- `NTLM_WB`
|
2020-04-20 00:10:41 +08:00
|
|
|
- `OpenSSL`
|
2020-05-27 20:28:51 +08:00
|
|
|
- `parsedate`
|
|
|
|
- `proxy`
|
2020-04-20 00:10:41 +08:00
|
|
|
- `PSL`
|
2022-01-09 18:59:10 +08:00
|
|
|
- `rustls`
|
2020-08-07 23:11:52 +08:00
|
|
|
- `Schannel`
|
2021-05-04 20:07:01 +08:00
|
|
|
- `sectransp`
|
2020-05-27 20:28:51 +08:00
|
|
|
- `shuffle-dns`
|
2020-04-20 00:10:41 +08:00
|
|
|
- `socks`
|
|
|
|
- `SPNEGO`
|
|
|
|
- `SSL`
|
|
|
|
- `SSLpinning`
|
|
|
|
- `SSPI`
|
|
|
|
- `threaded-resolver`
|
|
|
|
- `TLS-SRP`
|
|
|
|
- `TrackMemory`
|
2020-05-27 20:28:51 +08:00
|
|
|
- `typecheck`
|
2023-03-23 05:52:24 +08:00
|
|
|
- `threadsafe`
|
2021-01-21 02:08:49 +08:00
|
|
|
- `Unicode`
|
2020-04-20 00:10:41 +08:00
|
|
|
- `unittest`
|
|
|
|
- `unix-sockets`
|
2020-05-27 20:28:51 +08:00
|
|
|
- `verbose-strings`
|
2020-12-11 16:06:36 +08:00
|
|
|
- `wakeup`
|
2020-04-20 00:10:41 +08:00
|
|
|
- `win32`
|
2021-11-14 06:08:35 +08:00
|
|
|
- `wolfssh`
|
2022-01-09 23:23:56 +08:00
|
|
|
- `wolfssl`
|
2022-10-19 17:40:11 +08:00
|
|
|
- `xattr`
|
2023-03-23 05:52:24 +08:00
|
|
|
- `zstd`
|
2020-04-20 00:10:41 +08:00
|
|
|
|
2022-09-19 23:30:30 +08:00
|
|
|
as well as each protocol that curl supports. A protocol only needs to be
|
|
|
|
specified if it is different from the server (useful when the server is
|
|
|
|
`none`).
|
2020-04-20 00:10:41 +08:00
|
|
|
|
|
|
|
### `<killserver>`
|
|
|
|
Using the same syntax as in `<server>` but when mentioned here these servers
|
|
|
|
are explicitly KILLED when this test case is completed. Only use this if there
|
|
|
|
is no other alternatives. Using this of course requires subsequent tests to
|
|
|
|
restart servers.
|
|
|
|
|
|
|
|
### `<precheck>`
|
|
|
|
A command line that if set gets run by the test script before the test. If an
|
|
|
|
output is displayed by the command or if the return code is non-zero, the test
|
|
|
|
will be skipped and the (single-line) output will be displayed as reason for
|
2020-05-12 04:44:58 +08:00
|
|
|
not running the test.
|
2020-04-20 00:10:41 +08:00
|
|
|
|
|
|
|
### `<postcheck>`
|
|
|
|
A command line that if set gets run by the test script after the test. If
|
|
|
|
the command exists with a non-zero status code, the test will be considered
|
2020-05-12 04:44:58 +08:00
|
|
|
to have failed.
|
2020-04-20 00:10:41 +08:00
|
|
|
|
|
|
|
### `<tool>`
|
|
|
|
Name of tool to invoke instead of "curl". This tool must be built and exist
|
2022-09-21 05:30:19 +08:00
|
|
|
either in the `libtest/` directory (if the tool name starts with `lib`) or in
|
|
|
|
the `unit/` directory (if the tool name starts with `unit`).
|
2020-04-20 00:10:41 +08:00
|
|
|
|
|
|
|
### `<name>`
|
|
|
|
Brief test case description, shown when the test runs.
|
|
|
|
|
|
|
|
### `<setenv>`
|
|
|
|
variable1=contents1
|
|
|
|
variable2=contents2
|
2024-02-06 00:04:28 +08:00
|
|
|
variable3
|
2020-04-20 00:10:41 +08:00
|
|
|
|
|
|
|
Set the given environment variables to the specified value before the actual
|
2024-02-06 00:04:28 +08:00
|
|
|
command is run. They are restored back to their former values again after the
|
|
|
|
command has been run.
|
|
|
|
|
|
|
|
If the variable name has no assignment, no `=`, then that variable is just
|
|
|
|
deleted.
|
2020-05-12 04:44:58 +08:00
|
|
|
|
2020-09-15 21:42:56 +08:00
|
|
|
### `<command [option="no-output/no-include/force-output/binary-trace"] [timeout="secs"][delay="secs"][type="perl/shell"]>`
|
2020-05-12 04:44:58 +08:00
|
|
|
Command line to run.
|
2020-04-20 00:10:41 +08:00
|
|
|
|
|
|
|
Note that the URL that gets passed to the server actually controls what data
|
|
|
|
that is returned. The last slash in the URL must be followed by a number. That
|
|
|
|
number (N) will be used by the test-server to load test case N and return the
|
|
|
|
data that is defined within the `<reply><data></data></reply>` section.
|
|
|
|
|
|
|
|
If there's no test number found above, the HTTP test server will use the
|
|
|
|
number following the last dot in the given hostname (made so that a CONNECT
|
|
|
|
can still pass on test number) so that "foo.bar.123" gets treated as test case
|
|
|
|
123. Alternatively, if an IPv6 address is provided to CONNECT, the last
|
|
|
|
hexadecimal group in the address will be used as the test number! For example
|
|
|
|
the address "[1234::ff]" would be treated as test case 255.
|
|
|
|
|
|
|
|
Set `type="perl"` to write the test case as a perl script. It implies that
|
|
|
|
there's no memory debugging and valgrind gets shut off for this test.
|
|
|
|
|
2020-09-15 21:42:56 +08:00
|
|
|
Set `type="shell"` to write the test case as a shell script. It implies that
|
|
|
|
there's no memory debugging and valgrind gets shut off for this test.
|
|
|
|
|
2020-04-20 00:10:41 +08:00
|
|
|
Set `option="no-output"` to prevent the test script to slap on the `--output`
|
|
|
|
argument that directs the output to a file. The `--output` is also not added
|
|
|
|
if the verify/stdout section is used.
|
|
|
|
|
|
|
|
Set `option="force-output"` to make use of `--output` even when the test is
|
|
|
|
otherwise written to verify stdout.
|
|
|
|
|
|
|
|
Set `option="no-include"` to prevent the test script to slap on the
|
|
|
|
`--include` argument.
|
|
|
|
|
|
|
|
Set `option="binary-trace"` to use `--trace` instead of `--trace-ascii` for
|
2022-09-19 23:30:30 +08:00
|
|
|
tracing. Suitable for binary-oriented protocols such as MQTT.
|
2020-04-20 00:10:41 +08:00
|
|
|
|
|
|
|
Set `timeout="secs"` to override default server logs advisor read lock
|
2022-09-19 23:30:30 +08:00
|
|
|
timeout. This timeout is used by the test harness, once that the command has
|
2020-04-20 00:10:41 +08:00
|
|
|
completed execution, to wait for the test server to write out server side log
|
|
|
|
files and remove the lock that advised not to read them. The "secs" parameter
|
|
|
|
is the not negative integer number of seconds for the timeout. This `timeout`
|
|
|
|
attribute is documented for completeness sake, but is deep test harness stuff
|
2022-09-19 23:30:30 +08:00
|
|
|
and only needed for singular and specific test cases. Avoid using it.
|
2020-04-20 00:10:41 +08:00
|
|
|
|
|
|
|
Set `delay="secs"` to introduce a time delay once that the command has
|
|
|
|
completed execution and before the `<postcheck>` section runs. The "secs"
|
|
|
|
parameter is the not negative integer number of seconds for the delay. This
|
2022-09-19 23:30:30 +08:00
|
|
|
'delay' attribute is intended for specific test cases, and normally not
|
2020-04-20 00:10:41 +08:00
|
|
|
needed.
|
|
|
|
|
2023-03-29 09:20:54 +08:00
|
|
|
### `<file name="%LOGDIR/filename" [nonewline="yes"]>`
|
2020-04-20 00:10:41 +08:00
|
|
|
This creates the named file with this content before the test case is run,
|
2020-05-12 04:44:58 +08:00
|
|
|
which is useful if the test case needs a file to act on.
|
2020-04-20 00:10:41 +08:00
|
|
|
|
2022-09-21 05:30:19 +08:00
|
|
|
If `nonewline="yes"` is used, the created file will have the final newline
|
2020-09-15 20:45:08 +08:00
|
|
|
stripped off.
|
|
|
|
|
2020-04-20 00:10:41 +08:00
|
|
|
### `<stdin [nonewline="yes"]>`
|
|
|
|
Pass this given data on stdin to the tool.
|
|
|
|
|
2022-09-21 05:30:19 +08:00
|
|
|
If `nonewline` is set, we will cut off the trailing newline of this given data
|
2020-04-20 00:10:41 +08:00
|
|
|
before comparing with the one actually received by the client
|
|
|
|
|
|
|
|
## `<verify>`
|
|
|
|
### `<errorcode>`
|
|
|
|
numerical error code curl is supposed to return. Specify a list of accepted
|
|
|
|
error codes by separating multiple numbers with comma. See test 237 for an
|
|
|
|
example.
|
|
|
|
|
|
|
|
### `<strip>`
|
|
|
|
One regex per line that is removed from the protocol dumps before the
|
2022-09-19 23:30:30 +08:00
|
|
|
comparison is made. This is useful to remove dependencies on dynamically
|
2020-04-20 00:10:41 +08:00
|
|
|
changing protocol data such as port numbers or user-agent strings.
|
|
|
|
|
|
|
|
### `<strippart>`
|
|
|
|
One perl op per line that operates on the protocol dump. This is pretty
|
|
|
|
advanced. Example: `s/^EPRT .*/EPRT stripped/`.
|
|
|
|
|
2022-12-27 18:50:23 +08:00
|
|
|
### `<protocol [nonewline="yes"][crlf="yes"]>`
|
2020-04-20 00:10:41 +08:00
|
|
|
|
2022-09-21 05:30:19 +08:00
|
|
|
the protocol dump curl should transmit, if `nonewline` is set, we will cut off
|
2020-04-20 00:10:41 +08:00
|
|
|
the trailing newline of this given data before comparing with the one actually
|
2020-05-12 04:44:58 +08:00
|
|
|
sent by the client The `<strip>` and `<strippart>` rules are applied before
|
|
|
|
comparisons are made.
|
2020-04-20 00:10:41 +08:00
|
|
|
|
2022-12-01 16:21:04 +08:00
|
|
|
`crlf=yes` forces the newlines to become CRLF even if not written so in the
|
|
|
|
test.
|
|
|
|
|
2022-12-27 18:50:23 +08:00
|
|
|
### `<proxy [nonewline="yes"][crlf="yes"]>`
|
2020-04-20 00:10:41 +08:00
|
|
|
|
2022-10-26 14:59:35 +08:00
|
|
|
The protocol dump curl should transmit to an HTTP proxy (when the http-proxy
|
2022-09-21 05:30:19 +08:00
|
|
|
server is used), if `nonewline` is set, we will cut off the trailing newline
|
2020-04-20 00:10:41 +08:00
|
|
|
of this given data before comparing with the one actually sent by the client
|
2020-05-12 04:44:58 +08:00
|
|
|
The `<strip>` and `<strippart>` rules are applied before comparisons are made.
|
2020-04-20 00:10:41 +08:00
|
|
|
|
2020-06-18 15:46:38 +08:00
|
|
|
### `<stderr [mode="text"] [nonewline="yes"]>`
|
|
|
|
This verifies that this data was passed to stderr.
|
|
|
|
|
|
|
|
Use the mode="text" attribute if the output is in text mode on platforms that
|
|
|
|
have a text/binary difference.
|
|
|
|
|
2022-09-21 05:30:19 +08:00
|
|
|
If `nonewline` is set, we will cut off the trailing newline of this given data
|
2020-06-18 15:46:38 +08:00
|
|
|
before comparing with the one actually received by the client
|
|
|
|
|
2023-08-02 06:02:43 +08:00
|
|
|
### `<stdout [mode="text"] [nonewline="yes"] [crlf="yes"] [loadfile="filename"]>`
|
2020-05-12 04:44:58 +08:00
|
|
|
This verifies that this data was passed to stdout.
|
2020-04-20 00:10:41 +08:00
|
|
|
|
|
|
|
Use the mode="text" attribute if the output is in text mode on platforms that
|
|
|
|
have a text/binary difference.
|
|
|
|
|
2022-09-21 05:30:19 +08:00
|
|
|
If `nonewline` is set, we will cut off the trailing newline of this given data
|
2020-04-20 00:10:41 +08:00
|
|
|
before comparing with the one actually received by the client
|
|
|
|
|
2022-12-01 16:21:04 +08:00
|
|
|
`crlf=yes` forces the newlines to become CRLF even if not written so in the
|
|
|
|
test.
|
|
|
|
|
2023-08-02 06:02:43 +08:00
|
|
|
`loadfile="filename"` makes loading the data from an external file.
|
|
|
|
|
2023-03-29 09:20:54 +08:00
|
|
|
### `<file name="%LOGDIR/filename" [mode="text"]>`
|
2022-09-19 23:30:30 +08:00
|
|
|
The file's contents must be identical to this after the test is complete. Use
|
2020-04-20 00:10:41 +08:00
|
|
|
the mode="text" attribute if the output is in text mode on platforms that have
|
2020-05-12 04:44:58 +08:00
|
|
|
a text/binary difference.
|
2020-04-20 00:10:41 +08:00
|
|
|
|
|
|
|
### `<file1>`
|
|
|
|
1 to 4 can be appended to 'file' to compare more files.
|
|
|
|
|
|
|
|
### `<file2>`
|
|
|
|
|
|
|
|
### `<file3>`
|
|
|
|
|
|
|
|
### `<file4>`
|
|
|
|
|
|
|
|
### `<stripfile>`
|
|
|
|
One perl op per line that operates on the output file or stdout before being
|
|
|
|
compared with what is stored in the test file. This is pretty
|
|
|
|
advanced. Example: "s/^EPRT .*/EPRT stripped/"
|
|
|
|
|
|
|
|
### `<stripfile1>`
|
2023-09-01 07:25:26 +08:00
|
|
|
1 to 4 can be appended to `stripfile` to strip the corresponding `<fileN>`
|
2020-04-20 00:10:41 +08:00
|
|
|
content
|
|
|
|
|
|
|
|
### `<stripfile2>`
|
|
|
|
|
|
|
|
### `<stripfile3>`
|
|
|
|
|
|
|
|
### `<stripfile4>`
|
|
|
|
|
|
|
|
### `<upload>`
|
|
|
|
the contents of the upload data curl should have sent
|
|
|
|
|
|
|
|
### `<valgrind>`
|
|
|
|
disable - disables the valgrind log check for this test
|