/* Copyright 2019 SINTEF Digital, Mathematics and Cybernetics. 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 #define BOOST_TEST_MODULE TestParallelSerialization #define BOOST_TEST_NO_MAIN #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include template std::tuple PackUnpack(T& in) { const auto& comm = Dune::MPIHelper::getCommunication(); Opm::Parallel::MpiSerializer ser(comm); ser.pack(in); const size_t pos1 = ser.position(); T out; ser.unpack(out); const size_t pos2 = ser.position(); return std::make_tuple(out, pos1, pos2); } #define TEST_FOR_TYPE_NAMED_OBJ(TYPE, NAME, OBJ) \ BOOST_AUTO_TEST_CASE(NAME) \ { \ auto val1 = Opm::TYPE::OBJ(); \ auto val2 = PackUnpack(val1); \ BOOST_CHECK_MESSAGE(std::get<1>(val2) == std::get<2>(val2), "Packed size differ from unpack size for " #TYPE); \ BOOST_CHECK_MESSAGE(val1 == std::get<0>(val2), "Deserialized " #TYPE " differ"); \ } #define TEST_FOR_TYPE_NAMED(TYPE, NAME) \ TEST_FOR_TYPE_NAMED_OBJ(TYPE, NAME, serializationTestObject) #define TEST_FOR_TYPE(TYPE) \ TEST_FOR_TYPE_NAMED(TYPE, TYPE) TEST_FOR_TYPE(Actdims) TEST_FOR_TYPE(Aqudims) TEST_FOR_TYPE(Aquancon) TEST_FOR_TYPE(AquiferConfig) TEST_FOR_TYPE(AquiferCT) TEST_FOR_TYPE(Aquifetp) TEST_FOR_TYPE(AutoICD) TEST_FOR_TYPE_NAMED(Action::Actions, Actions) TEST_FOR_TYPE_NAMED(Action::ActionX, ActionX) TEST_FOR_TYPE_NAMED(Action::AST, ActionAST) TEST_FOR_TYPE_NAMED(Action::ASTNode, ActionASTNode) TEST_FOR_TYPE_NAMED(Action::State, ActionState) TEST_FOR_TYPE(BCConfig) TEST_FOR_TYPE(BrineDensityTable) TEST_FOR_TYPE(ColumnSchema) TEST_FOR_TYPE(Connection) TEST_FOR_TYPE_NAMED_OBJ(data::AquiferData, AquiferData_CarterTracy, serializationTestObjectC) TEST_FOR_TYPE_NAMED_OBJ(data::AquiferData, AquiferData_Fetkovich, serializationTestObjectF) TEST_FOR_TYPE_NAMED_OBJ(data::AquiferData, AquiferData_Numeric, serializationTestObjectN) TEST_FOR_TYPE_NAMED(data::CarterTracyData, CarterTracyData) TEST_FOR_TYPE_NAMED(data::CellData, CellData) TEST_FOR_TYPE_NAMED(data::Connection, dataConnection) TEST_FOR_TYPE_NAMED(data::CurrentControl, CurrentControl) TEST_FOR_TYPE_NAMED(data::FetkovichData, FetkovichData) TEST_FOR_TYPE_NAMED(data::GroupAndNetworkValues, GroupAndNetworkValues) TEST_FOR_TYPE_NAMED(data::GroupConstraints, GroupConstraints) TEST_FOR_TYPE_NAMED(data::GroupData, GroupData) TEST_FOR_TYPE_NAMED(data::GroupGuideRates, GroupGuideRates) TEST_FOR_TYPE_NAMED(data::GuideRateValue, GuideRateValue) TEST_FOR_TYPE_NAMED(data::NodeData, NodeData) TEST_FOR_TYPE_NAMED(data::NumericAquiferData, NumericAquiferData) TEST_FOR_TYPE_NAMED(data::Rates, Rates) TEST_FOR_TYPE_NAMED(data::Segment, dataSegment) TEST_FOR_TYPE_NAMED(data::SegmentPressures, SegmentPressures) TEST_FOR_TYPE_NAMED(data::Solution, Solution) TEST_FOR_TYPE_NAMED(data::Well, dataWell) TEST_FOR_TYPE_NAMED(data::Wells, Wells) TEST_FOR_TYPE_NAMED(data::WellBlockAvgPress, dataWBPObject) TEST_FOR_TYPE_NAMED(data::WellBlockAveragePressures, dataWBPCollection) TEST_FOR_TYPE(Deck) TEST_FOR_TYPE(DeckItem) TEST_FOR_TYPE(DeckKeyword) TEST_FOR_TYPE(DeckRecord) TEST_FOR_TYPE(DensityTable) TEST_FOR_TYPE(DenT) TEST_FOR_TYPE(Dimension) TEST_FOR_TYPE(EclHysterConfig) TEST_FOR_TYPE(EclipseConfig) TEST_FOR_TYPE(EndpointScaling) TEST_FOR_TYPE(Eqldims) TEST_FOR_TYPE(Equil) TEST_FOR_TYPE(TLMixpar) TEST_FOR_TYPE(Events) TEST_FOR_TYPE(Fault) TEST_FOR_TYPE(FaultCollection) TEST_FOR_TYPE(FaultFace) TEST_FOR_TYPE_NAMED(Fieldprops::TranCalculator, TranCalculator) TEST_FOR_TYPE(FoamConfig) TEST_FOR_TYPE(FoamData) TEST_FOR_TYPE(GConSale) TEST_FOR_TYPE(GConSump) TEST_FOR_TYPE(GridDims) TEST_FOR_TYPE(Group) TEST_FOR_TYPE_NAMED(Group::GroupInjectionProperties, GroupInjectionProperties) TEST_FOR_TYPE_NAMED(Group::GroupProductionProperties, GroupProductionProperties) TEST_FOR_TYPE(GuideRateConfig) TEST_FOR_TYPE(GuideRateModel) TEST_FOR_TYPE(InitConfig) TEST_FOR_TYPE(IOConfig) TEST_FOR_TYPE(JFunc) TEST_FOR_TYPE(KeywordLocation) TEST_FOR_TYPE(MessageLimits) TEST_FOR_TYPE(MULTREGTScanner) TEST_FOR_TYPE(NNC) TEST_FOR_TYPE_NAMED(Network::Node, NetworkNode) TEST_FOR_TYPE(OilVaporizationProperties) TEST_FOR_TYPE(PAvg) TEST_FOR_TYPE(Phases) TEST_FOR_TYPE(PlymwinjTable) TEST_FOR_TYPE(PlyshlogTable) TEST_FOR_TYPE(PvcdoTable) TEST_FOR_TYPE(PvtgTable) TEST_FOR_TYPE(PvtoTable) TEST_FOR_TYPE(PvtwsaltTable) TEST_FOR_TYPE(PvtwTable) TEST_FOR_TYPE(Regdims) TEST_FOR_TYPE(RestartKey) TEST_FOR_TYPE(RestartValue) TEST_FOR_TYPE(RSTConfig) TEST_FOR_TYPE(RFTConfig) TEST_FOR_TYPE(RockConfig) TEST_FOR_TYPE(RockTable) TEST_FOR_TYPE(RocktabTable) TEST_FOR_TYPE(Rock2dtrTable) TEST_FOR_TYPE(Rock2dTable) TEST_FOR_TYPE(Runspec) TEST_FOR_TYPE(Schedule) TEST_FOR_TYPE(ScheduleDeck) TEST_FOR_TYPE(Segment) TEST_FOR_TYPE(SimpleTable) TEST_FOR_TYPE(SimulationConfig) TEST_FOR_TYPE(SkprpolyTable) TEST_FOR_TYPE(SkprwatTable) TEST_FOR_TYPE(SICD) TEST_FOR_TYPE(SolventDensityTable) TEST_FOR_TYPE(Source) TEST_FOR_TYPE(SummaryConfig) TEST_FOR_TYPE(SummaryConfigNode) TEST_FOR_TYPE(SummaryState) TEST_FOR_TYPE(Tabdims) TEST_FOR_TYPE(TableColumn) TEST_FOR_TYPE(TableContainer) TEST_FOR_TYPE(TableManager) TEST_FOR_TYPE(TableSchema) TEST_FOR_TYPE(ThresholdPressure) TEST_FOR_TYPE(TracerConfig) TEST_FOR_TYPE(TransMult) TEST_FOR_TYPE(Tuning) TEST_FOR_TYPE(UDAValue) TEST_FOR_TYPE(UDQAssign) TEST_FOR_TYPE(UDQActive) TEST_FOR_TYPE(UDQASTNode) TEST_FOR_TYPE(UDQConfig) TEST_FOR_TYPE(UDQDefine) TEST_FOR_TYPE(UDQIndex) TEST_FOR_TYPE(UDQParams) TEST_FOR_TYPE(UDQState) TEST_FOR_TYPE(UnitSystem) TEST_FOR_TYPE(Valve) TEST_FOR_TYPE(VFPInjTable) TEST_FOR_TYPE(VFPProdTable) TEST_FOR_TYPE(ViscrefTable) TEST_FOR_TYPE(WatdentTable) TEST_FOR_TYPE(Well) TEST_FOR_TYPE(Welldims) TEST_FOR_TYPE(WellBrineProperties) TEST_FOR_TYPE(WellConnections) TEST_FOR_TYPE(WellEconProductionLimits) TEST_FOR_TYPE(WellFoamProperties) TEST_FOR_TYPE_NAMED(Well::WellGuideRate, WellGuideRate) TEST_FOR_TYPE_NAMED(Well::WellInjectionProperties, WellInjectionProperties) TEST_FOR_TYPE(WellPolymerProperties) TEST_FOR_TYPE_NAMED(Well::WellProductionProperties, WellProductionProperties) TEST_FOR_TYPE(WellTracerProperties) TEST_FOR_TYPE(WellSegmentDims) TEST_FOR_TYPE(WellSegments) TEST_FOR_TYPE(WellTestConfig) TEST_FOR_TYPE(WellTestState) TEST_FOR_TYPE(WellType) TEST_FOR_TYPE(WListManager) TEST_FOR_TYPE(WriteRestartFileEvents) bool init_unit_test_func() { return true; } int main(int argc, char** argv) { Dune::MPIHelper::instance(argc, argv); return boost::unit_test::unit_test_main(&init_unit_test_func, argc, argv); }