{section: Testing HTCondor On Linux} Starting in 8.9.3, HTCondor tests can be invoked using the =ctest= framework. {subsection: Building HTCondor} This is a simple primer for building HTCondor; refer to BuildingHtcondorOnLinux for more in-depth build instructions. *NOTE*: Prior to 8.9.3, builds must be done IN-SOURCE if you want to run tests. Starting in 8.9.3, out-of-source builds are acceptable (preferable!). 1: Get the source code from any of the following locations: {code} git clone https://github.com/htcondor/htcondor.git # Source code can also be obtained from tarballs on HTCondor's website {endcode} 2: Compiling the code and tests.(See {wiki: BuildingHtcondorOnLinux} for more details on building the code and pre-requisites) {code} cd htcondor # change directory to the root of source tree ./configure_uw make install {endcode} Prior to 8.9.3, =make tests= is also required. {subsection: Running ctest} From the build directory, after creating a release directory via =make install= (or equivalent), run: {code} ctest {endcode} That's it! The tests should be idempotent - it should be safe to re-run them as many times as desired. If all the tests fail and the failures happened very quickly (i.e., no condor was launched), the first place to check is =Testing/Temporary/LastTest.log=. *NOTE*: Some tests failures cause a personal =condor_pool= to be leaked. If you have issues re-running the tests, try doing =killall condor_master=. Some =ctest= tips and tricks: {code} # Run 20 test cases in parallel: ctest -j 20 # Run all tests labelled `quick` (a bit of a misnomer in HTCondor...) ctest -L quick # Run all tests matching the regex `cmr`: ctest -R cmr {endcode} {subsection: Running Tests Prior to 8.9.3} For HTCondor 8.9.2 and prior, running tests require you to invoke the various perl scripts driectly. 1: Get the source code from any of the following locations: {code} git clone ssh://emperor-02.cs.wisc.edu/p/condor/repository/CONDOR_SRC.git # git on afs # OR From git clone https://github.com/htcondor/htcondor.git # github mirror, trails behind afs git by a few hours # Source code can also be obtained from tarballs on HTCondor's website {endcode} 2: Compiling the code and tests.(See {wiki: BuildingHtcondorOnLinux} for more details on building the code and pre-requisites) {code} cd CONDOR_SRC # change directory to the root of source tree ./configure_uw make install make tests {endcode} 3: Make Personal Condor in a new directory outside the source tree (lets call the directory personal_condor) {code} cd /release_dir/condor_install --make-personal-condor --local-dir=`pwd` # Please follow the step as is and run this command from personal_condor directory only {endcode} 4: Change /etc/condor_config as follows- *:: Modify RELEASE_DIR to point to *:: Modify LOCAL_DIR to point to /local.$(HOSTNAME) *:: Modify LOCAL_CONFIG_FILE to point to /local.$(HOSTNAME)/condor_config.local 6: Ready to run the tests! {code} source condor.sh # condor.sh is in # start the personal HTCondor, needed for some tests. condor_master -f condor_who -wait:60 "NumDead > 0 || AllAlive" cd /condor_tests ./run_test.pl -d . -t # for example # ./run_test.pl -d . -t job_test_scheddrotation.run {endcode} Always run tests with run_test.pl. Tests requirements are mentioned in a special file (Test_Requirements) which indicates which tests need to have HTCondor already running before running the test. certain tests may not want to run condor or may want to change the condor's configuration file before running so they will start condor themselves. At present, only the BatLab glue knows how to run multiple tests. {wiki: BatLabTest}.