source: src/documentation/tests/regression-tests.dox@ 88c8ec

Action_Thermostats Add_AtomRandomPerturbation Add_FitFragmentPartialChargesAction Add_RotateAroundBondAction Add_SelectAtomByNameAction Added_ParseSaveFragmentResults AddingActions_SaveParseParticleParameters Adding_Graph_to_ChangeBondActions Adding_MD_integration_tests Adding_ParticleName_to_Atom Adding_StructOpt_integration_tests AtomFragments Automaking_mpqc_open AutomationFragmentation_failures Candidate_v1.5.4 Candidate_v1.6.0 Candidate_v1.6.1 Candidate_v1.7.0 ChangeBugEmailaddress ChangingTestPorts ChemicalSpaceEvaluator CombiningParticlePotentialParsing Combining_Subpackages Debian_Package_split Debian_package_split_molecuildergui_only Disabling_MemDebug Docu_Python_wait EmpiricalPotential_contain_HomologyGraph EmpiricalPotential_contain_HomologyGraph_documentation Enable_parallel_make_install Enhance_userguide Enhanced_StructuralOptimization Enhanced_StructuralOptimization_continued Example_ManyWaysToTranslateAtom Exclude_Hydrogens_annealWithBondGraph FitPartialCharges_GlobalError Fix_BoundInBox_CenterInBox_MoleculeActions Fix_ChargeSampling_PBC Fix_ChronosMutex Fix_FitPartialCharges Fix_FitPotential_needs_atomicnumbers Fix_ForceAnnealing Fix_IndependentFragmentGrids Fix_ParseParticles Fix_ParseParticles_split_forward_backward_Actions Fix_PopActions Fix_QtFragmentList_sorted_selection Fix_Restrictedkeyset_FragmentMolecule Fix_StatusMsg Fix_StepWorldTime_single_argument Fix_Verbose_Codepatterns Fix_fitting_potentials Fixes ForceAnnealing_goodresults ForceAnnealing_oldresults ForceAnnealing_tocheck ForceAnnealing_with_BondGraph ForceAnnealing_with_BondGraph_continued ForceAnnealing_with_BondGraph_continued_betteresults ForceAnnealing_with_BondGraph_contraction-expansion FragmentAction_writes_AtomFragments FragmentMolecule_checks_bonddegrees GeometryObjects Gui_Fixes Gui_displays_atomic_force_velocity ImplicitCharges IndependentFragmentGrids IndependentFragmentGrids_IndividualZeroInstances IndependentFragmentGrids_IntegrationTest IndependentFragmentGrids_Sole_NN_Calculation JobMarket_RobustOnKillsSegFaults JobMarket_StableWorkerPool JobMarket_unresolvable_hostname_fix MoreRobust_FragmentAutomation ODR_violation_mpqc_open PartialCharges_OrthogonalSummation PdbParser_setsAtomName PythonUI_with_named_parameters QtGui_reactivate_TimeChanged_changes Recreated_GuiChecks Rewrite_FitPartialCharges RotateToPrincipalAxisSystem_UndoRedo SaturateAtoms_findBestMatching SaturateAtoms_singleDegree StoppableMakroAction Subpackage_CodePatterns Subpackage_JobMarket Subpackage_LinearAlgebra Subpackage_levmar Subpackage_mpqc_open Subpackage_vmg Switchable_LogView ThirdParty_MPQC_rebuilt_buildsystem TrajectoryDependenant_MaxOrder TremoloParser_IncreasedPrecision TremoloParser_MultipleTimesteps TremoloParser_setsAtomName Ubuntu_1604_changes stable
Last change on this file since 88c8ec was 6ffc0b, checked in by Frederik Heber <heber@…>, 13 years ago

DOCU: Enhanced documentation of tests with information from TRAC.

  • Property mode set to 100644
File size: 6.4 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. 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 *
27 * \section regressiontest-structure Directory structure
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 *
38 * \section regressiontest-launch-all Launching all tests
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
45 * (at you liberty with option \a -j8 or similar for running the tests in
46 * parallel.
47 *
48 * \section regressiontest-launch-some Launching a specific tests
49 *
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.
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,
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).
62 *
63 * \subsection regressiontest-launch-by-number ... by number
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 *
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
76 *
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.
80 *
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 *
85 * \section regressiontest-add Adding a new test
86 *
87 * The basic working is: have a input file, do something with it and compare
88 * to output file against a stored one.
89 *
90 * \attention Name convention of files and directories, e.g.
91 * \b tests/regression/Parser/Pdb with \b testsuite-parser-pdb-save.at
92 * - the test directory should either be called as the token of the Action it
93 * tests or a unique and brief description but with no spaces, no dashes,
94 * but CamelCase (i.e. Capitalize each new word)
95 * - the test script file should be called as follows:
96 * -# testsuite-...
97 * -# ...each directory (non-capital letters) with a dash...
98 * -# ..the name of the test directory...
99 * -# a further description of there are multiple test scripts in the
100 * test directory.
101 *
102 * Adding a new regression tests consists of the following items:
103 * -# Create a new folder in a matching category
104 * -# Create therein subfolders \b pre and \b post
105 * -# Create a test script where the name begins with \b testsuite- and contains
106 * category and the action token. See other test scripts to get an idea on how
107 * to write these and also look here (http://www.gnu.org/s/hello/manual/autoconf/Using-Autotest.html#Using-Autotest).
108 * -# In the command \a AT_KEYWORD which must be present you should given the
109 * token of the Action as it would be called from the command line (see below for
110 * the reason).
111 * -# Include your testscript in the one present one directory-level up.
112 * -# Also include your script in \b tests/scripts/Makefile.am such that the
113 * testsuite is automatically re-compiled when one of the test files has changed.
114 *
115 * On how to write a testsuite test, we refer you to one of these .at files to get a
116 * notion and here to have a reference of the possible autotest commands at hand.
117 * The scheme is always the same basically:
118 * \code
119 * AT_SETUP([General test part - description of this testsuite section])
120 * AT_KEYWORDS([<some keywords>,<actionname>,[undo/redo]])
121 * ...
122 * AT_CHECK([this], <return value>, [ignore], [ignore])
123 * AT_CHECK([that], <return value>, [stdout], [stderr])
124 * AT_CHECk([fgrep "test fine" stdout], 0, [ignore], ignore])
125 * ...
126 * AT_CLEANUP #remove all temporary files
127 * \endcode
128 * where <return value> is some number the code returns to indicate everything
129 * worked fine. The global theme is specified only once per .at file, file
130 * AT_SETUP and AT_CLEANUP sort of embrace every specific test that you want to do.
131 * Note that it is required to list the action name under AT_KEYWORDS and also
132 * give undo oder redo as an additional keyword if the undo or redo of the action
133 * is tested. It is advised to give further keywords, e.g. the directory name
134 * giving the general theme of the tests (selection, analysis, ...). Also note
135 * that all keywords are always lower-case!
136 *
137 * Note that testing the undo/redo-functionality of an Action is always placed
138 * into the same test file along with the normal functionality but in different
139 * tests (i.e. undo and redo each have their own AT_SETUP .. AT_CLEANUP wrapping).
140 *
141 *
142 * \date 2011-10-31
143 *
144 */
Note: See TracBrowser for help on using the repository browser.