Changelog
+Dan F (30 April 2007)
+- Improved the test harness to allow running test servers on other than
+ the default port numbers, allowing more than one test suite to run
+ simultaneously on the same host.
+
Daniel S (28 April 2007)
- Peter O'Gorman fixed libcurl to not init GnuTLS as early as we did before,
since it then inits libgcrypt and libgcrypt is being evil and EXITS the
the protocol dump curl should transmit, if 'nonewline' is set, we will cut
off the trailing newline of this given data before comparing with the one
actually sent by the client
+Variables are substituted as in the <command> section.
</protocol>
<stdout [mode="text"]>
This verifies that this data was passed to stdout.
stunnel (for HTTPS and FTPS tests)
sshd (for SCP and SFTP tests; OpenSSH ver. 3.8 is known to work)
-TCP ports used:
+TCP ports used by default:
- 8990 on localhost for HTTP tests
- 8991 on localhost for HTTPS tests
The test suite runs simple FTP, HTTP and TFTP servers on these ports to
which it makes requests. For SSL tests, it runs stunnel to handle
encryption to the regular servers. For SSH, it runs a standard OpenSSH
- server.
+ server.
+
+ The base port number shown above can be changed using runtests' -b option
+ to allow running more than one instance of the test suite simultaneously
+ on one machine.
Run:
'make test'. This invokes the 'runtests.pl' perl script. Edit the top
<command option="no-output">
"http://%HOSTIP:%HTTPPORT/[2-1]" -o "log/weee#1.dump" --stderr -
</command>
+# The error message on stdout implicitly depends on the length of the
+# URL, so refuse to run if the length is unexpected.
+<precheck>
+perl %SRCDIR/libtest/test75.pl http://%HOSTIP:%HTTPPORT/ 22
+</precheck>
</client>
#
LIBDIR = $(top_builddir)/lib
-EXTRA_DIST = test307.pl
+EXTRA_DIST = test75.pl test307.pl test610.pl
# files used only in some libcurl test programs
TESTUTIL = testutil.c testutil.h
--- /dev/null
+#!/usr/bin/env perl
+# Check that the length of a given URL is correct
+if ( $#ARGV != 1 )
+{
+ print "Usage: $0 string length\n";
+ exit 3;
+}
+if (length(@ARGV[0]) != @ARGV[1])
+{
+ print "Given host IP and port not supported\n";
+ exit 1;
+}
+exit 0;
# verbose output
$verbose=1;
}
+ elsif($ARGV[0] =~ /^-b(.*)/) {
+ my $portno=$1;
+ if($portno =~ s/(\d+)$//) {
+ $base = int $1;
+ }
+ }
elsif ($ARGV[0] eq "-c") {
# use this path to curl instead of default
$DBGCURL=$CURL=$ARGV[1];
elsif($ARGV[0] eq "-h") {
# show help text
print <<EOHELP
-Usage: runtests.pl [options]
+Usage: runtests.pl [options] [test number(s)]
-a continue even if a test fails
+ -bN use base port number N for test servers (default $base)
+ -c path use this curl executable
-d display server debug info
-g run the test case with gdb
-h this help text
-k keep stdout and stderr files present after tests
-l list all test case names/descriptions
- -n No valgrind
- -p Print log file contents when a test fails
+ -n no valgrind
+ -p print log file contents when a test fails
-s short output
- -t torture
+ -t[N] torture (simulate memory alloc failures); N means fail Nth alloc
-v verbose output
[num] like "5 6 9" or " 5 to 22 " to run those tests only
- ![num] like "!5 !6 !9" to disable those tests
+ [!num] like "!5 !6 !9" to disable those tests
EOHELP
;
exit;