source: src/documentation/tests/regression-tests.dox@ ee19b7

Add_FitFragmentPartialChargesAction Fix_ChargeSampling_PBC Fix_FitPartialCharges Fix_FitPotential_needs_atomicnumbers Fix_ParseParticles_split_forward_backward_Actions
Last change on this file since ee19b7 was caece4, checked in by Frederik Heber <heber@…>, 11 years ago

Enhanced documentation significantly.

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