2009-01-09 17:52:38 +11:00
Introduction
------------
2012-04-20 16:37:09 +10:00
For a developer, the simplest way of running most tests on a local
machine from within the git repository is:
2009-01-09 17:52:38 +11:00
2012-04-20 16:37:09 +10:00
make test
2009-01-09 17:52:38 +11:00
2019-09-18 16:32:40 +10:00
This runs all UNIT and INTEGRATION tests.
2009-01-09 17:52:38 +11:00
2013-11-29 10:15:20 +01:00
tests/run_tests.sh
------------------
2009-01-09 17:52:38 +11:00
2019-09-18 16:32:40 +10:00
This script can be used to manually run all tests or selected tests,
with a variety of options. For usage, run:
2013-11-29 10:15:20 +01:00
2019-09-18 16:32:40 +10:00
tests/run_tests.sh -h
2013-11-29 10:15:20 +01:00
2019-09-18 16:32:40 +10:00
If no tests are specified this runs all of the UNIT and INTEGRATION
tests.
2013-11-29 10:15:20 +01:00
2019-09-18 16:32:40 +10:00
By default:
2013-11-29 10:15:20 +01:00
2019-09-18 16:32:40 +10:00
* INTEGRATION tests are run against 3 local daemons
2013-11-29 10:15:20 +01:00
2019-09-18 16:32:40 +10:00
* When testing is complete, a summary showing a list is printed
showing the tests run and their results
2009-01-09 17:52:38 +11:00
2019-09-18 16:32:40 +10:00
Tests can be selected in various ways:
2009-01-09 17:52:38 +11:00
2019-09-18 16:32:40 +10:00
* tests/run_tests.sh UNIT INTEGRATION
2009-01-09 17:52:38 +11:00
2019-09-18 16:32:40 +10:00
runs all UNIT and INTEGRATION tests, and is like specifying no tests
2009-01-09 17:52:38 +11:00
2019-09-18 16:32:40 +10:00
* tests/run_tests.sh UNIT/tool
2009-01-09 17:52:38 +11:00
2019-09-18 16:32:40 +10:00
runs all of the "tool" UNIT tests
2009-01-09 17:52:38 +11:00
2019-09-18 16:32:40 +10:00
* tests/run_tests.sh tests/UNIT/eventscripts/00.ctdb.setup.001.sh
tests/run_tests.sh tests/INTEGRATION/simple/basics.001.listnodes.sh
2012-04-27 17:19:45 +10:00
2019-09-18 16:32:40 +10:00
each runs a single specified test case
2012-04-27 17:19:45 +10:00
2019-09-18 16:32:40 +10:00
* tests/run_tests.sh UNIT/eventscripts UNIT/tool tests/UNIT/onnode/0001.sh
2012-04-27 17:19:45 +10:00
2019-09-18 16:32:40 +10:00
runs a combination of UNIT test suites and a single UNIT test
2012-04-27 17:19:45 +10:00
2019-09-18 16:32:40 +10:00
Testing on a cluster
--------------------
2009-01-09 17:52:38 +11:00
2019-09-18 16:32:40 +10:00
INTEGRATION and CLUSTER tests can be run on a real or virtual cluster
using tests/run_cluster_tests.sh (or "tests/run_tests.sh -c"). The
test code needs to be available on all cluster nodes, as well as the
test client node. The test client node needs to have a nodes file
where the onnode(1) command will find it.
2009-01-09 17:52:38 +11:00
2012-04-20 16:37:09 +10:00
If the all of the cluster nodes have the CTDB git tree in the same
location as on the test client then no special action is necessary.
The simplest way of doing this is to share the tree to cluster nodes
and test clients via NFS.
2009-01-09 17:52:38 +11:00
2019-09-18 16:32:40 +10:00
Alternatively, the tests can be installed on all nodes. One technique
is to build a package containing the tests and install it on all
nodes. CTDB developers do a lot of testing this way using the
provided sample packaging, which produces a ctdb-tests RPM package.
2009-01-09 17:52:38 +11:00
2019-09-18 16:32:40 +10:00
Finally, if the test code is installed in a different place on the
cluster nodes, then CTDB_TEST_REMOTE_DIR can be set on the test client
node to point to a directory that contains the test_wrap script on the
cluster nodes.
2009-01-09 17:52:38 +11:00
2019-09-18 16:32:40 +10:00
Running tests under valgrind
----------------------------
2009-01-09 17:52:38 +11:00
2012-04-20 16:37:09 +10:00
The easiest way of doing this is something like:
2009-01-09 17:52:38 +11:00
2019-09-18 16:32:40 +10:00
VALGRIND="valgrind -q" tests/run_tests ...
2009-01-09 17:52:38 +11:00
2019-09-18 16:32:40 +10:00
This can be used to cause all invocations of the ctdb tool, test
programs and, with local daemons, the ctdbd daemons themselves to run
under valgrind.
2009-01-09 17:52:38 +11:00
2012-04-20 16:37:09 +10:00
How is the ctdb tool invoked?
-----------------------------
2009-01-09 17:52:38 +11:00
2012-04-20 16:37:09 +10:00
$CTDB determines how to invoke the ctdb client. If not already set
and if $VALGRIND is set, this is set to "$VALGRIND ctdb". If this is
not already set but $VALGRIND is not set, this is simply set to "ctdb"
2018-04-05 15:37:42 +10:00
Test and debugging variable options
-----------------------------------
CTDB_TEST_MODE
Set this environment variable to enable test mode.
2018-07-05 19:04:37 +10:00
This enables daemons and tools to locate their socket and
PID file relative to CTDB_BASE.
2018-04-05 15:37:42 +10:00
When testing with multiple local daemons on a single
2018-07-05 19:04:37 +10:00
machine this does 3 extra things:
2018-04-05 15:37:42 +10:00
* Disables checks related to public IP addresses
* Speeds up the initial recovery during startup at the
expense of some consistency checking
* Disables real-time scheduling
2018-04-05 16:12:31 +10:00
CTDB_DEBUG_HUNG_SCRIPT_LOGFILE=FILENAME
FILENAME specifies where log messages should go when
debugging hung eventscripts. This is a testing option. See
also CTDB_DEBUG_HUNG_SCRIPT.
No default. Messages go to stdout/stderr and are logged to
the same place as other CTDB log messages.
CTDB_SYS_ETCDIR=DIRECTORY
DIRECTORY containing system configuration files. This is
used to provide alternate configuration when testing and
should not need to be changed from the default.
Default is /etc.
CTDB_RUN_TIMEOUT_MONITOR=yes|no
Whether CTDB should simulate timing out monitor
2018-07-05 19:04:37 +10:00
events in local daemon tests.
2018-04-05 16:12:31 +10:00
Default is no.
2019-02-06 13:57:00 +11:00
CTDB_TEST_SAMBA_VERSION=VERSION
VERSION is a 32-bit number containg the Samba major
version in the most significant 16 bits and the minor
version in the least significant 16 bits. This can be
used to test CTDB's checking of incompatible versions
without installing an incompatible version. This is
probably best set like this:
export CTDB_TEST_SAMBA_VERSION=$(( (4 << 16) | 12 ))
2018-04-05 16:12:31 +10:00
CTDB_VARDIR=DIRECTORY
DIRECTORY containing CTDB files that are modified at runtime.
Defaults to /usr/local/var/lib/ctdb.