source: src/Parser/Parameters/unittests/ContinuousValueUnitTest.cpp@ a636f8

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 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 a636f8 was 0aa122, checked in by Frederik Heber <heber@…>, 13 years ago

Updated all source files's copyright note to current year 2012.

  • Property mode set to 100644
File size: 6.2 KB
Line 
1/*
2 * Project: MoleCuilder
3 * Description: creates and alters molecular systems
4 * Copyright (C) 2010-2012 University of Bonn. All rights reserved.
5 * Please see the LICENSE file or "Copyright notice" in builder.cpp for details.
6 */
7
8/*
9 * ContinuousValueUnitTest.cpp
10 *
11 * Created on: Sep 29, 2011
12 * Author: heber
13 */
14
15// include config.h
16#ifdef HAVE_CONFIG_H
17#include <config.h>
18#endif
19
20#include "ContinuousValueUnitTest.hpp"
21
22#include <cppunit/CompilerOutputter.h>
23#include <cppunit/extensions/TestFactoryRegistry.h>
24#include <cppunit/ui/text/TestRunner.h>
25
26#include "Parser/Parameters/ContinuousValue.hpp"
27
28#include "CodePatterns/toString.hpp"
29
30#ifdef HAVE_TESTRUNNER
31#include "UnitTestMain.hpp"
32#endif /*HAVE_TESTRUNNER*/
33
34// Registers the fixture into the 'registry'
35CPPUNIT_TEST_SUITE_REGISTRATION( ContinuousValueTest );
36
37
38void ContinuousValueTest::setUp()
39{
40 // failing asserts should be thrown
41 ASSERT_DO(Assert::Throw);
42
43 ValidRange = new range<int>(1,4);
44}
45
46void ContinuousValueTest::tearDown()
47{
48 delete ValidRange;
49}
50
51/************************************ tests ***********************************/
52
53/** Unit test for isValid.
54 *
55 */
56void ContinuousValueTest::isValidValueTest()
57{
58 // create instance
59 ContinuousValue<int> test(*ValidRange);
60
61 // checking valid values
62 for (int i=1; i<=4;++i)
63 CPPUNIT_ASSERT_EQUAL(true, test.isValidValue(i));
64
65 // checking invalid values
66 for (int i=-10; i<=0;++i)
67 CPPUNIT_ASSERT_EQUAL(false, test.isValidValue(i));
68 for (int i=5; i<=0;++i)
69 CPPUNIT_ASSERT_EQUAL(false, test.isValidValue(i));
70}
71
72/** Unit test for isValid.
73 *
74 */
75void ContinuousValueTest::isValidTest()
76{
77 // create instance
78 ContinuousValue<int> test(*ValidRange);
79
80 // checking valid values
81 for (int i=1; i<=4;++i)
82 CPPUNIT_ASSERT_EQUAL(true, test.isValid(toString(i)));
83
84 // checking invalid values
85 for (int i=-10; i<=0;++i)
86 CPPUNIT_ASSERT_EQUAL(false, test.isValid(toString(i)));
87 for (int i=5; i<=0;++i)
88 CPPUNIT_ASSERT_EQUAL(false, test.isValid(toString(i)));
89}
90
91/** Unit test for setting/getting valid range.
92 *
93 */
94void ContinuousValueTest::setgetValidRangeTest()
95{
96 {
97 // create instance
98 ContinuousValue<int> test(*ValidRange);
99
100 // extending range and checking
101 for (int i=5; i<=6;++i)
102 CPPUNIT_ASSERT_EQUAL(false, test.isValidValue(i));
103 test.setValidRange(range<int>(1,6));
104 for (int i=5; i<=6;++i)
105 CPPUNIT_ASSERT_EQUAL(true, test.isValidValue(i));
106 }
107
108 {
109 // create instance
110 ContinuousValue<int> test(*ValidRange);
111
112 // lowering range with set value
113 test.setValue(4);
114 CPPUNIT_ASSERT_EQUAL(true, test.ValueSet);
115#ifndef NDEBUG
116 std::cout << "The following Assert failures are intended and do not indicate a failure of the test." << std::endl;
117 CPPUNIT_ASSERT_THROW(test.setValidRange(range<int>(1,3)), Assert::AssertionFailure);
118#else
119 test.setValidRange(range<int>(1,3));
120#endif
121#ifndef NDEBUG
122 // no value is not set
123 std::cout << "The following Assert failures are intended and do not indicate a failure of the test." << std::endl;
124 CPPUNIT_ASSERT_THROW(test.get(), Assert::AssertionFailure);
125#endif
126 // value gets invalidated in either case
127 CPPUNIT_ASSERT_EQUAL(false, test.ValueSet);
128 }
129}
130
131/** Unit test for setValue and getValue.
132 *
133 */
134void ContinuousValueTest::settergetterValueTest()
135{
136 // create instance
137 ContinuousValue<int> test(*ValidRange);
138
139 // unset calling of get, throws
140#ifndef NDEBUG
141 std::cout << "The following Assert failures are intended and do not indicate a failure of the test." << std::endl;
142 CPPUNIT_ASSERT_THROW(test.getValue(), Assert::AssertionFailure);
143#endif
144
145 // setting invalid, throws
146#ifndef NDEBUG
147 std::cout << "The following Assert failures are intended and do not indicate a failure of the test." << std::endl;
148 CPPUNIT_ASSERT_THROW(test.setValue(5), Assert::AssertionFailure);
149#endif
150#ifndef NDEBUG
151 std::cout << "The following Assert failures are intended and do not indicate a failure of the test." << std::endl;
152 CPPUNIT_ASSERT_THROW(test.setValue(0), Assert::AssertionFailure);
153#endif
154
155 CPPUNIT_ASSERT_EQUAL(false, test.ValueSet);
156 // checking all valid ones
157 for (int i=1; i<=4;++i) {
158 test.setValue(i);
159 CPPUNIT_ASSERT_EQUAL(true, test.ValueSet);
160 CPPUNIT_ASSERT_EQUAL(i, test.getValue());
161 }
162}
163
164/** Unit test for setters and getters.
165 *
166 */
167void ContinuousValueTest::settergetterTest()
168{
169 // create instance
170 ContinuousValue<int> test(*ValidRange);
171
172 // unset calling of get, throws
173#ifndef NDEBUG
174 std::cout << "The following Assert failures are intended and do not indicate a failure of the test." << std::endl;
175 CPPUNIT_ASSERT_THROW(test.get(), Assert::AssertionFailure);
176#endif
177
178 // setting invalid, throws
179#ifndef NDEBUG
180 std::cout << "The following Assert failures are intended and do not indicate a failure of the test." << std::endl;
181 CPPUNIT_ASSERT_THROW(test.set(toString(5)), Assert::AssertionFailure);
182#endif
183#ifndef NDEBUG
184 std::cout << "The following Assert failures are intended and do not indicate a failure of the test." << std::endl;
185 CPPUNIT_ASSERT_THROW(test.set(toString(0)), Assert::AssertionFailure);
186#endif
187
188 // checking all valid ones
189 for (int i=1; i<=4;++i) {
190 test.set(toString(i));
191 CPPUNIT_ASSERT_EQUAL(toString(i), test.get());
192 }
193}
194
195/** Unit test for comparator.
196 *
197 */
198void ContinuousValueTest::comparatorTest()
199{
200 {
201 // create instance
202 ContinuousValue<int> test(*ValidRange);
203 ContinuousValue<int> instance(*ValidRange);
204 test.setValue(1);
205 instance.setValue(1);
206
207 // same value, same range
208 {
209 CPPUNIT_ASSERT(test == instance);
210 }
211
212 // different value, same range
213 {
214 const int oldvalue = instance.getValue();
215 instance.setValue(2);
216 CPPUNIT_ASSERT(test != instance);
217 instance.setValue(oldvalue);
218 }
219 }
220 {
221 ContinuousValue<int> test(*ValidRange);
222 range<int> OtherValidRange(1,5);
223 ContinuousValue<int> instance(OtherValidRange);
224
225 test.setValue(1);
226 instance.setValue(1);
227
228 // same value, same range
229 {
230 CPPUNIT_ASSERT(test != instance);
231 }
232
233 // different value, same range
234 {
235 const int oldvalue = instance.getValue();
236 instance.setValue(2);
237 CPPUNIT_ASSERT(test != instance);
238 instance.setValue(oldvalue);
239 }
240 }
241}
Note: See TracBrowser for help on using the repository browser.