2013-03-21 15:37:40 +01:00
|
|
|
/*
|
|
|
|
|
Copyright 2013 Statoil ASA.
|
|
|
|
|
|
|
|
|
|
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/>.
|
2013-04-08 14:32:17 +02:00
|
|
|
*/
|
2013-03-21 15:37:40 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
#define BOOST_TEST_MODULE ParserTests
|
|
|
|
|
#include <boost/test/unit_test.hpp>
|
|
|
|
|
|
2013-07-30 14:10:07 +02:00
|
|
|
#include <opm/json/JsonObject.hpp>
|
2013-06-20 15:30:37 +02:00
|
|
|
#include "opm/parser/eclipse/Parser/ParserKeyword.hpp"
|
2013-06-03 15:54:16 +02:00
|
|
|
#include "opm/parser/eclipse/Parser/ParserIntItem.hpp"
|
|
|
|
|
#include "opm/parser/eclipse/Parser/ParserItem.hpp"
|
|
|
|
|
|
2013-03-21 15:37:40 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
using namespace Opm;
|
|
|
|
|
|
2013-05-27 14:28:23 +02:00
|
|
|
BOOST_AUTO_TEST_CASE(construct_withname_nameSet) {
|
2013-06-20 15:30:37 +02:00
|
|
|
ParserKeyword parserKeyword("BPR");
|
|
|
|
|
BOOST_CHECK_EQUAL(parserKeyword.getName(), "BPR");
|
2013-03-21 15:37:40 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(NamedInit) {
|
2013-05-06 12:13:49 +02:00
|
|
|
std::string keyword("KEYWORD");
|
2013-03-21 15:37:40 +01:00
|
|
|
|
2013-06-24 14:08:53 +02:00
|
|
|
ParserKeyword parserKeyword(keyword, 100);
|
2013-06-20 15:30:37 +02:00
|
|
|
BOOST_CHECK_EQUAL(parserKeyword.getName(), keyword);
|
2013-04-08 14:32:17 +02:00
|
|
|
}
|
2013-04-02 15:19:32 +02:00
|
|
|
|
2013-08-06 16:26:49 +02:00
|
|
|
BOOST_AUTO_TEST_CASE(ParserKeyword_default_SizeTypedefault) {
|
|
|
|
|
std::string keyword("KEYWORD");
|
|
|
|
|
ParserKeyword parserKeyword(keyword);
|
|
|
|
|
BOOST_CHECK_EQUAL(parserKeyword.getSizeType() , UNDEFINED);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(ParserKeyword_withSize_SizeTypeFIXED) {
|
|
|
|
|
std::string keyword("KEYWORD");
|
|
|
|
|
ParserKeyword parserKeyword(keyword, 100);
|
|
|
|
|
BOOST_CHECK_EQUAL(parserKeyword.getSizeType() , FIXED);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(ParserKeyword_withOtherSize_SizeTypeOTHER) {
|
|
|
|
|
std::string keyword("KEYWORD");
|
|
|
|
|
ParserKeyword parserKeyword(keyword, "EQUILDIMS" , "NTEQUIL");
|
2013-08-14 08:43:54 +02:00
|
|
|
const std::pair<std::string,std::string>& sizeKW = parserKeyword.getSizeDefinitionPair();
|
2013-08-06 16:26:49 +02:00
|
|
|
BOOST_CHECK_EQUAL(OTHER , parserKeyword.getSizeType() );
|
|
|
|
|
BOOST_CHECK_EQUAL("EQUILDIMS", sizeKW.first );
|
|
|
|
|
BOOST_CHECK_EQUAL("NTEQUIL" , sizeKW.second );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2013-08-21 12:43:15 +02:00
|
|
|
BOOST_AUTO_TEST_CASE(ParserKeyword_validName) {
|
2013-08-21 23:15:40 +02:00
|
|
|
BOOST_CHECK_EQUAL( true , ParserKeyword::validName("SUMMARY"));
|
|
|
|
|
BOOST_CHECK_EQUAL( false , ParserKeyword::validName("MixeCase"));
|
|
|
|
|
BOOST_CHECK_EQUAL( false , ParserKeyword::validName("NAMETOOLONG"));
|
|
|
|
|
BOOST_CHECK_EQUAL( true , ParserKeyword::validName("STRING88"));
|
|
|
|
|
BOOST_CHECK_EQUAL( false , ParserKeyword::validName("88STRING"));
|
|
|
|
|
BOOST_CHECK_EQUAL( false , ParserKeyword::validName("KEY.EXT"));
|
|
|
|
|
BOOST_CHECK_EQUAL( false , ParserKeyword::validName("STRING~"));
|
2013-08-21 12:43:15 +02:00
|
|
|
}
|
|
|
|
|
|
2013-08-06 16:26:49 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2013-07-31 17:58:05 +02:00
|
|
|
/*****************************************************************/
|
|
|
|
|
/* json */
|
2013-07-30 14:10:07 +02:00
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(ConstructFromJsonObject) {
|
2013-08-21 23:15:40 +02:00
|
|
|
Json::JsonObject jsonObject("{\"name\": \"XXX\" , \"size\" : 0}");
|
2013-07-30 14:10:07 +02:00
|
|
|
ParserKeyword parserKeyword(jsonObject);
|
2013-08-21 23:15:40 +02:00
|
|
|
BOOST_CHECK_EQUAL("XXX" , parserKeyword.getName());
|
|
|
|
|
BOOST_CHECK_EQUAL( true , parserKeyword.hasFixedSize() );
|
2013-07-30 14:10:07 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2013-08-21 23:15:40 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2013-07-30 14:10:07 +02:00
|
|
|
BOOST_AUTO_TEST_CASE(ConstructFromJsonObject_withSize) {
|
2013-08-21 23:15:40 +02:00
|
|
|
Json::JsonObject jsonObject("{\"name\": \"BPR\", \"size\" : 100 , \"items\" :[{\"name\":\"ItemX\" , \"size_type\":\"SINGLE\" , \"value_type\" : \"FLOAT\"}]}");
|
|
|
|
|
|
2013-07-30 14:10:07 +02:00
|
|
|
ParserKeyword parserKeyword(jsonObject);
|
|
|
|
|
BOOST_CHECK_EQUAL("BPR" , parserKeyword.getName());
|
|
|
|
|
BOOST_CHECK_EQUAL( true , parserKeyword.hasFixedSize() );
|
|
|
|
|
BOOST_CHECK_EQUAL( 100U , parserKeyword.getFixedSize() );
|
2013-08-21 23:15:40 +02:00
|
|
|
|
|
|
|
|
BOOST_CHECK_EQUAL( 1U , parserKeyword.numItems());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(ConstructFromJsonObject_missingItemThrows) {
|
|
|
|
|
Json::JsonObject jsonObject("{\"name\": \"BPR\", \"size\" : 100}");
|
|
|
|
|
BOOST_CHECK_THROW( ParserKeyword parserKeyword(jsonObject) , std::invalid_argument);
|
2013-07-30 14:10:07 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2013-08-06 16:26:49 +02:00
|
|
|
BOOST_AUTO_TEST_CASE(ConstructFromJsonObject_withSizeOther) {
|
2013-08-21 23:15:40 +02:00
|
|
|
Json::JsonObject jsonObject("{\"name\": \"BPR\", \"size\" : {\"keyword\" : \"Bjarne\" , \"item\": \"BjarneIgjen\"}, \"items\" :[{\"name\":\"ItemX\" , \"size_type\":\"SINGLE\" , \"value_type\" : \"FLOAT\"}]}");
|
2013-08-06 16:26:49 +02:00
|
|
|
ParserKeyword parserKeyword(jsonObject);
|
2013-08-14 08:43:54 +02:00
|
|
|
const std::pair<std::string,std::string>& sizeKW = parserKeyword.getSizeDefinitionPair();
|
2013-08-06 16:26:49 +02:00
|
|
|
BOOST_CHECK_EQUAL("BPR" , parserKeyword.getName());
|
|
|
|
|
BOOST_CHECK_EQUAL( false , parserKeyword.hasFixedSize() );
|
|
|
|
|
BOOST_CHECK_EQUAL( parserKeyword.getSizeType() , OTHER);
|
|
|
|
|
BOOST_CHECK_EQUAL("Bjarne", sizeKW.first );
|
|
|
|
|
BOOST_CHECK_EQUAL("BjarneIgjen" , sizeKW.second );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2013-07-31 11:29:16 +02:00
|
|
|
BOOST_AUTO_TEST_CASE(ConstructFromJsonObject_missingName_throws) {
|
|
|
|
|
Json::JsonObject jsonObject("{\"nameXX\": \"BPR\", \"size\" : 100}");
|
|
|
|
|
BOOST_CHECK_THROW(ParserKeyword parserKeyword(jsonObject) , std::invalid_argument);
|
|
|
|
|
}
|
|
|
|
|
|
2013-07-31 17:58:05 +02:00
|
|
|
/*
|
|
|
|
|
"items": [{"name" : "I" , "size_type" : "SINGLE" , "value_type" : "int"}]
|
|
|
|
|
*/
|
|
|
|
|
BOOST_AUTO_TEST_CASE(ConstructFromJsonObject_invalidItems_throws) {
|
|
|
|
|
Json::JsonObject jsonObject("{\"name\": \"BPR\", \"size\" : 100 , \"items\" : 100}");
|
|
|
|
|
BOOST_CHECK_THROW(ParserKeyword parserKeyword(jsonObject) , std::invalid_argument);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(ConstructFromJsonObject_ItemMissingName_throws) {
|
|
|
|
|
Json::JsonObject jsonObject("{\"name\": \"BPR\", \"size\" : 100 , \"items\" : [{\"nameX\" : \"I\" , \"size_type\" : \"SINGLE\" , \"value_type\" : \"INT\"}]}");
|
|
|
|
|
BOOST_CHECK_THROW(ParserKeyword parserKeyword(jsonObject) , std::invalid_argument);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(ConstructFromJsonObject_ItemMissingSizeType_throws) {
|
|
|
|
|
Json::JsonObject jsonObject("{\"name\": \"BPR\", \"size\" : 100 , \"items\" : [{\"name\" : \"I\" , \"Xsize_type\" : \"SINGLE\" , \"value_type\" : \"INT\"}]}");
|
|
|
|
|
BOOST_CHECK_THROW(ParserKeyword parserKeyword(jsonObject) , std::invalid_argument);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(ConstructFromJsonObject_ItemMissingValueType_throws) {
|
|
|
|
|
Json::JsonObject jsonObject("{\"name\": \"BPR\", \"size\" : 100 , \"items\" : [{\"name\" : \"I\" , \"size_type\" : \"SINGLE\" , \"Xvalue_type\" : \"INT\"}]}");
|
|
|
|
|
BOOST_CHECK_THROW(ParserKeyword parserKeyword(jsonObject) , std::invalid_argument);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(ConstructFromJsonObject_ItemInvalidEnum_throws) {
|
|
|
|
|
Json::JsonObject jsonObject1("{\"name\": \"BPR\", \"size\" : 100 , \"items\" : [{\"name\" : \"I\" , \"size_type\" : \"XSINGLE\" , \"value_type\" : \"INT\"}]}");
|
|
|
|
|
Json::JsonObject jsonObject2("{\"name\": \"BPR\", \"size\" : 100 , \"items\" : [{\"name\" : \"I\" , \"size_type\" : \"SINGLE\" , \"value_type\" : \"INTX\"}]}");
|
|
|
|
|
|
|
|
|
|
BOOST_CHECK_THROW(ParserKeyword parserKeyword(jsonObject1) , std::invalid_argument);
|
|
|
|
|
BOOST_CHECK_THROW(ParserKeyword parserKeyword(jsonObject2) , std::invalid_argument);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(ConstructFromJsonObjectItemsOK) {
|
|
|
|
|
Json::JsonObject jsonObject("{\"name\": \"BPR\", \"size\" : 100 , \"items\" : [{\"name\" : \"I\" , \"size_type\" : \"SINGLE\" , \"value_type\" : \"INT\"}]}");
|
|
|
|
|
ParserKeyword parserKeyword(jsonObject);
|
|
|
|
|
ParserRecordConstPtr record = parserKeyword.getRecord();
|
|
|
|
|
ParserItemConstPtr item = record->get( 0 );
|
|
|
|
|
BOOST_CHECK_EQUAL( 1U , record->size( ) );
|
|
|
|
|
BOOST_CHECK_EQUAL( "I" , item->name( ) );
|
|
|
|
|
BOOST_CHECK_EQUAL( SINGLE , item->sizeType());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2013-08-06 16:26:49 +02:00
|
|
|
BOOST_AUTO_TEST_CASE(ConstructFromJsonObject_sizeFromOther) {
|
2013-08-21 23:15:40 +02:00
|
|
|
Json::JsonObject jsonConfig("{\"name\": \"EQUILX\", \"size\" : {\"keyword\":\"EQLDIMS\" , \"item\" : \"NTEQUL\"}, \"items\" :[{\"name\":\"ItemX\" , \"size_type\":\"SINGLE\" , \"value_type\" : \"FLOAT\"}]}");
|
2013-08-06 16:26:49 +02:00
|
|
|
BOOST_CHECK_NO_THROW( ParserKeyword parserKeyword(jsonConfig) );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2013-07-31 11:29:16 +02:00
|
|
|
|
2013-07-31 17:58:05 +02:00
|
|
|
/* </Json> */
|
|
|
|
|
/*****************************************************************/
|
2013-05-27 14:28:23 +02:00
|
|
|
|
2013-06-24 14:08:53 +02:00
|
|
|
BOOST_AUTO_TEST_CASE(constructor_nametoolongwithfixedsize_exceptionthrown) {
|
2013-05-06 12:13:49 +02:00
|
|
|
std::string keyword("KEYWORDTOOLONG");
|
2013-06-24 14:08:53 +02:00
|
|
|
BOOST_CHECK_THROW(ParserKeyword parserKeyword(keyword, 100), std::invalid_argument);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(constructor_nametoolong_exceptionthrown) {
|
|
|
|
|
std::string keyword("KEYWORDTOOLONG");
|
|
|
|
|
BOOST_CHECK_THROW(ParserKeyword parserKeyword(keyword), std::invalid_argument);
|
2013-03-21 15:37:40 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(MixedCase) {
|
2013-05-06 12:13:49 +02:00
|
|
|
std::string keyword("KeyWord");
|
2013-04-08 14:32:17 +02:00
|
|
|
|
2013-06-24 14:08:53 +02:00
|
|
|
BOOST_CHECK_THROW(ParserKeyword parserKeyword(keyword, 100), std::invalid_argument);
|
2013-03-21 15:37:40 +01:00
|
|
|
}
|
2013-06-21 15:34:06 +02:00
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(getFixedSize_sizeObjectHasFixedSize_sizeReturned) {
|
2013-06-24 14:08:53 +02:00
|
|
|
ParserKeywordPtr parserKeyword(new ParserKeyword("JA", 3));
|
2013-06-21 15:34:06 +02:00
|
|
|
BOOST_CHECK_EQUAL(3U, parserKeyword->getFixedSize());
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(getFixedSize_sizeObjectDoesNotHaveFixedSizeObjectSet_ExceptionThrown) {
|
2013-06-24 14:08:53 +02:00
|
|
|
ParserKeywordPtr parserKeyword(new ParserKeyword("JA"));
|
2013-06-21 15:34:06 +02:00
|
|
|
BOOST_CHECK_THROW(parserKeyword->getFixedSize(), std::logic_error);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(hasFixedSize_hasFixedSizeObject_returnstrue) {
|
2013-06-24 14:08:53 +02:00
|
|
|
ParserKeywordPtr parserKeyword(new ParserKeyword("JA", 2));
|
2013-06-21 15:34:06 +02:00
|
|
|
BOOST_CHECK(parserKeyword->hasFixedSize());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(hasFixedSize_sizeObjectDoesNotHaveFixedSize_returnsfalse) {
|
|
|
|
|
ParserKeywordPtr parserKeyword(new ParserKeyword("JA"));
|
|
|
|
|
BOOST_CHECK(!parserKeyword->hasFixedSize());
|
|
|
|
|
}
|
|
|
|
|
|
2013-08-19 22:37:48 +02:00
|
|
|
|