8053 beefd0184a 2022-08-08 ct_chen 2 rokov pred
..
.deps beefd0184a 2022-08-08 ct_chen 2 rokov pred
docroot beefd0184a 2022-08-08 ct_chen 2 rokov pred
CMakeLists.txt beefd0184a 2022-08-08 ct_chen 2 rokov pred
LightyTest.pm beefd0184a 2022-08-08 ct_chen 2 rokov pred
Makefile beefd0184a 2022-08-08 ct_chen 2 rokov pred
Makefile.am beefd0184a 2022-08-08 ct_chen 2 rokov pred
Makefile.in beefd0184a 2022-08-08 ct_chen 2 rokov pred
README beefd0184a 2022-08-08 ct_chen 2 rokov pred
SConscript beefd0184a 2022-08-08 ct_chen 2 rokov pred
cleanup.sh beefd0184a 2022-08-08 ct_chen 2 rokov pred
condition.conf beefd0184a 2022-08-08 ct_chen 2 rokov pred
core-condition.t beefd0184a 2022-08-08 ct_chen 2 rokov pred
fastcgi-responder.conf beefd0184a 2022-08-08 ct_chen 2 rokov pred
fcgi-responder.c beefd0184a 2022-08-08 ct_chen 2 rokov pred
lighttpd.conf beefd0184a 2022-08-08 ct_chen 2 rokov pred
lighttpd.htpasswd beefd0184a 2022-08-08 ct_chen 2 rokov pred
lighttpd.user beefd0184a 2022-08-08 ct_chen 2 rokov pred
meson.build beefd0184a 2022-08-08 ct_chen 2 rokov pred
mod-fastcgi.t beefd0184a 2022-08-08 ct_chen 2 rokov pred
mod-scgi.t beefd0184a 2022-08-08 ct_chen 2 rokov pred
prepare.sh beefd0184a 2022-08-08 ct_chen 2 rokov pred
proxy.conf beefd0184a 2022-08-08 ct_chen 2 rokov pred
request.t beefd0184a 2022-08-08 ct_chen 2 rokov pred
run-tests.pl beefd0184a 2022-08-08 ct_chen 2 rokov pred
scgi-responder.c beefd0184a 2022-08-08 ct_chen 2 rokov pred
scgi-responder.conf beefd0184a 2022-08-08 ct_chen 2 rokov pred
var-include-sub.conf beefd0184a 2022-08-08 ct_chen 2 rokov pred
wrapper.sh beefd0184a 2022-08-08 ct_chen 2 rokov pred

README

Running tests
-------------

$ make check

If run from tests/ dir, tests will fail to run tests if lighttpd not built.
If run from top level, 'make' will build lighttpd exectuable if not yet built,
and then will run tests.


Running individual tests programs
---------------------------------

prep
$ cd tests/
$ ./prepare.sh

then, for any particular *.t such as request.t,
$ ./request.t
or
$ VERBOSE=1 RUNTESTS=request ./run-tests.pl

More information is output by tests with additional environment settings:
$ TRACE_HTTP=1 ./request.t

See LightyTest.pm before trying TRACEME
$ less LightyTest.pm

$ TRACEME=strace ./request.t # output to file 'strace'
$ TRACEME=truss ./request.t # output to file 'strace'
$ TRACEME=gdb ./request.t # not for interactive debugging (see below)
$ TRACEME=valgrind ./request.t

To reduce noise from valgrind --show-leak-kinds=all (or =reachable), avoid FAM.
Use server.stat-cache-engine = "simple" (not server.stat-cache-engine = "fam")
in lighttpd.conf. (FAM creates /usr/libexec/gam_server as child process.)


Running lighttpd server with a config from tests/*.conf
-------------------------------------------------------

Each *.t loads the lighttpd server with one or more config files.
See each *.t for which config file is used, e.g. tests/lighttpd.conf

To run a specific config
repo=$PWD # from root of src repository
cd tests/
./prepare.sh
PERL=/usr/bin/perl SRCDIR=$repo/tests \
$repo/src/lighttpd -D -f lighttpd.conf -m $repo/src/.libs

The PERL, PHP, and SRCDIR environment variables are set by LightyTest.pm
when 'make check' is run. PERL and PHP can be set to paths to perl and php,
e.g. export PERL=/usr/bin/perl

To run a specific config under gdb
repo=$PWD # from root of src repository
cd tests/
./prepare.sh
PERL=/usr/bin/perl SRCDIR=$repo/tests \
gdb --args $repo/src/lighttpd -D -f lighttpd.conf -m $repo/src/.libs

(gdb) start
(gdb) ...


Hints and tips
--------------
Q: What do I do if tests fail with:
bind: Address already in use at LightyTest.pm line 429.
A: It is likely that something else on the machine is already using the port
that tests are trying to use to run a backend. Try exiting out of your web
browser and then run the tests again. (root can use 'netstat' or 'ss' to
find out which process is using the port.)


Additional documentation
------------------------
https://redmine.lighttpd.net/projects/lighttpd/wiki/RunningUnitTests
https://redmine.lighttpd.net/projects/lighttpd/wiki/HowToReportABug
https://redmine.lighttpd.net/projects/lighttpd/wiki/DebugVariables