opm-common/tests/test_SummaryNode.cpp
Bård Skaflestad 03a94a7288 Add New Summary Node Category of Completion
This enables detecting the last remaining case that has a valid NUMS
entry despite nominally being a well-level keyword.
2022-09-27 18:16:47 +02:00

191 lines
6.9 KiB
C++

/*
Copyright 2019 Equinor
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 SummaryNode
#include <boost/test/unit_test.hpp>
#include <opm/io/eclipse/SummaryNode.hpp>
#include <initializer_list>
#include <stdexcept>
#include <string>
#include <vector>
namespace {
void expect_key(const Opm::EclIO::SummaryNode& node, const std::string& unique_key) {
BOOST_CHECK_EQUAL(node.unique_key(), unique_key);
}
} // Anonymous namespace
BOOST_AUTO_TEST_SUITE(UniqueKey)
BOOST_AUTO_TEST_CASE(UniqueKey) {
using Category = Opm::EclIO::SummaryNode::Category;
using Type = Opm::EclIO::SummaryNode::Type;
expect_key( { "KEYW", Category::Well, Type::Rate, "NORA", 1, std::nullopt, std::nullopt}, "KEYW:NORA" );
expect_key( { "KEYW", Category::Group, Type::Rate, "NORA", 2, std::nullopt, std::nullopt}, "KEYW:NORA" );
expect_key( { "KEYW", Category::Field, Type::Rate, "NORA", 3, std::nullopt, std::nullopt}, "KEYW" );
expect_key( { "KEYW", Category::Region, Type::Rate, "NORA", 4, std::nullopt, std::nullopt}, "KEYW:4" );
expect_key( { "KEYW", Category::Block, Type::Rate, "NORA", 5, std::nullopt, std::nullopt}, "KEYW:5" );
expect_key( { "KEYW", Category::Connection, Type::Rate, "NORA", 6, std::nullopt, std::nullopt}, "KEYW:NORA:6" );
expect_key( { "KEYW", Category::Segment, Type::Rate, "NORA", 7, std::nullopt, std::nullopt}, "KEYW:NORA:7" );
expect_key( { "KEYW", Category::Miscellaneous, Type::Rate, "NORA", 8, std::nullopt, std::nullopt}, "KEYW" );
}
BOOST_AUTO_TEST_CASE(InjectedNumberRenderer) {
using Category = Opm::EclIO::SummaryNode::Category;
using Type = Opm::EclIO::SummaryNode::Type;
Opm::EclIO::SummaryNode positiveNode {
"SIGN",
Category::Region,
Type::Undefined,
"-",
2,
std::nullopt,
std::nullopt
};
Opm::EclIO::SummaryNode negativeNode {
"SIGN",
Category::Region,
Type::Undefined,
"-",
-2,
std::nullopt,
std::nullopt
};
auto chooseSign = [](const Opm::EclIO::SummaryNode& node) -> std::string {
return node.number > 0 ? "+" : "-";
};
BOOST_CHECK_EQUAL(positiveNode.unique_key(chooseSign), "SIGN:+");
BOOST_CHECK_EQUAL(negativeNode.unique_key(chooseSign), "SIGN:-");
}
BOOST_AUTO_TEST_CASE(user_defined) {
auto summary_node = Opm::EclIO::SummaryNode{"FU_VAR1",
Opm::EclIO::SummaryNode::Category::Field,
Opm::EclIO::SummaryNode::Type::Undefined,
"", -1 , std::nullopt, std::nullopt};
BOOST_CHECK( summary_node.is_user_defined() );
}
BOOST_AUTO_TEST_SUITE_END() // UniqueKey
// ===========================================================================
BOOST_AUTO_TEST_SUITE(Category)
namespace {
std::string to_string(const Opm::EclIO::SummaryNode::Category cat)
{
using Cat = Opm::EclIO::SummaryNode::Category;
switch (cat) {
case Cat::Aquifer: return "Aquifer";
case Cat::Well: return "Well";
case Cat::Group: return "Group";
case Cat::Field: return "Field";
case Cat::Region: return "Region";
case Cat::Block: return "Block";
case Cat::Connection: return "Connection";
case Cat::Completion: return "Completion";
case Cat::Segment: return "Segment";
case Cat::Node: return "Node";
case Cat::Miscellaneous: return "Miscellaneous";
}
throw std::invalid_argument {
"Unhandled Summary Parameter Category '"
+ std::to_string(static_cast<int>(cat)) + '\''
};
}
Opm::EclIO::SummaryNode::Category category(const std::string& kw)
{
return Opm::EclIO::SummaryNode::category_from_keyword(kw);
}
} // Anonymous namespace
BOOST_AUTO_TEST_CASE(Well)
{
const auto well_kw = std::vector<std::string> {
"WOPR", "WOPT", "WGIR", "WWIR",
};
for (const auto& kw : well_kw) {
BOOST_CHECK_MESSAGE(category(kw) == Opm::EclIO::SummaryNode::Category::Well,
"Keyword '" << kw << "' must be category 'Well'. Got '" <<
to_string(category(kw)) << "' instead");
}
BOOST_CHECK_MESSAGE(category("WOPRL") != Opm::EclIO::SummaryNode::Category::Well,
"Keyword 'WOPRL' must NOT be category 'Well'");
}
BOOST_AUTO_TEST_CASE(Connection)
{
const auto connection_kw = std::vector<std::string> {
"COPR", "COPT", "CGIR", "CWIR",
};
for (const auto& kw : connection_kw) {
BOOST_CHECK_MESSAGE(category(kw) == Opm::EclIO::SummaryNode::Category::Connection,
"Keyword '" << kw << "' must be category 'Connection'. Got '" <<
to_string(category(kw)) << "' instead");
}
BOOST_CHECK_MESSAGE(category("COPRL") != Opm::EclIO::SummaryNode::Category::Connection,
"Keyword 'COPRL' must NOT be category 'Connection'");
}
BOOST_AUTO_TEST_CASE(Completion)
{
const auto compl_kw = std::vector<std::string> {
"OPRL", "OPTL", "GIRL", "WIRL",
};
for (const auto& kw_base : compl_kw) {
const auto kw = 'C' + kw_base;
BOOST_CHECK_MESSAGE(category(kw) == Opm::EclIO::SummaryNode::Category::Completion,
"Keyword '" << kw << "' must be category 'Completion'. Got '" <<
to_string(category(kw)) << "' instead");
}
for (const auto* suffix : { "", "__1", "_12", "123" }) {
for (const auto& kw_base : compl_kw) {
const auto kw = 'W' + kw_base + suffix;
BOOST_CHECK_MESSAGE(category(kw) == Opm::EclIO::SummaryNode::Category::Completion,
"Keyword '" << kw << "' must be category 'Completion'. Got '" <<
to_string(category(kw)) << "' instead");
}
}
for (const auto* kw : { "WOPRLK", "CGIR", "WKITL__8", "WOOOOPRL", "WHIRL" }) {
BOOST_CHECK_MESSAGE(category(kw) != Opm::EclIO::SummaryNode::Category::Completion,
"Keyword '" << kw << "' must NOT be category 'Completion'");
}
}
BOOST_AUTO_TEST_SUITE_END() // Category