This document is intended mostly for developers who wish to ensure that their changes to Bacula don't introduce bugs in the base code. However, you don't need to be a developer to run the regression scripts. They are simply shell scripts that drive Bacula through bconsole and then typically compare the input and output with diff.
You can find the existing regression script in the Bacula SVN on the SourceForge SVN in the project tree named regress. I strongly recommend that you check it out of the SVN because afterwards, you can easily get updates made to them.
To get started, we recommend that you create a directory named bacula, under which you will put the current source code and the current set of regression scripts. Below, we will describe how to set this up for the SVN trunk, but you can also set it up for any branch, such as the current Branch-2.2, where the currently released code resides.
The top level directory that we call bacula can be named anything you want. Note, all the standard regression scripts run as non-root and can be run on the same machine as a production Bacula system (Kern runs it this way).
To create the directory structure for the current trunk code and to checkout the necessary files, do the following (note, we assume you are working in your home directory in a non-root account):
cd mkdir bacula cd bacula svn checkout https://bacula.svn.sourceforge.net/svnroot/bacula/trunk/bacula svn checkout https://bacula.svn.sourceforge.net/svnroot/bacula/trunk/regress
This will get the base files that you need. The above should be needed only once. Thereafter to update to the latest code, you do:
cd bacula/bacula svn update cd ../regress svn update
If you want to test with SQLite and it is not installed on your system, you will need to download the latest depkgs release from Source Forge and unpack it into bacula/depkgs, then simply:
cd bacula/depkgs make
There are two different aspects of regression testing that this document will discuss: 1. Running the Regression Script, 2. Writing a Regression test.
There are a number of different tests that may be run, such as: the standard set that uses disk Volumes and runs under any userid; a small set of tests that write to tape; another set of tests where you must be root to run them. Normally, I run all my tests as non-root and very rarely run the root tests. The tests vary in length, and running the full tests including disk based testing, tape based testing, autochanger based testing, and multiple drive autochanger based testing can take 3 or 4 hours.
There is nothing you need to change in the source directory.
To begin:
cd bacula/regress
The very first time you are going to run the regression scripts, you will need to create a custom config file for your system. We suggest that you start by:
cp prototype.conf config
Then you can edit the config file directly.
# Where to get the source to be tested BACULA_SOURCE="${HOME}/bacula/bacula" # Where to send email !!!!! Change me !!!!!!! EMAIL=your-name@your-domain.com SMTP_HOST="localhost" # Full "default" path where to find sqlite (no quotes!) SQLITE3_DIR=${HOME}/bacula/depkgs/sqlite3 SQLITE_DIR=${HOME}/bacula/depkgs/sqlite TAPE_DRIVE="/dev/nst0" # if you don't have an autochanger set AUTOCHANGER to /dev/null AUTOCHANGER="/dev/sg0" # For two drive tests -- set to /dev/null if you do not have it TAPE_DRIVE1="/dev/null" # This must be the path to the autochanger including its name AUTOCHANGER_PATH="/usr/sbin/mtx" # Set your database here #WHICHDB="--with-sqlite=${SQLITE_DIR}" #WHICHDB="--with-sqlite3=${SQLITE3_DIR}" #WHICHDB="--with-mysql" WHICHDB="--with-postgresql" # Set this to "--with-tcp-wrappers" or "--without-tcp-wrappers" TCPWRAPPERS="--with-tcp-wrappers" # Set this to "" to disable OpenSSL support, "--with-openssl=yes" # to enable it, or provide the path to the OpenSSL installation, # eg "--with-openssl=/usr/local" OPENSSL="--with-openssl" # You may put your real host name here, but localhost is valid also # and it has the advantage that it works on a non-newtworked machine HOST="localhost"
--
with-postgresql''. For
MySQL use ``WHICHDB=''--
with-mysql``.
The advantage of using SQLite is that it is totally independent of any installation you may have running on your system, and there is no special configuration or authorization that must be done to run it. With both MySQL and PostgreSQL, you must pre-install the packages, initialize them and ensure that you have authorization to access the database and create and delete tables.
Once the above variables are set, you can build the Makefile by entering:
./config xxx.conf
Where xxx.conf is the name of the conf file containing your system parameters. This will build a Makefile from Makefile.in, and you should not need to do this again unless you want to change the database or other regression configuration parameter.
If you are using MySQL or PostgreSQL, you will need to establish an account with your database engine for the user name regress and you will need to manually create a database named regress that can be used by user name regress, which means you will have to give the user regress sufficient permissions to use the database named regress. There is no password on the regress account.
You have probably already done this procedure for the user name and database named bacula. If not, the manual describes roughly how to do it, and the scripts in bacula/regress/build/src/cats named create_mysql_database, create_postgresql_database, grant_mysql_privileges, and grant_postgresql_privileges may be of a help to you.
Generally, to do the above, you will need to run under root to be able to create databases and modify permissions within MySQL and PostgreSQL.
Every time the Bacula source code has changed, you will need to recompile it under the regression directory. You do so with:
make setup
The above will then copy the source code within the regression tree (in directory regress/build), configure it, and build it. There should be no errors. If there are, please correct them before continuing. From this point on, as long as you don't change the Bacula source code, you should not need to repeat any of the above steps. If you pull down a new version of the source code, simply run make setup again.
Once Bacula is built, you can run the basic disk only non-root regression test by entering:
make test
This will run the base set of tests using disk Volumes. If you are testing on a non-Linux machine several of the of the tests may not be run. In any case, as we add new tests, the number will vary. It will take about 1 hour and you don't need to be root to run these tests (I run under my regular userid). The result should be something similar to:
Test results ===== auto-label-test OK 12:31:33 ===== ===== backup-bacula-test OK 12:32:32 ===== ===== bextract-test OK 12:33:27 ===== ===== bscan-test OK 12:34:47 ===== ===== bsr-opt-test OK 12:35:46 ===== ===== compressed-test OK 12:36:52 ===== ===== compressed-encrypt-test OK 12:38:18 ===== ===== concurrent-jobs-test OK 12:39:49 ===== ===== data-encrypt-test OK 12:41:11 ===== ===== encrypt-bug-test OK 12:42:00 ===== ===== fifo-test OK 12:43:46 ===== ===== backup-bacula-fifo OK 12:44:54 ===== ===== differential-test OK 12:45:36 ===== ===== four-concurrent-jobs-test OK 12:47:39 ===== ===== four-jobs-test OK 12:49:22 ===== ===== incremental-test OK 12:50:38 ===== ===== query-test OK 12:51:37 ===== ===== recycle-test OK 12:53:52 ===== ===== restore2-by-file-test OK 12:54:53 ===== ===== restore-by-file-test OK 12:55:40 ===== ===== restore-disk-seek-test OK 12:56:29 ===== ===== six-vol-test OK 12:57:44 ===== ===== span-vol-test OK 12:58:52 ===== ===== sparse-compressed-test OK 13:00:00 ===== ===== sparse-test OK 13:01:04 ===== ===== two-jobs-test OK 13:02:39 ===== ===== two-vol-test OK 13:03:49 ===== ===== verify-vol-test OK 13:04:56 ===== ===== weird-files2-test OK 13:05:47 ===== ===== weird-files-test OK 13:06:33 ===== ===== migration-job-test OK 13:08:15 ===== ===== migration-jobspan-test OK 13:09:33 ===== ===== migration-volume-test OK 13:10:48 ===== ===== migration-time-test OK 13:12:59 ===== ===== hardlink-test OK 13:13:50 ===== ===== two-pool-test OK 13:18:17 ===== ===== fast-two-pool-test OK 13:24:02 ===== ===== two-volume-test OK 13:25:06 ===== ===== incremental-2disk OK 13:25:57 ===== ===== 2drive-incremental-2disk OK 13:26:53 ===== ===== scratch-pool-test OK 13:28:01 ===== Total time = 0:57:55 or 3475 secs
and the working tape tests are run with
make full_test
Test results ===== Bacula tape test OK ===== ===== Small File Size test OK ===== ===== restore-by-file-tape test OK ===== ===== incremental-tape test OK ===== ===== four-concurrent-jobs-tape OK ===== ===== four-jobs-tape OK =====
Each separate test is self contained in that it initializes to run Bacula from scratch (i.e. newly created database). It will also kill any Bacula session that is currently running. In addition, it uses ports 8101, 8102, and 8103 so that it does not intefere with a production system.
There are a number of other tests that can be run as well. All the tests are a simply shell script keep in the regress directory. For example the ''make test`` simply executes ./all-non-root-tests. The other tests, which are invoked by directly running the script are:
If you one or more tests fail, the line output will be similar to:
!!!!! concurrent-jobs-test failed!!! !!!!!
If you want to determine why the test failed, you will need to rerun the script with the debug output turned on. You do so by defining the environment variable REGRESS_DEBUG with commands such as:
REGRESS_DEBUG=1 export REGRESS_DEBUG
Then from the "regress" directory (all regression scripts assume that you have "regress" as the current directory), enter:
tests/test-name
where test-name should be the name of a test script -- for example: tests/backup-bacula-test.
If you wish to run a single test, you can simply:
cd regress tests/<name-of-test>
or, if the source code has been updated, you would do:
cd bacula/bacula svn update cd ../regress svn update make setup tests/backup-to-null
Any developer, who implements a major new feature, should write a regression test that exercises and validates the new feature. Each regression test is a complete test by itself. It terminates any running Bacula, initializes the database, starts Bacula, then runs the test by using the console program.
You can run any individual test by hand by cd'ing to the regress directory and entering:
tests/<test-name>
The directory structure of the regression tests is:
regress - Makefile, scripts to start tests |------ scripts - Scripts and conf files |-------tests - All test scripts are here | |------------------ -- All directories below this point are used | for testing, but are created from the | above directories and are removed with | "make distclean" | |------ bin - This is the install directory for | Bacula to be used testing |------ build - Where the Bacula source build tree is |------ tmp - Most temp files go here |------ working - Bacula working directory |------ weird-files - Weird files used in two of the tests.
If you want to write a new regression test, it is best to start with one of the existing test scripts, and modify it to do the new test.
When adding a new test, be extremely careful about adding anything to any of the daemons' configuration files. The reason is that it may change the prompts that are sent to the console. For example, adding a Pool means that the current scripts, which assume that Bacula automatically selects a Pool, will now be presented with a new prompt, so the test will fail. If you need to enhance the configuration files, consider making your own versions.
REGRESS_WAIT=1 export REGRESS_WAIT
Then executing the script. When the script prints the following line:
Start Bacula under debugger and enter anything when ready ...
You start the Bacula component you want to run under the debugger in a different shell window. For example:
cd .../regress/bin gdb bacula-sd (possibly set breakpoints, ...) run -s -f
Then enter any character in the window with the above message. An error message will appear saying that the daemon you are debugging is already running, which is the case. You can simply ignore the error message.
Kern Sibbald 2008-07-31