- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
src/unittests/CountBondsUnitTest.cpp
r920c70 rfe238c 16 16 #include <stdio.h> 17 17 #include <cstring> 18 19 #include "Helpers/Assert.hpp"20 18 21 19 #include "analysis_bonds.hpp" … … 26 24 #include "molecule.hpp" 27 25 #include "periodentafel.hpp" 28 #include "World.hpp"29 26 #include "CountBondsUnitTest.hpp" 30 31 #ifdef HAVE_TESTRUNNER32 #include "UnitTestMain.hpp"33 #endif /*HAVE_TESTRUNNER*/34 27 35 28 /********************************************** Test classes **************************************/ … … 43 36 atom *Walker = NULL; 44 37 38 // init private all pointers to zero 39 molecules = NULL; 40 TestMolecule1 = NULL; 41 TestMolecule2 = NULL; 42 hydrogen = NULL; 43 oxygen = NULL; 44 tafel = NULL; 45 45 46 // construct element 46 hydrogen = World::getInstance().getPeriode()->FindElement(1); 47 oxygen = World::getInstance().getPeriode()->FindElement(8); 48 CPPUNIT_ASSERT(hydrogen != NULL && "could not find element hydrogen"); 49 CPPUNIT_ASSERT(oxygen != NULL && "could not find element oxygen"); 47 hydrogen = new element; 48 hydrogen->Z = 1; 49 hydrogen->CovalentRadius = 0.23; 50 strcpy(hydrogen->name, "hydrogen"); 51 strcpy(hydrogen->symbol, "H"); 52 oxygen = new element; 53 oxygen->Z = 8; 54 oxygen->CovalentRadius = 0.68; 55 strcpy(oxygen->name, "oxygen"); 56 strcpy(oxygen->symbol, "O"); 57 58 // construct periodentafel 59 tafel = new periodentafel; 60 tafel->AddElement(hydrogen); 61 tafel->AddElement(oxygen); 50 62 51 63 // construct molecule (water molecule) 52 TestMolecule1 = World::getInstance().createMolecule(); 53 CPPUNIT_ASSERT(TestMolecule1 != NULL && "could not create first molecule"); 54 Walker = World::getInstance().createAtom(); 55 CPPUNIT_ASSERT(Walker != NULL && "could not create atom"); 56 Walker->type = hydrogen; 57 *Walker->node = Vector(-0.2418, 0.9350, 0. ); 64 molecules = new MoleculeListClass; 65 TestMolecule1 = new molecule(tafel); 66 Walker = new atom(); 67 Walker->type = hydrogen; 68 Walker->node->Init(-0.2418, 0.9350, 0. ); 58 69 TestMolecule1->AddAtom(Walker); 59 Walker = World::getInstance().createAtom(); 60 CPPUNIT_ASSERT(Walker != NULL && "could not create atom"); 61 Walker->type = hydrogen; 62 *Walker->node = Vector(0.9658, 0., 0. ); 70 Walker = new atom(); 71 Walker->type = hydrogen; 72 Walker->node->Init(0.9658, 0., 0. ); 63 73 TestMolecule1->AddAtom(Walker); 64 Walker = World::getInstance().createAtom(); 65 CPPUNIT_ASSERT(Walker != NULL && "could not create atom"); 74 Walker = new atom(); 66 75 Walker->type = oxygen; 67 *Walker->node = Vector(0., 0., 0. );76 Walker->node->Init(0., 0., 0. ); 68 77 TestMolecule1->AddAtom(Walker); 69 70 TestMolecule2 = World::getInstance().createMolecule(); 71 CPPUNIT_ASSERT(TestMolecule2 != NULL && "could not create second molecule"); 72 Walker = World::getInstance().createAtom(); 73 CPPUNIT_ASSERT(Walker != NULL && "could not create atom"); 74 Walker->type = hydrogen; 75 *Walker->node = Vector(-0.2418, 0.9350, 0. ); 78 molecules->insert(TestMolecule1); 79 80 TestMolecule2 = new molecule(tafel); 81 Walker = new atom(); 82 Walker->type = hydrogen; 83 Walker->node->Init(-0.2418, 0.9350, 0. ); 76 84 TestMolecule2->AddAtom(Walker); 77 Walker = World::getInstance().createAtom(); 78 CPPUNIT_ASSERT(Walker != NULL && "could not create atom"); 79 Walker->type = hydrogen; 80 *Walker->node = Vector(0.9658, 0., 0. ); 85 Walker = new atom(); 86 Walker->type = hydrogen; 87 Walker->node->Init(0.9658, 0., 0. ); 81 88 TestMolecule2->AddAtom(Walker); 82 Walker = World::getInstance().createAtom(); 83 CPPUNIT_ASSERT(Walker != NULL && "could not create atom"); 89 Walker = new atom(); 84 90 Walker->type = oxygen; 85 *Walker->node = Vector(0., 0., 0. );91 Walker->node->Init(0., 0., 0. ); 86 92 TestMolecule2->AddAtom(Walker); 87 88 molecules = World::getInstance().getMolecules();89 CPPUNIT_ASSERT(molecules != NULL && "could not obtain list of molecules");90 molecules->insert(TestMolecule1);91 93 molecules->insert(TestMolecule2); 92 94 … … 101 103 // create a small file with table 102 104 BG = new BondGraph(true); 103 CPPUNIT_ASSERT(BG != NULL && "could not create BondGraph");104 105 105 106 // construct bond graphs … … 116 117 delete(BG); 117 118 118 World::purgeInstance(); 119 // remove molecule 120 delete(molecules); 121 // note that all the atoms are cleaned by TestMolecule 122 delete(tafel); 123 // note that element is cleaned by periodentafel 119 124 }; 120 125 … … 148 153 { 149 154 double *mirror = new double[3]; 150 CPPUNIT_ASSERT(mirror != NULL && "could not create array of doubles");151 155 for (int i=0;i<3;i++) 152 156 mirror[i] = -1.; … … 156 160 157 161 cout << "Case 1: offset of (3,0,0), hence angles are (104.5, 0, 75.5, 180) < 30." << endl; 158 Translator = Vector(3,0,0);162 Translator.Init(3,0,0); 159 163 TestMolecule2->Translate(&Translator); 160 164 CPPUNIT_ASSERT_EQUAL( 1 , CountHydrogenBridgeBonds(molecules, NULL) ); 161 165 CPPUNIT_ASSERT_EQUAL( 0 , CountHydrogenBridgeBonds(molecules, oxygen) ); 162 166 //OutputTestMolecule(TestMolecule2, "testmolecule2-1.xyz"); 163 Translator = Vector(-3,0,0);167 Translator.Init(-3,0,0); 164 168 TestMolecule2->Translate(&Translator); 165 169 166 170 cout << "Case 2: offset of (0,3,0), hence angle are (14.5, 165.5, 90) < 30 (only three, because other 90 is missing due to first H01 only fulfilling H-bond criteria)." << endl; 167 Translator = Vector(0,3,0);171 Translator.Init(0,3,0); 168 172 TestMolecule2->Translate(&Translator); 169 173 CPPUNIT_ASSERT_EQUAL( 1 , CountHydrogenBridgeBonds(molecules, NULL) ); 170 174 //OutputTestMolecule(TestMolecule2, "testmolecule2-2.xyz"); 171 Translator = Vector(0,-3,0);175 Translator.Init(0,-3,0); 172 176 TestMolecule2->Translate(&Translator); 173 177 174 178 cout << "Case 3: offset of (0,-3,0) and mirror, hence angle are (165.5, 90, 165.5, 90) > 30." << endl; 175 Translator = Vector(0,-3,0);179 Translator.Init(0,-3,0); 176 180 TestMolecule2->Scale((const double ** const)&mirror); 177 181 TestMolecule2->Translate(&Translator); 178 182 CPPUNIT_ASSERT_EQUAL( 0 , CountHydrogenBridgeBonds(molecules, NULL) ); 179 183 //OutputTestMolecule(TestMolecule2, "testmolecule2-3.xyz"); 180 Translator = Vector(0,3,0);184 Translator.Init(0,3,0); 181 185 TestMolecule2->Translate(&Translator); 182 186 TestMolecule2->Scale((const double ** const)&mirror); 183 187 184 188 cout << "Case 4: offset of (2,1,0), hence angle are (78, 26.6, 102, 153.4) < 30." << endl; 185 Translator = Vector(2,1,0);189 Translator.Init(2,1,0); 186 190 TestMolecule2->Translate(&Translator); 187 191 CPPUNIT_ASSERT_EQUAL( 1 , CountHydrogenBridgeBonds(molecules, NULL) ); 188 192 //OutputTestMolecule(TestMolecule2, "testmolecule2-4.xyz"); 189 Translator = Vector(-2,-1,0);193 Translator.Init(-2,-1,0); 190 194 TestMolecule2->Translate(&Translator); 191 195 192 196 cout << "Case 5: offset of (0,0,3), hence angle are (90, 90, 90, 90) > 30." << endl; 193 Translator = Vector(0,0,3);197 Translator.Init(0,0,3); 194 198 TestMolecule2->Translate(&Translator); 195 199 CPPUNIT_ASSERT_EQUAL( 0 , CountHydrogenBridgeBonds(molecules, NULL) ); 196 200 //OutputTestMolecule(TestMolecule2, "testmolecule2-5.xyz"); 197 Translator = Vector(0,0,-3);201 Translator.Init(0,0,-3); 198 202 TestMolecule2->Translate(&Translator); 199 203 200 204 cout << "Case 6: offset of (-3,0,0) and mirror, hence angle are (75.5, 180, 104.5, 180) > 30." << endl; 201 Translator = Vector(-3,0,0);205 Translator.Init(-3,0,0); 202 206 TestMolecule2->Scale((const double ** const)&mirror); 203 207 TestMolecule2->Translate(&Translator); 204 208 CPPUNIT_ASSERT_EQUAL( 0 , CountHydrogenBridgeBonds(molecules, NULL) ); 205 209 //OutputTestMolecule(TestMolecule2, "testmolecule2-6.xyz"); 206 Translator = Vector(3,0,0);210 Translator.Init(3,0,0); 207 211 TestMolecule2->Translate(&Translator); 208 212 TestMolecule2->Scale((const double ** const)&mirror); 209 213 210 214 cout << "Case 7: offset of (3,0,0) and mirror, hence angles are (104.5, 0, 104.5, 0) < 30, but interfering hydrogens." << endl; 211 Translator = Vector(3,0,0);215 Translator.Init(3,0,0); 212 216 TestMolecule2->Scale((const double ** const)&mirror); 213 217 TestMolecule2->Translate(&Translator); 214 218 CPPUNIT_ASSERT_EQUAL( 0 , CountHydrogenBridgeBonds(molecules, NULL) ); 215 219 //OutputTestMolecule(TestMolecule2, "testmolecule2-7.xyz"); 216 Translator = Vector(-3,0,0);220 Translator.Init(-3,0,0); 217 221 TestMolecule2->Translate(&Translator); 218 222 TestMolecule2->Scale((const double ** const)&mirror); 219 223 220 224 cout << "Case 8: offset of (0,3,0), hence angle are (14.5, 90, 14.5, 90) < 30, but interfering hydrogens." << endl; 221 Translator = Vector(0,3,0);225 Translator.Init(0,3,0); 222 226 TestMolecule2->Scale((const double ** const)&mirror); 223 227 TestMolecule2->Translate(&Translator); 224 228 //OutputTestMolecule(TestMolecule2, "testmolecule2-8.xyz"); 225 229 CPPUNIT_ASSERT_EQUAL( 0 , CountHydrogenBridgeBonds(molecules, NULL) ); 226 Translator = Vector(0,-3,0); 227 TestMolecule2->Translate(&Translator); 228 TestMolecule2->Scale((const double ** const)&mirror); 229 230 delete[](mirror); 231 }; 230 Translator.Init(0,-3,0); 231 TestMolecule2->Translate(&Translator); 232 TestMolecule2->Scale((const double ** const)&mirror); 233 234 delete(mirror); 235 }; 236 237 238 /********************************************** Main routine **************************************/ 239 240 int main(int argc, char **argv) 241 { 242 // Get the top level suite from the registry 243 CppUnit::Test *suite = CppUnit::TestFactoryRegistry::getRegistry().makeTest(); 244 245 // Adds the test to the list of test to run 246 CppUnit::TextUi::TestRunner runner; 247 runner.addTest( suite ); 248 249 // Change the default outputter to a compiler error format outputter 250 runner.setOutputter( new CppUnit::CompilerOutputter( &runner.result(), 251 std::cerr ) ); 252 // Run the tests. 253 bool wasSucessful = runner.run(); 254 255 // Return error code 1 if the one of test failed. 256 return wasSucessful ? 0 : 1; 257 };
Note:
See TracChangeset
for help on using the changeset viewer.