/* Copyright 2014 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 . */ #define BOOST_TEST_MODULE ScheduleIntegrationTests #include #include #include #include #include #include #include #include using namespace Opm; BOOST_AUTO_TEST_CASE(CreateCPGrid) { ParserPtr parser(new Parser()); boost::filesystem::path scheduleFile("testdata/integration_tests/GRID/CORNERPOINT.DATA"); DeckPtr deck = parser->parseFile(scheduleFile.string()); std::shared_ptr runspecSection(new RUNSPECSection(deck) ); std::shared_ptr gridSection(new GRIDSection(deck) ); std::shared_ptr grid(new EclipseGrid( runspecSection , gridSection )); BOOST_CHECK_EQUAL( 10 , grid->getNX( )); BOOST_CHECK_EQUAL( 10 , grid->getNY( )); BOOST_CHECK_EQUAL( 5 , grid->getNZ( )); BOOST_CHECK_EQUAL( 500 , grid->getNumActive() ); } BOOST_AUTO_TEST_CASE(CreateCPActnumGrid) { ParserPtr parser(new Parser()); boost::filesystem::path scheduleFile("testdata/integration_tests/GRID/CORNERPOINT_ACTNUM.DATA"); DeckPtr deck = parser->parseFile(scheduleFile.string()); std::shared_ptr runspecSection(new RUNSPECSection(deck) ); std::shared_ptr gridSection(new GRIDSection(deck) ); std::shared_ptr grid(new EclipseGrid( runspecSection , gridSection )); BOOST_CHECK_EQUAL( 10 , grid->getNX( )); BOOST_CHECK_EQUAL( 10 , grid->getNY( )); BOOST_CHECK_EQUAL( 5 , grid->getNZ( )); BOOST_CHECK_EQUAL( 100 , grid->getNumActive() ); } BOOST_AUTO_TEST_CASE(ExportFromCPGridAllActive) { ParserPtr parser(new Parser()); boost::filesystem::path scheduleFile("testdata/integration_tests/GRID/CORNERPOINT.DATA"); DeckPtr deck = parser->parseFile(scheduleFile.string()); std::shared_ptr runspecSection(new RUNSPECSection(deck) ); std::shared_ptr gridSection(new GRIDSection(deck) ); std::shared_ptr grid(new EclipseGrid( runspecSection , gridSection )); std::vector actnum; actnum.push_back(100); grid->exportACTNUM( actnum ); BOOST_CHECK_EQUAL( actnum.size() , 0U ); } BOOST_AUTO_TEST_CASE(ExportFromCPGridACTNUM) { ParserPtr parser(new Parser()); boost::filesystem::path scheduleFile("testdata/integration_tests/GRID/CORNERPOINT_ACTNUM.DATA"); DeckPtr deck = parser->parseFile(scheduleFile.string()); std::shared_ptr runspecSection(new RUNSPECSection(deck) ); std::shared_ptr gridSection(new GRIDSection(deck) ); std::shared_ptr grid(new EclipseGrid( runspecSection , gridSection )); std::vector coord; std::vector zcorn; std::vector actnum; size_t volume = grid->getNX()*grid->getNY()*grid->getNZ(); grid->exportCOORD( coord ); BOOST_CHECK_EQUAL( coord.size() , (size_t) (grid->getNX() + 1) * (grid->getNY() + 1) * 6); grid->exportZCORN( zcorn ); BOOST_CHECK_EQUAL( zcorn.size() , volume * 8); grid->exportACTNUM( actnum ); BOOST_CHECK_EQUAL( actnum.size() , volume ); { const std::vector& deckActnum = deck->getKeyword("ACTNUM")->getIntData(); const std::vector& deckZCORN = deck->getKeyword("ZCORN")->getSIDoubleData(); for (size_t i = 0; i < volume; i++) { BOOST_CHECK_EQUAL( deckActnum[i] , actnum[i]); for (size_t j=0; j < 8; j++) BOOST_CHECK_CLOSE( zcorn[i*8 + j] , deckZCORN[i*8 + j] , 0.0001); } } }