Ignore:
File:
1 edited

Legend:

Unmodified
Added
Removed
  • src/unittests/CountBondsUnitTest.cpp

    r920c70 rfe238c  
    1616#include <stdio.h>
    1717#include <cstring>
    18 
    19 #include "Helpers/Assert.hpp"
    2018
    2119#include "analysis_bonds.hpp"
     
    2624#include "molecule.hpp"
    2725#include "periodentafel.hpp"
    28 #include "World.hpp"
    2926#include "CountBondsUnitTest.hpp"
    30 
    31 #ifdef HAVE_TESTRUNNER
    32 #include "UnitTestMain.hpp"
    33 #endif /*HAVE_TESTRUNNER*/
    3427
    3528/********************************************** Test classes **************************************/
     
    4336  atom *Walker = NULL;
    4437
     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
    4546  // 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);
    5062
    5163  // 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. );
    5869  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. );
    6373  TestMolecule1->AddAtom(Walker);
    64   Walker = World::getInstance().createAtom();
    65   CPPUNIT_ASSERT(Walker != NULL && "could not create atom");
     74  Walker = new atom();
    6675  Walker->type = oxygen;
    67   *Walker->node = Vector(0., 0., 0. );
     76  Walker->node->Init(0., 0., 0. );
    6877  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. );
    7684  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. );
    8188  TestMolecule2->AddAtom(Walker);
    82   Walker = World::getInstance().createAtom();
    83   CPPUNIT_ASSERT(Walker != NULL && "could not create atom");
     89  Walker = new atom();
    8490  Walker->type = oxygen;
    85   *Walker->node = Vector(0., 0., 0. );
     91  Walker->node->Init(0., 0., 0. );
    8692  TestMolecule2->AddAtom(Walker);
    87 
    88   molecules = World::getInstance().getMolecules();
    89   CPPUNIT_ASSERT(molecules != NULL && "could not obtain list of molecules");
    90   molecules->insert(TestMolecule1);
    9193  molecules->insert(TestMolecule2);
    9294
     
    101103  // create a small file with table
    102104  BG = new BondGraph(true);
    103   CPPUNIT_ASSERT(BG != NULL && "could not create BondGraph");
    104105
    105106  // construct bond graphs
     
    116117  delete(BG);
    117118
    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
    119124};
    120125
     
    148153{
    149154  double *mirror = new double[3];
    150   CPPUNIT_ASSERT(mirror != NULL && "could not create array of doubles");
    151155  for (int i=0;i<3;i++)
    152156    mirror[i] = -1.;
     
    156160
    157161  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);
    159163  TestMolecule2->Translate(&Translator);
    160164  CPPUNIT_ASSERT_EQUAL( 1 , CountHydrogenBridgeBonds(molecules, NULL) );
    161165  CPPUNIT_ASSERT_EQUAL( 0 , CountHydrogenBridgeBonds(molecules, oxygen) );
    162166  //OutputTestMolecule(TestMolecule2, "testmolecule2-1.xyz");
    163   Translator = Vector(-3,0,0);
     167  Translator.Init(-3,0,0);
    164168  TestMolecule2->Translate(&Translator);
    165169
    166170  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);
    168172  TestMolecule2->Translate(&Translator);
    169173  CPPUNIT_ASSERT_EQUAL( 1 , CountHydrogenBridgeBonds(molecules, NULL) );
    170174  //OutputTestMolecule(TestMolecule2, "testmolecule2-2.xyz");
    171   Translator = Vector(0,-3,0);
     175  Translator.Init(0,-3,0);
    172176  TestMolecule2->Translate(&Translator);
    173177
    174178  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);
    176180  TestMolecule2->Scale((const double ** const)&mirror);
    177181  TestMolecule2->Translate(&Translator);
    178182  CPPUNIT_ASSERT_EQUAL( 0 , CountHydrogenBridgeBonds(molecules, NULL) );
    179183  //OutputTestMolecule(TestMolecule2, "testmolecule2-3.xyz");
    180   Translator = Vector(0,3,0);
     184  Translator.Init(0,3,0);
    181185  TestMolecule2->Translate(&Translator);
    182186  TestMolecule2->Scale((const double ** const)&mirror);
    183187
    184188  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);
    186190  TestMolecule2->Translate(&Translator);
    187191  CPPUNIT_ASSERT_EQUAL( 1 , CountHydrogenBridgeBonds(molecules, NULL) );
    188192  //OutputTestMolecule(TestMolecule2, "testmolecule2-4.xyz");
    189   Translator = Vector(-2,-1,0);
     193  Translator.Init(-2,-1,0);
    190194  TestMolecule2->Translate(&Translator);
    191195
    192196  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);
    194198  TestMolecule2->Translate(&Translator);
    195199  CPPUNIT_ASSERT_EQUAL( 0 , CountHydrogenBridgeBonds(molecules, NULL) );
    196200  //OutputTestMolecule(TestMolecule2, "testmolecule2-5.xyz");
    197   Translator = Vector(0,0,-3);
     201  Translator.Init(0,0,-3);
    198202  TestMolecule2->Translate(&Translator);
    199203
    200204  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);
    202206  TestMolecule2->Scale((const double ** const)&mirror);
    203207  TestMolecule2->Translate(&Translator);
    204208  CPPUNIT_ASSERT_EQUAL( 0 , CountHydrogenBridgeBonds(molecules, NULL) );
    205209  //OutputTestMolecule(TestMolecule2, "testmolecule2-6.xyz");
    206   Translator = Vector(3,0,0);
     210  Translator.Init(3,0,0);
    207211  TestMolecule2->Translate(&Translator);
    208212  TestMolecule2->Scale((const double ** const)&mirror);
    209213
    210214  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);
    212216  TestMolecule2->Scale((const double ** const)&mirror);
    213217  TestMolecule2->Translate(&Translator);
    214218  CPPUNIT_ASSERT_EQUAL( 0 , CountHydrogenBridgeBonds(molecules, NULL) );
    215219  //OutputTestMolecule(TestMolecule2, "testmolecule2-7.xyz");
    216   Translator = Vector(-3,0,0);
     220  Translator.Init(-3,0,0);
    217221  TestMolecule2->Translate(&Translator);
    218222  TestMolecule2->Scale((const double ** const)&mirror);
    219223
    220224  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);
    222226  TestMolecule2->Scale((const double ** const)&mirror);
    223227  TestMolecule2->Translate(&Translator);
    224228  //OutputTestMolecule(TestMolecule2, "testmolecule2-8.xyz");
    225229  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
     240int 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.