/* Copyright 2023 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 TestOutputDir #define BOOST_TEST_NO_MAIN #include #include #include #include #include namespace { struct Fixture { Fixture() { const std::string deck = R"(RUNSPEC DIMENS 10 10 3 / START 8 OCT 2020 / GRID DXV 10*100.0 / DYV 10*100.0 / DZV 3*10.0 / DEPTHZ 121*2000.0 / PERMX 300*100.0 / PERMY 300*100.0 / PERMZ 300*10.0 / PORO 300*0.3 / PROPS SOLUTION SCHEDULE TSTEP 10 / END )"; input_path = std::filesystem::temp_directory_path() / "outputdir_test/"; std::filesystem::remove_all(input_path); std::filesystem::create_directories(input_path / "subdir" / "subdir"); for (const auto& file_path : {input_path / "INPUT.DATA", input_path / "subdir" / "INPUT.DATA", input_path / "subdir" / "subdir" / "INPUT.DATA"}) { std::ofstream of(file_path); of << deck; } } ~Fixture() { std::filesystem::remove_all(input_path); } std::filesystem::path input_path; }; } BOOST_FIXTURE_TEST_CASE(WithOutputDir, Fixture) { std::filesystem::current_path(input_path); using PathPair = std::pair; for (const bool createFaultyFileWithDirectory : {true, false}) { for (const auto& Case : {PathPair{input_path, input_path / "output1"}, PathPair{input_path / "subdir", input_path / "output2"}, PathPair{input_path / "subdir" / "subdir", input_path / "output3"}}) { const std::string output_path = "--output-dir=" + Case.second.string(); const std::string input_file_path = (Case.first / "INPUT.DATA"); const std::string output_dbg_path = (Case.second / "INPUT.DBG"); if (createFaultyFileWithDirectory) { std::filesystem::create_directories(Case.second); // Create file with faulty content std::string dummy = R"(dummy)"; std::ofstream of(output_dbg_path); of << dummy << std::endl; } const char* no_param[] = {"test_outputdir", input_file_path.c_str(), output_path.c_str(), nullptr}; Opm::Parameters::reset(); Opm::ThreadManager::registerParameters(); Opm::Main main(3, const_cast(no_param), false); BOOST_CHECK_EQUAL(main.justInitialize(), EXIT_SUCCESS); // Check if the files have been created at the right spot BOOST_CHECK(!std::filesystem::exists(input_path / "INPUT.PRT")); BOOST_CHECK(!std::filesystem::exists(input_path / "INPUT.DBG")); BOOST_CHECK(!std::filesystem::exists(Case.first / "INPUT.PRT")); BOOST_CHECK(!std::filesystem::exists(Case.first / "INPUT.DBG")); BOOST_CHECK(std::filesystem::exists(Case.second / "INPUT.PRT")); BOOST_CHECK(std::filesystem::exists(output_dbg_path)); // Check if the file with the faulty content has been removed and replaced by a valid one std::ifstream file(output_dbg_path); std::string line; std::getline(file, line); BOOST_CHECK(line.find("dummy") == std::string::npos); } } } BOOST_FIXTURE_TEST_CASE(NoOutputDir, Fixture) { std::filesystem::current_path(input_path); for (const auto& Case : {input_path / "subdir" / "subdir", input_path / "subdir"}) { const std::string input_file_path = (Case / "INPUT.DATA"); const std::string output_dbg_path = (Case / "INPUT.DBG"); // Create file with faulty content std::string dummy = R"(dummy)"; std::ofstream of(output_dbg_path); of << dummy << std::endl; const char* no_param[] = {"test_outputdir", input_file_path.c_str(), nullptr}; Opm::Parameters::reset(); Opm::ThreadManager::registerParameters(); Opm::Main main(2, const_cast(no_param), false); BOOST_CHECK_EQUAL(main.justInitialize(), EXIT_SUCCESS); // Check if the files have been created at the right spot BOOST_CHECK(!std::filesystem::exists(input_path / "INPUT.PRT")); BOOST_CHECK(!std::filesystem::exists(input_path / "INPUT.DBG")); BOOST_CHECK(std::filesystem::exists(Case/ "INPUT.PRT")); BOOST_CHECK(std::filesystem::exists(output_dbg_path)); // Check if the file with the faulty content has been removed and replaced by a valid one std::ifstream file(output_dbg_path); std::string line; std::getline(file, line); BOOST_CHECK(line.find("dummy") == std::string::npos); } } bool init_unit_test_func() { return true; } int main(int argc, char** argv) { // MPI setup. int argcDummy = 1; const char *tmp[] = {"test_outputdir"}; char **argvDummy = const_cast(tmp); #if HAVE_DUNE_FEM Dune::Fem::MPIManager::initialize(argcDummy, argvDummy); #else Dune::MPIHelper::instance(argcDummy, argvDummy); #endif Opm::FlowGenericVanguard::setCommunication(std::make_unique()); return boost::unit_test::unit_test_main(&init_unit_test_func, argc, argv); }