opm-common/tests/parser/FaceDirTests.cpp
2023-01-03 16:32:56 +01:00

90 lines
4.0 KiB
C++

/*
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 <http://www.gnu.org/licenses/>.
*/
#include <stdexcept>
#include <memory>
#define BOOST_TEST_MODULE FaceDirTests
#include <boost/test/unit_test.hpp>
#include <opm/input/eclipse/EclipseState/Grid/FaceDir.hpp>
namespace Opm {
BOOST_AUTO_TEST_CASE(CheckEnum) {
BOOST_CHECK_EQUAL( FaceDir::XPlus , FaceDir::FromString( "X"));
BOOST_CHECK_EQUAL( FaceDir::XPlus , FaceDir::FromString( "I"));
BOOST_CHECK_EQUAL( FaceDir::XMinus , FaceDir::FromString( "X-"));
BOOST_CHECK_EQUAL( FaceDir::XMinus , FaceDir::FromString( "I-"));
BOOST_CHECK_EQUAL( FaceDir::YPlus , FaceDir::FromString( "Y"));
BOOST_CHECK_EQUAL( FaceDir::YPlus , FaceDir::FromString( "J"));
BOOST_CHECK_EQUAL( FaceDir::YMinus , FaceDir::FromString( "Y-"));
BOOST_CHECK_EQUAL( FaceDir::YMinus , FaceDir::FromString( "J-"));
BOOST_CHECK_EQUAL( FaceDir::ZPlus , FaceDir::FromString( "Z"));
BOOST_CHECK_EQUAL( FaceDir::ZPlus , FaceDir::FromString( "K"));
BOOST_CHECK_EQUAL( FaceDir::ZMinus , FaceDir::FromString( "Z-"));
BOOST_CHECK_EQUAL( FaceDir::ZMinus , FaceDir::FromString( "K-"));
BOOST_CHECK_THROW( FaceDir::FromString("??") , std::invalid_argument);
}
BOOST_AUTO_TEST_CASE(CheckComposite) {
BOOST_CHECK( FaceDir::XPlus & FaceDir::FromMULTREGTString("X"));
BOOST_CHECK( FaceDir::XMinus & FaceDir::FromMULTREGTString("X"));
BOOST_CHECK_EQUAL( FaceDir::XPlus + FaceDir::XMinus , FaceDir::FromMULTREGTString("X"));
BOOST_CHECK( FaceDir::YPlus & FaceDir::FromMULTREGTString("Y"));
BOOST_CHECK( FaceDir::YMinus & FaceDir::FromMULTREGTString("Y"));
BOOST_CHECK_EQUAL( FaceDir::YPlus + FaceDir::YMinus , FaceDir::FromMULTREGTString("Y"));
BOOST_CHECK( FaceDir::ZPlus & FaceDir::FromMULTREGTString("Z"));
BOOST_CHECK( FaceDir::ZMinus & FaceDir::FromMULTREGTString("Z"));
BOOST_CHECK_EQUAL( FaceDir::ZPlus + FaceDir::ZMinus , FaceDir::FromMULTREGTString("Z"));
BOOST_CHECK_EQUAL( FaceDir::XPlus + FaceDir::YPlus + FaceDir::XMinus + FaceDir::YMinus , FaceDir::FromMULTREGTString("XY"));
BOOST_CHECK_EQUAL( FaceDir::XPlus + FaceDir::ZPlus + FaceDir::XMinus + FaceDir::ZMinus, FaceDir::FromMULTREGTString("XZ"));
BOOST_CHECK_EQUAL( FaceDir::ZPlus + FaceDir::YPlus + FaceDir::ZMinus + FaceDir::YMinus, FaceDir::FromMULTREGTString("YZ"));
BOOST_CHECK_EQUAL( FaceDir::ZPlus + FaceDir::XPlus + FaceDir::YPlus + FaceDir::ZMinus + FaceDir::XMinus + FaceDir::YMinus , FaceDir::FromMULTREGTString("XYZ"));
BOOST_CHECK_THROW( FaceDir::FromString("??") , std::invalid_argument);
BOOST_CHECK_THROW( FaceDir::FromString("x") , std::invalid_argument);
BOOST_CHECK_THROW( FaceDir::FromString("ZY") , std::invalid_argument);
BOOST_CHECK_THROW( FaceDir::FromString("YX") , std::invalid_argument);
}
BOOST_AUTO_TEST_CASE(CheckIntersection) {
BOOST_CHECK_EQUAL(FaceDir::FromIntersectionIndex(0), FaceDir::XMinus);
BOOST_CHECK_EQUAL(FaceDir::FromIntersectionIndex(1), FaceDir::XPlus);
BOOST_CHECK_EQUAL(FaceDir::FromIntersectionIndex(2), FaceDir::YMinus);
BOOST_CHECK_EQUAL(FaceDir::FromIntersectionIndex(3), FaceDir::YPlus);
BOOST_CHECK_EQUAL(FaceDir::FromIntersectionIndex(4), FaceDir::ZMinus);
BOOST_CHECK_EQUAL(FaceDir::FromIntersectionIndex(5), FaceDir::ZPlus);
BOOST_CHECK_THROW(FaceDir::FromIntersectionIndex(-1), std::invalid_argument);
BOOST_CHECK_THROW(FaceDir::FromIntersectionIndex(6), std::invalid_argument);
}
}