Files
opm-common/opm/parser/eclipse/Parser/tests/MessageContainerTest.cpp

81 lines
2.5 KiB
C++
Raw Normal View History

2016-03-25 10:55:22 +08:00
/*
2016-03-25 11:21:43 +08:00
Copyright 2016 Statoil ASA.
2016-03-25 10:55:22 +08:00
This file is part of the Open Porous Media project (OPM).
OPM is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
OPM is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with OPM. If not, see <http://www.gnu.org/licenses/>.
*/
#define BOOST_TEST_MODULE MessageContainerTest
#include <boost/test/unit_test.hpp>
#include <opm/parser/eclipse/Parser/MessageContainer.hpp>
using namespace Opm;
BOOST_AUTO_TEST_CASE(TestIterator) {
MessageContainer msgContainer;
msgContainer.error("This is an error.");
msgContainer.bug("This is a bug.", "dummy.log", 20);
{
BOOST_CHECK_EQUAL("This is an error.", msgContainer.begin()->message);
BOOST_CHECK_EQUAL("dummy.log", (msgContainer.end()-1)->location.filename);
BOOST_CHECK_EQUAL(20U , (msgContainer.end()-1)->location.lineno);
2016-03-25 10:55:22 +08:00
}
2016-03-28 08:52:56 +08:00
MessageContainer msgList;
msgList.debug("Debug");
msgList.info("Info");
msgList.warning("Warning");
msgList.error("Error");
msgList.problem("Problem");
msgList.bug("Bug");
2016-03-29 10:21:10 +08:00
std::vector<std::string> msgString = {"Debug", "Info", "Warning", "Error", "Problem", "Bug"};
2016-03-28 08:52:56 +08:00
int i = 0;
2016-03-29 10:21:10 +08:00
for (const auto& msg : msgList) {
BOOST_CHECK_EQUAL(msg.message, msgString[i]);
2016-03-28 08:52:56 +08:00
i++;
}
}
2016-03-28 08:52:56 +08:00
BOOST_AUTO_TEST_CASE(LocationImplicitConversion) {
MessageContainer mc;
mc.warning( "Warning" );
mc.info( "Info", "filename", 10 );
2016-03-29 10:21:10 +08:00
BOOST_CHECK( !mc.begin()->location );
BOOST_CHECK( (mc.begin() + 1)->location );
BOOST_CHECK_THROW( mc.info( "msg", "filename", 0 ), std::invalid_argument );
2016-03-25 10:55:22 +08:00
}
2016-04-13 14:04:21 +08:00
BOOST_AUTO_TEST_CASE(appendMessages) {
MessageContainer msgContainer;
MessageContainer msgList;
2016-04-13 15:07:12 +08:00
2016-04-13 14:04:21 +08:00
msgContainer.error("Error: msgContainer.");
2016-04-13 15:07:12 +08:00
BOOST_CHECK_EQUAL(1, msgContainer.size());
2016-04-13 14:04:21 +08:00
msgList.warning("Warning: msgList.");
msgContainer.appendMessages(msgList);
2016-04-13 15:07:12 +08:00
BOOST_CHECK_EQUAL(2, msgContainer.size());
2016-04-13 14:04:21 +08:00
BOOST_CHECK_EQUAL("Error: msgContainer.", msgContainer.begin()->message);
2016-04-13 15:07:12 +08:00
BOOST_CHECK_EQUAL("Warning: msgList.", (msgContainer.end()-1)->message);
2016-04-13 14:04:21 +08:00
}