mirror of
				https://github.com/OPM/opm-simulators.git
				synced 2025-02-25 18:55:30 -06:00 
			
		
		
		
	
		
			
				
	
	
		
			59 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			59 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|   Copyright 2014 IRIS
 | |
|   
 | |
|   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 <config.h>
 | |
| #include <chrono>
 | |
| 
 | |
| #define BOOST_TEST_MODULE StoppedWellsTests
 | |
| 
 | |
| #include <boost/test/unit_test.hpp>
 | |
| 
 | |
| #include <opm/parser/eclipse/Deck/Deck.hpp>
 | |
| #include <opm/parser/eclipse/Python/Python.hpp>
 | |
| #include <opm/parser/eclipse/Parser/Parser.hpp>
 | |
| #include <opm/parser/eclipse/EclipseState/Schedule/Schedule.hpp>
 | |
| 
 | |
| 
 | |
| using namespace Opm;
 | |
| 
 | |
| BOOST_AUTO_TEST_CASE(TestStoppedWells)
 | |
| {
 | |
|     const std::string filename = "wells_stopped.data";
 | |
|     Opm::Parser parser;
 | |
|     Opm::Deck deck(parser.parseFile(filename));
 | |
|     Opm::EclipseState eclipseState(deck);
 | |
|     auto python = std::make_shared<Opm::Python>();
 | |
|     const Schedule sched(deck, eclipseState, python);
 | |
| 
 | |
|     // Both wells are open in the first schedule step
 | |
|     {
 | |
|         auto wells = sched.getWells(0);
 | |
|         BOOST_CHECK(wells[0].getStatus() == Opm::Well::Status::OPEN);
 | |
|         BOOST_CHECK(wells[1].getStatus() == Opm::Well::Status::OPEN);
 | |
|     }
 | |
| 
 | |
| 
 | |
|     // The injector is stopped
 | |
|     {
 | |
|         auto wells = sched.getWells(1);
 | |
|         BOOST_CHECK(wells[0].getStatus() == Opm::Well::Status::STOP);
 | |
|         BOOST_CHECK(wells[1].getStatus() == Opm::Well::Status::OPEN);
 | |
|     }
 | |
| }
 |