| [19bc74] | 1 | /* | 
|---|
|  | 2 | * Project: MoleCuilder | 
|---|
|  | 3 | * Description: creates and alters molecular systems | 
|---|
|  | 4 | * Copyright (C)  2010 University of Bonn. All rights reserved. | 
|---|
|  | 5 | * Please see the LICENSE file or "Copyright notice" in builder.cpp for details. | 
|---|
|  | 6 | */ | 
|---|
|  | 7 |  | 
|---|
|  | 8 | /** | 
|---|
|  | 9 | * \file regression-tests.dox | 
|---|
|  | 10 | * | 
|---|
|  | 11 | * This file contains explanation how to write, launch and use regression tests. | 
|---|
|  | 12 | * | 
|---|
|  | 13 | * Created on: Oct 11, 2011 | 
|---|
|  | 14 | *    Author: heber | 
|---|
|  | 15 | */ | 
|---|
|  | 16 |  | 
|---|
|  | 17 |  | 
|---|
|  | 18 | /** | 
|---|
|  | 19 | * \page regressiontest "Regression tests" | 
|---|
|  | 20 | * | 
|---|
|  | 21 | * Regression test with this project are used to check on the functionality of | 
|---|
|  | 22 | * all Actions. The launch the MoleCuilder from the command line with a given | 
|---|
|  | 23 | * action and option and basically diff the output against a stored file with | 
|---|
|  | 24 | * the desired result. This should be the behavior of more than 90% of all | 
|---|
|  | 25 | * regression tests. | 
|---|
|  | 26 | * | 
|---|
| [750cff] | 27 | * \section regressiontest-structure Directory structure | 
|---|
| [19bc74] | 28 | * | 
|---|
|  | 29 | * They are contained in the source folder \b tests/regression. There are | 
|---|
|  | 30 | * categories containing a distinct folder for each action. The folder for the | 
|---|
|  | 31 | * test of a specific Action has the following structure: | 
|---|
|  | 32 | *  \li a folder \b pre contains all files required as input to the test. | 
|---|
|  | 33 | *  \li a folder \b post contains all output files against which we compare all | 
|---|
|  | 34 | *  or a number of resulting files. | 
|---|
|  | 35 | *  \li a test script \b testsuite-....at which is included in a similarly- | 
|---|
|  | 36 | *  named test script one directory level higher. | 
|---|
|  | 37 | * | 
|---|
| [750cff] | 38 | *  \section regressiontest-launch-all Launching all tests | 
|---|
| [19bc74] | 39 | * | 
|---|
|  | 40 | *  Launching all regression tests is as simple as: | 
|---|
|  | 41 | *  -# Enter the build directory | 
|---|
|  | 42 | *  -# There, enter \b tests/regression | 
|---|
|  | 43 | *  -# Run | 
|---|
|  | 44 | *  \code make check \endcode | 
|---|
| [750cff] | 45 | *  (at you liberty with option \a -j8 or similar for running the tests in | 
|---|
|  | 46 | *  parallel. | 
|---|
| [19bc74] | 47 | * | 
|---|
| [750cff] | 48 | *  \section regressiontest-launch-some Launching a specific tests | 
|---|
| [19bc74] | 49 | * | 
|---|
| [750cff] | 50 | *  Launching a single or just some of the tests is only a little bit more | 
|---|
|  | 51 | *  complicated. There are two options: either by the test number which however | 
|---|
|  | 52 | *  changes when new tests are added, and by keywords. | 
|---|
| [19bc74] | 53 | * | 
|---|
|  | 54 | *  Then proceed as follows: | 
|---|
|  | 55 | *  -# Enter the build directory | 
|---|
|  | 56 | *  -# There, enter \b tests/regression | 
|---|
|  | 57 | *  -# Run | 
|---|
|  | 58 | *  \code ../../../tests/regression/testsuite <option> AUTOTEST_PATH="<buildpath>/src" \endcode, | 
|---|
| [750cff] | 59 | *  where \a <option> is explained in the subsections below and \a <buildpath> | 
|---|
|  | 60 | *  is the build path (i.e. the variable \a AUTOTEST_PATH should contain the | 
|---|
|  | 61 | *  path to the executable). | 
|---|
| [19bc74] | 62 | * | 
|---|
| [750cff] | 63 | *  \subsection regressiontest-launch-by-number ... by number | 
|---|
| [19bc74] | 64 | * | 
|---|
|  | 65 | *    Tests can be launched by specifying their test number, e.g. then \a <option> | 
|---|
|  | 66 | *    might be \a 283 or \a 283-284 or \a 283,285-286 or alike | 
|---|
|  | 67 | * | 
|---|
| [750cff] | 68 | *  \subsection regressiontest-launch-by-keyword .. by keyword | 
|---|
|  | 69 | * | 
|---|
|  | 70 | *    Tests may as well be launched by some keywords, e.g. each Action has a | 
|---|
|  | 71 | *    specific token which is also one of its keyword (see above for the | 
|---|
|  | 72 | *    policy). I.e. we may launch the test on fill-void via the \a <option> | 
|---|
|  | 73 | *    \a -k \a fill-void. Also multiple keywords may be given. | 
|---|
|  | 74 | * | 
|---|
|  | 75 | * \section regressiontest-results Inspecting test results | 
|---|
| [19bc74] | 76 | * | 
|---|
| [750cff] | 77 | *  The testsuite can be launched with the additional option of \a -d which | 
|---|
|  | 78 | *  leaves the directory of the test present even though the test has passed | 
|---|
|  | 79 | *  for inspection. | 
|---|
| [19bc74] | 80 | * | 
|---|
| [750cff] | 81 | *  If a test fails, in whatever way it was launched, will leave in the build | 
|---|
|  | 82 | *  directory a folder \b tests/regression/testsuite.dir/<nr> where \a <nr> is | 
|---|
|  | 83 | *  the number of the test (padded maybe with some zeros). | 
|---|
|  | 84 | * | 
|---|
| [d0faa8] | 85 | * \subsection regressiontest-results-failures Typical failure causes | 
|---|
|  | 86 | * | 
|---|
|  | 87 | *  Here, we note down some typical failure causes: | 
|---|
|  | 88 | *  -# A test fails on installcheck on \code make distcheck \endcode: In the test | 
|---|
|  | 89 | *     a file is probably copied and then some work is done on it. Due to autoconf's | 
|---|
|  | 90 | *     distcheck policy, files copied from the archive are write-protected, hence | 
|---|
|  | 91 | *     cannot be modified. And so is the copy. The remedy is to add the line | 
|---|
|  | 92 | *     \code | 
|---|
|  | 93 | *     AT_CHECK([chmod u+w $file], 0) | 
|---|
|  | 94 | *     \endcode | 
|---|
|  | 95 | *     just after the copying to modify the write permission of the copied file \a $file | 
|---|
|  | 96 | *     and allow its modification. | 
|---|
|  | 97 | * | 
|---|
| [750cff] | 98 | * \section regressiontest-add Adding a new test | 
|---|
|  | 99 | * | 
|---|
| [6ffc0b] | 100 | *  The basic working is: have a input file, do something with it and compare | 
|---|
|  | 101 | *  to output file against a stored one. | 
|---|
|  | 102 | * | 
|---|
| [750cff] | 103 | *  \attention Name convention of files and directories, e.g. | 
|---|
|  | 104 | *  \b tests/regression/Parser/Pdb with \b testsuite-parser-pdb-save.at | 
|---|
|  | 105 | *  - the test directory should either be called as the token of the Action it | 
|---|
|  | 106 | *    tests or a unique and brief description but with no spaces, no dashes, | 
|---|
|  | 107 | *    but CamelCase (i.e. Capitalize each new word) | 
|---|
|  | 108 | *  - the test script file should be called as follows: | 
|---|
|  | 109 | *    -# testsuite-... | 
|---|
|  | 110 | *    -# ...each directory (non-capital letters) with a dash... | 
|---|
|  | 111 | *    -# ..the name of the test directory... | 
|---|
|  | 112 | *    -# a further description of there are multiple test scripts in the | 
|---|
|  | 113 | *      test directory. | 
|---|
|  | 114 | * | 
|---|
|  | 115 | *  Adding a new regression tests consists of the following items: | 
|---|
|  | 116 | *  -# Create a new folder in a matching category | 
|---|
|  | 117 | *  -# Create therein subfolders \b pre and \b post | 
|---|
|  | 118 | *  -# Create a test script where the name begins with \b testsuite- and contains | 
|---|
|  | 119 | *  category and the action token. See other test scripts to get an idea on how | 
|---|
|  | 120 | *  to write these and also look here (http://www.gnu.org/s/hello/manual/autoconf/Using-Autotest.html#Using-Autotest). | 
|---|
|  | 121 | *  -# In the command \a AT_KEYWORD which must be present you should given the | 
|---|
|  | 122 | *  token of the Action as it would be called from the command line (see below for | 
|---|
|  | 123 | *  the reason). | 
|---|
|  | 124 | *  -# Include your testscript in the one present one directory-level up. | 
|---|
|  | 125 | *  -# Also include your script in \b tests/scripts/Makefile.am such that the | 
|---|
|  | 126 | *  testsuite is automatically re-compiled when one of the test files has changed. | 
|---|
| [19bc74] | 127 | * | 
|---|
| [6ffc0b] | 128 | *  On how to write a testsuite test, we refer you to one of these .at files to get a | 
|---|
|  | 129 | *  notion and  here to have a reference of the possible autotest commands at hand. | 
|---|
|  | 130 | *  The scheme is always the same basically: | 
|---|
|  | 131 | *  \code | 
|---|
|  | 132 | * AT_SETUP([General test part - description of this testsuite section]) | 
|---|
|  | 133 | * AT_KEYWORDS([<some keywords>,<actionname>,[undo/redo]]) | 
|---|
|  | 134 | * ... | 
|---|
|  | 135 | * AT_CHECK([this], <return value>, [ignore], [ignore]) | 
|---|
|  | 136 | * AT_CHECK([that], <return value>, [stdout], [stderr]) | 
|---|
|  | 137 | * AT_CHECk([fgrep "test fine" stdout], 0, [ignore], ignore]) | 
|---|
|  | 138 | * ... | 
|---|
|  | 139 | * AT_CLEANUP #remove all temporary files | 
|---|
|  | 140 | * \endcode | 
|---|
|  | 141 | * where <return value> is some number the code returns to indicate everything | 
|---|
|  | 142 | * worked fine. The global theme is specified only once per .at file, file | 
|---|
|  | 143 | * AT_SETUP and AT_CLEANUP sort of embrace every specific test that you want to do. | 
|---|
|  | 144 | * Note that it is required to list the action name under AT_KEYWORDS and also | 
|---|
|  | 145 | * give undo oder redo as an additional keyword if the undo or redo of the action | 
|---|
|  | 146 | * is tested. It is advised to give further keywords, e.g. the directory name | 
|---|
|  | 147 | * giving the general theme of the tests (selection, analysis, ...). Also note | 
|---|
|  | 148 | * that all keywords are always lower-case! | 
|---|
|  | 149 | * | 
|---|
|  | 150 | * Note that testing the undo/redo-functionality of an Action is always placed | 
|---|
|  | 151 | * into the same test file along with the normal functionality but in different | 
|---|
|  | 152 | * tests (i.e. undo and redo each have their own AT_SETUP .. AT_CLEANUP wrapping). | 
|---|
|  | 153 | * | 
|---|
| [19bc74] | 154 | * | 
|---|
| [750cff] | 155 | * \date 2011-10-31 | 
|---|
| [19bc74] | 156 | * | 
|---|
|  | 157 | */ | 
|---|