source: src/Parser/unittests/ParserXyzUnitTest.cpp@ af3aed

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 af3aed was 006e1e, checked in by Frederik Heber <heber@…>, 14 years ago

FIX: ChangeTracker has not been observing AtomObserver so far.

  • This is introduced due to cleaning of observer structure.
  • FIX: Cleaned ChangeTracker declaration from false includes.
  • FIX: TextWindow.cpp lacked include World.
  • TESTFIX: All Parser...UnitTest needed to purge AtomObserver instance.
  • Property mode set to 100644
File size: 4.8 KB
RevLine 
[9e4fd1]1/*
2 * Project: MoleCuilder
3 * Description: creates and alters molecular systems
[0aa122]4 * Copyright (C) 2010-2012 University of Bonn. All rights reserved.
[9e4fd1]5 * Please see the LICENSE file or "Copyright notice" in builder.cpp for details.
6 */
7
8/*
9 * ParserXyzUnitTest.cpp
10 *
11 * Created on: Mar 3, 2010
12 * Author: metzler
13 */
14
15// include config.h
16#ifdef HAVE_CONFIG_H
17#include <config.h>
18#endif
19
20#include "ParserXyzUnitTest.hpp"
21
22#include <cppunit/CompilerOutputter.h>
23#include <cppunit/extensions/TestFactoryRegistry.h>
24#include <cppunit/ui/text/TestRunner.h>
25
[6f0841]26#include "Atom/atom.hpp"
[006e1e]27#include "Atom/AtomObserver.hpp"
[255829]28#include "CodePatterns/Log.hpp"
[9e4fd1]29#include "Descriptors/AtomTypeDescriptor.hpp"
[006e1e]30#include "Element/element.hpp"
31#include "Element/periodentafel.hpp"
[765f16]32#include "Parser/ChangeTracker.hpp"
33#include "Parser/XyzParser.hpp"
[006e1e]34#include "World.hpp"
[9e4fd1]35
36#ifdef HAVE_TESTRUNNER
37#include "UnitTestMain.hpp"
38#endif /*HAVE_TESTRUNNER*/
39
40using namespace std;
41
42// Registers the fixture into the 'registry'
43CPPUNIT_TEST_SUITE_REGISTRATION( ParserXyzUnitTest );
44
[0180d6]45static string waterXyz = "\
463\n\
47\tH2O: water molecule\n\
48O\t0\t0\t0\n\
49H\t0.758602\t0\t0.504284\n\
50H\t0.758602\t0\t-0.504284\n";
51static string waterMultiXyz = "\
523\n\
53\tH2O: water molecule, time step 0\n\
54O\t0\t0\t0\n\
55H\t0.758602\t0\t0.504284\n\
56H\t0.758602\t0\t-0.504284\n\
573\n\
58\tH2O: water molecule, time step 1\n\
59O\t0\t0\t0\n\
60H\t0.76\t0\t0.504284\n\
61H\t0.756\t0\t-0.504284\n";
[9e4fd1]62
63void ParserXyzUnitTest::setUp() {
64 World::getInstance();
65
[765f16]66 parser = new FormatParser<xyz>();
67
[9e4fd1]68 setVerbosity(2);
69
70 // we need hydrogens and oxygens in the following tests
71 CPPUNIT_ASSERT(World::getInstance().getPeriode()->FindElement(1) != NULL);
72 CPPUNIT_ASSERT(World::getInstance().getPeriode()->FindElement(8) != NULL);
73}
74
[765f16]75void ParserXyzUnitTest::tearDown()
76{
77 delete parser;
[9e4fd1]78 ChangeTracker::purgeInstance();
[006e1e]79 AtomObserver::purgeInstance();
[9e4fd1]80 World::purgeInstance();
81}
82
83/************************************ tests ***********************************/
84
85void ParserXyzUnitTest::rewriteAnXyzTest() {
86 cout << "Testing the XYZ parser." << endl;
87 stringstream input;
88 input << waterXyz;
[765f16]89 parser->load(&input);
[9e4fd1]90 input.clear();
91
92 CPPUNIT_ASSERT_EQUAL(3, World::getInstance().numAtoms());
93
94 // store and parse in again
95 {
96 stringstream output;
97 std::vector<atom *> atoms = World::getInstance().getAllAtoms();
[765f16]98 parser->save(&output, atoms);
[9e4fd1]99 input << output.str();
[765f16]100 parser->load(&input);
[9e4fd1]101 }
102
103 // now twice as many
104 CPPUNIT_ASSERT_EQUAL(6, World::getInstance().numAtoms());
105
106 // check every atom
107 std::vector<atom *> atoms = World::getInstance().getAllAtoms();
108 std::vector<atom *>::const_iterator firstiter = atoms.begin();
109 std::vector<atom *>::const_iterator seconditer = atoms.begin();
110 for (size_t i=0;i<3;i++)
111 ++seconditer;
112 for (;
113 seconditer != atoms.end();
114 ++firstiter,++seconditer) {
115 // check position and type (only stuff xyz stores)
116 CPPUNIT_ASSERT_EQUAL((*firstiter)->getPosition(),(*seconditer)->getPosition());
117 CPPUNIT_ASSERT_EQUAL((*firstiter)->getType(),(*seconditer)->getType());
118 }
119}
[0180d6]120
121void ParserXyzUnitTest::readMultiXyzTest() {
122 cout << "Testing the multi time step XYZ parser." << endl;
123 stringstream input;
124 input << waterMultiXyz;
[765f16]125 parser->load(&input);
[0180d6]126 input.clear();
127
128 // 3 not 6 atoms!
129 CPPUNIT_ASSERT_EQUAL(3, World::getInstance().numAtoms());
130
131 // check for trajectory size
132 BOOST_FOREACH (atom *_atom, World::getInstance().getAllAtoms())
133 CPPUNIT_ASSERT_EQUAL((size_t) 2, _atom->getTrajectorySize());
134}
135
136void ParserXyzUnitTest::writeMultiXyzTest() {
137 stringstream input;
138 input << waterMultiXyz;
[765f16]139 parser->load(&input);
[0180d6]140 input.clear();
141
142 // 3 not 6 atoms!
143 CPPUNIT_ASSERT_EQUAL(3, World::getInstance().numAtoms());
144
145 // store and parse in again
146 {
147 stringstream output;
148 std::vector<atom *> atoms = World::getInstance().getAllAtoms();
[765f16]149 parser->save(&output, atoms);
[0180d6]150 input << output.str();
[765f16]151 parser->load(&input);
[0180d6]152 }
153
154 // now twice as many
155 CPPUNIT_ASSERT_EQUAL(6, World::getInstance().numAtoms());
156
157 // check for trajectory size of all 6! atoms
158 BOOST_FOREACH (atom *_atom, World::getInstance().getAllAtoms())
159 CPPUNIT_ASSERT_EQUAL((size_t) 2, _atom->getTrajectorySize());
160
161 // check every atom
162 std::vector<atom *> atoms = World::getInstance().getAllAtoms();
163 std::vector<atom *>::const_iterator firstiter = atoms.begin();
164 std::vector<atom *>::const_iterator seconditer = atoms.begin();
165 for (size_t i=0;i<3;i++)
166 ++seconditer;
167 for (;
168 seconditer != atoms.end();
169 ++firstiter,++seconditer) {
170 CPPUNIT_ASSERT_EQUAL((*firstiter)->getType(),(*seconditer)->getType());
171 for (unsigned int step = 0; step < 2; ++step) {
172 // check position and type (only stuff xyz stores)
173 CPPUNIT_ASSERT_EQUAL(
174 (*firstiter)->getPositionAtStep(step),
175 (*seconditer)->getPositionAtStep(step));
176 }
177 }
178}
Note: See TracBrowser for help on using the repository browser.