Introduction ------------ For a developer, the simplest way of running most tests on a local machine from within the git repository is: make test This runs all unit tests (onnode, takeover, tool, eventscripts) and the tests against local daemons (simple) using the script tests/run_tests.sh. When running tests against a real or virtual cluster the script tests/run_cluster_tests.sh can be used. This runs all integration tests (simple, complex). Both of these scripts can also take a list of tests to run. You can also pass options, which are then passed to run_tests. However, if you just try to pass options to run_tests then you lose the default list of tests that are run. You can't have everything... tests/run_tests.sh ------------------ This script can be used to manually run all or selected unit tests and simple integration tests against local daemons. Test selection is done by specifying optional call parameters. If no parameter is given, all unit tests and simple integration tests are run. This runs all unit tests of the "tool" category: ./tests/run_tests.sh tool In order to run a single test, one simply specifies the path of the test script to run as the last parameter, e.g.: ./tests/run_tests.sh ./tests/eventscripts/00.ctdb.monitor.001 ./tests/run_tests.sh ./tests/simple/76_ctdb_pdb_recovery.sh One can also specify multiple test suites and tests: ./tests/run_tests.sh eventscripts tool ./tests/onnode/0001.sh The script also has number of command-line switches. Some of the more useful options include: -s Print a summary of tests results after running all tests -l Use local daemons for integration tests This allows the tests in "simple" to be run against local daemons. All integration tests communicate with cluster nodes using onnode or the ctdb tool, which both have some test hooks to support local daemons. By default 3 daemons are used. If you want to use a different number of daemons then do not use this option but set TEST_LOCAL_DAEMONS to the desired number of daemons instead. The -l option just sets TEST_LOCAL_DAEMONS to 3... :-) -e Exit on the first test failure -C Clean up - kill daemons and remove $TEST_VAR_DIR when done Tests uses a temporary/var directory for test state. By default, this directory is not removed when tests are complete, so you can do forensics or, for integration tests, re-run tests that have failed against the same directory (with the same local daemons setup). So this option cleans things up. Also kills local daemons associated with directory. -V Use