/* 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 . */ #include #include #include #define BOOST_TEST_MODULE CompletionSetTests #include #include #include #include #include #include #include #include namespace Opm { inline std::ostream& operator<<( std::ostream& stream, const Completion& c ) { return stream << "(" << c.getI() << "," << c.getJ() << "," << c.getK() << ")"; } inline std::ostream& operator<<( std::ostream& stream, const CompletionSet& cs ) { stream << "{ "; for( const auto& c : cs ) stream << c << " "; return stream << "}"; } } BOOST_AUTO_TEST_CASE(CreateCompletionSetOK) { Opm::CompletionSet completionSet; BOOST_CHECK_EQUAL( 0U , completionSet.size() ); } BOOST_AUTO_TEST_CASE(AddCompletionSizeCorrect) { Opm::CompletionSet completionSet; Opm::Completion completion1( 10,10,10, 1, 0.0,Opm::WellCompletion::OPEN , Opm::Value("ConnectionTransmissibilityFactor",99.88), Opm::Value("D",22.33), Opm::Value("SKIN",33.22), 0); Opm::Completion completion2( 11,10,10, 1, 0.0,Opm::WellCompletion::OPEN , Opm::Value("ConnectionTransmissibilityFactor",99.88), Opm::Value("D",22.33), Opm::Value("SKIN",33.22), 0); completionSet.add( completion1 ); BOOST_CHECK_EQUAL( 1U , completionSet.size() ); completionSet.add( completion2 ); BOOST_CHECK_EQUAL( 2U , completionSet.size() ); BOOST_CHECK_EQUAL( completion1 , completionSet.get(0) ); } BOOST_AUTO_TEST_CASE(CompletionSetGetOutOfRangeThrows) { Opm::CompletionSet completionSet; Opm::Completion completion1( 10,10,10,1, 0.0,Opm::WellCompletion::OPEN , Opm::Value("ConnectionTransmissibilityFactor",99.88), Opm::Value("D",22.33), Opm::Value("SKIN",33.22), 0); Opm::Completion completion2( 11,10,10,1, 0.0,Opm::WellCompletion::OPEN , Opm::Value("ConnectionTransmissibilityFactor",99.88), Opm::Value("D",22.33), Opm::Value("SKIN",33.22), 0); completionSet.add( completion1 ); BOOST_CHECK_EQUAL( 1U , completionSet.size() ); completionSet.add( completion2 ); BOOST_CHECK_EQUAL( 2U , completionSet.size() ); BOOST_CHECK_THROW( completionSet.get(10) , std::out_of_range ); } BOOST_AUTO_TEST_CASE(AddCompletionSameCellUpdates) { Opm::CompletionSet completionSet; Opm::Completion completion1( 10,10,10, 1, 0.0, Opm::WellCompletion::OPEN , Opm::Value("ConnectionTransmissibilityFactor",99.88), Opm::Value("D",22.33), Opm::Value("SKIN",33.22), 0); Opm::Completion completion2( 10,10,10, 1, 0.0,Opm::WellCompletion::SHUT , Opm::Value("ConnectionTransmissibilityFactor",99.88), Opm::Value("D",22.33), Opm::Value("SKIN",33.22), 0); completionSet.add( completion1 ); BOOST_CHECK_EQUAL( 1U , completionSet.size() ); completionSet.add( completion2 ); BOOST_CHECK_EQUAL( 1U , completionSet.size() ); } BOOST_AUTO_TEST_CASE(AddCompletionCopy) { Opm::CompletionSet completionSet; Opm::Completion completion1( 10,10,10, 1, 0.0, Opm::WellCompletion::OPEN , Opm::Value("ConnectionTransmissibilityFactor",99.88), Opm::Value("D",22.33), Opm::Value("SKIN",33.22), 0); Opm::Completion completion2( 10,10,11, 1, 0.0, Opm::WellCompletion::SHUT , Opm::Value("ConnectionTransmissibilityFactor",99.88), Opm::Value("D",22.33), Opm::Value("SKIN",33.22), 0); Opm::Completion completion3( 10,10,12, 1, 0.0, Opm::WellCompletion::SHUT , Opm::Value("ConnectionTransmissibilityFactor",99.88), Opm::Value("D",22.33), Opm::Value("SKIN",33.22), 0); completionSet.add( completion1 ); completionSet.add( completion2 ); completionSet.add( completion3 ); BOOST_CHECK_EQUAL( 3U , completionSet.size() ); auto copy = completionSet; BOOST_CHECK_EQUAL( 3U , copy.size() ); BOOST_CHECK_EQUAL( completion1 , copy.get(0)); BOOST_CHECK_EQUAL( completion2 , copy.get(1)); BOOST_CHECK_EQUAL( completion3 , copy.get(2)); }