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
|
|
|
|
|
|
2016-04-13 13:04:33 +02:00
|
|
|
#include <opm/common/utility/platform_dependent/disable_warnings.h>
|
2016-03-25 10:55:22 +08:00
|
|
|
#include <boost/test/unit_test.hpp>
|
2016-04-13 13:04:33 +02:00
|
|
|
#include <opm/common/utility/platform_dependent/reenable_warnings.h>
|
2016-03-25 10:55:22 +08:00
|
|
|
|
|
|
|
|
#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);
|
2016-04-04 10:18:54 +02:00
|
|
|
BOOST_CHECK_EQUAL("dummy.log", (msgContainer.end()-1)->location.filename);
|
2016-04-12 13:59:02 +02:00
|
|
|
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-06-07 14:09:35 +02:00
|
|
|
msgList.info("Prtinfo");
|
|
|
|
|
std::vector<std::string> msgString = {"Debug", "Info", "Warning", "Error", "Problem", "Bug", "Prtinfo"};
|
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-04-01 10:46:31 +02:00
|
|
|
}
|
2016-03-28 08:52:56 +08:00
|
|
|
|
2016-04-01 10:46:31 +02:00
|
|
|
BOOST_AUTO_TEST_CASE(LocationImplicitConversion) {
|
|
|
|
|
MessageContainer mc;
|
|
|
|
|
mc.warning( "Warning" );
|
|
|
|
|
mc.info( "Info", "filename", 10 );
|
2016-03-29 10:21:10 +08:00
|
|
|
|
2016-04-01 10:46:31 +02:00
|
|
|
BOOST_CHECK( !mc.begin()->location );
|
|
|
|
|
BOOST_CHECK( (mc.begin() + 1)->location );
|
2016-04-06 11:41:22 +02:00
|
|
|
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-12 17:01:29 +02:00
|
|
|
BOOST_CHECK_EQUAL(1U, msgContainer.size());
|
2016-04-13 15:07:12 +08:00
|
|
|
|
2016-04-13 14:04:21 +08:00
|
|
|
msgList.warning("Warning: msgList.");
|
|
|
|
|
msgContainer.appendMessages(msgList);
|
2016-04-12 17:01:29 +02:00
|
|
|
BOOST_CHECK_EQUAL(2U, msgContainer.size());
|
2016-04-13 15:07:12 +08:00
|
|
|
|
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
|
|
|
}
|