- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
src/unittests/CountBondsUnitTest.cpp
rfe238c r920c70 16 16 #include <stdio.h> 17 17 #include <cstring> 18 19 #include "Helpers/Assert.hpp" 18 20 19 21 #include "analysis_bonds.hpp" … … 24 26 #include "molecule.hpp" 25 27 #include "periodentafel.hpp" 28 #include "World.hpp" 26 29 #include "CountBondsUnitTest.hpp" 30 31 #ifdef HAVE_TESTRUNNER 32 #include "UnitTestMain.hpp" 33 #endif /*HAVE_TESTRUNNER*/ 27 34 28 35 /********************************************** Test classes **************************************/ … … 36 43 atom *Walker = NULL; 37 44 38 // init private all pointers to zero39 molecules = NULL;40 TestMolecule1 = NULL;41 TestMolecule2 = NULL;42 hydrogen = NULL;43 oxygen = NULL;44 tafel = NULL;45 46 45 // construct element 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); 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"); 62 50 63 51 // construct molecule (water molecule) 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. ); 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. ); 69 58 TestMolecule1->AddAtom(Walker); 70 Walker = new atom(); 71 Walker->type = hydrogen; 72 Walker->node->Init(0.9658, 0., 0. ); 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. ); 73 63 TestMolecule1->AddAtom(Walker); 74 Walker = new atom(); 64 Walker = World::getInstance().createAtom(); 65 CPPUNIT_ASSERT(Walker != NULL && "could not create atom"); 75 66 Walker->type = oxygen; 76 Walker->node->Init(0., 0., 0. );67 *Walker->node = Vector(0., 0., 0. ); 77 68 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. ); 76 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. ); 81 TestMolecule2->AddAtom(Walker); 82 Walker = World::getInstance().createAtom(); 83 CPPUNIT_ASSERT(Walker != NULL && "could not create atom"); 84 Walker->type = oxygen; 85 *Walker->node = Vector(0., 0., 0. ); 86 TestMolecule2->AddAtom(Walker); 87 88 molecules = World::getInstance().getMolecules(); 89 CPPUNIT_ASSERT(molecules != NULL && "could not obtain list of molecules"); 78 90 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. );84 TestMolecule2->AddAtom(Walker);85 Walker = new atom();86 Walker->type = hydrogen;87 Walker->node->Init(0.9658, 0., 0. );88 TestMolecule2->AddAtom(Walker);89 Walker = new atom();90 Walker->type = oxygen;91 Walker->node->Init(0., 0., 0. );92 TestMolecule2->AddAtom(Walker);93 91 molecules->insert(TestMolecule2); 94 92 … … 103 101 // create a small file with table 104 102 BG = new BondGraph(true); 103 CPPUNIT_ASSERT(BG != NULL && "could not create BondGraph"); 105 104 106 105 // construct bond graphs … … 117 116 delete(BG); 118 117 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 118 World::purgeInstance(); 124 119 }; 125 120 … … 153 148 { 154 149 double *mirror = new double[3]; 150 CPPUNIT_ASSERT(mirror != NULL && "could not create array of doubles"); 155 151 for (int i=0;i<3;i++) 156 152 mirror[i] = -1.; … … 160 156 161 157 cout << "Case 1: offset of (3,0,0), hence angles are (104.5, 0, 75.5, 180) < 30." << endl; 162 Translator .Init(3,0,0);158 Translator = Vector(3,0,0); 163 159 TestMolecule2->Translate(&Translator); 164 160 CPPUNIT_ASSERT_EQUAL( 1 , CountHydrogenBridgeBonds(molecules, NULL) ); 165 161 CPPUNIT_ASSERT_EQUAL( 0 , CountHydrogenBridgeBonds(molecules, oxygen) ); 166 162 //OutputTestMolecule(TestMolecule2, "testmolecule2-1.xyz"); 167 Translator .Init(-3,0,0);163 Translator = Vector(-3,0,0); 168 164 TestMolecule2->Translate(&Translator); 169 165 170 166 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; 171 Translator .Init(0,3,0);167 Translator = Vector(0,3,0); 172 168 TestMolecule2->Translate(&Translator); 173 169 CPPUNIT_ASSERT_EQUAL( 1 , CountHydrogenBridgeBonds(molecules, NULL) ); 174 170 //OutputTestMolecule(TestMolecule2, "testmolecule2-2.xyz"); 175 Translator .Init(0,-3,0);171 Translator = Vector(0,-3,0); 176 172 TestMolecule2->Translate(&Translator); 177 173 178 174 cout << "Case 3: offset of (0,-3,0) and mirror, hence angle are (165.5, 90, 165.5, 90) > 30." << endl; 179 Translator .Init(0,-3,0);175 Translator = Vector(0,-3,0); 180 176 TestMolecule2->Scale((const double ** const)&mirror); 181 177 TestMolecule2->Translate(&Translator); 182 178 CPPUNIT_ASSERT_EQUAL( 0 , CountHydrogenBridgeBonds(molecules, NULL) ); 183 179 //OutputTestMolecule(TestMolecule2, "testmolecule2-3.xyz"); 184 Translator .Init(0,3,0);180 Translator = Vector(0,3,0); 185 181 TestMolecule2->Translate(&Translator); 186 182 TestMolecule2->Scale((const double ** const)&mirror); 187 183 188 184 cout << "Case 4: offset of (2,1,0), hence angle are (78, 26.6, 102, 153.4) < 30." << endl; 189 Translator .Init(2,1,0);185 Translator = Vector(2,1,0); 190 186 TestMolecule2->Translate(&Translator); 191 187 CPPUNIT_ASSERT_EQUAL( 1 , CountHydrogenBridgeBonds(molecules, NULL) ); 192 188 //OutputTestMolecule(TestMolecule2, "testmolecule2-4.xyz"); 193 Translator .Init(-2,-1,0);189 Translator = Vector(-2,-1,0); 194 190 TestMolecule2->Translate(&Translator); 195 191 196 192 cout << "Case 5: offset of (0,0,3), hence angle are (90, 90, 90, 90) > 30." << endl; 197 Translator .Init(0,0,3);193 Translator = Vector(0,0,3); 198 194 TestMolecule2->Translate(&Translator); 199 195 CPPUNIT_ASSERT_EQUAL( 0 , CountHydrogenBridgeBonds(molecules, NULL) ); 200 196 //OutputTestMolecule(TestMolecule2, "testmolecule2-5.xyz"); 201 Translator .Init(0,0,-3);197 Translator = Vector(0,0,-3); 202 198 TestMolecule2->Translate(&Translator); 203 199 204 200 cout << "Case 6: offset of (-3,0,0) and mirror, hence angle are (75.5, 180, 104.5, 180) > 30." << endl; 205 Translator .Init(-3,0,0);201 Translator = Vector(-3,0,0); 206 202 TestMolecule2->Scale((const double ** const)&mirror); 207 203 TestMolecule2->Translate(&Translator); 208 204 CPPUNIT_ASSERT_EQUAL( 0 , CountHydrogenBridgeBonds(molecules, NULL) ); 209 205 //OutputTestMolecule(TestMolecule2, "testmolecule2-6.xyz"); 210 Translator .Init(3,0,0);206 Translator = Vector(3,0,0); 211 207 TestMolecule2->Translate(&Translator); 212 208 TestMolecule2->Scale((const double ** const)&mirror); 213 209 214 210 cout << "Case 7: offset of (3,0,0) and mirror, hence angles are (104.5, 0, 104.5, 0) < 30, but interfering hydrogens." << endl; 215 Translator .Init(3,0,0);211 Translator = Vector(3,0,0); 216 212 TestMolecule2->Scale((const double ** const)&mirror); 217 213 TestMolecule2->Translate(&Translator); 218 214 CPPUNIT_ASSERT_EQUAL( 0 , CountHydrogenBridgeBonds(molecules, NULL) ); 219 215 //OutputTestMolecule(TestMolecule2, "testmolecule2-7.xyz"); 220 Translator .Init(-3,0,0);216 Translator = Vector(-3,0,0); 221 217 TestMolecule2->Translate(&Translator); 222 218 TestMolecule2->Scale((const double ** const)&mirror); 223 219 224 220 cout << "Case 8: offset of (0,3,0), hence angle are (14.5, 90, 14.5, 90) < 30, but interfering hydrogens." << endl; 225 Translator .Init(0,3,0);221 Translator = Vector(0,3,0); 226 222 TestMolecule2->Scale((const double ** const)&mirror); 227 223 TestMolecule2->Translate(&Translator); 228 224 //OutputTestMolecule(TestMolecule2, "testmolecule2-8.xyz"); 229 225 CPPUNIT_ASSERT_EQUAL( 0 , CountHydrogenBridgeBonds(molecules, NULL) ); 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 }; 226 Translator = Vector(0,-3,0); 227 TestMolecule2->Translate(&Translator); 228 TestMolecule2->Scale((const double ** const)&mirror); 229 230 delete[](mirror); 231 };
Note:
See TracChangeset
for help on using the changeset viewer.