2014-03-21 14:39:24 +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/>.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#define BOOST_TEST_MODULE SectionTests
|
|
|
|
|
|
|
|
|
|
#include <stdexcept>
|
2014-03-25 12:34:48 +01:00
|
|
|
#include <iostream>
|
2014-03-24 18:55:35 +01:00
|
|
|
#include <typeinfo>
|
2014-03-21 14:39:24 +01:00
|
|
|
#include <boost/test/unit_test.hpp>
|
|
|
|
|
#include <opm/parser/eclipse/Deck/Section.hpp>
|
|
|
|
|
|
|
|
|
|
using namespace Opm;
|
|
|
|
|
|
2014-03-24 14:48:23 +01:00
|
|
|
BOOST_AUTO_TEST_CASE(SectionTest) {
|
2014-03-24 18:55:35 +01:00
|
|
|
DeckPtr deck(new Deck());
|
2014-03-24 14:48:23 +01:00
|
|
|
DeckKeywordPtr test1(new DeckKeyword("TEST1"));
|
2014-03-24 18:55:35 +01:00
|
|
|
deck->addKeyword(test1);
|
2014-03-24 14:48:23 +01:00
|
|
|
DeckKeywordPtr test2(new DeckKeyword("TEST2"));
|
2014-03-24 18:55:35 +01:00
|
|
|
deck->addKeyword(test2);
|
2014-03-24 14:48:23 +01:00
|
|
|
DeckKeywordPtr test3(new DeckKeyword("TEST3"));
|
2014-03-24 18:55:35 +01:00
|
|
|
deck->addKeyword(test3);
|
2014-03-24 14:48:23 +01:00
|
|
|
DeckKeywordPtr test4(new DeckKeyword("TEST4"));
|
2014-03-24 18:55:35 +01:00
|
|
|
deck->addKeyword(test4);
|
2014-03-24 14:48:23 +01:00
|
|
|
Section section(deck, "TEST1", std::vector<std::string>() = {"TEST3", "TEST4"});
|
|
|
|
|
BOOST_CHECK_EQUAL(true, section.hasKeyword("TEST1"));
|
|
|
|
|
BOOST_CHECK_EQUAL(true, section.hasKeyword("TEST2"));
|
|
|
|
|
BOOST_CHECK_EQUAL(false, section.hasKeyword("TEST3"));
|
|
|
|
|
BOOST_CHECK_EQUAL(false, section.hasKeyword("TEST4"));
|
2014-06-02 09:06:09 +02:00
|
|
|
|
|
|
|
|
BOOST_CHECK_EQUAL( section.name() , "TEST1" );
|
2014-03-24 14:48:23 +01:00
|
|
|
}
|
|
|
|
|
|
2014-03-24 18:55:35 +01:00
|
|
|
BOOST_AUTO_TEST_CASE(IteratorTest) {
|
|
|
|
|
DeckPtr deck(new Deck());
|
|
|
|
|
DeckKeywordPtr test1(new DeckKeyword("TEST1"));
|
|
|
|
|
deck->addKeyword(test1);
|
|
|
|
|
DeckKeywordPtr test2(new DeckKeyword("TEST2"));
|
|
|
|
|
deck->addKeyword(test2);
|
|
|
|
|
DeckKeywordPtr test3(new DeckKeyword("TEST3"));
|
|
|
|
|
deck->addKeyword(test3);
|
|
|
|
|
DeckKeywordPtr test4(new DeckKeyword("TEST4"));
|
|
|
|
|
deck->addKeyword(test4);
|
|
|
|
|
Section section(deck, "TEST1", std::vector<std::string>() = {"TEST3", "TEST4"});
|
|
|
|
|
|
|
|
|
|
int numberOfItems = 0;
|
|
|
|
|
for (auto iter=section.begin(); iter != section.end(); ++iter) {
|
2014-03-25 09:26:43 +01:00
|
|
|
std::cout << (*iter)->name() << std::endl;
|
2014-03-24 18:55:35 +01:00
|
|
|
numberOfItems++;
|
|
|
|
|
}
|
|
|
|
|
BOOST_CHECK_EQUAL(2, numberOfItems);
|
|
|
|
|
}
|
|
|
|
|
|
2014-03-24 14:48:23 +01:00
|
|
|
BOOST_AUTO_TEST_CASE(RUNSPECSection_EmptyDeck) {
|
2014-03-24 18:55:35 +01:00
|
|
|
DeckPtr deck(new Deck());
|
2014-03-25 09:26:43 +01:00
|
|
|
BOOST_REQUIRE_THROW(RUNSPECSection section(deck), std::invalid_argument);
|
2014-03-21 15:40:44 +01:00
|
|
|
}
|
|
|
|
|
|
2014-03-24 14:48:23 +01:00
|
|
|
BOOST_AUTO_TEST_CASE(RUNSPECSection_ReadSimpleDeck) {
|
2014-03-24 18:55:35 +01:00
|
|
|
DeckPtr deck(new Deck());
|
2014-03-21 15:40:44 +01:00
|
|
|
DeckKeywordPtr test1(new DeckKeyword("TEST1"));
|
2014-03-24 18:55:35 +01:00
|
|
|
deck->addKeyword(test1);
|
2014-03-21 15:40:44 +01:00
|
|
|
DeckKeywordPtr runSpec(new DeckKeyword("RUNSPEC"));
|
2014-03-24 18:55:35 +01:00
|
|
|
deck->addKeyword(runSpec);
|
2014-03-21 15:40:44 +01:00
|
|
|
DeckKeywordPtr test2(new DeckKeyword("TEST2"));
|
2014-03-24 18:55:35 +01:00
|
|
|
deck->addKeyword(test2);
|
2014-03-21 15:40:44 +01:00
|
|
|
DeckKeywordPtr test3(new DeckKeyword("TEST3"));
|
2014-03-24 18:55:35 +01:00
|
|
|
deck->addKeyword(test3);
|
2014-03-21 15:40:44 +01:00
|
|
|
DeckKeywordPtr grid(new DeckKeyword("GRID"));
|
2014-03-24 18:55:35 +01:00
|
|
|
deck->addKeyword(grid);
|
2014-03-24 10:05:22 +01:00
|
|
|
DeckKeywordPtr test4(new DeckKeyword("TEST4"));
|
2014-03-24 18:55:35 +01:00
|
|
|
deck->addKeyword(test4);
|
2014-03-24 14:48:23 +01:00
|
|
|
RUNSPECSection section(deck);
|
2014-03-24 10:05:22 +01:00
|
|
|
BOOST_CHECK_EQUAL(false, section.hasKeyword("TEST1"));
|
|
|
|
|
BOOST_CHECK_EQUAL(true, section.hasKeyword("RUNSPEC"));
|
2014-03-21 15:40:44 +01:00
|
|
|
BOOST_CHECK_EQUAL(true, section.hasKeyword("TEST2"));
|
2014-03-24 10:05:22 +01:00
|
|
|
BOOST_CHECK_EQUAL(true, section.hasKeyword("TEST3"));
|
2014-03-24 14:48:23 +01:00
|
|
|
BOOST_CHECK_EQUAL(false, section.hasKeyword("GRID"));
|
2014-03-24 10:05:22 +01:00
|
|
|
BOOST_CHECK_EQUAL(false, section.hasKeyword("TEST4"));
|
2014-03-21 14:39:24 +01:00
|
|
|
}
|
|
|
|
|
|
2014-03-24 14:48:23 +01:00
|
|
|
BOOST_AUTO_TEST_CASE(RUNSPECSection_ReadSmallestPossibleDeck) {
|
2014-03-24 18:55:35 +01:00
|
|
|
DeckPtr deck(new Deck());
|
2014-03-24 10:05:22 +01:00
|
|
|
DeckKeywordPtr runSpec(new DeckKeyword("RUNSPEC"));
|
2014-03-24 18:55:35 +01:00
|
|
|
deck->addKeyword(runSpec);
|
2014-03-24 10:05:22 +01:00
|
|
|
DeckKeywordPtr grid(new DeckKeyword("GRID"));
|
2014-03-24 18:55:35 +01:00
|
|
|
deck->addKeyword(grid);
|
2014-03-24 14:48:23 +01:00
|
|
|
RUNSPECSection section(deck);
|
2014-03-24 10:05:22 +01:00
|
|
|
BOOST_CHECK_EQUAL(true, section.hasKeyword("RUNSPEC"));
|
2014-03-24 14:48:23 +01:00
|
|
|
BOOST_CHECK_EQUAL(false, section.hasKeyword("GRID"));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(GRIDSection_TerminatedByEDITKeyword) {
|
2014-03-24 18:55:35 +01:00
|
|
|
DeckPtr deck(new Deck());
|
|
|
|
|
DeckKeywordPtr grid(new DeckKeyword("GRID"));
|
|
|
|
|
deck->addKeyword(grid);
|
|
|
|
|
DeckKeywordPtr edit(new DeckKeyword("EDIT"));
|
|
|
|
|
deck->addKeyword(edit);
|
2014-03-24 14:48:23 +01:00
|
|
|
GRIDSection section(deck);
|
2014-03-24 10:05:22 +01:00
|
|
|
BOOST_CHECK_EQUAL(true, section.hasKeyword("GRID"));
|
2014-03-24 14:48:23 +01:00
|
|
|
BOOST_CHECK_EQUAL(false, section.hasKeyword("EDIT"));
|
2014-03-24 10:05:22 +01:00
|
|
|
}
|
|
|
|
|
|
2014-03-24 14:48:23 +01:00
|
|
|
BOOST_AUTO_TEST_CASE(GRIDSection_TerminatedByPROPSKeyword) {
|
2014-03-24 18:55:35 +01:00
|
|
|
DeckPtr deck(new Deck());
|
|
|
|
|
DeckKeywordPtr grid(new DeckKeyword("GRID"));
|
|
|
|
|
deck->addKeyword(grid);
|
|
|
|
|
DeckKeywordPtr props(new DeckKeyword("PROPS"));
|
|
|
|
|
deck->addKeyword(props);
|
2014-03-24 14:48:23 +01:00
|
|
|
GRIDSection section(deck);
|
|
|
|
|
BOOST_CHECK_EQUAL(true, section.hasKeyword("GRID"));
|
|
|
|
|
BOOST_CHECK_EQUAL(false, section.hasKeyword("PROPS"));
|
|
|
|
|
}
|
2014-03-24 10:05:22 +01:00
|
|
|
|
2014-03-24 14:48:23 +01:00
|
|
|
BOOST_AUTO_TEST_CASE(EDITSection_TerminatedByPROPSKeyword) {
|
2014-03-24 18:55:35 +01:00
|
|
|
DeckPtr deck(new Deck());
|
|
|
|
|
DeckKeywordPtr edit(new DeckKeyword("EDIT"));
|
|
|
|
|
deck->addKeyword(edit);
|
|
|
|
|
DeckKeywordPtr props(new DeckKeyword("PROPS"));
|
|
|
|
|
deck->addKeyword(props);
|
2014-03-24 14:48:23 +01:00
|
|
|
EDITSection section(deck);
|
|
|
|
|
BOOST_CHECK_EQUAL(true, section.hasKeyword("EDIT"));
|
|
|
|
|
BOOST_CHECK_EQUAL(false, section.hasKeyword("PROPS"));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(PROPSSection_TerminatedByREGIONSKeyword) {
|
2014-03-24 18:55:35 +01:00
|
|
|
DeckPtr deck(new Deck());
|
|
|
|
|
DeckKeywordPtr props(new DeckKeyword("PROPS"));
|
|
|
|
|
deck->addKeyword(props);
|
|
|
|
|
DeckKeywordPtr regions(new DeckKeyword("REGIONS"));
|
|
|
|
|
deck->addKeyword(regions);
|
2014-03-24 14:48:23 +01:00
|
|
|
PROPSSection section(deck);
|
|
|
|
|
BOOST_CHECK_EQUAL(true, section.hasKeyword("PROPS"));
|
|
|
|
|
BOOST_CHECK_EQUAL(false, section.hasKeyword("REGIONS"));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(PROPSSection_TerminatedBySOLUTIONKeyword) {
|
2014-03-24 18:55:35 +01:00
|
|
|
DeckPtr deck(new Deck());
|
|
|
|
|
DeckKeywordPtr props(new DeckKeyword("PROPS"));
|
|
|
|
|
deck->addKeyword(props);
|
|
|
|
|
DeckKeywordPtr solution(new DeckKeyword("SOLUTION"));
|
|
|
|
|
deck->addKeyword(solution);
|
2014-03-24 14:48:23 +01:00
|
|
|
PROPSSection section(deck);
|
|
|
|
|
BOOST_CHECK_EQUAL(true, section.hasKeyword("PROPS"));
|
|
|
|
|
BOOST_CHECK_EQUAL(false, section.hasKeyword("SOLUTION"));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(REGIONSSection_TerminatedBySOLUTIONKeyword) {
|
2014-03-24 18:55:35 +01:00
|
|
|
DeckPtr deck(new Deck());
|
|
|
|
|
DeckKeywordPtr regions(new DeckKeyword("REGIONS"));
|
|
|
|
|
deck->addKeyword(regions);
|
|
|
|
|
DeckKeywordPtr solution(new DeckKeyword("SOLUTION"));
|
|
|
|
|
deck->addKeyword(solution);
|
2014-03-24 14:48:23 +01:00
|
|
|
REGIONSSection section(deck);
|
|
|
|
|
BOOST_CHECK_EQUAL(true, section.hasKeyword("REGIONS"));
|
|
|
|
|
BOOST_CHECK_EQUAL(false, section.hasKeyword("SOLUTION"));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(SOLUTIONSection_TerminatedBySUMMARYKeyword) {
|
2014-03-24 18:55:35 +01:00
|
|
|
DeckPtr deck(new Deck());
|
|
|
|
|
DeckKeywordPtr solution(new DeckKeyword("SOLUTION"));
|
|
|
|
|
deck->addKeyword(solution);
|
|
|
|
|
DeckKeywordPtr summary(new DeckKeyword("SUMMARY"));
|
|
|
|
|
deck->addKeyword(summary);
|
2014-03-24 14:48:23 +01:00
|
|
|
SOLUTIONSection section(deck);
|
|
|
|
|
BOOST_CHECK_EQUAL(true, section.hasKeyword("SOLUTION"));
|
|
|
|
|
BOOST_CHECK_EQUAL(false, section.hasKeyword("SUMMARY"));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(SOLUTIONSection_TerminatedBySCHEDULEKeyword) {
|
2014-03-24 18:55:35 +01:00
|
|
|
DeckPtr deck(new Deck());
|
|
|
|
|
DeckKeywordPtr solution(new DeckKeyword("SOLUTION"));
|
|
|
|
|
deck->addKeyword(solution);
|
|
|
|
|
DeckKeywordPtr schedule(new DeckKeyword("SCHEDULE"));
|
|
|
|
|
deck->addKeyword(schedule);
|
2014-03-24 14:48:23 +01:00
|
|
|
SOLUTIONSection section(deck);
|
|
|
|
|
BOOST_CHECK_EQUAL(true, section.hasKeyword("SOLUTION"));
|
|
|
|
|
BOOST_CHECK_EQUAL(false, section.hasKeyword("SCHEDULE"));
|
2014-03-24 10:05:22 +01:00
|
|
|
}
|
2014-03-24 18:55:35 +01:00
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(SCHEDULESection_NotTerminated) {
|
|
|
|
|
DeckPtr deck(new Deck());
|
|
|
|
|
DeckKeywordPtr schedule(new DeckKeyword("SCHEDULE"));
|
|
|
|
|
deck->addKeyword(schedule);
|
|
|
|
|
DeckKeywordPtr test1(new DeckKeyword("TEST1"));
|
|
|
|
|
deck->addKeyword(test1);
|
|
|
|
|
DeckKeywordPtr test2(new DeckKeyword("TEST2"));
|
|
|
|
|
deck->addKeyword(test2);
|
|
|
|
|
DeckKeywordPtr test3(new DeckKeyword("TEST3"));
|
2014-03-25 16:05:36 +01:00
|
|
|
DeckKeywordPtr test4(new DeckKeyword("TEST3"));
|
2014-03-24 18:55:35 +01:00
|
|
|
deck->addKeyword(test3);
|
2014-03-25 16:05:36 +01:00
|
|
|
deck->addKeyword(test4);
|
2014-03-24 18:55:35 +01:00
|
|
|
SCHEDULESection section(deck);
|
|
|
|
|
BOOST_CHECK_EQUAL(true, section.hasKeyword("SCHEDULE"));
|
|
|
|
|
BOOST_CHECK_EQUAL(true, section.hasKeyword("TEST1"));
|
|
|
|
|
BOOST_CHECK_EQUAL(true, section.hasKeyword("TEST2"));
|
|
|
|
|
BOOST_CHECK_EQUAL(true, section.hasKeyword("TEST3"));
|
2014-03-25 16:05:36 +01:00
|
|
|
|
|
|
|
|
BOOST_CHECK_EQUAL( test1 , section.getKeyword("TEST1"));
|
|
|
|
|
BOOST_CHECK_EQUAL( test2 , section.getKeyword("TEST2"));
|
|
|
|
|
BOOST_CHECK_EQUAL( test2 , section.getKeyword(2));
|
|
|
|
|
|
|
|
|
|
BOOST_CHECK_EQUAL( test4 , section.getKeyword("TEST3"));
|
|
|
|
|
BOOST_CHECK_EQUAL( test3 , section.getKeyword("TEST3",0));
|
|
|
|
|
BOOST_CHECK_EQUAL( test4 , section.getKeyword("TEST3",1));
|
2014-05-16 13:10:20 +02:00
|
|
|
|
|
|
|
|
BOOST_CHECK( Section::hasSCHEDULE(deck ));
|
|
|
|
|
BOOST_CHECK( !Section::hasREGIONS(deck ));
|
2014-03-24 18:55:35 +01:00
|
|
|
}
|