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

ForceAnnealing_goodresults ForceAnnealing_tocheck
Last change on this file since d07be9 was fac58f, checked in by Frederik Heber <heber@…>, 10 years ago

Converted FormatParser::save() to using vector of const atom ptrs.

  • required to change all save() functions in all parsers.
  • Property mode set to 100644
File size: 5.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.
[5aaa43]5 * Copyright (C) 2013 Frederik Heber. All rights reserved.
[94d5ac6]6 *
7 *
8 * This file is part of MoleCuilder.
9 *
10 * MoleCuilder is free software: you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation, either version 2 of the License, or
13 * (at your option) any later version.
14 *
15 * MoleCuilder is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
19 *
20 * You should have received a copy of the GNU General Public License
21 * along with MoleCuilder. If not, see <http://www.gnu.org/licenses/>.
[9e4fd1]22 */
23
24/*
25 * ParserXyzUnitTest.cpp
26 *
27 * Created on: Mar 3, 2010
28 * Author: metzler
29 */
30
31// include config.h
32#ifdef HAVE_CONFIG_H
33#include <config.h>
34#endif
35
36#include "ParserXyzUnitTest.hpp"
37
38#include <cppunit/CompilerOutputter.h>
39#include <cppunit/extensions/TestFactoryRegistry.h>
40#include <cppunit/ui/text/TestRunner.h>
41
[6f0841]42#include "Atom/atom.hpp"
[006e1e]43#include "Atom/AtomObserver.hpp"
[255829]44#include "CodePatterns/Log.hpp"
[9e4fd1]45#include "Descriptors/AtomTypeDescriptor.hpp"
[006e1e]46#include "Element/element.hpp"
47#include "Element/periodentafel.hpp"
[765f16]48#include "Parser/ChangeTracker.hpp"
49#include "Parser/XyzParser.hpp"
[006e1e]50#include "World.hpp"
[9e4fd1]51
52#ifdef HAVE_TESTRUNNER
53#include "UnitTestMain.hpp"
54#endif /*HAVE_TESTRUNNER*/
55
56using namespace std;
57
58// Registers the fixture into the 'registry'
59CPPUNIT_TEST_SUITE_REGISTRATION( ParserXyzUnitTest );
60
[0180d6]61static string waterXyz = "\
623\n\
63\tH2O: water molecule\n\
64O\t0\t0\t0\n\
65H\t0.758602\t0\t0.504284\n\
66H\t0.758602\t0\t-0.504284\n";
67static string waterMultiXyz = "\
683\n\
69\tH2O: water molecule, time step 0\n\
70O\t0\t0\t0\n\
71H\t0.758602\t0\t0.504284\n\
72H\t0.758602\t0\t-0.504284\n\
733\n\
74\tH2O: water molecule, time step 1\n\
75O\t0\t0\t0\n\
76H\t0.76\t0\t0.504284\n\
77H\t0.756\t0\t-0.504284\n";
[9e4fd1]78
79void ParserXyzUnitTest::setUp() {
80 World::getInstance();
81
[765f16]82 parser = new FormatParser<xyz>();
83
[9e4fd1]84 setVerbosity(2);
85
86 // we need hydrogens and oxygens in the following tests
87 CPPUNIT_ASSERT(World::getInstance().getPeriode()->FindElement(1) != NULL);
88 CPPUNIT_ASSERT(World::getInstance().getPeriode()->FindElement(8) != NULL);
89}
90
[765f16]91void ParserXyzUnitTest::tearDown()
92{
93 delete parser;
[9e4fd1]94 ChangeTracker::purgeInstance();
95 World::purgeInstance();
[708277]96 AtomObserver::purgeInstance();
[9e4fd1]97}
98
99/************************************ tests ***********************************/
100
101void ParserXyzUnitTest::rewriteAnXyzTest() {
102 cout << "Testing the XYZ parser." << endl;
103 stringstream input;
104 input << waterXyz;
[765f16]105 parser->load(&input);
[9e4fd1]106 input.clear();
107
[fac58f]108 CPPUNIT_ASSERT_EQUAL(3, const_cast<const World &>(World::getInstance()).numAtoms());
[9e4fd1]109
110 // store and parse in again
111 {
112 stringstream output;
[fac58f]113 std::vector<const atom *> atoms = const_cast<const World &>(World::getInstance()).
114 getAllAtoms();
[765f16]115 parser->save(&output, atoms);
[9e4fd1]116 input << output.str();
[765f16]117 parser->load(&input);
[9e4fd1]118 }
119
120 // now twice as many
121 CPPUNIT_ASSERT_EQUAL(6, World::getInstance().numAtoms());
122
123 // check every atom
124 std::vector<atom *> atoms = World::getInstance().getAllAtoms();
125 std::vector<atom *>::const_iterator firstiter = atoms.begin();
126 std::vector<atom *>::const_iterator seconditer = atoms.begin();
127 for (size_t i=0;i<3;i++)
128 ++seconditer;
129 for (;
130 seconditer != atoms.end();
131 ++firstiter,++seconditer) {
132 // check position and type (only stuff xyz stores)
133 CPPUNIT_ASSERT_EQUAL((*firstiter)->getPosition(),(*seconditer)->getPosition());
134 CPPUNIT_ASSERT_EQUAL((*firstiter)->getType(),(*seconditer)->getType());
135 }
136}
[0180d6]137
138void ParserXyzUnitTest::readMultiXyzTest() {
139 cout << "Testing the multi time step XYZ parser." << endl;
140 stringstream input;
141 input << waterMultiXyz;
[765f16]142 parser->load(&input);
[0180d6]143 input.clear();
144
145 // 3 not 6 atoms!
[a58c16]146 CPPUNIT_ASSERT_EQUAL(3, const_cast<const World &>(World::getInstance()).numAtoms());
[0180d6]147
148 // check for trajectory size
[a58c16]149 BOOST_FOREACH (const atom *_atom, const_cast<const World &>(World::getInstance()).getAllAtoms())
[0180d6]150 CPPUNIT_ASSERT_EQUAL((size_t) 2, _atom->getTrajectorySize());
151}
152
153void ParserXyzUnitTest::writeMultiXyzTest() {
154 stringstream input;
155 input << waterMultiXyz;
[765f16]156 parser->load(&input);
[0180d6]157 input.clear();
158
159 // 3 not 6 atoms!
[fac58f]160 CPPUNIT_ASSERT_EQUAL(3, const_cast<const World &>(World::getInstance()).numAtoms());
[0180d6]161
162 // store and parse in again
163 {
164 stringstream output;
[fac58f]165 std::vector<const atom *> atoms = const_cast<const World &>(World::getInstance()).
166 getAllAtoms();
[765f16]167 parser->save(&output, atoms);
[0180d6]168 input << output.str();
[765f16]169 parser->load(&input);
[0180d6]170 }
171
172 // now twice as many
173 CPPUNIT_ASSERT_EQUAL(6, World::getInstance().numAtoms());
174
175 // check for trajectory size of all 6! atoms
[a58c16]176 BOOST_FOREACH (const atom *_atom, const_cast<const World &>(World::getInstance()).getAllAtoms())
[0180d6]177 CPPUNIT_ASSERT_EQUAL((size_t) 2, _atom->getTrajectorySize());
178
179 // check every atom
[a58c16]180 std::vector<const atom *> atoms = const_cast<const World &>(World::getInstance()).
181 getAllAtoms();
182 std::vector<const atom *>::const_iterator firstiter = atoms.begin();
183 std::vector<const atom *>::const_iterator seconditer = atoms.begin();
[0180d6]184 for (size_t i=0;i<3;i++)
185 ++seconditer;
186 for (;
187 seconditer != atoms.end();
188 ++firstiter,++seconditer) {
189 CPPUNIT_ASSERT_EQUAL((*firstiter)->getType(),(*seconditer)->getType());
190 for (unsigned int step = 0; step < 2; ++step) {
191 // check position and type (only stuff xyz stores)
192 CPPUNIT_ASSERT_EQUAL(
193 (*firstiter)->getPositionAtStep(step),
194 (*seconditer)->getPositionAtStep(step));
195 }
196 }
197}
Note: See TracBrowser for help on using the repository browser.