2013-10-25 10:28:56 -05:00
|
|
|
/*
|
|
|
|
Copyright 2013 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 <iostream>
|
|
|
|
#include <boost/filesystem.hpp>
|
|
|
|
|
|
|
|
#define BOOST_TEST_MODULE ScheduleTests
|
2015-08-10 06:06:50 -05:00
|
|
|
|
2013-10-25 10:28:56 -05:00
|
|
|
#include <boost/test/unit_test.hpp>
|
|
|
|
#include <boost/date_time/posix_time/posix_time.hpp>
|
|
|
|
|
2019-01-22 10:04:54 -06:00
|
|
|
#include <ert/util/util.hpp>
|
|
|
|
|
2016-01-15 01:42:57 -06:00
|
|
|
#include <opm/parser/eclipse/EclipseState/Grid/EclipseGrid.hpp>
|
2013-10-25 10:28:56 -05:00
|
|
|
#include <opm/parser/eclipse/EclipseState/Schedule/Schedule.hpp>
|
2017-06-19 02:45:43 -05:00
|
|
|
#include <opm/parser/eclipse/EclipseState/Schedule/TimeMap.hpp>
|
2019-04-03 11:46:29 -05:00
|
|
|
#include <opm/parser/eclipse/EclipseState/Schedule/RFTConfig.hpp>
|
2016-01-15 01:42:57 -06:00
|
|
|
#include <opm/parser/eclipse/EclipseState/Schedule/OilVaporizationProperties.hpp>
|
2019-03-08 00:12:07 -06:00
|
|
|
#include <opm/parser/eclipse/EclipseState/Schedule/Well/WellConnections.hpp>
|
2019-03-23 10:11:37 -05:00
|
|
|
#include <opm/parser/eclipse/EclipseState/Schedule/Well/Well2.hpp>
|
2018-11-19 02:43:50 -06:00
|
|
|
#include <opm/parser/eclipse/EclipseState/Schedule/SummaryState.hpp>
|
|
|
|
|
2013-10-25 10:28:56 -05:00
|
|
|
#include <opm/parser/eclipse/Deck/Deck.hpp>
|
2016-02-09 05:09:40 -06:00
|
|
|
#include <opm/parser/eclipse/Deck/DeckItem.hpp>
|
2016-01-24 14:49:39 -06:00
|
|
|
#include <opm/parser/eclipse/Deck/DeckKeyword.hpp>
|
|
|
|
#include <opm/parser/eclipse/Deck/DeckRecord.hpp>
|
2014-01-22 07:40:10 -06:00
|
|
|
#include <opm/parser/eclipse/Parser/Parser.hpp>
|
2016-01-24 14:49:39 -06:00
|
|
|
#include <opm/parser/eclipse/Units/Dimension.hpp>
|
2016-01-15 01:42:57 -06:00
|
|
|
#include <opm/parser/eclipse/Units/UnitSystem.hpp>
|
2013-10-25 10:28:56 -05:00
|
|
|
|
2019-08-13 04:56:17 -05:00
|
|
|
#include <opm/parser/eclipse/EclipseState/Schedule/Well/WellProductionProperties.hpp>
|
|
|
|
#include <opm/parser/eclipse/EclipseState/Schedule/Well/WellInjectionProperties.hpp>
|
2019-05-19 08:39:03 -05:00
|
|
|
|
2013-10-25 10:28:56 -05:00
|
|
|
using namespace Opm;
|
|
|
|
|
2016-10-13 03:13:32 -05:00
|
|
|
static Deck createDeck() {
|
2014-02-26 15:15:02 -06:00
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START\n"
|
|
|
|
"8 MAR 1998 /\n"
|
|
|
|
"\n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"\n";
|
2013-10-25 10:28:56 -05:00
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
return parser.parseString(input);
|
2013-11-05 08:25:47 -06:00
|
|
|
}
|
|
|
|
|
2016-10-13 03:13:32 -05:00
|
|
|
static Deck createDeckWithWells() {
|
2014-01-22 07:40:10 -06:00
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"10 MAI 2007 / \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"WELSPECS\n"
|
|
|
|
" \'W_1\' \'OP\' 30 37 3.33 \'OIL\' 7* / \n"
|
|
|
|
"/ \n"
|
|
|
|
"DATES -- 1\n"
|
|
|
|
" 10 \'JUN\' 2007 / \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 2,3\n"
|
|
|
|
" 10 JLY 2007 / \n"
|
|
|
|
" 10 AUG 2007 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WELSPECS\n"
|
2014-05-14 08:10:17 -05:00
|
|
|
" \'WX2\' \'OP\' 30 37 3.33 \'OIL\' 7* / \n"
|
2014-01-22 07:40:10 -06:00
|
|
|
" \'W_3\' \'OP\' 20 51 3.92 \'OIL\' 7* / \n"
|
|
|
|
"/\n";
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
return parser.parseString(input);
|
2014-01-22 07:40:10 -06:00
|
|
|
}
|
|
|
|
|
2018-05-13 21:18:07 -05:00
|
|
|
static Deck createDeckWTEST() {
|
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"10 MAI 2007 / \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"WELSPECS\n"
|
|
|
|
" \'DEFAULT\' \'OP\' 30 37 3.33 \'OIL\' 7*/ \n"
|
|
|
|
" \'ALLOW\' \'OP\' 30 37 3.33 \'OIL\' 3* YES / \n"
|
|
|
|
" \'BAN\' \'OP\' 20 51 3.92 \'OIL\' 3* NO / \n"
|
2019-03-14 03:23:03 -05:00
|
|
|
" \'W1\' \'OP\' 20 51 3.92 \'OIL\' 3* NO / \n"
|
|
|
|
" \'W2\' \'OP\' 20 51 3.92 \'OIL\' 3* NO / \n"
|
|
|
|
" \'W3\' \'OP\' 20 51 3.92 \'OIL\' 3* NO / \n"
|
2018-05-13 21:18:07 -05:00
|
|
|
"/\n"
|
|
|
|
|
|
|
|
"COMPDAT\n"
|
|
|
|
" \'BAN\' 1 1 1 1 \'OPEN\' 1* 1.168 0.311 107.872 1* 1* \'Z\' 21.925 / \n"
|
|
|
|
"/\n"
|
|
|
|
|
|
|
|
"WCONHIST\n"
|
|
|
|
" 'BAN' 'OPEN' 'RESV' 0.000 0.000 0.000 5* / \n"
|
|
|
|
"/\n"
|
|
|
|
|
|
|
|
"WTEST\n"
|
|
|
|
" 'ALLOW' 1 'PE' / \n"
|
|
|
|
"/\n"
|
|
|
|
|
|
|
|
"DATES -- 1\n"
|
|
|
|
" 10 JUN 2007 / \n"
|
|
|
|
"/\n"
|
|
|
|
|
|
|
|
"WTEST\n"
|
|
|
|
" 'ALLOW' 1 '' / \n"
|
|
|
|
" 'BAN' 1 'DGC' / \n"
|
|
|
|
"/\n"
|
|
|
|
|
|
|
|
"WCONHIST\n"
|
|
|
|
" 'BAN' 'OPEN' 'RESV' 1.000 0.000 0.000 5* / \n"
|
|
|
|
"/\n"
|
|
|
|
|
|
|
|
"DATES -- 2\n"
|
|
|
|
" 10 JUL 2007 / \n"
|
|
|
|
"/\n"
|
|
|
|
|
2019-03-14 03:23:03 -05:00
|
|
|
"WELSPECS\n"
|
|
|
|
" \'I1\' \'OP\' 20 51 3.92 \'OIL\' 3* NO / \n"
|
|
|
|
" \'I2\' \'OP\' 20 51 3.92 \'OIL\' 3* NO / \n"
|
|
|
|
" \'I3\' \'OP\' 20 51 3.92 \'OIL\' 3* NO / \n"
|
|
|
|
"/\n"
|
|
|
|
|
|
|
|
"WLIST\n"
|
|
|
|
" \'*ILIST\' \'NEW\' I1 /\n"
|
|
|
|
" \'*ILIST\' \'ADD\' I2 /\n"
|
|
|
|
"/\n"
|
|
|
|
|
2018-05-13 21:18:07 -05:00
|
|
|
"WCONPROD\n"
|
|
|
|
" 'BAN' 'OPEN' 'ORAT' 0.000 0.000 0.000 5* / \n"
|
|
|
|
"/\n"
|
|
|
|
|
|
|
|
|
|
|
|
"DATES -- 3\n"
|
|
|
|
" 10 AUG 2007 / \n"
|
|
|
|
"/\n"
|
|
|
|
|
|
|
|
"WCONINJH\n"
|
|
|
|
" 'BAN' 'WATER' 1* 0 / \n"
|
|
|
|
"/\n"
|
|
|
|
|
|
|
|
"DATES -- 4\n"
|
|
|
|
" 10 SEP 2007 / \n"
|
|
|
|
"/\n"
|
|
|
|
|
|
|
|
"WELOPEN\n"
|
|
|
|
" 'BAN' OPEN / \n"
|
|
|
|
"/\n"
|
|
|
|
|
|
|
|
"DATES -- 4\n"
|
|
|
|
" 10 NOV 2007 / \n"
|
|
|
|
"/\n"
|
|
|
|
|
|
|
|
"WCONINJH\n"
|
|
|
|
" 'BAN' 'WATER' 1* 1.0 / \n"
|
|
|
|
"/\n";
|
|
|
|
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
return parser.parseString(input);
|
2018-05-13 21:18:07 -05:00
|
|
|
}
|
|
|
|
|
2016-10-13 03:13:32 -05:00
|
|
|
static Deck createDeckForTestingCrossFlow() {
|
2015-10-06 08:47:07 -05:00
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"10 MAI 2007 / \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"WELSPECS\n"
|
|
|
|
" \'DEFAULT\' \'OP\' 30 37 3.33 \'OIL\' 7*/ \n"
|
|
|
|
" \'ALLOW\' \'OP\' 30 37 3.33 \'OIL\' 3* YES / \n"
|
|
|
|
" \'BAN\' \'OP\' 20 51 3.92 \'OIL\' 3* NO / \n"
|
2015-10-08 05:17:29 -05:00
|
|
|
"/\n"
|
|
|
|
|
|
|
|
"COMPDAT\n"
|
|
|
|
" \'BAN\' 1 1 1 1 \'OPEN\' 1* 1.168 0.311 107.872 1* 1* \'Z\' 21.925 / \n"
|
|
|
|
"/\n"
|
|
|
|
|
|
|
|
"WCONHIST\n"
|
|
|
|
" 'BAN' 'OPEN' 'RESV' 0.000 0.000 0.000 5* / \n"
|
|
|
|
"/\n"
|
|
|
|
|
|
|
|
"DATES -- 1\n"
|
|
|
|
" 10 JUN 2007 / \n"
|
|
|
|
"/\n"
|
|
|
|
|
|
|
|
"WCONHIST\n"
|
|
|
|
" 'BAN' 'OPEN' 'RESV' 1.000 0.000 0.000 5* / \n"
|
|
|
|
"/\n"
|
|
|
|
|
|
|
|
"DATES -- 2\n"
|
|
|
|
" 10 JUL 2007 / \n"
|
|
|
|
"/\n"
|
|
|
|
|
|
|
|
"WCONPROD\n"
|
|
|
|
" 'BAN' 'OPEN' 'ORAT' 0.000 0.000 0.000 5* / \n"
|
|
|
|
"/\n"
|
|
|
|
|
|
|
|
|
|
|
|
"DATES -- 3\n"
|
|
|
|
" 10 AUG 2007 / \n"
|
|
|
|
"/\n"
|
|
|
|
|
|
|
|
"WCONINJH\n"
|
|
|
|
" 'BAN' 'WATER' 1* 0 / \n"
|
|
|
|
"/\n"
|
|
|
|
|
|
|
|
"DATES -- 4\n"
|
|
|
|
" 10 SEP 2007 / \n"
|
|
|
|
"/\n"
|
|
|
|
|
2015-11-09 02:54:10 -06:00
|
|
|
"WELOPEN\n"
|
|
|
|
" 'BAN' OPEN / \n"
|
|
|
|
"/\n"
|
|
|
|
|
|
|
|
"DATES -- 4\n"
|
|
|
|
" 10 NOV 2007 / \n"
|
|
|
|
"/\n"
|
|
|
|
|
2015-10-08 05:17:29 -05:00
|
|
|
"WCONINJH\n"
|
|
|
|
" 'BAN' 'WATER' 1* 1.0 / \n"
|
2015-10-06 08:47:07 -05:00
|
|
|
"/\n";
|
|
|
|
|
2015-10-08 05:17:29 -05:00
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
return parser.parseString(input);
|
2015-10-06 08:47:07 -05:00
|
|
|
}
|
|
|
|
|
2016-10-13 03:13:32 -05:00
|
|
|
static Deck createDeckWithWellsOrdered() {
|
2014-04-30 07:45:37 -05:00
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"10 MAI 2007 / \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"WELSPECS\n"
|
2018-03-18 13:33:58 -05:00
|
|
|
" \'CW_1\' \'CG\' 30 37 3.33 \'OIL\' 7* / \n"
|
|
|
|
" \'BW_2\' \'BG\' 30 37 3.33 \'OIL\' 7* / \n"
|
|
|
|
" \'AW_3\' \'AG\' 20 51 3.92 \'OIL\' 7* / \n"
|
2014-04-30 07:45:37 -05:00
|
|
|
"/\n";
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
return parser.parseString(input);
|
2014-04-30 07:45:37 -05:00
|
|
|
}
|
|
|
|
|
2017-07-25 12:50:06 -05:00
|
|
|
static Deck createDeckWithWellsOrderedGRUPTREE() {
|
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"10 MAI 2007 / \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"GRUPTREE\n"
|
|
|
|
" PG1 PLATFORM /\n"
|
|
|
|
" PG2 PLATFORM /\n"
|
|
|
|
" CG1 PG1 /\n"
|
|
|
|
" CG2 PG2 /\n"
|
|
|
|
"/\n"
|
|
|
|
"WELSPECS\n"
|
|
|
|
" \'DW_0\' \'CG1\' 30 37 3.33 \'OIL\' 7* / \n"
|
|
|
|
" \'CW_1\' \'CG1\' 30 37 3.33 \'OIL\' 7* / \n"
|
|
|
|
" \'BW_2\' \'CG2\' 30 37 3.33 \'OIL\' 7* / \n"
|
|
|
|
" \'AW_3\' \'CG2\' 20 51 3.92 \'OIL\' 7* / \n"
|
|
|
|
"/\n";
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
return parser.parseString(input);
|
2017-07-25 12:50:06 -05:00
|
|
|
}
|
|
|
|
|
2016-10-13 03:13:32 -05:00
|
|
|
static Deck createDeckWithWellsAndCompletionData() {
|
2014-12-05 05:59:53 -06:00
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"1 NOV 1979 / \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"DATES -- 1\n"
|
|
|
|
" 1 DES 1979/ \n"
|
|
|
|
"/\n"
|
|
|
|
"WELSPECS\n"
|
2014-12-08 11:26:13 -06:00
|
|
|
" 'OP_1' 'OP' 9 9 1* 'OIL' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
" 'OP_2' 'OP' 8 8 1* 'OIL' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
" 'OP_3' 'OP' 7 7 1* 'OIL' 1* 1* 1* 1* 1* 1* 1* / \n"
|
2014-12-05 05:59:53 -06:00
|
|
|
"/\n"
|
|
|
|
"COMPDAT\n"
|
2014-12-08 11:26:13 -06:00
|
|
|
" 'OP_1' 9 9 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
" 'OP_1' 9 9 2 2 'OPEN' 1* 46.825 0.311 4332.346 1* 1* 'X' 22.123 / \n"
|
|
|
|
" 'OP_2' 8 8 1 3 'OPEN' 1* 1.168 0.311 107.872 1* 1* 'Y' 21.925 / \n"
|
|
|
|
" 'OP_2' 8 7 3 3 'OPEN' 1* 15.071 0.311 1391.859 1* 1* 'Y' 21.920 / \n"
|
|
|
|
" 'OP_2' 8 7 3 6 'OPEN' 1* 6.242 0.311 576.458 1* 1* 'Y' 21.915 / \n"
|
|
|
|
" 'OP_3' 7 7 1 1 'OPEN' 1* 27.412 0.311 2445.337 1* 1* 'Y' 18.521 / \n"
|
|
|
|
" 'OP_3' 7 7 2 2 'OPEN' 1* 55.195 0.311 4923.842 1* 1* 'Y' 18.524 / \n"
|
2014-12-05 05:59:53 -06:00
|
|
|
"/\n"
|
|
|
|
"DATES -- 2,3\n"
|
|
|
|
" 10 JUL 2007 / \n"
|
|
|
|
" 10 AUG 2007 / \n"
|
|
|
|
"/\n"
|
2016-07-14 07:46:19 -05:00
|
|
|
"COMPDAT\n" // with defaulted I and J
|
|
|
|
" 'OP_1' 0 * 3 9 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
2014-12-05 05:59:53 -06:00
|
|
|
"/\n";
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
return parser.parseString(input);
|
2014-12-05 05:59:53 -06:00
|
|
|
}
|
|
|
|
|
2019-06-23 03:20:46 -05:00
|
|
|
static Deck createDeckRFTConfig() {
|
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"1 NOV 1979 / \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"DATES -- 1\n"
|
|
|
|
" 1 DES 1979/ \n"
|
|
|
|
"/\n"
|
|
|
|
"WELSPECS\n"
|
|
|
|
" 'OP_1' 'OP' 9 9 1* 'OIL' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
" 'OP_2' 'OP' 8 8 1* 'OIL' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
" 'OP_3' 'OP' 7 7 1* 'OIL' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
"/\n"
|
|
|
|
"COMPDAT\n"
|
|
|
|
" 'OP_1' 9 9 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
" 'OP_1' 9 9 2 2 'OPEN' 1* 46.825 0.311 4332.346 1* 1* 'X' 22.123 / \n"
|
|
|
|
" 'OP_2' 8 8 1 3 'OPEN' 1* 1.168 0.311 107.872 1* 1* 'Y' 21.925 / \n"
|
|
|
|
" 'OP_2' 8 7 3 3 'OPEN' 1* 15.071 0.311 1391.859 1* 1* 'Y' 21.920 / \n"
|
|
|
|
" 'OP_2' 8 7 3 6 'OPEN' 1* 6.242 0.311 576.458 1* 1* 'Y' 21.915 / \n"
|
|
|
|
" 'OP_3' 7 7 1 1 'OPEN' 1* 27.412 0.311 2445.337 1* 1* 'Y' 18.521 / \n"
|
|
|
|
" 'OP_3' 7 7 2 2 'OPEN' 1* 55.195 0.311 4923.842 1* 1* 'Y' 18.524 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WELOPEN\n"
|
|
|
|
" 'OP_2' 'OPEN' /\n"
|
|
|
|
"/\n"
|
|
|
|
"DATES\n"
|
|
|
|
" 10 JUL 2007 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WRFTPLT"
|
|
|
|
" 'OP_2' 'YES' 'NO' 'NO' / \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES \n"
|
|
|
|
" 10 AUG 2007 / \n"
|
|
|
|
"/\n"
|
|
|
|
"COMPDAT\n" // with defaulted I and J
|
|
|
|
" 'OP_1' 0 * 3 9 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
"/\n";
|
2019-04-17 01:24:12 -05:00
|
|
|
|
2019-06-23 03:20:46 -05:00
|
|
|
return parser.parseString(input);
|
|
|
|
}
|
2013-11-05 08:25:47 -06:00
|
|
|
BOOST_AUTO_TEST_CASE(CreateScheduleDeckMissingReturnsDefaults) {
|
2016-10-13 03:13:32 -05:00
|
|
|
Deck deck;
|
|
|
|
deck.addKeyword( DeckKeyword( "SCHEDULE" ) );
|
2016-09-08 12:42:45 -05:00
|
|
|
EclipseGrid grid(10,10,10);
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule(deck, grid , eclipseProperties, runspec );
|
2017-06-19 02:45:43 -05:00
|
|
|
BOOST_CHECK_EQUAL( schedule.getStartTime() , TimeMap::mkdate(1983, 1 , 1));
|
2013-11-05 08:25:47 -06:00
|
|
|
}
|
|
|
|
|
2014-04-30 07:45:37 -05:00
|
|
|
BOOST_AUTO_TEST_CASE(CreateScheduleDeckWellsOrdered) {
|
2016-10-13 03:13:32 -05:00
|
|
|
auto deck = createDeckWithWellsOrdered();
|
2016-09-08 12:42:45 -05:00
|
|
|
EclipseGrid grid(100,100,100);
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule(deck, grid , eclipseProperties, runspec);
|
2019-03-23 10:11:37 -05:00
|
|
|
auto well_names = schedule.wellNames();
|
2014-12-08 09:34:28 -06:00
|
|
|
|
2019-03-23 10:11:37 -05:00
|
|
|
BOOST_CHECK_EQUAL( "CW_1" , well_names[0]);
|
|
|
|
BOOST_CHECK_EQUAL( "BW_2" , well_names[1]);
|
|
|
|
BOOST_CHECK_EQUAL( "AW_3" , well_names[2]);
|
2018-03-18 13:33:58 -05:00
|
|
|
|
2019-07-07 01:46:17 -05:00
|
|
|
auto group_names = schedule.groupNames();
|
|
|
|
BOOST_CHECK_EQUAL( "FIELD", group_names[0]);
|
|
|
|
BOOST_CHECK_EQUAL( "CG", group_names[1]);
|
|
|
|
BOOST_CHECK_EQUAL( "BG", group_names[2]);
|
|
|
|
BOOST_CHECK_EQUAL( "AG", group_names[3]);
|
2014-04-30 07:45:37 -05:00
|
|
|
}
|
|
|
|
|
2017-07-25 12:50:06 -05:00
|
|
|
|
2019-05-04 05:00:32 -05:00
|
|
|
bool has_well( const std::vector<Well2>& wells, const std::string& well_name) {
|
2017-07-25 12:50:06 -05:00
|
|
|
for (const auto& well : wells )
|
2019-05-04 05:00:32 -05:00
|
|
|
if (well.name( ) == well_name)
|
2017-07-25 12:50:06 -05:00
|
|
|
return true;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(CreateScheduleDeckWellsOrderedGRUPTREE) {
|
|
|
|
auto deck = createDeckWithWellsOrderedGRUPTREE();
|
|
|
|
EclipseGrid grid(100,100,100);
|
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule(deck, grid , eclipseProperties, runspec);
|
2017-07-25 12:50:06 -05:00
|
|
|
|
2019-09-01 00:57:48 -05:00
|
|
|
BOOST_CHECK_THROW( schedule.getChildWells2( "NO_SUCH_GROUP" , 1 ), std::invalid_argument);
|
2019-05-04 05:00:32 -05:00
|
|
|
{
|
2019-09-01 00:57:48 -05:00
|
|
|
auto field_wells = schedule.getChildWells2("FIELD" , 0);
|
2019-05-04 05:00:32 -05:00
|
|
|
BOOST_CHECK_EQUAL( field_wells.size() , 4U);
|
|
|
|
|
|
|
|
BOOST_CHECK( has_well( field_wells, "DW_0" ));
|
|
|
|
BOOST_CHECK( has_well( field_wells, "CW_1" ));
|
|
|
|
BOOST_CHECK( has_well( field_wells, "BW_2" ));
|
|
|
|
BOOST_CHECK( has_well( field_wells, "AW_3" ));
|
|
|
|
}
|
|
|
|
|
|
|
|
{
|
2019-09-01 00:57:48 -05:00
|
|
|
auto platform_wells = schedule.getChildWells2("PLATFORM" , 0);
|
2019-05-04 05:00:32 -05:00
|
|
|
BOOST_CHECK_EQUAL( platform_wells.size() , 4U);
|
|
|
|
|
|
|
|
BOOST_CHECK( has_well( platform_wells, "DW_0" ));
|
|
|
|
BOOST_CHECK( has_well( platform_wells, "CW_1" ));
|
|
|
|
BOOST_CHECK( has_well( platform_wells, "BW_2" ));
|
|
|
|
BOOST_CHECK( has_well( platform_wells, "AW_3" ));
|
|
|
|
}
|
|
|
|
|
|
|
|
{
|
2019-09-01 00:57:48 -05:00
|
|
|
auto child_wells1 = schedule.getChildWells2("CG1" , 0);
|
2019-05-04 05:00:32 -05:00
|
|
|
BOOST_CHECK_EQUAL( child_wells1.size() , 2U);
|
|
|
|
|
|
|
|
BOOST_CHECK( has_well( child_wells1, "DW_0" ));
|
|
|
|
BOOST_CHECK( has_well( child_wells1, "CW_1" ));
|
|
|
|
}
|
|
|
|
|
|
|
|
{
|
2019-09-01 00:57:48 -05:00
|
|
|
auto parent_wells2 = schedule.getChildWells2("PG2" , 0);
|
2019-05-04 05:00:32 -05:00
|
|
|
BOOST_CHECK_EQUAL( parent_wells2.size() , 2U);
|
|
|
|
|
|
|
|
BOOST_CHECK( has_well( parent_wells2, "BW_2" ));
|
|
|
|
BOOST_CHECK( has_well( parent_wells2, "AW_3" ));
|
|
|
|
}
|
2019-07-07 01:46:17 -05:00
|
|
|
auto group_names = schedule.groupNames("P*", 0);
|
|
|
|
BOOST_CHECK( std::find(group_names.begin(), group_names.end(), "PG1") != group_names.end() );
|
|
|
|
BOOST_CHECK( std::find(group_names.begin(), group_names.end(), "PG2") != group_names.end() );
|
|
|
|
BOOST_CHECK( std::find(group_names.begin(), group_names.end(), "PLATFORM") != group_names.end() );
|
2017-07-25 12:50:06 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-07-25 04:46:15 -05:00
|
|
|
BOOST_AUTO_TEST_CASE(GroupTree2TEST) {
|
|
|
|
auto deck = createDeckWithWellsOrderedGRUPTREE();
|
|
|
|
EclipseGrid grid(100,100,100);
|
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
|
|
|
Runspec runspec (deck);
|
|
|
|
Schedule schedule(deck, grid , eclipseProperties, runspec);
|
|
|
|
|
|
|
|
BOOST_CHECK_THROW( schedule.groupTree("NO_SUCH_GROUP", 0), std::invalid_argument);
|
|
|
|
auto cg1 = schedule.getGroup2("CG1", 0);
|
|
|
|
BOOST_CHECK( cg1.hasWell("DW_0"));
|
|
|
|
BOOST_CHECK( cg1.hasWell("CW_1"));
|
|
|
|
|
|
|
|
auto cg1_tree = schedule.groupTree("CG1", 0);
|
|
|
|
BOOST_CHECK_EQUAL(cg1_tree.wells().size(), 2);
|
|
|
|
|
|
|
|
auto gt = schedule.groupTree(0);
|
|
|
|
BOOST_CHECK_EQUAL(gt.wells().size(), 0);
|
|
|
|
BOOST_CHECK_EQUAL(gt.group().name(), "FIELD");
|
|
|
|
BOOST_CHECK_THROW(gt.parent(), std::invalid_argument);
|
|
|
|
|
|
|
|
auto cg = gt.groups();
|
|
|
|
auto pg = cg[0];
|
|
|
|
BOOST_CHECK_EQUAL(cg.size(), 1);
|
|
|
|
BOOST_CHECK_EQUAL(pg.group().name(), "PLATFORM");
|
|
|
|
BOOST_CHECK_EQUAL(pg.parent().name(), "FIELD");
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2013-11-05 08:25:47 -06:00
|
|
|
BOOST_AUTO_TEST_CASE(CreateScheduleDeckWithStart) {
|
2016-10-13 03:13:32 -05:00
|
|
|
auto deck = createDeck();
|
2016-09-08 12:42:45 -05:00
|
|
|
EclipseGrid grid(10,10,10);
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule(deck, grid , eclipseProperties, runspec);
|
2017-06-19 02:45:43 -05:00
|
|
|
BOOST_CHECK_EQUAL( schedule.getStartTime() , TimeMap::mkdate(1998, 3 , 8 ));
|
2013-10-25 10:28:56 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(CreateScheduleDeckWithSCHEDULENoThrow) {
|
2016-10-13 03:13:32 -05:00
|
|
|
Deck deck;
|
2016-09-08 12:42:45 -05:00
|
|
|
EclipseGrid grid(10,10,10);
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
2019-04-17 01:24:12 -05:00
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2016-10-13 03:13:32 -05:00
|
|
|
deck.addKeyword( DeckKeyword( "SCHEDULE" ) );
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2014-12-08 09:34:28 -06:00
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
BOOST_CHECK_NO_THROW( Schedule( deck, grid , eclipseProperties, runspec));
|
2013-10-25 10:28:56 -05:00
|
|
|
}
|
|
|
|
|
2013-11-05 08:25:47 -06:00
|
|
|
BOOST_AUTO_TEST_CASE(EmptyScheduleHasNoWells) {
|
2016-09-08 12:42:45 -05:00
|
|
|
EclipseGrid grid(10,10,10);
|
2016-10-13 03:13:32 -05:00
|
|
|
auto deck = createDeck();
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule(deck, grid , eclipseProperties, runspec);
|
2013-11-05 08:25:47 -06:00
|
|
|
BOOST_CHECK_EQUAL( 0U , schedule.numWells() );
|
|
|
|
BOOST_CHECK_EQUAL( false , schedule.hasWell("WELL1") );
|
2019-05-04 05:00:32 -05:00
|
|
|
BOOST_CHECK_THROW( schedule.getWell2("WELL2", 0) , std::invalid_argument );
|
2013-11-05 08:25:47 -06:00
|
|
|
}
|
|
|
|
|
2014-12-08 09:34:28 -06:00
|
|
|
|
2013-11-14 09:08:10 -06:00
|
|
|
|
2013-11-18 06:11:49 -06:00
|
|
|
BOOST_AUTO_TEST_CASE(EmptyScheduleHasFIELDGroup) {
|
2016-09-08 12:42:45 -05:00
|
|
|
EclipseGrid grid(10,10,10);
|
2016-10-13 03:13:32 -05:00
|
|
|
auto deck = createDeck();
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule(deck , grid , eclipseProperties, runspec);
|
2017-09-27 09:34:38 -05:00
|
|
|
|
2013-11-18 06:11:49 -06:00
|
|
|
BOOST_CHECK_EQUAL( 1U , schedule.numGroups() );
|
|
|
|
BOOST_CHECK_EQUAL( true , schedule.hasGroup("FIELD") );
|
|
|
|
BOOST_CHECK_EQUAL( false , schedule.hasGroup("GROUP") );
|
2019-08-06 15:40:14 -05:00
|
|
|
BOOST_CHECK_THROW( schedule.getGroup2("GROUP", 0) , std::invalid_argument );
|
2013-11-18 06:11:49 -06:00
|
|
|
}
|
|
|
|
|
2014-01-22 07:40:10 -06:00
|
|
|
BOOST_AUTO_TEST_CASE(WellsIterator_Empty_EmptyVectorReturned) {
|
2016-09-08 12:42:45 -05:00
|
|
|
EclipseGrid grid(10,10,10);
|
2016-10-13 03:13:32 -05:00
|
|
|
auto deck = createDeck();
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule(deck , grid , eclipseProperties, runspec);
|
2019-05-04 05:00:32 -05:00
|
|
|
|
|
|
|
const auto wells_alltimesteps = schedule.getWells2atEnd();
|
2014-01-22 07:40:10 -06:00
|
|
|
BOOST_CHECK_EQUAL(0U, wells_alltimesteps.size());
|
2019-05-04 05:00:32 -05:00
|
|
|
|
|
|
|
const auto wells_t0 = schedule.getWells2(0);
|
2014-01-22 07:40:10 -06:00
|
|
|
BOOST_CHECK_EQUAL(0U, wells_t0.size());
|
|
|
|
|
2019-05-04 05:00:32 -05:00
|
|
|
// The time argument is beyond the length of the vector
|
|
|
|
BOOST_CHECK_THROW(schedule.getWells2(1), std::invalid_argument);
|
2014-01-22 07:40:10 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(WellsIterator_HasWells_WellsReturned) {
|
2016-09-08 12:42:45 -05:00
|
|
|
EclipseGrid grid(10,10,10);
|
2016-10-13 03:13:32 -05:00
|
|
|
auto deck = createDeckWithWells();
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule(deck , grid , eclipseProperties, runspec);
|
2015-12-21 07:54:38 -06:00
|
|
|
size_t timeStep = 0;
|
2014-01-22 07:40:10 -06:00
|
|
|
|
2019-05-04 05:00:32 -05:00
|
|
|
const auto wells_alltimesteps = schedule.getWells2atEnd();
|
2014-01-22 07:40:10 -06:00
|
|
|
BOOST_CHECK_EQUAL(3U, wells_alltimesteps.size());
|
2019-05-04 05:00:32 -05:00
|
|
|
const auto wells_t0 = schedule.getWells2(timeStep);
|
2014-01-22 07:40:10 -06:00
|
|
|
BOOST_CHECK_EQUAL(1U, wells_t0.size());
|
2019-05-04 05:00:32 -05:00
|
|
|
const auto wells_t3 = schedule.getWells2(3);
|
2014-01-22 07:40:10 -06:00
|
|
|
BOOST_CHECK_EQUAL(3U, wells_t3.size());
|
|
|
|
}
|
2013-11-18 06:11:49 -06:00
|
|
|
|
2014-05-06 02:54:37 -05:00
|
|
|
|
|
|
|
|
2014-12-05 05:59:53 -06:00
|
|
|
BOOST_AUTO_TEST_CASE(ReturnNumWellsTimestep) {
|
2016-09-08 12:42:45 -05:00
|
|
|
EclipseGrid grid(10,10,10);
|
2016-10-13 03:13:32 -05:00
|
|
|
auto deck = createDeckWithWells();
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule(deck, grid , eclipseProperties, runspec);
|
2014-12-05 05:59:53 -06:00
|
|
|
|
|
|
|
BOOST_CHECK_EQUAL(schedule.numWells(0), 1);
|
|
|
|
BOOST_CHECK_EQUAL(schedule.numWells(1), 1);
|
|
|
|
BOOST_CHECK_EQUAL(schedule.numWells(2), 1);
|
|
|
|
BOOST_CHECK_EQUAL(schedule.numWells(3), 3);
|
|
|
|
}
|
|
|
|
|
2015-10-06 08:47:07 -05:00
|
|
|
BOOST_AUTO_TEST_CASE(TestCrossFlowHandling) {
|
2016-09-08 12:42:45 -05:00
|
|
|
EclipseGrid grid(10,10,10);
|
2016-10-13 03:13:32 -05:00
|
|
|
auto deck = createDeckForTestingCrossFlow();
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule(deck, grid , eclipseProperties, runspec);
|
2015-10-06 08:47:07 -05:00
|
|
|
|
2019-05-04 05:00:32 -05:00
|
|
|
BOOST_CHECK_EQUAL(schedule.getWell2("BAN", 0).getAllowCrossFlow(), false);
|
|
|
|
BOOST_CHECK_EQUAL(schedule.getWell2("ALLOW", 0).getAllowCrossFlow(), true);
|
|
|
|
BOOST_CHECK_EQUAL(schedule.getWell2("DEFAULT", 0).getAllowCrossFlow(), true);
|
2019-08-23 06:58:39 -05:00
|
|
|
BOOST_CHECK(Well2::Status::SHUT == schedule.getWell2("BAN", 0).getStatus());
|
|
|
|
BOOST_CHECK(Well2::Status::OPEN == schedule.getWell2("BAN", 1).getStatus());
|
|
|
|
BOOST_CHECK(Well2::Status::OPEN == schedule.getWell2("BAN", 2).getStatus());
|
|
|
|
BOOST_CHECK(Well2::Status::SHUT == schedule.getWell2("BAN", 3).getStatus());
|
|
|
|
BOOST_CHECK(Well2::Status::SHUT == schedule.getWell2("BAN", 4).getStatus()); // not allow to open
|
|
|
|
BOOST_CHECK(Well2::Status::OPEN == schedule.getWell2("BAN", 5).getStatus());
|
2015-10-06 08:47:07 -05:00
|
|
|
}
|
2014-12-05 05:59:53 -06:00
|
|
|
|
2018-06-10 13:54:34 -05:00
|
|
|
static Deck createDeckWithWellsAndConnectionDataWithWELOPEN() {
|
2015-01-13 04:25:46 -06:00
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"1 NOV 1979 / \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"DATES -- 1\n"
|
|
|
|
" 1 DES 1979/ \n"
|
|
|
|
"/\n"
|
|
|
|
"WELSPECS\n"
|
|
|
|
" 'OP_1' 'OP' 9 9 1* 'OIL' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
" 'OP_2' 'OP' 8 8 1* 'OIL' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
" 'OP_3' 'OP' 7 7 1* 'OIL' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
"/\n"
|
|
|
|
"COMPDAT\n"
|
|
|
|
" 'OP_1' 9 9 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
" 'OP_1' 9 9 2 2 'OPEN' 1* 46.825 0.311 4332.346 1* 1* 'X' 22.123 / \n"
|
|
|
|
" 'OP_2' 8 8 1 3 'OPEN' 1* 1.168 0.311 107.872 1* 1* 'Y' 21.925 / \n"
|
|
|
|
" 'OP_2' 8 7 3 3 'OPEN' 1* 15.071 0.311 1391.859 1* 1* 'Y' 21.920 / \n"
|
|
|
|
" 'OP_2' 8 7 3 6 'OPEN' 1* 6.242 0.311 576.458 1* 1* 'Y' 21.915 / \n"
|
|
|
|
" 'OP_3' 7 7 1 1 'OPEN' 1* 27.412 0.311 2445.337 1* 1* 'Y' 18.521 / \n"
|
|
|
|
" 'OP_3' 7 7 2 2 'OPEN' 1* 55.195 0.311 4923.842 1* 1* 'Y' 18.524 / \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 2,3\n"
|
|
|
|
" 10 JUL 2007 / \n"
|
|
|
|
" 10 AUG 2007 / \n"
|
|
|
|
"/\n"
|
|
|
|
"COMPDAT\n"
|
|
|
|
" 'OP_1' 9 9 3 9 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WELOPEN\n"
|
|
|
|
" 'OP_1' SHUT / \n"
|
|
|
|
" '*' OPEN 0 0 3 / \n"
|
2015-01-13 05:56:17 -06:00
|
|
|
" 'OP_2' SHUT 0 0 0 4 6 / \n "
|
2015-01-13 08:06:28 -06:00
|
|
|
" 'OP_3' SHUT 0 0 0 / \n"
|
2015-01-13 05:56:17 -06:00
|
|
|
"/\n"
|
|
|
|
"DATES -- 4\n"
|
|
|
|
" 10 JUL 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WELOPEN\n"
|
2015-01-13 08:06:28 -06:00
|
|
|
" 'OP_1' OPEN / \n"
|
2015-01-13 05:56:17 -06:00
|
|
|
" 'OP_2' OPEN 0 0 0 4 6 / \n "
|
2015-01-13 08:06:28 -06:00
|
|
|
" 'OP_3' OPEN 0 0 0 / \n"
|
2015-01-16 10:49:28 -06:00
|
|
|
"/\n"
|
|
|
|
"DATES -- 5\n"
|
|
|
|
" 10 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WELOPEN\n"
|
|
|
|
" 'OP_1' SHUT 0 0 0 0 0 / \n "
|
2015-01-13 04:25:46 -06:00
|
|
|
"/\n";
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
return parser.parseString(input);
|
2015-01-13 04:25:46 -06:00
|
|
|
}
|
|
|
|
|
2018-06-10 13:54:34 -05:00
|
|
|
BOOST_AUTO_TEST_CASE(CreateScheduleDeckWellsAndConnectionDataWithWELOPEN) {
|
2016-09-08 12:42:45 -05:00
|
|
|
EclipseGrid grid(10,10,10);
|
2019-05-04 05:00:32 -05:00
|
|
|
auto deck = createDeckWithWellsAndConnectionDataWithWELOPEN();
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule(deck ,grid , eclipseProperties, runspec);
|
2019-05-04 05:00:32 -05:00
|
|
|
{
|
2019-08-23 06:58:39 -05:00
|
|
|
constexpr auto well_shut = Well2::Status::SHUT;
|
|
|
|
constexpr auto well_open = Well2::Status::OPEN;
|
2015-01-13 08:06:28 -06:00
|
|
|
|
2019-08-23 06:58:39 -05:00
|
|
|
BOOST_CHECK(well_shut == schedule.getWell2("OP_1", 3).getStatus( ));
|
|
|
|
BOOST_CHECK(well_open == schedule.getWell2("OP_1", 4).getStatus( ));
|
|
|
|
BOOST_CHECK(well_shut == schedule.getWell2("OP_1", 5).getStatus( ));
|
2019-05-04 05:00:32 -05:00
|
|
|
}
|
|
|
|
{
|
2019-08-27 16:14:32 -05:00
|
|
|
constexpr auto comp_shut = Connection::State::SHUT;
|
|
|
|
constexpr auto comp_open = Connection::State::OPEN;
|
2019-05-04 05:00:32 -05:00
|
|
|
{
|
|
|
|
const auto& well = schedule.getWell2("OP_2", 3);
|
|
|
|
const auto& cs = well.getConnections( );
|
|
|
|
|
|
|
|
BOOST_CHECK_EQUAL( 7U, cs.size() );
|
2019-08-27 16:14:32 -05:00
|
|
|
BOOST_CHECK(comp_shut == cs.getFromIJK( 7, 6, 2 ).state());
|
|
|
|
BOOST_CHECK(comp_shut == cs.getFromIJK( 7, 6, 3 ).state());
|
|
|
|
BOOST_CHECK(comp_shut == cs.getFromIJK( 7, 6, 4 ).state());
|
|
|
|
BOOST_CHECK(comp_open == cs.getFromIJK( 7, 7, 2 ).state());
|
2019-05-04 05:00:32 -05:00
|
|
|
}
|
|
|
|
{
|
|
|
|
const auto& well = schedule.getWell2("OP_2", 4);
|
|
|
|
const auto& cs2 = well.getConnections( );
|
2019-08-27 16:14:32 -05:00
|
|
|
BOOST_CHECK(comp_open == cs2.getFromIJK( 7, 6, 2 ).state());
|
|
|
|
BOOST_CHECK(comp_open == cs2.getFromIJK( 7, 6, 3 ).state());
|
|
|
|
BOOST_CHECK(comp_open == cs2.getFromIJK( 7, 6, 4 ).state());
|
|
|
|
BOOST_CHECK(comp_open == cs2.getFromIJK( 7, 7, 2 ).state());
|
2019-05-04 05:00:32 -05:00
|
|
|
}
|
|
|
|
{
|
|
|
|
const auto& well = schedule.getWell2("OP_3", 3);
|
|
|
|
const auto& cs3 = well.getConnections( );
|
2019-08-27 16:14:32 -05:00
|
|
|
BOOST_CHECK(comp_shut == cs3.get( 0 ).state());
|
2019-05-04 05:00:32 -05:00
|
|
|
}
|
|
|
|
{
|
|
|
|
const auto& well = schedule.getWell2("OP_3", 4);
|
|
|
|
const auto& cs4 = well.getConnections( );
|
2019-08-27 16:14:32 -05:00
|
|
|
BOOST_CHECK(comp_open == cs4.get( 0 ).state());
|
2019-05-04 05:00:32 -05:00
|
|
|
}
|
|
|
|
}
|
2015-01-13 04:25:46 -06:00
|
|
|
}
|
|
|
|
|
2015-01-21 07:07:02 -06:00
|
|
|
BOOST_AUTO_TEST_CASE(CreateScheduleDeckWithWELOPEN_TryToOpenWellWithShutCompletionsDoNotOpenWell) {
|
2019-03-23 10:11:37 -05:00
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"1 NOV 1979 / \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"DATES -- 1\n"
|
|
|
|
" 1 DES 1979/ \n"
|
|
|
|
"/\n"
|
|
|
|
"WELSPECS\n"
|
|
|
|
" 'OP_1' 'OP' 9 9 1* 'OIL' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
"/\n"
|
|
|
|
"COMPDAT\n"
|
|
|
|
" 'OP_1' 9 9 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
" 'OP_1' 9 9 2 2 'OPEN' 1* 46.825 0.311 4332.346 1* 1* 'X' 22.123 / \n"
|
|
|
|
" 'OP_1' 9 9 3 9 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 2\n"
|
|
|
|
" 10 JUL 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WELOPEN\n"
|
|
|
|
" 'OP_1' OPEN / \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 3\n"
|
|
|
|
" 10 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WELOPEN\n"
|
|
|
|
" 'OP_1' SHUT 0 0 0 0 0 / \n "
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 4\n"
|
|
|
|
" 10 NOV 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WELOPEN\n"
|
|
|
|
" 'OP_1' OPEN / \n "
|
|
|
|
"/\n";
|
2015-01-16 10:49:28 -06:00
|
|
|
|
2019-03-23 10:11:37 -05:00
|
|
|
EclipseGrid grid(10,10,10);
|
|
|
|
auto deck = parser.parseString(input);
|
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
|
|
|
Runspec runspec (deck);
|
|
|
|
Schedule schedule(deck , grid , eclipseProperties, runspec);
|
2019-05-04 05:00:32 -05:00
|
|
|
const auto& well2_3 = schedule.getWell2("OP_1",3);
|
|
|
|
const auto& well2_4 = schedule.getWell2("OP_1",4);
|
2019-08-23 06:58:39 -05:00
|
|
|
BOOST_CHECK(Well2::Status::SHUT == well2_3.getStatus());
|
|
|
|
BOOST_CHECK(Well2::Status::SHUT == well2_4.getStatus());
|
2015-01-16 10:49:28 -06:00
|
|
|
}
|
|
|
|
|
2017-09-26 02:32:29 -05:00
|
|
|
BOOST_AUTO_TEST_CASE(CreateScheduleDeckWithWELOPEN_CombineShutCompletionsAndAddNewCompletionsDoNotShutWell) {
|
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"1 NOV 1979 / \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"DATES -- 1\n"
|
|
|
|
" 1 DES 1979/ \n"
|
|
|
|
"/\n"
|
|
|
|
"WELSPECS\n"
|
|
|
|
" 'OP_1' 'OP' 9 9 1* 'OIL' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
"/\n"
|
|
|
|
"COMPDAT\n"
|
|
|
|
" 'OP_1' 9 9 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
" 'OP_1' 9 9 2 2 'OPEN' 1* 46.825 0.311 4332.346 1* 1* 'X' 22.123 / \n"
|
|
|
|
" 'OP_1' 9 9 3 9 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 2\n"
|
|
|
|
" 10 JUL 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WELOPEN\n"
|
|
|
|
" 'OP_1' OPEN / \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 3\n"
|
|
|
|
" 10 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WELOPEN\n"
|
|
|
|
" 'OP_1' SHUT 0 0 0 0 0 / \n "
|
|
|
|
"/\n"
|
|
|
|
"COMPDAT\n"
|
|
|
|
" 'OP_1' 9 9 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 4\n"
|
|
|
|
" 10 NOV 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WELOPEN\n"
|
|
|
|
" 'OP_1' SHUT 0 0 0 0 0 / \n "
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 5\n"
|
|
|
|
" 11 NOV 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"COMPDAT\n"
|
|
|
|
" 'OP_1' 9 9 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 6\n"
|
|
|
|
" 12 NOV 2008 / \n"
|
|
|
|
"/\n";
|
|
|
|
|
|
|
|
EclipseGrid grid(10,10,10);
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = parser.parseString(input);
|
2017-09-26 02:32:29 -05:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule(deck, grid , eclipseProperties, runspec);
|
2019-05-04 05:00:32 -05:00
|
|
|
const auto& well_3 = schedule.getWell2("OP_1", 3);
|
|
|
|
const auto& well_4 = schedule.getWell2("OP_1", 4);
|
|
|
|
const auto& well_5 = schedule.getWell2("OP_1", 5);
|
|
|
|
// timestep 3. Close all completions with WELOPEN and immediately open new completions with COMPDAT.
|
2019-08-23 06:58:39 -05:00
|
|
|
BOOST_CHECK(Well2::Status::OPEN == well_3.getStatus());
|
2019-05-04 05:00:32 -05:00
|
|
|
BOOST_CHECK( !schedule.hasWellEvent( "OP_1", ScheduleEvents::WELL_STATUS_CHANGE , 3 ));
|
|
|
|
// timestep 4. Close all completions with WELOPEN. The well will be shut since no completions
|
|
|
|
// are open.
|
2019-08-23 06:58:39 -05:00
|
|
|
BOOST_CHECK(Well2::Status::SHUT == well_4.getStatus());
|
2019-05-04 05:00:32 -05:00
|
|
|
BOOST_CHECK( schedule.hasWellEvent( "OP_1", ScheduleEvents::WELL_STATUS_CHANGE , 4 ));
|
|
|
|
// timestep 5. Open new completions. But keep the well shut,
|
2019-08-23 06:58:39 -05:00
|
|
|
BOOST_CHECK(Well2::Status::SHUT == well_5.getStatus());
|
2017-09-26 02:32:29 -05:00
|
|
|
}
|
|
|
|
|
2015-02-06 07:55:03 -06:00
|
|
|
BOOST_AUTO_TEST_CASE(CreateScheduleDeckWithWRFT) {
|
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"1 NOV 1979 / \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"DATES -- 1\n"
|
|
|
|
" 1 DES 1979/ \n"
|
|
|
|
"/\n"
|
|
|
|
"WELSPECS\n"
|
|
|
|
" 'OP_1' 'OP' 9 9 1* 'OIL' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
" 'OP_2' 'OP' 4 4 1* 'OIL' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
"/\n"
|
|
|
|
"COMPDAT\n"
|
|
|
|
" 'OP_1' 9 9 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
" 'OP_1' 9 9 2 2 'OPEN' 1* 46.825 0.311 4332.346 1* 1* 'X' 22.123 / \n"
|
|
|
|
" 'OP_1' 9 9 3 9 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
" 'OP_2' 4 4 4 9 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 2\n"
|
|
|
|
" 10 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WRFT \n"
|
|
|
|
"/ \n"
|
|
|
|
"WELOPEN\n"
|
|
|
|
" 'OP_1' OPEN / \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 3\n"
|
|
|
|
" 10 NOV 2008 / \n"
|
2016-03-27 07:06:06 -05:00
|
|
|
"/\n"
|
|
|
|
"WELOPEN\n"
|
|
|
|
" 'OP_2' OPEN / \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 4\n"
|
|
|
|
" 30 NOV 2008 / \n"
|
2015-02-06 07:55:03 -06:00
|
|
|
"/\n";
|
|
|
|
|
2016-03-27 07:06:06 -05:00
|
|
|
|
2016-09-08 12:42:45 -05:00
|
|
|
EclipseGrid grid(10,10,10);
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = parser.parseString(input);
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule(deck, grid , eclipseProperties, runspec);
|
2019-04-03 11:47:02 -05:00
|
|
|
const auto& rft_config = schedule.rftConfig();
|
2015-02-06 07:55:03 -06:00
|
|
|
|
2019-04-03 11:47:02 -05:00
|
|
|
BOOST_CHECK_EQUAL(2 , rft_config.firstRFTOutput());
|
|
|
|
BOOST_CHECK_EQUAL(true, rft_config.rft("OP_1", 2));
|
|
|
|
BOOST_CHECK_EQUAL(true, rft_config.rft("OP_2", 3));
|
2015-02-06 07:55:03 -06:00
|
|
|
}
|
|
|
|
|
2019-04-03 11:47:02 -05:00
|
|
|
|
2015-02-06 07:55:03 -06:00
|
|
|
BOOST_AUTO_TEST_CASE(CreateScheduleDeckWithWRFTPLT) {
|
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"1 NOV 1979 / \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"DATES -- 1\n"
|
|
|
|
" 1 DES 1979/ \n"
|
|
|
|
"/\n"
|
|
|
|
"WELSPECS\n"
|
|
|
|
" 'OP_1' 'OP' 9 9 1* 'OIL' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
"/\n"
|
|
|
|
"COMPDAT\n"
|
|
|
|
" 'OP_1' 9 9 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
" 'OP_1' 9 9 2 2 'OPEN' 1* 46.825 0.311 4332.346 1* 1* 'X' 22.123 / \n"
|
|
|
|
" 'OP_1' 9 9 3 9 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WELOPEN\n"
|
|
|
|
" 'OP_1' SHUT / \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 2\n"
|
|
|
|
" 10 OKT 2006 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WELOPEN\n"
|
|
|
|
" 'OP_1' SHUT / \n"
|
|
|
|
"/\n"
|
|
|
|
"WRFTPLT \n"
|
|
|
|
" 'OP_1' FOPN / \n"
|
|
|
|
"/ \n"
|
|
|
|
"DATES -- 3\n"
|
|
|
|
" 10 OKT 2007 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WELOPEN\n"
|
|
|
|
" 'OP_1' OPEN 0 0 0 0 0 / \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 4\n"
|
|
|
|
" 10 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WELOPEN\n"
|
|
|
|
" 'OP_1' OPEN / \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 5\n"
|
|
|
|
" 10 NOV 2008 / \n"
|
|
|
|
"/\n";
|
2016-09-08 12:42:45 -05:00
|
|
|
EclipseGrid grid(10,10,10);
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = parser.parseString(input);
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule(deck, grid , eclipseProperties, runspec);
|
2019-05-04 05:00:32 -05:00
|
|
|
const auto& well = schedule.getWell2("OP_1", 4);
|
2019-08-23 06:58:39 -05:00
|
|
|
BOOST_CHECK(Well2::Status::OPEN == well.getStatus());
|
2019-04-03 11:47:02 -05:00
|
|
|
|
2019-03-23 10:11:37 -05:00
|
|
|
const auto& rft_config = schedule.rftConfig();
|
|
|
|
BOOST_CHECK_EQUAL(rft_config.rft("OP_1", 3),false);
|
|
|
|
BOOST_CHECK_EQUAL(rft_config.rft("OP_1", 4),true);
|
|
|
|
BOOST_CHECK_EQUAL(rft_config.rft("OP_1", 5),false);
|
2015-02-06 07:55:03 -06:00
|
|
|
}
|
2015-01-13 08:06:28 -06:00
|
|
|
|
2015-03-25 02:20:22 -05:00
|
|
|
BOOST_AUTO_TEST_CASE(createDeckWithWeltArg) {
|
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"19 JUN 2007 / \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"DATES -- 1\n"
|
|
|
|
" 10 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WELSPECS\n"
|
|
|
|
" 'OP_1' 'OP' 9 9 1* 'OIL' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
"/\n"
|
|
|
|
"COMPDAT\n"
|
|
|
|
" 'OP_1' 9 9 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
" 'OP_1' 9 9 2 2 'OPEN' 1* 46.825 0.311 4332.346 1* 1* 'X' 22.123 / \n"
|
|
|
|
" 'OP_1' 9 9 3 9 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 2\n"
|
|
|
|
" 20 JAN 2010 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WELTARG\n"
|
|
|
|
" OP_1 ORAT 1300 /\n"
|
|
|
|
" OP_1 WRAT 1400 /\n"
|
2015-04-07 01:02:06 -05:00
|
|
|
" OP_1 GRAT 1500.52 /\n"
|
2015-03-25 02:20:22 -05:00
|
|
|
" OP_1 LRAT 1600.58 /\n"
|
|
|
|
" OP_1 RESV 1801.05 /\n"
|
|
|
|
" OP_1 BHP 1900 /\n"
|
|
|
|
" OP_1 THP 2000 /\n"
|
2015-04-07 01:02:06 -05:00
|
|
|
" OP_1 VFP 2100.09 /\n"
|
|
|
|
" OP_1 GUID 2300.14 /\n"
|
2015-03-25 02:20:22 -05:00
|
|
|
"/\n";
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = parser.parseString(input);
|
2016-09-08 12:42:45 -05:00
|
|
|
EclipseGrid grid(10,10,10);
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule(deck, grid , eclipseProperties, runspec);
|
2016-10-13 03:13:32 -05:00
|
|
|
Opm::UnitSystem unitSystem = deck.getActiveUnitSystem();
|
2016-10-07 09:55:04 -05:00
|
|
|
double siFactorL = unitSystem.parse("LiquidSurfaceVolume/Time").getSIScaling();
|
|
|
|
double siFactorG = unitSystem.parse("GasSurfaceVolume/Time").getSIScaling();
|
|
|
|
double siFactorP = unitSystem.parse("Pressure").getSIScaling();
|
2015-04-07 01:02:06 -05:00
|
|
|
|
2019-05-04 05:00:32 -05:00
|
|
|
const auto& well_1 = schedule.getWell2("OP_1", 1);
|
|
|
|
const auto wpp_1 = well_1.getProductionProperties();
|
2019-06-24 02:34:11 -05:00
|
|
|
BOOST_CHECK_EQUAL(wpp_1.WaterRate.get<double>(), 0);
|
2019-05-04 05:00:32 -05:00
|
|
|
|
|
|
|
const auto& well_2 = schedule.getWell2("OP_1", 2);
|
|
|
|
const auto wpp_2 = well_2.getProductionProperties();
|
2019-06-24 02:34:11 -05:00
|
|
|
BOOST_CHECK_EQUAL(wpp_2.OilRate.get<double>(), 1300 * siFactorL);
|
|
|
|
BOOST_CHECK_EQUAL(wpp_2.WaterRate.get<double>(), 1400 * siFactorL);
|
|
|
|
BOOST_CHECK_EQUAL(wpp_2.GasRate.get<double>(), 1500.52 * siFactorG);
|
|
|
|
BOOST_CHECK_EQUAL(wpp_2.LiquidRate.get<double>(), 1600.58 * siFactorL);
|
2019-06-24 00:56:37 -05:00
|
|
|
BOOST_CHECK_EQUAL(wpp_2.ResVRate.get<double>(), 1801.05 * siFactorL);
|
2019-06-24 02:34:11 -05:00
|
|
|
BOOST_CHECK_EQUAL(wpp_2.BHPLimit.get<double>(), 1900 * siFactorP);
|
|
|
|
BOOST_CHECK_EQUAL(wpp_2.THPLimit.get<double>(), 2000 * siFactorP);
|
2019-05-04 05:00:32 -05:00
|
|
|
BOOST_CHECK_EQUAL(wpp_2.VFPTableNumber, 2100);
|
|
|
|
BOOST_CHECK_EQUAL(well_2.getGuideRate(), 2300.14);
|
2015-03-25 02:20:22 -05:00
|
|
|
}
|
2015-04-08 05:12:57 -05:00
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(createDeckWithWeltArgException) {
|
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
2015-07-26 16:13:49 -05:00
|
|
|
"SCHEDULE\n"
|
2015-04-08 05:12:57 -05:00
|
|
|
"WELTARG\n"
|
|
|
|
" OP_1 GRAT 1500.52 /\n"
|
|
|
|
" OP_1 LRAT /\n"
|
|
|
|
" OP_1 RESV 1801.05 /\n"
|
|
|
|
"/\n";
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = parser.parseString(input);
|
2016-09-08 12:42:45 -05:00
|
|
|
EclipseGrid grid(10,10,10);
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2015-04-08 05:12:57 -05:00
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
BOOST_CHECK_THROW(Schedule(deck, grid , eclipseProperties, runspec),
|
2017-09-27 09:34:38 -05:00
|
|
|
std::invalid_argument);
|
2015-04-08 05:12:57 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(createDeckWithWeltArgException2) {
|
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
2015-07-26 16:13:49 -05:00
|
|
|
"SCHEDULE\n"
|
2015-04-08 05:12:57 -05:00
|
|
|
"WELTARG\n"
|
|
|
|
" OP_1 LRAT /\n"
|
|
|
|
" OP_1 RESV 1801.05 /\n"
|
|
|
|
"/\n";
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = parser.parseString(input);
|
2016-09-08 12:42:45 -05:00
|
|
|
EclipseGrid grid(10,10,10);
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
BOOST_CHECK_THROW(Schedule(deck, grid , eclipseProperties, runspec), std::out_of_range);
|
2015-05-24 07:35:13 -05:00
|
|
|
}
|
|
|
|
|
2015-06-02 06:30:53 -05:00
|
|
|
BOOST_AUTO_TEST_CASE(createDeckWithWPIMULT) {
|
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"19 JUN 2007 / \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"DATES -- 1\n"
|
|
|
|
" 10 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WELSPECS\n"
|
|
|
|
" 'OP_1' 'OP' 9 9 1* 'OIL' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
"/\n"
|
|
|
|
"COMPDAT\n"
|
|
|
|
" 'OP_1' 9 9 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
" 'OP_1' 9 9 2 2 'OPEN' 1* 46.825 0.311 4332.346 1* 1* 'X' 22.123 / \n"
|
|
|
|
" 'OP_1' 9 9 3 9 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 2\n"
|
|
|
|
" 20 JAN 2010 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WPIMULT\n"
|
2015-06-10 00:51:50 -05:00
|
|
|
"OP_1 1.30 /\n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 3\n"
|
|
|
|
" 20 JAN 2011 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WPIMULT\n"
|
|
|
|
"OP_1 1.30 /\n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 4\n"
|
|
|
|
" 20 JAN 2012 / \n"
|
|
|
|
"/\n"
|
|
|
|
"COMPDAT\n"
|
|
|
|
" 'OP_1' 9 9 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
" 'OP_1' 9 9 2 2 'OPEN' 1* 46.825 0.311 4332.346 1* 1* 'X' 22.123 / \n"
|
|
|
|
" 'OP_1' 9 9 3 9 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
2015-06-02 06:30:53 -05:00
|
|
|
"/\n";
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = parser.parseString(input);
|
2016-09-08 12:42:45 -05:00
|
|
|
EclipseGrid grid(10,10,10);
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule(deck, grid , eclipseProperties, runspec);
|
2015-06-02 06:30:53 -05:00
|
|
|
|
2019-05-04 05:00:32 -05:00
|
|
|
const auto& cs2 = schedule.getWell2("OP_1", 2).getConnections();
|
|
|
|
const auto& cs3 = schedule.getWell2("OP_1", 3).getConnections();
|
|
|
|
const auto& cs4 = schedule.getWell2("OP_1", 4).getConnections();
|
|
|
|
for(size_t i = 0; i < cs2.size(); i++)
|
|
|
|
BOOST_CHECK_EQUAL(cs2.get( i ).wellPi(), 1.3);
|
2015-06-10 00:51:50 -05:00
|
|
|
|
2019-05-04 05:00:32 -05:00
|
|
|
for(size_t i = 0; i < cs3.size(); i++ )
|
|
|
|
BOOST_CHECK_EQUAL(cs3.get( i ).wellPi(), (1.3*1.3));
|
2019-01-22 10:04:54 -06:00
|
|
|
|
2019-05-04 05:00:32 -05:00
|
|
|
for(size_t i = 0; i < cs4.size(); i++ )
|
|
|
|
BOOST_CHECK_EQUAL(cs4.get( i ).wellPi(), 1.0);
|
2019-01-22 10:04:54 -06:00
|
|
|
|
2019-05-04 05:00:32 -05:00
|
|
|
for(size_t i = 0; i < cs4.size(); i++ )
|
|
|
|
BOOST_CHECK_EQUAL(cs4.get( i ).wellPi(), 1.0);
|
2019-05-04 05:00:32 -05:00
|
|
|
|
2019-01-22 10:04:54 -06:00
|
|
|
BOOST_CHECK_THROW(schedule.simTime(10000), std::invalid_argument);
|
|
|
|
auto sim_time1 = schedule.simTime(1);
|
|
|
|
int day, month,year;
|
|
|
|
util_set_date_values_utc(sim_time1, &day, &month, &year);
|
|
|
|
BOOST_CHECK_EQUAL(day, 10);
|
|
|
|
BOOST_CHECK_EQUAL(month, 10);
|
|
|
|
BOOST_CHECK_EQUAL(year, 2008);
|
|
|
|
|
|
|
|
sim_time1 = schedule.simTime(3);
|
|
|
|
util_set_date_values_utc(sim_time1, &day, &month, &year);
|
|
|
|
BOOST_CHECK_EQUAL(day, 20);
|
|
|
|
BOOST_CHECK_EQUAL(month, 1);
|
|
|
|
BOOST_CHECK_EQUAL(year, 2011);
|
2015-06-02 06:30:53 -05:00
|
|
|
}
|
|
|
|
|
2019-08-09 05:12:30 -05:00
|
|
|
BOOST_AUTO_TEST_CASE(WELSPECS_WGNAME_SPACE) {
|
|
|
|
Opm::Parser parser;
|
|
|
|
const std::string input = R"(
|
|
|
|
START -- 0
|
|
|
|
10 'JAN' 2000 /
|
|
|
|
RUNSPEC
|
|
|
|
DIMENS
|
|
|
|
10 10 10 /
|
|
|
|
GRID
|
|
|
|
DX
|
|
|
|
1000*0.25 /
|
|
|
|
DY
|
|
|
|
1000*0.25 /
|
|
|
|
DZ
|
|
|
|
1000*0.25 /
|
|
|
|
TOPS
|
|
|
|
100*0.25 /
|
|
|
|
SCHEDULE
|
|
|
|
DATES -- 1
|
|
|
|
10 OKT 2008 /
|
|
|
|
/
|
|
|
|
WELSPECS
|
|
|
|
' PROD1' 'G1' 1 1 10 'OIL' /
|
|
|
|
'PROD2' 'G2' 2 2 10 'OIL' /
|
|
|
|
'PROD3' 'H1' 3 3 10 'OIL' /
|
|
|
|
/
|
|
|
|
GCONPROD
|
|
|
|
'G1' 'ORAT' 1000 /
|
|
|
|
/
|
|
|
|
DATES -- 2
|
|
|
|
10 NOV 2008 /
|
|
|
|
/
|
|
|
|
GCONPROD
|
|
|
|
'G*' 'ORAT' 2000 /
|
|
|
|
/
|
|
|
|
)";
|
|
|
|
|
|
|
|
auto deck = parser.parseString(input);
|
|
|
|
EclipseGrid grid( deck );
|
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
|
|
|
Runspec runspec (deck);
|
|
|
|
ParseContext parseContext;
|
|
|
|
ErrorGuard errors;
|
|
|
|
|
|
|
|
parseContext.update(ParseContext::PARSE_WGNAME_SPACE, InputError::THROW_EXCEPTION);
|
|
|
|
BOOST_CHECK_THROW( Opm::Schedule(deck, grid, eclipseProperties, runspec, parseContext, errors), std::invalid_argument);
|
|
|
|
|
|
|
|
parseContext.update(ParseContext::PARSE_WGNAME_SPACE, InputError::IGNORE);
|
|
|
|
BOOST_CHECK_NO_THROW( Opm::Schedule(deck, grid, eclipseProperties, runspec, parseContext, errors));
|
|
|
|
}
|
|
|
|
|
2018-05-03 06:20:04 -05:00
|
|
|
BOOST_AUTO_TEST_CASE(createDeckModifyMultipleGCONPROD) {
|
|
|
|
Opm::Parser parser;
|
|
|
|
const std::string input = R"(
|
|
|
|
START -- 0
|
|
|
|
10 'JAN' 2000 /
|
|
|
|
RUNSPEC
|
|
|
|
DIMENS
|
|
|
|
10 10 10 /
|
|
|
|
GRID
|
|
|
|
DX
|
|
|
|
1000*0.25 /
|
|
|
|
DY
|
|
|
|
1000*0.25 /
|
|
|
|
DZ
|
|
|
|
1000*0.25 /
|
|
|
|
TOPS
|
|
|
|
100*0.25 /
|
|
|
|
SCHEDULE
|
|
|
|
DATES -- 1
|
|
|
|
10 OKT 2008 /
|
|
|
|
/
|
|
|
|
WELSPECS
|
|
|
|
'PROD1' 'G1' 1 1 10 'OIL' /
|
|
|
|
'PROD2' 'G2' 2 2 10 'OIL' /
|
|
|
|
'PROD3' 'H1' 3 3 10 'OIL' /
|
|
|
|
/
|
|
|
|
GCONPROD
|
|
|
|
'G1' 'ORAT' 1000 /
|
|
|
|
/
|
|
|
|
DATES -- 2
|
|
|
|
10 NOV 2008 /
|
|
|
|
/
|
|
|
|
GCONPROD
|
2019-08-19 03:47:22 -05:00
|
|
|
'G*' 'ORAT' 2000 0 0 0 'NONE' 'YES' 148 'OIL'/
|
2018-05-03 06:20:04 -05:00
|
|
|
/
|
|
|
|
)";
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = parser.parseString(input);
|
2018-05-03 06:20:04 -05:00
|
|
|
EclipseGrid grid( deck );
|
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Opm::Schedule schedule(deck, grid, eclipseProperties, runspec);
|
2019-08-05 10:44:21 -05:00
|
|
|
Opm::SummaryState st;
|
2018-05-03 06:20:04 -05:00
|
|
|
|
|
|
|
Opm::UnitSystem unitSystem = deck.getActiveUnitSystem();
|
|
|
|
double siFactorL = unitSystem.parse("LiquidSurfaceVolume/Time").getSIScaling();
|
|
|
|
|
2019-08-06 15:40:14 -05:00
|
|
|
{
|
|
|
|
auto g = schedule.getGroup2("G1", 1);
|
2019-08-05 10:44:21 -05:00
|
|
|
BOOST_CHECK_EQUAL(g.productionControls(st).oil_target, 1000 * siFactorL);
|
2019-09-02 03:49:23 -05:00
|
|
|
BOOST_CHECK(g.has_control(Group2::ProductionCMode::ORAT));
|
|
|
|
BOOST_CHECK(!g.has_control(Group2::ProductionCMode::WRAT));
|
2019-08-19 11:05:43 -05:00
|
|
|
BOOST_CHECK_EQUAL(g.productionControls(st).guide_rate, 0);
|
2019-08-06 15:40:14 -05:00
|
|
|
}
|
|
|
|
{
|
|
|
|
auto g = schedule.getGroup2("G1", 2);
|
2019-08-05 10:44:21 -05:00
|
|
|
BOOST_CHECK_EQUAL(g.productionControls(st).oil_target, 2000 * siFactorL);
|
2019-08-19 03:47:22 -05:00
|
|
|
BOOST_CHECK_EQUAL(g.productionControls(st).guide_rate, 148);
|
2019-09-02 06:09:42 -05:00
|
|
|
BOOST_CHECK_EQUAL(true, g.productionControls(st).guide_rate_def == Group2::GuideRateTarget::OIL);
|
2019-08-06 15:40:14 -05:00
|
|
|
}
|
2018-05-03 06:20:04 -05:00
|
|
|
|
2019-08-06 15:40:14 -05:00
|
|
|
auto g2 = schedule.getGroup2("G2", 2);
|
2019-08-05 10:44:21 -05:00
|
|
|
BOOST_CHECK_EQUAL(g2.productionControls(st).oil_target, 2000 * siFactorL);
|
2018-05-03 06:20:04 -05:00
|
|
|
|
2019-08-06 15:40:14 -05:00
|
|
|
auto gh = schedule.getGroup2("H1", 1);
|
2018-05-03 06:20:04 -05:00
|
|
|
}
|
|
|
|
|
2015-10-02 03:49:56 -05:00
|
|
|
BOOST_AUTO_TEST_CASE(createDeckWithDRSDT) {
|
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"19 JUN 2007 / \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"DATES -- 1\n"
|
|
|
|
" 10 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"DRSDT\n"
|
|
|
|
"0.0003\n"
|
|
|
|
"/\n";
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = parser.parseString(input);
|
2016-09-08 12:42:45 -05:00
|
|
|
EclipseGrid grid(10,10,10);
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule(deck, grid , eclipseProperties, runspec);
|
2015-10-02 03:49:56 -05:00
|
|
|
size_t currentStep = 1;
|
|
|
|
BOOST_CHECK_EQUAL(schedule.hasOilVaporizationProperties(), true);
|
2016-10-05 05:43:36 -05:00
|
|
|
const auto& ovap = schedule.getOilVaporizationProperties(currentStep);
|
2015-10-09 02:50:09 -05:00
|
|
|
|
2018-10-17 06:35:25 -05:00
|
|
|
BOOST_CHECK_EQUAL(true, ovap.getOption(0));
|
2019-09-01 00:44:16 -05:00
|
|
|
BOOST_CHECK(ovap.getType() == OilVaporizationProperties::OilVaporization::DRDT);
|
|
|
|
|
2018-10-17 06:35:25 -05:00
|
|
|
BOOST_CHECK_EQUAL(true, ovap.drsdtActive());
|
|
|
|
BOOST_CHECK_EQUAL(false, ovap.drvdtActive());
|
|
|
|
}
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(createDeckWithDRSDTR) {
|
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"19 JUN 2007 / \n"
|
|
|
|
"TABDIMS\n"
|
|
|
|
" 1* 3 \n "
|
|
|
|
"/\n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"DATES -- 1\n"
|
|
|
|
" 10 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"DRSDTR\n"
|
|
|
|
"0 /\n"
|
|
|
|
"1 /\n"
|
|
|
|
"2 /\n";
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = parser.parseString(input);
|
2018-10-17 06:35:25 -05:00
|
|
|
EclipseGrid grid(10,10,10);
|
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule(deck, grid , eclipseProperties, runspec);
|
2018-10-17 06:35:25 -05:00
|
|
|
size_t currentStep = 1;
|
|
|
|
BOOST_CHECK_EQUAL(schedule.hasOilVaporizationProperties(), true);
|
|
|
|
const auto& ovap = schedule.getOilVaporizationProperties(currentStep);
|
|
|
|
auto unitSystem = UnitSystem::newMETRIC();
|
|
|
|
for (int i = 0; i < 3; ++i) {
|
|
|
|
double value = unitSystem.to_si( UnitSystem::measure::gas_surface_rate, i );
|
|
|
|
BOOST_CHECK_EQUAL(value, ovap.getMaxDRSDT(i));
|
|
|
|
BOOST_CHECK_EQUAL(true, ovap.getOption(i));
|
|
|
|
}
|
|
|
|
|
2019-09-01 00:44:16 -05:00
|
|
|
BOOST_CHECK(ovap.getType() == OilVaporizationProperties::OilVaporization::DRDT);
|
2018-10-17 06:35:25 -05:00
|
|
|
BOOST_CHECK_EQUAL(true, ovap.drsdtActive());
|
|
|
|
BOOST_CHECK_EQUAL(false, ovap.drvdtActive());
|
2015-10-02 03:49:56 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(createDeckWithDRSDTthenDRVDT) {
|
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"19 JUN 2007 / \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"DATES -- 1\n"
|
|
|
|
" 10 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"DRSDT\n"
|
|
|
|
"0.0003\n"
|
|
|
|
"/\n"
|
2018-10-17 06:35:25 -05:00
|
|
|
"DATES -- 2\n"
|
2015-10-02 03:49:56 -05:00
|
|
|
" 10 OKT 2009 / \n"
|
|
|
|
"/\n"
|
|
|
|
"DRVDT\n"
|
|
|
|
"0.100\n"
|
2018-10-17 06:35:25 -05:00
|
|
|
"/\n"
|
|
|
|
"DATES -- 3\n"
|
|
|
|
" 10 OKT 20010 / \n"
|
|
|
|
"/\n"
|
|
|
|
"VAPPARS\n"
|
|
|
|
"2 0.100\n"
|
2015-10-02 03:49:56 -05:00
|
|
|
"/\n";
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = parser.parseString(input);
|
2016-09-08 12:42:45 -05:00
|
|
|
EclipseGrid grid(10,10,10);
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule(deck, grid , eclipseProperties, runspec);
|
2015-10-02 03:49:56 -05:00
|
|
|
BOOST_CHECK_EQUAL(schedule.hasOilVaporizationProperties(), true);
|
2018-10-17 06:35:25 -05:00
|
|
|
|
|
|
|
const OilVaporizationProperties& ovap1 = schedule.getOilVaporizationProperties(1);
|
2019-09-01 00:44:16 -05:00
|
|
|
BOOST_CHECK(ovap1.getType() == OilVaporizationProperties::OilVaporization::DRDT);
|
2018-10-17 06:35:25 -05:00
|
|
|
BOOST_CHECK_EQUAL(true, ovap1.drsdtActive());
|
|
|
|
BOOST_CHECK_EQUAL(false, ovap1.drvdtActive());
|
|
|
|
|
|
|
|
const OilVaporizationProperties& ovap2 = schedule.getOilVaporizationProperties(2);
|
|
|
|
//double value = ovap2.getMaxDRVDT(0);
|
|
|
|
//BOOST_CHECK_EQUAL(1.1574074074074074e-06, value);
|
2019-09-01 00:44:16 -05:00
|
|
|
BOOST_CHECK(ovap2.getType() == OilVaporizationProperties::OilVaporization::DRDT);
|
2018-10-17 06:35:25 -05:00
|
|
|
BOOST_CHECK_EQUAL(true, ovap2.drvdtActive());
|
|
|
|
BOOST_CHECK_EQUAL(true, ovap2.drsdtActive());
|
|
|
|
|
|
|
|
const OilVaporizationProperties& ovap3 = schedule.getOilVaporizationProperties(3);
|
2019-09-01 00:44:16 -05:00
|
|
|
BOOST_CHECK(ovap3.getType() == OilVaporizationProperties::OilVaporization::VAPPARS);
|
2018-10-17 06:35:25 -05:00
|
|
|
BOOST_CHECK_EQUAL(false, ovap3.drvdtActive());
|
|
|
|
BOOST_CHECK_EQUAL(false, ovap3.drsdtActive());
|
|
|
|
|
|
|
|
|
2015-10-02 03:49:56 -05:00
|
|
|
}
|
2015-06-02 06:30:53 -05:00
|
|
|
|
2015-10-02 03:49:56 -05:00
|
|
|
BOOST_AUTO_TEST_CASE(createDeckWithVAPPARS) {
|
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"19 JUN 2007 / \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"DATES -- 1\n"
|
|
|
|
" 10 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"VAPPARS\n"
|
|
|
|
"2 0.100\n"
|
|
|
|
"/\n";
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = parser.parseString(input);
|
2016-09-08 12:42:45 -05:00
|
|
|
EclipseGrid grid(10,10,10);
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule(deck, grid , eclipseProperties, runspec);
|
2015-10-02 03:49:56 -05:00
|
|
|
size_t currentStep = 1;
|
|
|
|
BOOST_CHECK_EQUAL(schedule.hasOilVaporizationProperties(), true);
|
2016-10-05 05:43:36 -05:00
|
|
|
const OilVaporizationProperties& ovap = schedule.getOilVaporizationProperties(currentStep);
|
2019-09-01 00:44:16 -05:00
|
|
|
BOOST_CHECK(ovap.getType() == OilVaporizationProperties::OilVaporization::VAPPARS);
|
2018-10-17 06:35:25 -05:00
|
|
|
double vap1 = ovap.getVap1(0);
|
2015-10-02 03:49:56 -05:00
|
|
|
BOOST_CHECK_EQUAL(2, vap1);
|
2018-10-17 06:35:25 -05:00
|
|
|
double vap2 = ovap.getVap2(0);
|
2015-10-02 03:49:56 -05:00
|
|
|
BOOST_CHECK_EQUAL(0.100, vap2);
|
2018-10-17 06:35:25 -05:00
|
|
|
BOOST_CHECK_EQUAL(false, ovap.drsdtActive());
|
|
|
|
BOOST_CHECK_EQUAL(false, ovap.drvdtActive());
|
2015-10-02 03:49:56 -05:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(createDeckWithOutOilVaporizationProperties) {
|
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"19 JUN 2007 / \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"DATES -- 1\n"
|
|
|
|
" 10 OKT 2008 / \n"
|
|
|
|
"/\n";
|
|
|
|
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = parser.parseString(input);
|
2016-09-08 12:42:45 -05:00
|
|
|
EclipseGrid grid(10,10,10);
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule(deck, grid , eclipseProperties, runspec);
|
2015-10-02 03:49:56 -05:00
|
|
|
|
|
|
|
BOOST_CHECK_EQUAL(schedule.hasOilVaporizationProperties(), false);
|
|
|
|
|
|
|
|
|
|
|
|
}
|
2015-10-27 03:46:09 -05:00
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(changeBhpLimitInHistoryModeWithWeltarg) {
|
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"19 JUN 2007 / \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"DATES -- 1\n"
|
|
|
|
" 10 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WELSPECS\n"
|
|
|
|
" 'P' 'OP' 9 9 1* 'OIL' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
" 'I' 'OP' 1 1 1* 'WATER' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
"/\n"
|
|
|
|
"COMPDAT\n"
|
|
|
|
" 'P' 9 9 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
" 'P' 9 9 2 2 'OPEN' 1* 46.825 0.311 4332.346 1* 1* 'X' 22.123 / \n"
|
|
|
|
" 'I' 1 1 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WCONHIST\n"
|
|
|
|
" 'P' 'OPEN' 'RESV' 6* 500 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WCONINJH\n"
|
|
|
|
" 'I' 'WATER' 1* 100 250 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WELTARG\n"
|
|
|
|
" 'P' 'BHP' 50 / \n"
|
|
|
|
" 'I' 'BHP' 600 / \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 2\n"
|
|
|
|
" 15 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WCONHIST\n"
|
|
|
|
" 'P' 'OPEN' 'RESV' 6* 500/\n/\n"
|
|
|
|
"WCONINJH\n"
|
|
|
|
" 'I' 'WATER' 1* 100 250 / \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 3\n"
|
|
|
|
" 18 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WCONHIST\n"
|
|
|
|
" 'I' 'OPEN' 'RESV' 6* /\n/\n"
|
2018-12-18 08:39:38 -06:00
|
|
|
"DATES -- 4\n"
|
2015-10-27 03:46:09 -05:00
|
|
|
" 20 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WCONINJH\n"
|
|
|
|
" 'I' 'WATER' 1* 100 250 / \n"
|
|
|
|
"/\n"
|
|
|
|
;
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = parser.parseString(input);
|
2016-09-08 12:42:45 -05:00
|
|
|
EclipseGrid grid(10,10,10);
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-05-04 05:00:32 -05:00
|
|
|
Schedule sched(deck, grid , eclipseProperties, runspec);
|
2015-10-27 03:46:09 -05:00
|
|
|
|
|
|
|
// The BHP limit should not be effected by WCONHIST
|
2019-06-24 02:34:11 -05:00
|
|
|
BOOST_CHECK_EQUAL(sched.getWell2("P", 1).getProductionProperties().BHPLimit.get<double>(), 50 * 1e5); // 1
|
|
|
|
BOOST_CHECK_EQUAL(sched.getWell2("P", 2).getProductionProperties().BHPLimit.get<double>(), 50 * 1e5); // 2
|
2015-10-27 03:46:09 -05:00
|
|
|
|
|
|
|
|
2019-06-24 02:34:11 -05:00
|
|
|
BOOST_CHECK_EQUAL(sched.getWell2("I", 1).getInjectionProperties().BHPLimit.get<double>(), 600 * 1e5); // 1
|
|
|
|
BOOST_CHECK_EQUAL(sched.getWell2("I", 2).getInjectionProperties().BHPLimit.get<double>(), 600 * 1e5); // 2
|
2015-10-27 03:46:09 -05:00
|
|
|
|
2019-08-26 06:11:15 -05:00
|
|
|
BOOST_CHECK_EQUAL(sched.getWell2("I", 2).getInjectionProperties().hasInjectionControl(Opm::Well2::InjectorCMode::BHP), true);
|
2015-10-29 06:49:30 -05:00
|
|
|
|
2019-05-04 05:00:32 -05:00
|
|
|
// The well is producer for timestep 3 and the injection properties BHPLimit should be set to zero.
|
|
|
|
BOOST_CHECK(sched.getWell2("I", 3).isProducer());
|
2019-06-24 02:34:11 -05:00
|
|
|
BOOST_CHECK_EQUAL(sched.getWell2("I", 3).getInjectionProperties().BHPLimit.get<double>(), 0); // 3
|
2019-08-29 10:05:00 -05:00
|
|
|
BOOST_CHECK_EQUAL(sched.getWell2("I", 3).getProductionProperties().hasProductionControl(Opm::Well2::ProducerCMode::BHP), true );
|
2019-08-26 06:11:15 -05:00
|
|
|
BOOST_CHECK_EQUAL(sched.getWell2("I", 4).getInjectionProperties().hasInjectionControl(Opm::Well2::InjectorCMode::BHP), true );
|
2019-06-24 02:34:11 -05:00
|
|
|
BOOST_CHECK_EQUAL(sched.getWell2("I", 4).getInjectionProperties().BHPLimit.get<double>(), 6891.2 * 1e5); // 4
|
2015-10-27 03:46:09 -05:00
|
|
|
}
|
|
|
|
|
2016-09-22 02:28:43 -05:00
|
|
|
BOOST_AUTO_TEST_CASE(changeModeWithWHISTCTL) {
|
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"19 JUN 2007 / \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"DATES -- 1\n"
|
|
|
|
" 10 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WELSPECS\n"
|
|
|
|
" 'P1' 'OP' 9 9 1* 'OIL' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
" 'P2' 'OP' 5 5 1* 'OIL' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
" 'I' 'OP' 1 1 1* 'WATER' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
"/\n"
|
|
|
|
"COMPDAT\n"
|
|
|
|
" 'P1' 9 9 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
" 'P1' 9 9 2 2 'OPEN' 1* 46.825 0.311 4332.346 1* 1* 'X' 22.123 / \n"
|
|
|
|
" 'P2' 5 5 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
" 'P2' 5 5 2 2 'OPEN' 1* 46.825 0.311 4332.346 1* 1* 'X' 22.123 / \n"
|
|
|
|
" 'I' 1 1 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WCONHIST\n"
|
|
|
|
" 'P1' 'OPEN' 'ORAT' 5*/ \n"
|
|
|
|
" 'P2' 'OPEN' 'ORAT' 5*/ \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 2\n"
|
|
|
|
" 15 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WHISTCTL\n"
|
|
|
|
" RESV / \n"
|
|
|
|
"WCONHIST\n"
|
|
|
|
" 'P1' 'OPEN' 'ORAT' 5*/ \n"
|
|
|
|
" 'P2' 'OPEN' 'ORAT' 5*/ \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 3\n"
|
|
|
|
" 18 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WCONHIST\n"
|
|
|
|
" 'P1' 'OPEN' 'ORAT' 5*/ \n"
|
|
|
|
" 'P2' 'OPEN' 'ORAT' 5*/ \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 4\n"
|
|
|
|
" 20 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WHISTCTL\n"
|
|
|
|
" LRAT / \n"
|
|
|
|
"WCONHIST\n"
|
|
|
|
" 'P1' 'OPEN' 'ORAT' 5*/ \n"
|
|
|
|
" 'P2' 'OPEN' 'ORAT' 5*/ \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 5\n"
|
|
|
|
" 25 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WHISTCTL\n"
|
|
|
|
" NONE / \n"
|
|
|
|
"WCONHIST\n"
|
|
|
|
" 'P1' 'OPEN' 'ORAT' 5*/ \n"
|
|
|
|
" 'P2' 'OPEN' 'ORAT' 5*/ \n"
|
|
|
|
"/\n"
|
|
|
|
;
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = parser.parseString(input);
|
2016-09-22 02:28:43 -05:00
|
|
|
EclipseGrid grid(10,10,10);
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule(deck, grid , eclipseProperties, runspec);
|
2016-09-22 02:28:43 -05:00
|
|
|
|
|
|
|
//Start
|
2019-03-23 10:11:37 -05:00
|
|
|
BOOST_CHECK_THROW(schedule.getWell2("P1", 0), std::invalid_argument);
|
|
|
|
BOOST_CHECK_THROW(schedule.getWell2("P2", 0), std::invalid_argument);
|
2016-09-22 02:28:43 -05:00
|
|
|
|
|
|
|
//10 OKT 2008
|
2019-08-29 10:05:00 -05:00
|
|
|
BOOST_CHECK(schedule.getWell2("P1", 1).getProductionProperties().controlMode == Opm::Well2::ProducerCMode::ORAT);
|
|
|
|
BOOST_CHECK(schedule.getWell2("P2", 1).getProductionProperties().controlMode == Opm::Well2::ProducerCMode::ORAT);
|
2016-09-22 02:28:43 -05:00
|
|
|
|
|
|
|
//15 OKT 2008
|
2019-05-04 05:00:32 -05:00
|
|
|
{
|
|
|
|
const auto& props1 = schedule.getWell2("P1", 2).getProductionProperties();
|
|
|
|
const auto& props2 = schedule.getWell2("P2", 2).getProductionProperties();
|
2019-03-23 10:11:37 -05:00
|
|
|
|
2019-08-29 10:05:00 -05:00
|
|
|
BOOST_CHECK(props1.controlMode == Opm::Well2::ProducerCMode::RESV);
|
|
|
|
BOOST_CHECK(props2.controlMode == Opm::Well2::ProducerCMode::RESV);
|
2019-05-04 05:00:32 -05:00
|
|
|
// under history mode, a producing well should have only one rate target/limit or have no rate target/limit.
|
|
|
|
// the rate target/limit from previous report step should not be kept.
|
2019-08-29 10:05:00 -05:00
|
|
|
BOOST_CHECK( !props1.hasProductionControl(Opm::Well2::ProducerCMode::ORAT) );
|
|
|
|
BOOST_CHECK( !props2.hasProductionControl(Opm::Well2::ProducerCMode::ORAT) );
|
2019-05-04 05:00:32 -05:00
|
|
|
}
|
2019-05-02 08:08:44 -05:00
|
|
|
|
|
|
|
//18 OKT 2008
|
2019-05-04 05:00:32 -05:00
|
|
|
{
|
|
|
|
const auto& props1 = schedule.getWell2("P1", 3).getProductionProperties();
|
|
|
|
const auto& props2 = schedule.getWell2("P2", 3).getProductionProperties();
|
|
|
|
|
2019-08-29 10:05:00 -05:00
|
|
|
BOOST_CHECK(props1.controlMode == Opm::Well2::ProducerCMode::RESV);
|
|
|
|
BOOST_CHECK(props2.controlMode == Opm::Well2::ProducerCMode::RESV);
|
2019-05-04 05:00:32 -05:00
|
|
|
|
2019-08-29 10:05:00 -05:00
|
|
|
BOOST_CHECK( !props1.hasProductionControl(Opm::Well2::ProducerCMode::ORAT) );
|
|
|
|
BOOST_CHECK( !props2.hasProductionControl(Opm::Well2::ProducerCMode::ORAT) );
|
2019-05-04 05:00:32 -05:00
|
|
|
}
|
2019-05-02 08:08:44 -05:00
|
|
|
|
|
|
|
// 20 OKT 2008
|
2019-05-04 05:00:32 -05:00
|
|
|
{
|
|
|
|
const auto& props1 = schedule.getWell2("P1", 4).getProductionProperties();
|
|
|
|
const auto& props2 = schedule.getWell2("P2", 4).getProductionProperties();
|
|
|
|
|
2019-08-29 10:05:00 -05:00
|
|
|
BOOST_CHECK(props1.controlMode == Opm::Well2::ProducerCMode::LRAT);
|
|
|
|
BOOST_CHECK(props2.controlMode == Opm::Well2::ProducerCMode::LRAT);
|
2019-05-04 05:00:32 -05:00
|
|
|
|
2019-08-29 10:05:00 -05:00
|
|
|
BOOST_CHECK( !props1.hasProductionControl(Opm::Well2::ProducerCMode::ORAT) );
|
|
|
|
BOOST_CHECK( !props2.hasProductionControl(Opm::Well2::ProducerCMode::ORAT) );
|
|
|
|
BOOST_CHECK( !props1.hasProductionControl(Opm::Well2::ProducerCMode::RESV) );
|
|
|
|
BOOST_CHECK( !props2.hasProductionControl(Opm::Well2::ProducerCMode::RESV) );
|
2019-05-04 05:00:32 -05:00
|
|
|
}
|
2019-05-02 08:08:44 -05:00
|
|
|
|
|
|
|
// 25 OKT 2008
|
2019-05-04 05:00:32 -05:00
|
|
|
{
|
|
|
|
const auto& props1 = schedule.getWell2("P1", 5).getProductionProperties();
|
|
|
|
const auto& props2 = schedule.getWell2("P2", 5).getProductionProperties();
|
|
|
|
|
2019-08-29 10:05:00 -05:00
|
|
|
BOOST_CHECK(props1.controlMode == Opm::Well2::ProducerCMode::ORAT);
|
|
|
|
BOOST_CHECK(props2.controlMode == Opm::Well2::ProducerCMode::ORAT);
|
2019-05-04 05:00:32 -05:00
|
|
|
|
2019-08-29 10:05:00 -05:00
|
|
|
BOOST_CHECK( !props1.hasProductionControl(Opm::Well2::ProducerCMode::LRAT) );
|
|
|
|
BOOST_CHECK( !props2.hasProductionControl(Opm::Well2::ProducerCMode::LRAT) );
|
|
|
|
BOOST_CHECK( !props1.hasProductionControl(Opm::Well2::ProducerCMode::RESV) );
|
|
|
|
BOOST_CHECK( !props2.hasProductionControl(Opm::Well2::ProducerCMode::RESV) );
|
2019-05-04 05:00:32 -05:00
|
|
|
}
|
2019-05-02 08:08:44 -05:00
|
|
|
}
|
|
|
|
|
2019-05-11 06:11:54 -05:00
|
|
|
BOOST_AUTO_TEST_CASE(fromWCONHISTtoWCONPROD) {
|
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"19 JUN 2007 / \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"DATES -- 1\n"
|
|
|
|
" 10 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WELSPECS\n"
|
|
|
|
" 'P1' 'OP' 9 9 1* 'OIL' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
" 'P2' 'OP' 5 5 1* 'OIL' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
" 'I' 'OP' 1 1 1* 'WATER' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
"/\n"
|
|
|
|
"COMPDAT\n"
|
|
|
|
" 'P1' 9 9 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
" 'P1' 9 9 2 2 'OPEN' 1* 46.825 0.311 4332.346 1* 1* 'X' 22.123 / \n"
|
|
|
|
" 'P2' 5 5 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
" 'P2' 5 5 2 2 'OPEN' 1* 46.825 0.311 4332.346 1* 1* 'X' 22.123 / \n"
|
|
|
|
" 'I' 1 1 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WCONHIST\n"
|
|
|
|
" 'P1' 'OPEN' 'ORAT' 5*/ \n"
|
|
|
|
" 'P2' 'OPEN' 'ORAT' 5*/ \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 2\n"
|
|
|
|
" 15 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WCONPROD\n"
|
|
|
|
" 'P1' 'OPEN' 'GRAT' 1* 200.0 300.0 / \n"
|
|
|
|
" 'P2' 'OPEN' 'WRAT' 1* 100.0 300.0 / \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 3\n"
|
|
|
|
" 18 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
;
|
|
|
|
|
|
|
|
auto deck = parser.parseString(input);
|
|
|
|
EclipseGrid grid(10,10,10);
|
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
|
|
|
Runspec runspec (deck);
|
|
|
|
Schedule schedule(deck, grid , eclipseProperties, runspec);
|
|
|
|
|
|
|
|
//Start
|
|
|
|
BOOST_CHECK_THROW(schedule.getWell2("P1", 0), std::invalid_argument);
|
|
|
|
BOOST_CHECK_THROW(schedule.getWell2("P2", 0), std::invalid_argument);
|
|
|
|
|
|
|
|
//10 OKT 2008
|
2019-08-29 10:05:00 -05:00
|
|
|
BOOST_CHECK(schedule.getWell2("P1", 1).getProductionProperties().controlMode == Opm::Well2::ProducerCMode::ORAT);
|
|
|
|
BOOST_CHECK(schedule.getWell2("P2", 1).getProductionProperties().controlMode == Opm::Well2::ProducerCMode::ORAT);
|
2019-05-11 06:11:54 -05:00
|
|
|
|
|
|
|
//15 OKT 2008
|
2019-08-29 10:05:00 -05:00
|
|
|
BOOST_CHECK(schedule.getWell2("P1", 2).getProductionProperties().controlMode == Opm::Well2::ProducerCMode::GRAT);
|
|
|
|
BOOST_CHECK(schedule.getWell2("P1", 2).getProductionProperties().hasProductionControl(Opm::Well2::ProducerCMode::WRAT) );
|
|
|
|
BOOST_CHECK(schedule.getWell2("P2", 2).getProductionProperties().controlMode == Opm::Well2::ProducerCMode::WRAT);
|
|
|
|
BOOST_CHECK(schedule.getWell2("P2", 2).getProductionProperties().hasProductionControl(Opm::Well2::ProducerCMode::GRAT) );
|
2019-05-11 06:11:54 -05:00
|
|
|
// the previous control limits/targets should not stay
|
2019-08-29 10:05:00 -05:00
|
|
|
BOOST_CHECK( !schedule.getWell2("P1", 2).getProductionProperties().hasProductionControl(Opm::Well2::ProducerCMode::ORAT) );
|
|
|
|
BOOST_CHECK( !schedule.getWell2("P2", 2).getProductionProperties().hasProductionControl(Opm::Well2::ProducerCMode::ORAT) );
|
2019-05-11 06:11:54 -05:00
|
|
|
}
|
|
|
|
|
2019-05-02 08:08:44 -05:00
|
|
|
BOOST_AUTO_TEST_CASE(WHISTCTL_NEW_WELL) {
|
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"19 JUN 2007 / \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"WHISTCTL\n"
|
|
|
|
" GRAT/ \n"
|
|
|
|
"DATES -- 1\n"
|
|
|
|
" 10 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WELSPECS\n"
|
|
|
|
" 'P1' 'OP' 9 9 1* 'OIL' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
" 'P2' 'OP' 5 5 1* 'OIL' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
" 'I' 'OP' 1 1 1* 'WATER' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
"/\n"
|
|
|
|
"COMPDAT\n"
|
|
|
|
" 'P1' 9 9 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
" 'P1' 9 9 2 2 'OPEN' 1* 46.825 0.311 4332.346 1* 1* 'X' 22.123 / \n"
|
|
|
|
" 'P2' 5 5 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
" 'P2' 5 5 2 2 'OPEN' 1* 46.825 0.311 4332.346 1* 1* 'X' 22.123 / \n"
|
|
|
|
" 'I' 1 1 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WCONHIST\n"
|
|
|
|
" 'P1' 'OPEN' 'ORAT' 5*/ \n"
|
|
|
|
" 'P2' 'OPEN' 'ORAT' 5*/ \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 2\n"
|
|
|
|
" 15 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WHISTCTL\n"
|
|
|
|
" RESV / \n"
|
|
|
|
"WCONHIST\n"
|
|
|
|
" 'P1' 'OPEN' 'ORAT' 5*/ \n"
|
|
|
|
" 'P2' 'OPEN' 'ORAT' 5*/ \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 3\n"
|
|
|
|
" 18 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WCONHIST\n"
|
|
|
|
" 'P1' 'OPEN' 'ORAT' 5*/ \n"
|
|
|
|
" 'P2' 'OPEN' 'ORAT' 5*/ \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 4\n"
|
|
|
|
" 20 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WHISTCTL\n"
|
|
|
|
" LRAT / \n"
|
|
|
|
"WCONHIST\n"
|
|
|
|
" 'P1' 'OPEN' 'ORAT' 5*/ \n"
|
|
|
|
" 'P2' 'OPEN' 'ORAT' 5*/ \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 5\n"
|
|
|
|
" 25 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WHISTCTL\n"
|
|
|
|
" NONE / \n"
|
|
|
|
"WCONHIST\n"
|
|
|
|
" 'P1' 'OPEN' 'ORAT' 5*/ \n"
|
|
|
|
" 'P2' 'OPEN' 'ORAT' 5*/ \n"
|
|
|
|
"/\n"
|
|
|
|
;
|
|
|
|
|
|
|
|
auto deck = parser.parseString(input);
|
|
|
|
EclipseGrid grid(10,10,10);
|
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
|
|
|
Runspec runspec (deck);
|
|
|
|
Schedule schedule(deck, grid , eclipseProperties, runspec);
|
|
|
|
|
|
|
|
//10 OKT 2008
|
2019-08-29 10:05:00 -05:00
|
|
|
BOOST_CHECK(schedule.getWell2("P1", 1).getProductionProperties().controlMode == Opm::Well2::ProducerCMode::GRAT);
|
|
|
|
BOOST_CHECK(schedule.getWell2("P2", 1).getProductionProperties().controlMode == Opm::Well2::ProducerCMode::GRAT);
|
2019-05-02 08:08:44 -05:00
|
|
|
|
|
|
|
//15 OKT 2008
|
2019-08-29 10:05:00 -05:00
|
|
|
BOOST_CHECK(schedule.getWell2("P1", 2).getProductionProperties().controlMode == Opm::Well2::ProducerCMode::RESV);
|
|
|
|
BOOST_CHECK(schedule.getWell2("P2", 2).getProductionProperties().controlMode == Opm::Well2::ProducerCMode::RESV);
|
2019-05-02 01:42:42 -05:00
|
|
|
// under history mode, a producing well should have only one rate target/limit or have no rate target/limit.
|
|
|
|
// the rate target/limit from previous report step should not be kept.
|
2019-08-29 10:05:00 -05:00
|
|
|
BOOST_CHECK( !schedule.getWell2("P1", 2).getProductionProperties().hasProductionControl(Opm::Well2::ProducerCMode::ORAT) );
|
|
|
|
BOOST_CHECK( !schedule.getWell2("P2", 2).getProductionProperties().hasProductionControl(Opm::Well2::ProducerCMode::ORAT) );
|
2016-09-22 02:28:43 -05:00
|
|
|
|
|
|
|
//18 OKT 2008
|
2019-08-29 10:05:00 -05:00
|
|
|
BOOST_CHECK(schedule.getWell2("P1", 3).getProductionProperties().controlMode == Opm::Well2::ProducerCMode::RESV);
|
|
|
|
BOOST_CHECK(schedule.getWell2("P2", 3).getProductionProperties().controlMode == Opm::Well2::ProducerCMode::RESV);
|
|
|
|
BOOST_CHECK( !schedule.getWell2("P1", 3).getProductionProperties().hasProductionControl(Opm::Well2::ProducerCMode::ORAT) );
|
|
|
|
BOOST_CHECK( !schedule.getWell2("P2", 3).getProductionProperties().hasProductionControl(Opm::Well2::ProducerCMode::ORAT) );
|
2016-09-22 02:28:43 -05:00
|
|
|
|
|
|
|
// 20 OKT 2008
|
2019-08-29 10:05:00 -05:00
|
|
|
BOOST_CHECK(schedule.getWell2("P1", 4).getProductionProperties().controlMode == Opm::Well2::ProducerCMode::LRAT);
|
|
|
|
BOOST_CHECK(schedule.getWell2("P2", 4).getProductionProperties().controlMode == Opm::Well2::ProducerCMode::LRAT);
|
|
|
|
BOOST_CHECK( !schedule.getWell2("P1", 4).getProductionProperties().hasProductionControl(Opm::Well2::ProducerCMode::ORAT) );
|
|
|
|
BOOST_CHECK( !schedule.getWell2("P2", 4).getProductionProperties().hasProductionControl(Opm::Well2::ProducerCMode::ORAT) );
|
|
|
|
BOOST_CHECK( !schedule.getWell2("P1", 4).getProductionProperties().hasProductionControl(Opm::Well2::ProducerCMode::RESV) );
|
|
|
|
BOOST_CHECK( !schedule.getWell2("P2", 4).getProductionProperties().hasProductionControl(Opm::Well2::ProducerCMode::RESV) );
|
2016-09-22 02:28:43 -05:00
|
|
|
|
|
|
|
// 25 OKT 2008
|
2019-08-29 10:05:00 -05:00
|
|
|
BOOST_CHECK(schedule.getWell2("P1", 5).getProductionProperties().controlMode == Opm::Well2::ProducerCMode::ORAT);
|
|
|
|
BOOST_CHECK(schedule.getWell2("P2", 5).getProductionProperties().controlMode == Opm::Well2::ProducerCMode::ORAT);
|
|
|
|
BOOST_CHECK( !schedule.getWell2("P1", 5).getProductionProperties().hasProductionControl(Opm::Well2::ProducerCMode::RESV) );
|
|
|
|
BOOST_CHECK( !schedule.getWell2("P2", 5).getProductionProperties().hasProductionControl(Opm::Well2::ProducerCMode::RESV) );
|
|
|
|
BOOST_CHECK( !schedule.getWell2("P1", 5).getProductionProperties().hasProductionControl(Opm::Well2::ProducerCMode::LRAT) );
|
|
|
|
BOOST_CHECK( !schedule.getWell2("P2", 5).getProductionProperties().hasProductionControl(Opm::Well2::ProducerCMode::LRAT) );
|
2016-09-22 02:28:43 -05:00
|
|
|
}
|
|
|
|
|
2019-03-23 10:11:37 -05:00
|
|
|
|
|
|
|
|
2016-09-22 02:28:43 -05:00
|
|
|
BOOST_AUTO_TEST_CASE(unsupportedOptionWHISTCTL) {
|
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"19 JUN 2007 / \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"DATES -- 1\n"
|
|
|
|
" 10 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WELSPECS\n"
|
|
|
|
" 'P1' 'OP' 9 9 1* 'OIL' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
" 'P2' 'OP' 5 5 1* 'OIL' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
" 'I' 'OP' 1 1 1* 'WATER' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
"/\n"
|
|
|
|
"COMPDAT\n"
|
|
|
|
" 'P1' 9 9 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
" 'P1' 9 9 2 2 'OPEN' 1* 46.825 0.311 4332.346 1* 1* 'X' 22.123 / \n"
|
|
|
|
" 'P2' 5 5 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
" 'P2' 5 5 2 2 'OPEN' 1* 46.825 0.311 4332.346 1* 1* 'X' 22.123 / \n"
|
|
|
|
" 'I' 1 1 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WCONHIST\n"
|
|
|
|
" 'P1' 'OPEN' 'ORAT' 5*/ \n"
|
|
|
|
" 'P2' 'OPEN' 'ORAT' 5*/ \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 2\n"
|
|
|
|
" 15 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WHISTCTL\n"
|
|
|
|
" * YES / \n"
|
|
|
|
;
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = parser.parseString(input);
|
2016-09-22 02:28:43 -05:00
|
|
|
EclipseGrid grid(10,10,10);
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
BOOST_CHECK_THROW(Schedule(deck, grid, eclipseProperties, runspec), std::invalid_argument);
|
2016-09-22 02:28:43 -05:00
|
|
|
}
|
2015-10-27 03:46:09 -05:00
|
|
|
|
2016-11-22 04:34:46 -06:00
|
|
|
BOOST_AUTO_TEST_CASE(move_HEAD_I_location) {
|
|
|
|
std::string input = R"(
|
|
|
|
START -- 0
|
|
|
|
19 JUN 2007 /
|
|
|
|
SCHEDULE
|
|
|
|
DATES -- 1
|
|
|
|
10 OKT 2008 /
|
|
|
|
/
|
|
|
|
WELSPECS
|
|
|
|
'W1' 'G1' 3 3 2873.94 'WATER' 0.00 'STD' 'SHUT' 'NO' 0 'SEG' /
|
|
|
|
'W2' 'G2' 5 5 1 'OIL' 0.00 'STD' 'SHUT' 'NO' 0 'SEG' /
|
|
|
|
/
|
|
|
|
DATES -- 2
|
|
|
|
15 OKT 2008 /
|
|
|
|
/
|
|
|
|
|
|
|
|
WELSPECS
|
|
|
|
'W1' 'G1' 4 3 2873.94 'WATER' 0.00 'STD' 'SHUT' 'NO' 0 'SEG' /
|
|
|
|
/
|
|
|
|
)";
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = Parser().parseString(input);
|
2016-11-22 04:34:46 -06:00
|
|
|
EclipseGrid grid(10,10,10);
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule( deck, grid, eclipseProperties,runspec);
|
2019-05-04 05:00:32 -05:00
|
|
|
BOOST_CHECK_EQUAL(2, schedule.getWell2("W1", 1).getHeadI());
|
|
|
|
BOOST_CHECK_EQUAL(3, schedule.getWell2("W1", 2).getHeadI());
|
2016-11-22 04:34:46 -06:00
|
|
|
}
|
|
|
|
|
2016-11-29 08:46:55 -06:00
|
|
|
BOOST_AUTO_TEST_CASE(change_ref_depth) {
|
2016-11-22 06:18:43 -06:00
|
|
|
std::string input = R"(
|
|
|
|
START -- 0
|
|
|
|
19 JUN 2007 /
|
|
|
|
SCHEDULE
|
|
|
|
DATES -- 1
|
|
|
|
10 OKT 2008 /
|
|
|
|
/
|
|
|
|
WELSPECS
|
|
|
|
'W1' 'G1' 3 3 2873.94 'WATER' 0.00 'STD' 'SHUT' 'NO' 0 'SEG' /
|
|
|
|
'W2' 'G2' 5 5 1 'OIL' 0.00 'STD' 'SHUT' 'NO' 0 'SEG' /
|
|
|
|
/
|
|
|
|
DATES -- 2
|
|
|
|
15 OKT 2008 /
|
|
|
|
/
|
|
|
|
|
|
|
|
WELSPECS
|
|
|
|
'W1' 'G1' 3 3 12.0 'WATER' 0.00 'STD' 'SHUT' 'NO' 0 'SEG' /
|
|
|
|
/
|
|
|
|
)";
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = Parser().parseString(input);
|
2016-11-22 06:18:43 -06:00
|
|
|
EclipseGrid grid(10,10,10);
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule( deck, grid, eclipseProperties,runspec);
|
2019-05-04 05:00:32 -05:00
|
|
|
BOOST_CHECK_CLOSE(2873.94, schedule.getWell2("W1", 1).getRefDepth(), 1e-5);
|
|
|
|
BOOST_CHECK_EQUAL(12.0, schedule.getWell2("W1", 2).getRefDepth());
|
2016-11-22 06:18:43 -06:00
|
|
|
}
|
|
|
|
|
2019-03-23 10:11:37 -05:00
|
|
|
|
2018-04-26 07:41:39 -05:00
|
|
|
BOOST_AUTO_TEST_CASE(WTEMP_well_template) {
|
2019-03-23 10:11:37 -05:00
|
|
|
std::string input = R"(
|
2018-04-26 07:41:39 -05:00
|
|
|
START -- 0
|
|
|
|
19 JUN 2007 /
|
|
|
|
SCHEDULE
|
|
|
|
DATES -- 1
|
|
|
|
10 OKT 2008 /
|
|
|
|
/
|
|
|
|
WELSPECS
|
|
|
|
'W1' 'G1' 3 3 2873.94 'OIL' 0.00 'STD' 'SHUT' 'NO' 0 'SEG' /
|
|
|
|
'W2' 'G2' 5 5 1 'WATER' 0.00 'STD' 'SHUT' 'NO' 0 'SEG' /
|
|
|
|
'W3' 'G2' 6 6 1 'WATER' 0.00 'STD' 'SHUT' 'NO' 0 'SEG' /
|
|
|
|
/
|
|
|
|
|
|
|
|
WCONINJE
|
|
|
|
'W2' 'WATER' 'OPEN' 'RATE' 20000 4* /
|
|
|
|
'W3' 'WATER' 'OPEN' 'RATE' 20000 4* /
|
|
|
|
/
|
|
|
|
|
|
|
|
DATES -- 2
|
|
|
|
15 OKT 2008 /
|
|
|
|
/
|
|
|
|
|
|
|
|
WTEMP
|
|
|
|
'W*' 40.0 /
|
|
|
|
/
|
|
|
|
)";
|
|
|
|
|
2019-03-23 10:11:37 -05:00
|
|
|
auto deck = Parser().parseString(input);
|
|
|
|
EclipseGrid grid(10,10,10);
|
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
|
|
|
Runspec runspec (deck);
|
|
|
|
Schedule schedule( deck, grid, eclipseProperties,runspec);
|
2018-04-26 07:41:39 -05:00
|
|
|
|
2019-03-23 10:11:37 -05:00
|
|
|
BOOST_CHECK_CLOSE(288.71, schedule.getWell2("W1", 1).getInjectionProperties().temperature, 1e-5);
|
|
|
|
BOOST_CHECK_CLOSE(288.71, schedule.getWell2("W1", 2).getInjectionProperties().temperature, 1e-5);
|
|
|
|
|
|
|
|
BOOST_CHECK_CLOSE(288.71, schedule.getWell2("W2", 1).getInjectionProperties().temperature, 1e-5);
|
|
|
|
BOOST_CHECK_CLOSE(313.15, schedule.getWell2("W2", 2).getInjectionProperties().temperature, 1e-5);
|
|
|
|
|
|
|
|
BOOST_CHECK_CLOSE(288.71, schedule.getWell2("W3", 1).getInjectionProperties().temperature, 1e-5);
|
|
|
|
BOOST_CHECK_CLOSE(313.15, schedule.getWell2("W3", 2).getInjectionProperties().temperature, 1e-5);
|
2018-04-26 07:41:39 -05:00
|
|
|
}
|
|
|
|
|
2019-03-23 10:11:37 -05:00
|
|
|
|
2018-04-26 07:41:39 -05:00
|
|
|
BOOST_AUTO_TEST_CASE(WTEMPINJ_well_template) {
|
|
|
|
std::string input = R"(
|
|
|
|
START -- 0
|
|
|
|
19 JUN 2007 /
|
|
|
|
SCHEDULE
|
|
|
|
DATES -- 1
|
|
|
|
10 OKT 2008 /
|
|
|
|
/
|
|
|
|
WELSPECS
|
|
|
|
'W1' 'G1' 3 3 2873.94 'OIL' 0.00 'STD' 'SHUT' 'NO' 0 'SEG' /
|
|
|
|
'W2' 'G2' 5 5 1 'WATER' 0.00 'STD' 'SHUT' 'NO' 0 'SEG' /
|
|
|
|
'W3' 'G2' 6 6 1 'WATER' 0.00 'STD' 'SHUT' 'NO' 0 'SEG' /
|
|
|
|
/
|
|
|
|
|
|
|
|
WCONINJE
|
|
|
|
'W2' 'WATER' 'OPEN' 'RATE' 20000 4* /
|
|
|
|
'W3' 'WATER' 'OPEN' 'RATE' 20000 4* /
|
|
|
|
/
|
|
|
|
|
|
|
|
DATES -- 2
|
|
|
|
15 OKT 2008 /
|
|
|
|
/
|
|
|
|
|
|
|
|
WINJTEMP
|
|
|
|
'W*' 1* 40.0 1* /
|
|
|
|
/
|
|
|
|
)";
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = Parser().parseString(input);
|
2018-04-26 07:41:39 -05:00
|
|
|
EclipseGrid grid(10,10,10);
|
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule( deck, grid, eclipseProperties,runspec);
|
2018-04-26 07:41:39 -05:00
|
|
|
|
|
|
|
// Producerwell - currently setting temperature only acts on injectors.
|
2019-03-23 10:11:37 -05:00
|
|
|
BOOST_CHECK_CLOSE(288.71, schedule.getWell2("W1", 1).getInjectionProperties().temperature, 1e-5);
|
|
|
|
BOOST_CHECK_CLOSE(288.71, schedule.getWell2("W1", 2).getInjectionProperties().temperature, 1e-5);
|
2018-04-26 07:41:39 -05:00
|
|
|
|
2019-03-23 10:11:37 -05:00
|
|
|
BOOST_CHECK_CLOSE(288.71, schedule.getWell2("W2", 1).getInjectionProperties().temperature, 1e-5);
|
|
|
|
BOOST_CHECK_CLOSE(313.15, schedule.getWell2("W2", 2).getInjectionProperties().temperature, 1e-5);
|
2018-04-26 07:41:39 -05:00
|
|
|
|
2019-03-23 10:11:37 -05:00
|
|
|
BOOST_CHECK_CLOSE(288.71, schedule.getWell2("W3", 1).getInjectionProperties().temperature, 1e-5);
|
|
|
|
BOOST_CHECK_CLOSE(313.15, schedule.getWell2("W3", 2).getInjectionProperties().temperature, 1e-5);
|
2018-04-26 07:41:39 -05:00
|
|
|
}
|
|
|
|
|
2016-11-30 09:46:58 -06:00
|
|
|
BOOST_AUTO_TEST_CASE( COMPDAT_sets_automatic_complnum ) {
|
|
|
|
std::string input = R"(
|
|
|
|
START -- 0
|
|
|
|
19 JUN 2007 /
|
2019-03-18 07:32:14 -05:00
|
|
|
GRID
|
|
|
|
PERMX
|
|
|
|
1000*0.10/
|
|
|
|
COPY
|
|
|
|
PERMX PERMY /
|
|
|
|
PERMX PERMZ /
|
|
|
|
/
|
2016-11-30 09:46:58 -06:00
|
|
|
SCHEDULE
|
|
|
|
DATES -- 1
|
|
|
|
10 OKT 2008 /
|
|
|
|
/
|
|
|
|
WELSPECS
|
|
|
|
'W1' 'G1' 3 3 2873.94 'WATER' 0.00 'STD' 'SHUT' 'NO' 0 'SEG' /
|
|
|
|
/
|
|
|
|
|
|
|
|
COMPDAT
|
|
|
|
'W1' 0 0 1 1 'SHUT' 1* / -- regular completion (1)
|
|
|
|
'W1' 0 0 2 2 'SHUT' 1* / -- regular completion (2)
|
|
|
|
'W1' 0 0 3 4 'SHUT' 1* / -- two completions in one record (3, 4)
|
|
|
|
/
|
|
|
|
|
|
|
|
DATES -- 2
|
|
|
|
11 OKT 2008 /
|
|
|
|
/
|
|
|
|
|
|
|
|
COMPDAT
|
|
|
|
'W1' 0 0 1 1 'SHUT' 1* / -- respecify, essentially ignore (1)
|
|
|
|
/
|
|
|
|
)";
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = Parser().parseString(input);
|
2016-11-30 09:46:58 -06:00
|
|
|
EclipseGrid grid(10,10,10);
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule( deck, grid, eclipseProperties,runspec);
|
2019-05-04 05:00:32 -05:00
|
|
|
const auto& cs1 = schedule.getWell2( "W1", 1 ).getConnections( );
|
|
|
|
BOOST_CHECK_EQUAL( 1, cs1.get( 0 ).complnum() );
|
|
|
|
BOOST_CHECK_EQUAL( 2, cs1.get( 1 ).complnum() );
|
|
|
|
BOOST_CHECK_EQUAL( 3, cs1.get( 2 ).complnum() );
|
|
|
|
BOOST_CHECK_EQUAL( 4, cs1.get( 3 ).complnum() );
|
2016-11-30 09:46:58 -06:00
|
|
|
|
2019-05-04 05:00:32 -05:00
|
|
|
const auto& cs2 = schedule.getWell2( "W1", 2 ).getConnections( );
|
|
|
|
BOOST_CHECK_EQUAL( 1, cs2.get( 0 ).complnum() );
|
|
|
|
BOOST_CHECK_EQUAL( 2, cs2.get( 1 ).complnum() );
|
|
|
|
BOOST_CHECK_EQUAL( 3, cs2.get( 2 ).complnum() );
|
|
|
|
BOOST_CHECK_EQUAL( 4, cs2.get( 3 ).complnum() );
|
2016-11-30 09:46:58 -06:00
|
|
|
}
|
|
|
|
|
2016-12-01 07:07:11 -06:00
|
|
|
BOOST_AUTO_TEST_CASE( COMPDAT_multiple_wells ) {
|
2016-11-30 09:46:58 -06:00
|
|
|
std::string input = R"(
|
|
|
|
START -- 0
|
|
|
|
19 JUN 2007 /
|
2019-03-18 07:32:14 -05:00
|
|
|
GRID
|
|
|
|
PERMX
|
|
|
|
1000*0.10/
|
|
|
|
COPY
|
|
|
|
PERMX PERMY /
|
|
|
|
PERMX PERMZ /
|
|
|
|
/
|
2016-11-30 09:46:58 -06:00
|
|
|
SCHEDULE
|
|
|
|
DATES -- 1
|
|
|
|
10 OKT 2008 /
|
|
|
|
/
|
|
|
|
WELSPECS
|
|
|
|
'W1' 'G1' 3 3 2873.94 'WATER' 0.00 'STD' 'SHUT' 'NO' 0 'SEG' /
|
|
|
|
'W2' 'G2' 5 5 1 'OIL' 0.00 'STD' 'SHUT' 'NO' 0 'SEG' /
|
|
|
|
/
|
|
|
|
|
|
|
|
COMPDAT
|
|
|
|
'W1' 0 0 1 1 'SHUT' 1* / -- regular completion (1)
|
|
|
|
'W1' 0 0 2 2 'SHUT' 1* / -- regular completion (2)
|
|
|
|
'W1' 0 0 3 4 'SHUT' 1* / -- two completions in one record (3, 4)
|
|
|
|
'W2' 0 0 3 3 'SHUT' 1* / -- regular completion (1)
|
|
|
|
'W2' 0 0 1 3 'SHUT' 1* / -- two completions (one exist already) (2, 3)
|
2018-04-26 03:40:40 -05:00
|
|
|
'W*' 0 0 3 5 'SHUT' 1* / -- two completions, two wells (includes existing
|
|
|
|
-- and adding for both wells)
|
2016-11-30 09:46:58 -06:00
|
|
|
/
|
|
|
|
)";
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = Parser().parseString( input);
|
2016-11-29 08:46:55 -06:00
|
|
|
EclipseGrid grid( 10, 10, 10 );
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule( deck, grid, eclipseProperties,runspec);
|
2016-11-30 09:46:58 -06:00
|
|
|
|
2019-06-22 17:02:23 -05:00
|
|
|
{
|
|
|
|
const auto& w1cs = schedule.getWell2( "W1", 1 ).getConnections();
|
|
|
|
BOOST_CHECK_EQUAL( 1, w1cs.get( 0 ).complnum() );
|
|
|
|
BOOST_CHECK_EQUAL( 2, w1cs.get( 1 ).complnum() );
|
|
|
|
BOOST_CHECK_EQUAL( 3, w1cs.get( 2 ).complnum() );
|
|
|
|
BOOST_CHECK_EQUAL( 4, w1cs.get( 3 ).complnum() );
|
|
|
|
BOOST_CHECK_EQUAL( 5, w1cs.get( 4 ).complnum() );
|
|
|
|
|
|
|
|
const auto& w2cs = schedule.getWell2( "W2", 1 ).getConnections();
|
|
|
|
BOOST_CHECK_EQUAL( 1, w2cs.getFromIJK( 4, 4, 2 ).complnum() );
|
|
|
|
BOOST_CHECK_EQUAL( 2, w2cs.getFromIJK( 4, 4, 0 ).complnum() );
|
|
|
|
BOOST_CHECK_EQUAL( 3, w2cs.getFromIJK( 4, 4, 1 ).complnum() );
|
|
|
|
BOOST_CHECK_EQUAL( 4, w2cs.getFromIJK( 4, 4, 3 ).complnum() );
|
|
|
|
BOOST_CHECK_EQUAL( 5, w2cs.getFromIJK( 4, 4, 4 ).complnum() );
|
|
|
|
}
|
2018-04-26 03:40:40 -05:00
|
|
|
|
2019-03-23 10:11:37 -05:00
|
|
|
{
|
|
|
|
const auto& w1cs = schedule.getWell2( "W1", 1 ).getConnections();
|
|
|
|
BOOST_CHECK_EQUAL( 1, w1cs.get( 0 ).complnum() );
|
|
|
|
BOOST_CHECK_EQUAL( 2, w1cs.get( 1 ).complnum() );
|
|
|
|
BOOST_CHECK_EQUAL( 3, w1cs.get( 2 ).complnum() );
|
|
|
|
BOOST_CHECK_EQUAL( 4, w1cs.get( 3 ).complnum() );
|
|
|
|
BOOST_CHECK_EQUAL( 5, w1cs.get( 4 ).complnum() );
|
|
|
|
|
|
|
|
const auto& w2cs = schedule.getWell2( "W2", 1 ).getConnections();
|
|
|
|
BOOST_CHECK_EQUAL( 1, w2cs.getFromIJK( 4, 4, 2 ).complnum() );
|
|
|
|
BOOST_CHECK_EQUAL( 2, w2cs.getFromIJK( 4, 4, 0 ).complnum() );
|
|
|
|
BOOST_CHECK_EQUAL( 3, w2cs.getFromIJK( 4, 4, 1 ).complnum() );
|
|
|
|
BOOST_CHECK_EQUAL( 4, w2cs.getFromIJK( 4, 4, 3 ).complnum() );
|
|
|
|
BOOST_CHECK_EQUAL( 5, w2cs.getFromIJK( 4, 4, 4 ).complnum() );
|
|
|
|
|
|
|
|
BOOST_CHECK_THROW( w2cs.get( 5 ).complnum(), std::out_of_range );
|
|
|
|
}
|
2016-11-30 09:46:58 -06:00
|
|
|
}
|
2016-12-01 07:07:11 -06:00
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE( COMPDAT_multiple_records_same_completion ) {
|
|
|
|
std::string input = R"(
|
|
|
|
START -- 0
|
|
|
|
19 JUN 2007 /
|
2019-03-18 07:32:14 -05:00
|
|
|
GRID
|
|
|
|
PERMX
|
|
|
|
1000*0.10/
|
|
|
|
COPY
|
|
|
|
PERMX PERMY /
|
|
|
|
PERMX PERMZ /
|
|
|
|
/
|
2016-12-01 07:07:11 -06:00
|
|
|
SCHEDULE
|
|
|
|
DATES -- 1
|
|
|
|
10 OKT 2008 /
|
|
|
|
/
|
|
|
|
WELSPECS
|
|
|
|
'W1' 'G1' 3 3 2873.94 'WATER' 0.00 'STD' 'SHUT' 'NO' 0 'SEG' /
|
|
|
|
'W2' 'G2' 5 5 1 'OIL' 0.00 'STD' 'SHUT' 'NO' 0 'SEG' /
|
|
|
|
/
|
|
|
|
|
|
|
|
COMPDAT
|
|
|
|
'W1' 0 0 1 2 'SHUT' 1* / -- multiple completion (1, 2)
|
|
|
|
'W1' 0 0 2 2 'SHUT' 1* / -- updated completion (2)
|
|
|
|
'W1' 0 0 3 3 'SHUT' 1* / -- regular completion (3)
|
|
|
|
/
|
|
|
|
)";
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = Parser().parseString(input);
|
2016-12-01 07:07:11 -06:00
|
|
|
EclipseGrid grid(10,10,10);
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule( deck, grid, eclipseProperties,runspec);
|
2019-05-04 05:00:32 -05:00
|
|
|
const auto& cs = schedule.getWell2( "W1", 1 ).getConnections();
|
|
|
|
BOOST_CHECK_EQUAL( 3U, cs.size() );
|
|
|
|
BOOST_CHECK_EQUAL( 1, cs.get( 0 ).complnum() );
|
|
|
|
BOOST_CHECK_EQUAL( 2, cs.get( 1 ).complnum() );
|
|
|
|
BOOST_CHECK_EQUAL( 3, cs.get( 2 ).complnum() );
|
2016-12-01 07:07:11 -06:00
|
|
|
}
|
2016-11-29 08:46:55 -06:00
|
|
|
|
2019-03-23 10:11:37 -05:00
|
|
|
|
2016-11-29 08:46:55 -06:00
|
|
|
BOOST_AUTO_TEST_CASE( complump_less_than_1 ) {
|
|
|
|
std::string input = R"(
|
|
|
|
START -- 0
|
|
|
|
19 JUN 2007 /
|
2019-03-18 07:32:14 -05:00
|
|
|
GRID
|
|
|
|
PERMX
|
|
|
|
1000*0.10/
|
|
|
|
COPY
|
|
|
|
PERMX PERMY /
|
|
|
|
PERMX PERMZ /
|
|
|
|
/
|
2016-11-29 08:46:55 -06:00
|
|
|
SCHEDULE
|
|
|
|
|
|
|
|
WELSPECS
|
|
|
|
'W1' 'G1' 3 3 2873.94 'WATER' 0.00 'STD' 'SHUT' 'NO' 0 'SEG' /
|
|
|
|
/
|
|
|
|
|
|
|
|
COMPDAT
|
|
|
|
'W1' 0 0 1 2 'SHUT' 1* /
|
|
|
|
/
|
|
|
|
|
|
|
|
COMPLUMP
|
|
|
|
'W1' 0 0 0 0 0 /
|
|
|
|
/
|
|
|
|
)";
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = Parser().parseString( input);
|
2016-11-29 08:46:55 -06:00
|
|
|
EclipseGrid grid( 10, 10, 10);
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
BOOST_CHECK_THROW( Schedule( deck , grid, eclipseProperties, runspec), std::invalid_argument );
|
2016-11-29 08:46:55 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE( complump ) {
|
|
|
|
std::string input = R"(
|
|
|
|
START -- 0
|
|
|
|
19 JUN 2007 /
|
2019-03-18 07:32:14 -05:00
|
|
|
GRID
|
|
|
|
PERMX
|
|
|
|
1000*0.10/
|
|
|
|
COPY
|
|
|
|
PERMX PERMY /
|
|
|
|
PERMX PERMZ /
|
|
|
|
/
|
2016-11-29 08:46:55 -06:00
|
|
|
SCHEDULE
|
|
|
|
|
|
|
|
WELSPECS
|
|
|
|
'W1' 'G1' 3 3 2873.94 'WATER' 0.00 'STD' 'SHUT' 'NO' 0 'SEG' /
|
|
|
|
'W2' 'G2' 5 5 1 'OIL' 0.00 'STD' 'SHUT' 'NO' 0 'SEG' /
|
|
|
|
/
|
|
|
|
|
|
|
|
COMPDAT
|
|
|
|
'W1' 0 0 1 2 'SHUT' 1* /
|
|
|
|
'W1' 0 0 2 3 'SHUT' 1* /
|
|
|
|
'W1' 0 0 4 6 'SHUT' 1* /
|
|
|
|
'W2' 0 0 3 4 'SHUT' 1* /
|
|
|
|
'W2' 0 0 1 4 'SHUT' 1* /
|
|
|
|
/
|
|
|
|
|
|
|
|
COMPLUMP
|
|
|
|
-- name I J K1 K2 C
|
|
|
|
-- where C is the completion number of this lump
|
|
|
|
'W1' 0 0 1 3 1 /
|
|
|
|
/
|
|
|
|
|
|
|
|
DATES -- 1
|
|
|
|
10 OKT 2008 /
|
|
|
|
/
|
|
|
|
|
|
|
|
WELOPEN
|
|
|
|
'W1' 'OPEN' 0 0 0 1 1 /
|
|
|
|
/
|
|
|
|
)";
|
|
|
|
|
2019-08-27 16:14:32 -05:00
|
|
|
constexpr auto open = Connection::State::OPEN;
|
|
|
|
constexpr auto shut = Connection::State::SHUT;
|
2016-11-29 08:46:55 -06:00
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = Parser().parseString(input);
|
2016-11-29 08:46:55 -06:00
|
|
|
EclipseGrid grid(10,10,10);
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule( deck, grid, eclipseProperties,runspec);
|
2016-11-29 08:46:55 -06:00
|
|
|
|
2019-05-04 05:00:32 -05:00
|
|
|
const auto& sc0 = schedule.getWell2("W1", 0).getConnections();
|
|
|
|
/* complnum should be modified by COMPLNUM */
|
|
|
|
BOOST_CHECK_EQUAL( 1, sc0.getFromIJK( 2, 2, 0 ).complnum() );
|
|
|
|
BOOST_CHECK_EQUAL( 1, sc0.getFromIJK( 2, 2, 1 ).complnum() );
|
|
|
|
BOOST_CHECK_EQUAL( 1, sc0.getFromIJK( 2, 2, 2 ).complnum() );
|
|
|
|
|
2019-08-27 16:14:32 -05:00
|
|
|
BOOST_CHECK( shut == sc0.getFromIJK( 2, 2, 0 ).state() );
|
|
|
|
BOOST_CHECK( shut == sc0.getFromIJK( 2, 2, 1 ).state() );
|
|
|
|
BOOST_CHECK( shut == sc0.getFromIJK( 2, 2, 2 ).state() );
|
2019-05-04 05:00:32 -05:00
|
|
|
|
|
|
|
const auto& sc1 = schedule.getWell2("W1", 1).getConnections();
|
2019-08-27 16:14:32 -05:00
|
|
|
BOOST_CHECK( open == sc1.getFromIJK( 2, 2, 0 ).state() );
|
|
|
|
BOOST_CHECK( open == sc1.getFromIJK( 2, 2, 1 ).state() );
|
|
|
|
BOOST_CHECK( open == sc1.getFromIJK( 2, 2, 2 ).state() );
|
|
|
|
BOOST_CHECK( shut == sc1.getFromIJK( 2, 2, 3 ).state() );
|
2019-05-04 05:00:32 -05:00
|
|
|
|
|
|
|
const auto& completions = schedule.getWell2("W1", 1).getCompletions();
|
|
|
|
BOOST_CHECK_EQUAL(completions.size(), 4);
|
|
|
|
|
|
|
|
const auto& c1 = completions.at(1);
|
|
|
|
BOOST_CHECK_EQUAL(c1.size(), 3);
|
|
|
|
|
|
|
|
for (const auto& pair : completions) {
|
|
|
|
if (pair.first == 1)
|
|
|
|
BOOST_CHECK(pair.second.size() > 1);
|
|
|
|
else
|
|
|
|
BOOST_CHECK_EQUAL(pair.second.size(), 1);
|
2018-06-25 17:07:15 -05:00
|
|
|
}
|
2016-11-29 08:46:55 -06:00
|
|
|
}
|
|
|
|
|
2018-06-25 16:53:58 -05:00
|
|
|
|
|
|
|
|
2016-11-29 08:46:55 -06:00
|
|
|
BOOST_AUTO_TEST_CASE( COMPLUMP_specific_coordinates ) {
|
|
|
|
std::string input = R"(
|
|
|
|
START -- 0
|
|
|
|
19 JUN 2007 /
|
2019-03-18 07:32:14 -05:00
|
|
|
GRID
|
|
|
|
PERMX
|
|
|
|
1000*0.10/
|
|
|
|
COPY
|
|
|
|
PERMX PERMY /
|
|
|
|
PERMX PERMZ /
|
|
|
|
/
|
2016-11-29 08:46:55 -06:00
|
|
|
SCHEDULE
|
|
|
|
|
|
|
|
WELSPECS
|
|
|
|
'W1' 'G1' 3 3 2873.94 'WATER' 0.00 'STD' 'SHUT' 'NO' 0 'SEG' /
|
|
|
|
/
|
|
|
|
|
|
|
|
COMPDAT -- completion number
|
|
|
|
'W1' 1 1 1 1 'SHUT' 1* / -- 1
|
|
|
|
'W1' 1 1 2 2 'SHUT' 1* / -- 2
|
|
|
|
'W1' 0 0 1 2 'SHUT' 1* / -- 3, 4
|
|
|
|
'W1' 0 0 2 3 'SHUT' 1* / -- 5
|
|
|
|
'W1' 2 2 1 1 'SHUT' 1* / -- 6
|
|
|
|
'W1' 2 2 4 6 'SHUT' 1* / -- 7, 8, 9
|
|
|
|
/
|
|
|
|
|
|
|
|
DATES -- 1
|
|
|
|
10 OKT 2008 /
|
|
|
|
/
|
|
|
|
|
|
|
|
|
|
|
|
DATES -- 2
|
|
|
|
15 OKT 2008 /
|
|
|
|
/
|
|
|
|
|
|
|
|
COMPLUMP
|
|
|
|
-- name I J K1 K2 C
|
|
|
|
-- where C is the completion number of this lump
|
|
|
|
'W1' 0 0 2 3 2 / -- all with k = [2 <= k <= 3] -> {2, 4, 5}
|
|
|
|
'W1' 2 2 1 5 7 / -- fix'd i,j, k = [1 <= k <= 5] -> {6, 7, 8}
|
|
|
|
/
|
|
|
|
|
|
|
|
WELOPEN
|
|
|
|
'W1' OPEN 0 0 0 2 2 / -- open the new 2 {2, 4, 5}
|
|
|
|
'W1' OPEN 0 0 0 5 7 / -- open 5..7 {5, 6, 7, 8}
|
|
|
|
/
|
|
|
|
)";
|
|
|
|
|
2019-08-27 16:14:32 -05:00
|
|
|
constexpr auto open = Connection::State::OPEN;
|
|
|
|
constexpr auto shut = Connection::State::SHUT;
|
2016-11-29 08:46:55 -06:00
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = Parser().parseString( input);
|
2016-11-29 08:46:55 -06:00
|
|
|
EclipseGrid grid( 10, 10, 10 );
|
2017-02-15 04:13:29 -06:00
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule( deck, grid, eclipseProperties,runspec);
|
2016-11-29 08:46:55 -06:00
|
|
|
|
2019-03-23 10:11:37 -05:00
|
|
|
const auto& cs1 = schedule.getWell2("W1", 1).getConnections();
|
|
|
|
const auto& cs2 = schedule.getWell2("W1", 2).getConnections();
|
2016-11-29 08:46:55 -06:00
|
|
|
BOOST_CHECK_EQUAL( 9U, cs1.size() );
|
2019-08-27 16:14:32 -05:00
|
|
|
BOOST_CHECK( shut == cs1.getFromIJK( 0, 0, 1 ).state() );
|
|
|
|
BOOST_CHECK( shut == cs1.getFromIJK( 2, 2, 0 ).state() );
|
|
|
|
BOOST_CHECK( shut == cs1.getFromIJK( 2, 2, 1 ).state() );
|
|
|
|
BOOST_CHECK( shut == cs1.getFromIJK( 2, 2, 2 ).state() );
|
|
|
|
BOOST_CHECK( shut == cs1.getFromIJK( 1, 1, 0 ).state() );
|
|
|
|
BOOST_CHECK( shut == cs1.getFromIJK( 1, 1, 3 ).state() );
|
|
|
|
BOOST_CHECK( shut == cs1.getFromIJK( 1, 1, 4 ).state() );
|
|
|
|
BOOST_CHECK( shut == cs1.getFromIJK( 1, 1, 5 ).state() );
|
|
|
|
|
|
|
|
BOOST_CHECK( open == cs2.getFromIJK( 0, 0, 1 ).state() );
|
|
|
|
BOOST_CHECK( shut == cs2.getFromIJK( 2, 2, 0 ).state() );
|
|
|
|
BOOST_CHECK( open == cs2.getFromIJK( 2, 2, 1 ).state() );
|
|
|
|
BOOST_CHECK( open == cs2.getFromIJK( 2, 2, 2 ).state() );
|
|
|
|
BOOST_CHECK( open == cs2.getFromIJK( 1, 1, 0 ).state() );
|
|
|
|
BOOST_CHECK( open == cs2.getFromIJK( 1, 1, 3 ).state() );
|
|
|
|
BOOST_CHECK( open == cs2.getFromIJK( 1, 1, 4 ).state() );
|
|
|
|
BOOST_CHECK( shut == cs2.getFromIJK( 1, 1, 5 ).state() );
|
2016-11-29 08:46:55 -06:00
|
|
|
}
|
2017-05-24 07:48:27 -05:00
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(TestCompletionStateEnum2String) {
|
2019-08-27 16:14:32 -05:00
|
|
|
BOOST_CHECK( "AUTO" == Connection::State2String(Connection::State::AUTO));
|
|
|
|
BOOST_CHECK( "OPEN" == Connection::State2String(Connection::State::OPEN));
|
|
|
|
BOOST_CHECK( "SHUT" == Connection::State2String(Connection::State::SHUT));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(TestCompletionStateEnumFromString) {
|
2019-08-27 16:14:32 -05:00
|
|
|
BOOST_CHECK_THROW( Connection::StateFromString("XXX") , std::invalid_argument );
|
|
|
|
BOOST_CHECK( Connection::State::AUTO == Connection::StateFromString("AUTO"));
|
|
|
|
BOOST_CHECK( Connection::State::SHUT == Connection::StateFromString("SHUT"));
|
|
|
|
BOOST_CHECK( Connection::State::SHUT == Connection::StateFromString("STOP"));
|
|
|
|
BOOST_CHECK( Connection::State::OPEN == Connection::StateFromString("OPEN"));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(TestCompletionStateEnumLoop) {
|
2019-08-27 16:14:32 -05:00
|
|
|
BOOST_CHECK( Connection::State::AUTO == Connection::StateFromString( Connection::State2String( Connection::State::AUTO ) ));
|
|
|
|
BOOST_CHECK( Connection::State::SHUT == Connection::StateFromString( Connection::State2String( Connection::State::SHUT ) ));
|
|
|
|
BOOST_CHECK( Connection::State::OPEN == Connection::StateFromString( Connection::State2String( Connection::State::OPEN ) ));
|
2017-05-24 07:48:27 -05:00
|
|
|
|
2019-08-27 16:14:32 -05:00
|
|
|
BOOST_CHECK( "AUTO" == Connection::State2String(Connection::StateFromString( "AUTO" ) ));
|
|
|
|
BOOST_CHECK( "OPEN" == Connection::State2String(Connection::StateFromString( "OPEN" ) ));
|
|
|
|
BOOST_CHECK( "SHUT" == Connection::State2String(Connection::StateFromString( "SHUT" ) ));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*****************************************************************/
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(TestCompletionDirectionEnum2String)
|
|
|
|
{
|
2019-08-27 17:12:20 -05:00
|
|
|
BOOST_CHECK("X" == Connection::Direction2String(Connection::Direction::X));
|
|
|
|
BOOST_CHECK("Y" == Connection::Direction2String(Connection::Direction::Y));
|
|
|
|
BOOST_CHECK("Z" == Connection::Direction2String(Connection::Direction::Z));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(TestCompletionDirectionEnumFromString)
|
|
|
|
{
|
2019-08-27 17:12:20 -05:00
|
|
|
BOOST_CHECK_THROW(Connection::DirectionFromString("XXX"), std::invalid_argument);
|
2017-05-24 07:48:27 -05:00
|
|
|
|
2019-08-27 17:12:20 -05:00
|
|
|
BOOST_CHECK(Connection::Direction::X == Connection::DirectionFromString("X"));
|
|
|
|
BOOST_CHECK(Connection::Direction::Y == Connection::DirectionFromString("Y"));
|
|
|
|
BOOST_CHECK(Connection::Direction::Z == Connection::DirectionFromString("Z"));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
2019-08-27 17:12:20 -05:00
|
|
|
BOOST_AUTO_TEST_CASE(TestCompletionConnectionDirectionLoop)
|
2017-05-24 07:48:27 -05:00
|
|
|
{
|
2019-08-27 17:12:20 -05:00
|
|
|
BOOST_CHECK(Connection::Direction::X == Connection::DirectionFromString(Connection::Direction2String(Connection::Direction::X)));
|
|
|
|
BOOST_CHECK(Connection::Direction::Y == Connection::DirectionFromString(Connection::Direction2String(Connection::Direction::Y)));
|
|
|
|
BOOST_CHECK(Connection::Direction::Z == Connection::DirectionFromString(Connection::Direction2String(Connection::Direction::Z)));
|
2017-05-24 07:48:27 -05:00
|
|
|
|
2019-08-27 17:12:20 -05:00
|
|
|
BOOST_CHECK("X" == Connection::Direction2String(Connection::DirectionFromString("X")));
|
|
|
|
BOOST_CHECK("Y" == Connection::Direction2String(Connection::DirectionFromString("Y")));
|
|
|
|
BOOST_CHECK("Z" == Connection::Direction2String(Connection::DirectionFromString("Z")));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/*****************************************************************/
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(TestGroupInjectionControlEnum2String) {
|
2019-09-02 02:54:50 -05:00
|
|
|
BOOST_CHECK_EQUAL( "NONE" , Group2::InjectionCMode2String(Group2::InjectionCMode::NONE));
|
|
|
|
BOOST_CHECK_EQUAL( "RATE" , Group2::InjectionCMode2String(Group2::InjectionCMode::RATE));
|
|
|
|
BOOST_CHECK_EQUAL( "RESV" , Group2::InjectionCMode2String(Group2::InjectionCMode::RESV));
|
|
|
|
BOOST_CHECK_EQUAL( "REIN" , Group2::InjectionCMode2String(Group2::InjectionCMode::REIN));
|
|
|
|
BOOST_CHECK_EQUAL( "VREP" , Group2::InjectionCMode2String(Group2::InjectionCMode::VREP));
|
|
|
|
BOOST_CHECK_EQUAL( "FLD" , Group2::InjectionCMode2String(Group2::InjectionCMode::FLD));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(TestGroupInjectionControlEnumFromString) {
|
2019-09-02 02:54:50 -05:00
|
|
|
BOOST_CHECK_THROW( Group2::InjectionCModeFromString("XXX") , std::invalid_argument );
|
|
|
|
BOOST_CHECK( Group2::InjectionCMode::NONE == Group2::InjectionCModeFromString("NONE"));
|
|
|
|
BOOST_CHECK( Group2::InjectionCMode::RATE == Group2::InjectionCModeFromString("RATE"));
|
|
|
|
BOOST_CHECK( Group2::InjectionCMode::RESV == Group2::InjectionCModeFromString("RESV"));
|
|
|
|
BOOST_CHECK( Group2::InjectionCMode::REIN == Group2::InjectionCModeFromString("REIN"));
|
|
|
|
BOOST_CHECK( Group2::InjectionCMode::VREP == Group2::InjectionCModeFromString("VREP"));
|
|
|
|
BOOST_CHECK( Group2::InjectionCMode::FLD == Group2::InjectionCModeFromString("FLD"));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(TestGroupInjectionControlEnumLoop) {
|
2019-09-02 02:54:50 -05:00
|
|
|
BOOST_CHECK( Group2::InjectionCMode::NONE == Group2::InjectionCModeFromString( Group2::InjectionCMode2String( Group2::InjectionCMode::NONE ) ));
|
|
|
|
BOOST_CHECK( Group2::InjectionCMode::RATE == Group2::InjectionCModeFromString( Group2::InjectionCMode2String( Group2::InjectionCMode::RATE ) ));
|
|
|
|
BOOST_CHECK( Group2::InjectionCMode::RESV == Group2::InjectionCModeFromString( Group2::InjectionCMode2String( Group2::InjectionCMode::RESV ) ));
|
|
|
|
BOOST_CHECK( Group2::InjectionCMode::REIN == Group2::InjectionCModeFromString( Group2::InjectionCMode2String( Group2::InjectionCMode::REIN ) ));
|
|
|
|
BOOST_CHECK( Group2::InjectionCMode::VREP == Group2::InjectionCModeFromString( Group2::InjectionCMode2String( Group2::InjectionCMode::VREP ) ));
|
|
|
|
BOOST_CHECK( Group2::InjectionCMode::FLD == Group2::InjectionCModeFromString( Group2::InjectionCMode2String( Group2::InjectionCMode::FLD ) ));
|
|
|
|
|
|
|
|
BOOST_CHECK_EQUAL( "NONE" , Group2::InjectionCMode2String(Group2::InjectionCModeFromString( "NONE" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "RATE" , Group2::InjectionCMode2String(Group2::InjectionCModeFromString( "RATE" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "RESV" , Group2::InjectionCMode2String(Group2::InjectionCModeFromString( "RESV" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "REIN" , Group2::InjectionCMode2String(Group2::InjectionCModeFromString( "REIN" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "VREP" , Group2::InjectionCMode2String(Group2::InjectionCModeFromString( "VREP" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "FLD" , Group2::InjectionCMode2String(Group2::InjectionCModeFromString( "FLD" ) ));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/*****************************************************************/
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(TestGroupProductionControlEnum2String) {
|
2019-09-02 03:49:23 -05:00
|
|
|
BOOST_CHECK_EQUAL( "NONE" , Group2::ProductionCMode2String(Group2::ProductionCMode::NONE));
|
|
|
|
BOOST_CHECK_EQUAL( "ORAT" , Group2::ProductionCMode2String(Group2::ProductionCMode::ORAT));
|
|
|
|
BOOST_CHECK_EQUAL( "WRAT" , Group2::ProductionCMode2String(Group2::ProductionCMode::WRAT));
|
|
|
|
BOOST_CHECK_EQUAL( "GRAT" , Group2::ProductionCMode2String(Group2::ProductionCMode::GRAT));
|
|
|
|
BOOST_CHECK_EQUAL( "LRAT" , Group2::ProductionCMode2String(Group2::ProductionCMode::LRAT));
|
|
|
|
BOOST_CHECK_EQUAL( "CRAT" , Group2::ProductionCMode2String(Group2::ProductionCMode::CRAT));
|
|
|
|
BOOST_CHECK_EQUAL( "RESV" , Group2::ProductionCMode2String(Group2::ProductionCMode::RESV));
|
|
|
|
BOOST_CHECK_EQUAL( "PRBL" , Group2::ProductionCMode2String(Group2::ProductionCMode::PRBL));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(TestGroupProductionControlEnumFromString) {
|
2019-09-02 03:49:23 -05:00
|
|
|
BOOST_CHECK_THROW(Group2::ProductionCModeFromString("XXX") , std::invalid_argument );
|
|
|
|
BOOST_CHECK(Group2::ProductionCMode::NONE == Group2::ProductionCModeFromString("NONE"));
|
|
|
|
BOOST_CHECK(Group2::ProductionCMode::ORAT == Group2::ProductionCModeFromString("ORAT"));
|
|
|
|
BOOST_CHECK(Group2::ProductionCMode::WRAT == Group2::ProductionCModeFromString("WRAT"));
|
|
|
|
BOOST_CHECK(Group2::ProductionCMode::GRAT == Group2::ProductionCModeFromString("GRAT"));
|
|
|
|
BOOST_CHECK(Group2::ProductionCMode::LRAT == Group2::ProductionCModeFromString("LRAT"));
|
|
|
|
BOOST_CHECK(Group2::ProductionCMode::CRAT == Group2::ProductionCModeFromString("CRAT"));
|
|
|
|
BOOST_CHECK(Group2::ProductionCMode::RESV == Group2::ProductionCModeFromString("RESV"));
|
|
|
|
BOOST_CHECK(Group2::ProductionCMode::PRBL == Group2::ProductionCModeFromString("PRBL"));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(TestGroupProductionControlEnumLoop) {
|
2019-09-02 03:49:23 -05:00
|
|
|
BOOST_CHECK( Group2::ProductionCMode::NONE == Group2::ProductionCModeFromString( Group2::ProductionCMode2String( Group2::ProductionCMode::NONE ) ));
|
|
|
|
BOOST_CHECK( Group2::ProductionCMode::ORAT == Group2::ProductionCModeFromString( Group2::ProductionCMode2String( Group2::ProductionCMode::ORAT ) ));
|
|
|
|
BOOST_CHECK( Group2::ProductionCMode::WRAT == Group2::ProductionCModeFromString( Group2::ProductionCMode2String( Group2::ProductionCMode::WRAT ) ));
|
|
|
|
BOOST_CHECK( Group2::ProductionCMode::GRAT == Group2::ProductionCModeFromString( Group2::ProductionCMode2String( Group2::ProductionCMode::GRAT ) ));
|
|
|
|
BOOST_CHECK( Group2::ProductionCMode::LRAT == Group2::ProductionCModeFromString( Group2::ProductionCMode2String( Group2::ProductionCMode::LRAT ) ));
|
|
|
|
BOOST_CHECK( Group2::ProductionCMode::CRAT == Group2::ProductionCModeFromString( Group2::ProductionCMode2String( Group2::ProductionCMode::CRAT ) ));
|
|
|
|
BOOST_CHECK( Group2::ProductionCMode::RESV == Group2::ProductionCModeFromString( Group2::ProductionCMode2String( Group2::ProductionCMode::RESV ) ));
|
|
|
|
BOOST_CHECK( Group2::ProductionCMode::PRBL == Group2::ProductionCModeFromString( Group2::ProductionCMode2String( Group2::ProductionCMode::PRBL ) ));
|
|
|
|
|
|
|
|
BOOST_CHECK_EQUAL( "NONE" , Group2::ProductionCMode2String(Group2::ProductionCModeFromString( "NONE" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "ORAT" , Group2::ProductionCMode2String(Group2::ProductionCModeFromString( "ORAT" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "WRAT" , Group2::ProductionCMode2String(Group2::ProductionCModeFromString( "WRAT" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "GRAT" , Group2::ProductionCMode2String(Group2::ProductionCModeFromString( "GRAT" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "LRAT" , Group2::ProductionCMode2String(Group2::ProductionCModeFromString( "LRAT" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "CRAT" , Group2::ProductionCMode2String(Group2::ProductionCModeFromString( "CRAT" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "RESV" , Group2::ProductionCMode2String(Group2::ProductionCModeFromString( "RESV" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "PRBL" , Group2::ProductionCMode2String(Group2::ProductionCModeFromString( "PRBL" ) ));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/*****************************************************************/
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(TestGroupProductionExceedLimitControlEnum2String) {
|
2019-09-02 01:28:36 -05:00
|
|
|
BOOST_CHECK_EQUAL( "NONE" , Group2::ExceedAction2String(Group2::ExceedAction::NONE));
|
|
|
|
BOOST_CHECK_EQUAL( "CON" , Group2::ExceedAction2String(Group2::ExceedAction::CON));
|
|
|
|
BOOST_CHECK_EQUAL( "+CON" , Group2::ExceedAction2String(Group2::ExceedAction::CON_PLUS));
|
|
|
|
BOOST_CHECK_EQUAL( "WELL" , Group2::ExceedAction2String(Group2::ExceedAction::WELL));
|
|
|
|
BOOST_CHECK_EQUAL( "PLUG" , Group2::ExceedAction2String(Group2::ExceedAction::PLUG));
|
|
|
|
BOOST_CHECK_EQUAL( "RATE" , Group2::ExceedAction2String(Group2::ExceedAction::RATE));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(TestGroupProductionExceedLimitActionEnumFromString) {
|
2019-09-02 01:28:36 -05:00
|
|
|
BOOST_CHECK_THROW( Group2::ExceedActionFromString("XXX") , std::invalid_argument );
|
2017-05-24 07:48:27 -05:00
|
|
|
|
2019-09-02 01:28:36 -05:00
|
|
|
BOOST_CHECK(Group2::ExceedAction::NONE == Group2::ExceedActionFromString("NONE"));
|
|
|
|
BOOST_CHECK(Group2::ExceedAction::CON == Group2::ExceedActionFromString("CON" ));
|
|
|
|
BOOST_CHECK(Group2::ExceedAction::CON_PLUS == Group2::ExceedActionFromString("+CON"));
|
|
|
|
BOOST_CHECK(Group2::ExceedAction::WELL == Group2::ExceedActionFromString("WELL"));
|
|
|
|
BOOST_CHECK(Group2::ExceedAction::PLUG == Group2::ExceedActionFromString("PLUG"));
|
|
|
|
BOOST_CHECK(Group2::ExceedAction::RATE == Group2::ExceedActionFromString("RATE"));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(TestGroupProductionExceedLimitActionEnumLoop) {
|
2019-09-02 01:28:36 -05:00
|
|
|
BOOST_CHECK( Group2::ExceedAction::NONE == Group2::ExceedActionFromString( Group2::ExceedAction2String( Group2::ExceedAction::NONE ) ));
|
|
|
|
BOOST_CHECK( Group2::ExceedAction::CON == Group2::ExceedActionFromString( Group2::ExceedAction2String( Group2::ExceedAction::CON ) ));
|
|
|
|
BOOST_CHECK( Group2::ExceedAction::CON_PLUS == Group2::ExceedActionFromString( Group2::ExceedAction2String( Group2::ExceedAction::CON_PLUS ) ));
|
|
|
|
BOOST_CHECK( Group2::ExceedAction::WELL == Group2::ExceedActionFromString( Group2::ExceedAction2String( Group2::ExceedAction::WELL ) ));
|
|
|
|
BOOST_CHECK( Group2::ExceedAction::PLUG == Group2::ExceedActionFromString( Group2::ExceedAction2String( Group2::ExceedAction::PLUG ) ));
|
|
|
|
BOOST_CHECK( Group2::ExceedAction::RATE == Group2::ExceedActionFromString( Group2::ExceedAction2String( Group2::ExceedAction::RATE ) ));
|
|
|
|
|
|
|
|
BOOST_CHECK_EQUAL("NONE" , Group2::ExceedAction2String(Group2::ExceedActionFromString( "NONE" ) ));
|
|
|
|
BOOST_CHECK_EQUAL("CON" , Group2::ExceedAction2String(Group2::ExceedActionFromString( "CON" ) ));
|
|
|
|
BOOST_CHECK_EQUAL("+CON" , Group2::ExceedAction2String(Group2::ExceedActionFromString( "+CON" ) ));
|
|
|
|
BOOST_CHECK_EQUAL("WELL" , Group2::ExceedAction2String(Group2::ExceedActionFromString( "WELL" ) ));
|
|
|
|
BOOST_CHECK_EQUAL("PLUG" , Group2::ExceedAction2String(Group2::ExceedActionFromString( "PLUG" ) ));
|
|
|
|
BOOST_CHECK_EQUAL("RATE" , Group2::ExceedAction2String(Group2::ExceedActionFromString( "RATE" ) ));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/*****************************************************************/
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(TestInjectorEnum2String) {
|
2019-08-23 11:29:07 -05:00
|
|
|
BOOST_CHECK_EQUAL( "OIL" , Well2::InjectorType2String(Well2::InjectorType::OIL));
|
|
|
|
BOOST_CHECK_EQUAL( "GAS" , Well2::InjectorType2String(Well2::InjectorType::GAS));
|
|
|
|
BOOST_CHECK_EQUAL( "WATER" , Well2::InjectorType2String(Well2::InjectorType::WATER));
|
|
|
|
BOOST_CHECK_EQUAL( "MULTI" , Well2::InjectorType2String(Well2::InjectorType::MULTI));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(TestInjectorEnumFromString) {
|
2019-08-23 11:29:07 -05:00
|
|
|
BOOST_CHECK_THROW( Well2::InjectorTypeFromString("XXX") , std::invalid_argument );
|
|
|
|
BOOST_CHECK( Well2::InjectorType::OIL == Well2::InjectorTypeFromString("OIL"));
|
|
|
|
BOOST_CHECK( Well2::InjectorType::WATER == Well2::InjectorTypeFromString("WATER"));
|
|
|
|
BOOST_CHECK( Well2::InjectorType::WATER == Well2::InjectorTypeFromString("WAT"));
|
|
|
|
BOOST_CHECK( Well2::InjectorType::GAS == Well2::InjectorTypeFromString("GAS"));
|
|
|
|
BOOST_CHECK( Well2::InjectorType::MULTI == Well2::InjectorTypeFromString("MULTI"));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(TestInjectorEnumLoop) {
|
2019-08-23 11:29:07 -05:00
|
|
|
BOOST_CHECK( Well2::InjectorType::OIL == Well2::InjectorTypeFromString( Well2::InjectorType2String( Well2::InjectorType::OIL ) ));
|
|
|
|
BOOST_CHECK( Well2::InjectorType::WATER == Well2::InjectorTypeFromString( Well2::InjectorType2String( Well2::InjectorType::WATER ) ));
|
|
|
|
BOOST_CHECK( Well2::InjectorType::GAS == Well2::InjectorTypeFromString( Well2::InjectorType2String( Well2::InjectorType::GAS ) ));
|
|
|
|
BOOST_CHECK( Well2::InjectorType::MULTI == Well2::InjectorTypeFromString( Well2::InjectorType2String( Well2::InjectorType::MULTI ) ));
|
|
|
|
|
|
|
|
BOOST_CHECK_EQUAL( "MULTI" , Well2::InjectorType2String(Well2::InjectorTypeFromString( "MULTI" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "OIL" , Well2::InjectorType2String(Well2::InjectorTypeFromString( "OIL" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "GAS" , Well2::InjectorType2String(Well2::InjectorTypeFromString( "GAS" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "WATER" , Well2::InjectorType2String(Well2::InjectorTypeFromString( "WATER" ) ));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/*****************************************************************/
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(InjectorCOntrolMopdeEnum2String) {
|
2019-08-26 06:11:15 -05:00
|
|
|
BOOST_CHECK_EQUAL( "RATE" , Well2::InjectorCMode2String(Well2::InjectorCMode::RATE));
|
|
|
|
BOOST_CHECK_EQUAL( "RESV" , Well2::InjectorCMode2String(Well2::InjectorCMode::RESV));
|
|
|
|
BOOST_CHECK_EQUAL( "BHP" , Well2::InjectorCMode2String(Well2::InjectorCMode::BHP));
|
|
|
|
BOOST_CHECK_EQUAL( "THP" , Well2::InjectorCMode2String(Well2::InjectorCMode::THP));
|
|
|
|
BOOST_CHECK_EQUAL( "GRUP" , Well2::InjectorCMode2String(Well2::InjectorCMode::GRUP));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(InjectorControlModeEnumFromString) {
|
2019-08-26 06:11:15 -05:00
|
|
|
BOOST_CHECK_THROW( Well2::InjectorCModeFromString("XXX") , std::invalid_argument );
|
|
|
|
BOOST_CHECK( Well2::InjectorCMode::RATE == Well2::InjectorCModeFromString("RATE"));
|
|
|
|
BOOST_CHECK( Well2::InjectorCMode::BHP == Well2::InjectorCModeFromString("BHP"));
|
|
|
|
BOOST_CHECK( Well2::InjectorCMode::RESV == Well2::InjectorCModeFromString("RESV"));
|
|
|
|
BOOST_CHECK( Well2::InjectorCMode::THP == Well2::InjectorCModeFromString("THP"));
|
|
|
|
BOOST_CHECK( Well2::InjectorCMode::GRUP == Well2::InjectorCModeFromString("GRUP"));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(InjectorControlModeEnumLoop) {
|
2019-08-26 06:11:15 -05:00
|
|
|
BOOST_CHECK( Well2::InjectorCMode::RATE == Well2::InjectorCModeFromString( Well2::InjectorCMode2String( Well2::InjectorCMode::RATE ) ));
|
|
|
|
BOOST_CHECK( Well2::InjectorCMode::BHP == Well2::InjectorCModeFromString( Well2::InjectorCMode2String( Well2::InjectorCMode::BHP ) ));
|
|
|
|
BOOST_CHECK( Well2::InjectorCMode::RESV == Well2::InjectorCModeFromString( Well2::InjectorCMode2String( Well2::InjectorCMode::RESV ) ));
|
|
|
|
BOOST_CHECK( Well2::InjectorCMode::THP == Well2::InjectorCModeFromString( Well2::InjectorCMode2String( Well2::InjectorCMode::THP ) ));
|
|
|
|
BOOST_CHECK( Well2::InjectorCMode::GRUP == Well2::InjectorCModeFromString( Well2::InjectorCMode2String( Well2::InjectorCMode::GRUP ) ));
|
|
|
|
|
|
|
|
BOOST_CHECK_EQUAL( "THP" , Well2::InjectorCMode2String(Well2::InjectorCModeFromString( "THP" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "RATE" , Well2::InjectorCMode2String(Well2::InjectorCModeFromString( "RATE" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "RESV" , Well2::InjectorCMode2String(Well2::InjectorCModeFromString( "RESV" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "BHP" , Well2::InjectorCMode2String(Well2::InjectorCModeFromString( "BHP" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "GRUP" , Well2::InjectorCMode2String(Well2::InjectorCModeFromString( "GRUP" ) ));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*****************************************************************/
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(InjectorStatusEnum2String) {
|
2019-08-23 06:58:39 -05:00
|
|
|
BOOST_CHECK_EQUAL( "OPEN", Well2::Status2String(Well2::Status::OPEN));
|
|
|
|
BOOST_CHECK_EQUAL( "SHUT", Well2::Status2String(Well2::Status::SHUT));
|
|
|
|
BOOST_CHECK_EQUAL( "AUTO", Well2::Status2String(Well2::Status::AUTO));
|
|
|
|
BOOST_CHECK_EQUAL( "STOP", Well2::Status2String(Well2::Status::STOP));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(InjectorStatusEnumFromString) {
|
2019-08-23 06:58:39 -05:00
|
|
|
BOOST_CHECK_THROW( Well2::StatusFromString("XXX") , std::invalid_argument );
|
|
|
|
BOOST_CHECK( Well2::Status::OPEN == Well2::StatusFromString("OPEN"));
|
|
|
|
BOOST_CHECK( Well2::Status::AUTO == Well2::StatusFromString("AUTO"));
|
|
|
|
BOOST_CHECK( Well2::Status::SHUT == Well2::StatusFromString("SHUT"));
|
|
|
|
BOOST_CHECK( Well2::Status::STOP == Well2::StatusFromString("STOP"));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(InjectorStatusEnumLoop) {
|
2019-08-23 06:58:39 -05:00
|
|
|
BOOST_CHECK( Well2::Status::OPEN == Well2::StatusFromString( Well2::Status2String( Well2::Status::OPEN ) ));
|
|
|
|
BOOST_CHECK( Well2::Status::AUTO == Well2::StatusFromString( Well2::Status2String( Well2::Status::AUTO ) ));
|
|
|
|
BOOST_CHECK( Well2::Status::SHUT == Well2::StatusFromString( Well2::Status2String( Well2::Status::SHUT ) ));
|
|
|
|
BOOST_CHECK( Well2::Status::STOP == Well2::StatusFromString( Well2::Status2String( Well2::Status::STOP ) ));
|
2017-05-24 07:48:27 -05:00
|
|
|
|
2019-08-23 06:58:39 -05:00
|
|
|
BOOST_CHECK_EQUAL( "STOP", Well2::Status2String(Well2::StatusFromString( "STOP" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "OPEN", Well2::Status2String(Well2::StatusFromString( "OPEN" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "SHUT", Well2::Status2String(Well2::StatusFromString( "SHUT" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "AUTO", Well2::Status2String(Well2::StatusFromString( "AUTO" ) ));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/*****************************************************************/
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(ProducerCOntrolMopdeEnum2String) {
|
2019-08-29 10:05:00 -05:00
|
|
|
BOOST_CHECK_EQUAL( "ORAT" , Well2::ProducerCMode2String(Well2::ProducerCMode::ORAT));
|
|
|
|
BOOST_CHECK_EQUAL( "WRAT" , Well2::ProducerCMode2String(Well2::ProducerCMode::WRAT));
|
|
|
|
BOOST_CHECK_EQUAL( "GRAT" , Well2::ProducerCMode2String(Well2::ProducerCMode::GRAT));
|
|
|
|
BOOST_CHECK_EQUAL( "LRAT" , Well2::ProducerCMode2String(Well2::ProducerCMode::LRAT));
|
|
|
|
BOOST_CHECK_EQUAL( "CRAT" , Well2::ProducerCMode2String(Well2::ProducerCMode::CRAT));
|
|
|
|
BOOST_CHECK_EQUAL( "RESV" , Well2::ProducerCMode2String(Well2::ProducerCMode::RESV));
|
|
|
|
BOOST_CHECK_EQUAL( "BHP" , Well2::ProducerCMode2String(Well2::ProducerCMode::BHP));
|
|
|
|
BOOST_CHECK_EQUAL( "THP" , Well2::ProducerCMode2String(Well2::ProducerCMode::THP));
|
|
|
|
BOOST_CHECK_EQUAL( "GRUP" , Well2::ProducerCMode2String(Well2::ProducerCMode::GRUP));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(ProducerControlModeEnumFromString) {
|
2019-08-29 10:05:00 -05:00
|
|
|
BOOST_CHECK_THROW( Well2::ProducerCModeFromString("XRAT") , std::invalid_argument );
|
|
|
|
BOOST_CHECK( Well2::ProducerCMode::ORAT == Well2::ProducerCModeFromString("ORAT"));
|
|
|
|
BOOST_CHECK( Well2::ProducerCMode::WRAT == Well2::ProducerCModeFromString("WRAT"));
|
|
|
|
BOOST_CHECK( Well2::ProducerCMode::GRAT == Well2::ProducerCModeFromString("GRAT"));
|
|
|
|
BOOST_CHECK( Well2::ProducerCMode::LRAT == Well2::ProducerCModeFromString("LRAT"));
|
|
|
|
BOOST_CHECK( Well2::ProducerCMode::CRAT == Well2::ProducerCModeFromString("CRAT"));
|
|
|
|
BOOST_CHECK( Well2::ProducerCMode::RESV == Well2::ProducerCModeFromString("RESV"));
|
|
|
|
BOOST_CHECK( Well2::ProducerCMode::BHP == Well2::ProducerCModeFromString("BHP" ));
|
|
|
|
BOOST_CHECK( Well2::ProducerCMode::THP == Well2::ProducerCModeFromString("THP" ));
|
|
|
|
BOOST_CHECK( Well2::ProducerCMode::GRUP == Well2::ProducerCModeFromString("GRUP"));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(ProducerControlModeEnumLoop) {
|
2019-08-29 10:05:00 -05:00
|
|
|
BOOST_CHECK( Well2::ProducerCMode::ORAT == Well2::ProducerCModeFromString( Well2::ProducerCMode2String( Well2::ProducerCMode::ORAT ) ));
|
|
|
|
BOOST_CHECK( Well2::ProducerCMode::WRAT == Well2::ProducerCModeFromString( Well2::ProducerCMode2String( Well2::ProducerCMode::WRAT ) ));
|
|
|
|
BOOST_CHECK( Well2::ProducerCMode::GRAT == Well2::ProducerCModeFromString( Well2::ProducerCMode2String( Well2::ProducerCMode::GRAT ) ));
|
|
|
|
BOOST_CHECK( Well2::ProducerCMode::LRAT == Well2::ProducerCModeFromString( Well2::ProducerCMode2String( Well2::ProducerCMode::LRAT ) ));
|
|
|
|
BOOST_CHECK( Well2::ProducerCMode::CRAT == Well2::ProducerCModeFromString( Well2::ProducerCMode2String( Well2::ProducerCMode::CRAT ) ));
|
|
|
|
BOOST_CHECK( Well2::ProducerCMode::RESV == Well2::ProducerCModeFromString( Well2::ProducerCMode2String( Well2::ProducerCMode::RESV ) ));
|
|
|
|
BOOST_CHECK( Well2::ProducerCMode::BHP == Well2::ProducerCModeFromString( Well2::ProducerCMode2String( Well2::ProducerCMode::BHP ) ));
|
|
|
|
BOOST_CHECK( Well2::ProducerCMode::THP == Well2::ProducerCModeFromString( Well2::ProducerCMode2String( Well2::ProducerCMode::THP ) ));
|
|
|
|
BOOST_CHECK( Well2::ProducerCMode::GRUP == Well2::ProducerCModeFromString( Well2::ProducerCMode2String( Well2::ProducerCMode::GRUP ) ));
|
|
|
|
|
|
|
|
BOOST_CHECK_EQUAL( "ORAT" , Well2::ProducerCMode2String(Well2::ProducerCModeFromString( "ORAT" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "WRAT" , Well2::ProducerCMode2String(Well2::ProducerCModeFromString( "WRAT" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "GRAT" , Well2::ProducerCMode2String(Well2::ProducerCModeFromString( "GRAT" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "LRAT" , Well2::ProducerCMode2String(Well2::ProducerCModeFromString( "LRAT" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "CRAT" , Well2::ProducerCMode2String(Well2::ProducerCModeFromString( "CRAT" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "RESV" , Well2::ProducerCMode2String(Well2::ProducerCModeFromString( "RESV" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "BHP" , Well2::ProducerCMode2String(Well2::ProducerCModeFromString( "BHP" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "THP" , Well2::ProducerCMode2String(Well2::ProducerCModeFromString( "THP" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "GRUP" , Well2::ProducerCMode2String(Well2::ProducerCModeFromString( "GRUP" ) ));
|
2017-05-24 07:48:27 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
/*******************************************************************/
|
|
|
|
/*****************************************************************/
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(GuideRatePhaseEnum2String) {
|
|
|
|
BOOST_CHECK_EQUAL( "OIL" , GuideRate::GuideRatePhaseEnum2String(GuideRate::OIL));
|
|
|
|
BOOST_CHECK_EQUAL( "WAT" , GuideRate::GuideRatePhaseEnum2String(GuideRate::WAT));
|
|
|
|
BOOST_CHECK_EQUAL( "GAS" , GuideRate::GuideRatePhaseEnum2String(GuideRate::GAS));
|
|
|
|
BOOST_CHECK_EQUAL( "LIQ" , GuideRate::GuideRatePhaseEnum2String(GuideRate::LIQ));
|
|
|
|
BOOST_CHECK_EQUAL( "COMB" , GuideRate::GuideRatePhaseEnum2String(GuideRate::COMB));
|
|
|
|
BOOST_CHECK_EQUAL( "WGA" , GuideRate::GuideRatePhaseEnum2String(GuideRate::WGA));
|
|
|
|
BOOST_CHECK_EQUAL( "CVAL" , GuideRate::GuideRatePhaseEnum2String(GuideRate::CVAL));
|
|
|
|
BOOST_CHECK_EQUAL( "RAT" , GuideRate::GuideRatePhaseEnum2String(GuideRate::RAT));
|
|
|
|
BOOST_CHECK_EQUAL( "RES" , GuideRate::GuideRatePhaseEnum2String(GuideRate::RES));
|
|
|
|
BOOST_CHECK_EQUAL( "UNDEFINED" , GuideRate::GuideRatePhaseEnum2String(GuideRate::UNDEFINED));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(GuideRatePhaseEnumFromString) {
|
|
|
|
BOOST_CHECK_THROW( GuideRate::GuideRatePhaseEnumFromString("XRAT") , std::invalid_argument );
|
|
|
|
BOOST_CHECK_EQUAL( GuideRate::OIL , GuideRate::GuideRatePhaseEnumFromString("OIL"));
|
|
|
|
BOOST_CHECK_EQUAL( GuideRate::WAT , GuideRate::GuideRatePhaseEnumFromString("WAT"));
|
|
|
|
BOOST_CHECK_EQUAL( GuideRate::GAS , GuideRate::GuideRatePhaseEnumFromString("GAS"));
|
|
|
|
BOOST_CHECK_EQUAL( GuideRate::LIQ , GuideRate::GuideRatePhaseEnumFromString("LIQ"));
|
|
|
|
BOOST_CHECK_EQUAL( GuideRate::COMB , GuideRate::GuideRatePhaseEnumFromString("COMB"));
|
|
|
|
BOOST_CHECK_EQUAL( GuideRate::WGA , GuideRate::GuideRatePhaseEnumFromString("WGA"));
|
|
|
|
BOOST_CHECK_EQUAL( GuideRate::CVAL , GuideRate::GuideRatePhaseEnumFromString("CVAL"));
|
|
|
|
BOOST_CHECK_EQUAL( GuideRate::RAT , GuideRate::GuideRatePhaseEnumFromString("RAT"));
|
|
|
|
BOOST_CHECK_EQUAL( GuideRate::RES , GuideRate::GuideRatePhaseEnumFromString("RES"));
|
|
|
|
BOOST_CHECK_EQUAL( GuideRate::UNDEFINED, GuideRate::GuideRatePhaseEnumFromString("UNDEFINED"));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(GuideRatePhaseEnum2Loop) {
|
|
|
|
BOOST_CHECK_EQUAL( GuideRate::OIL , GuideRate::GuideRatePhaseEnumFromString( GuideRate::GuideRatePhaseEnum2String( GuideRate::OIL ) ));
|
|
|
|
BOOST_CHECK_EQUAL( GuideRate::WAT , GuideRate::GuideRatePhaseEnumFromString( GuideRate::GuideRatePhaseEnum2String( GuideRate::WAT ) ));
|
|
|
|
BOOST_CHECK_EQUAL( GuideRate::GAS , GuideRate::GuideRatePhaseEnumFromString( GuideRate::GuideRatePhaseEnum2String( GuideRate::GAS ) ));
|
|
|
|
BOOST_CHECK_EQUAL( GuideRate::LIQ , GuideRate::GuideRatePhaseEnumFromString( GuideRate::GuideRatePhaseEnum2String( GuideRate::LIQ ) ));
|
|
|
|
BOOST_CHECK_EQUAL( GuideRate::COMB , GuideRate::GuideRatePhaseEnumFromString( GuideRate::GuideRatePhaseEnum2String( GuideRate::COMB ) ));
|
|
|
|
BOOST_CHECK_EQUAL( GuideRate::WGA , GuideRate::GuideRatePhaseEnumFromString( GuideRate::GuideRatePhaseEnum2String( GuideRate::WGA ) ));
|
|
|
|
BOOST_CHECK_EQUAL( GuideRate::CVAL , GuideRate::GuideRatePhaseEnumFromString( GuideRate::GuideRatePhaseEnum2String( GuideRate::CVAL ) ));
|
|
|
|
BOOST_CHECK_EQUAL( GuideRate::RAT , GuideRate::GuideRatePhaseEnumFromString( GuideRate::GuideRatePhaseEnum2String( GuideRate::RAT ) ));
|
|
|
|
BOOST_CHECK_EQUAL( GuideRate::RES , GuideRate::GuideRatePhaseEnumFromString( GuideRate::GuideRatePhaseEnum2String( GuideRate::RES ) ));
|
|
|
|
BOOST_CHECK_EQUAL( GuideRate::UNDEFINED , GuideRate::GuideRatePhaseEnumFromString( GuideRate::GuideRatePhaseEnum2String( GuideRate::UNDEFINED ) ));
|
|
|
|
|
|
|
|
BOOST_CHECK_EQUAL( "OIL" , GuideRate::GuideRatePhaseEnum2String(GuideRate::GuideRatePhaseEnumFromString( "OIL" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "WAT" , GuideRate::GuideRatePhaseEnum2String(GuideRate::GuideRatePhaseEnumFromString( "WAT" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "GAS" , GuideRate::GuideRatePhaseEnum2String(GuideRate::GuideRatePhaseEnumFromString( "GAS" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "LIQ" , GuideRate::GuideRatePhaseEnum2String(GuideRate::GuideRatePhaseEnumFromString( "LIQ" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "COMB" , GuideRate::GuideRatePhaseEnum2String(GuideRate::GuideRatePhaseEnumFromString( "COMB" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "WGA" , GuideRate::GuideRatePhaseEnum2String(GuideRate::GuideRatePhaseEnumFromString( "WGA" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "CVAL" , GuideRate::GuideRatePhaseEnum2String(GuideRate::GuideRatePhaseEnumFromString( "CVAL" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "RAT" , GuideRate::GuideRatePhaseEnum2String(GuideRate::GuideRatePhaseEnumFromString( "RAT" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "RES" , GuideRate::GuideRatePhaseEnum2String(GuideRate::GuideRatePhaseEnumFromString( "RES" ) ));
|
|
|
|
BOOST_CHECK_EQUAL( "UNDEFINED" , GuideRate::GuideRatePhaseEnum2String(GuideRate::GuideRatePhaseEnumFromString( "UNDEFINED" ) ));
|
|
|
|
|
|
|
|
}
|
2017-11-21 02:55:07 -06:00
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(handleWEFAC) {
|
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"19 JUN 2007 / \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"DATES -- 1\n"
|
|
|
|
" 10 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WELSPECS\n"
|
|
|
|
" 'P' 'OP' 9 9 1* 'OIL' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
" 'I' 'OP' 1 1 1* 'WATER' 1* 1* 1* 1* 1* 1* 1* / \n"
|
|
|
|
"/\n"
|
|
|
|
"COMPDAT\n"
|
|
|
|
" 'P' 9 9 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
" 'P' 9 9 2 2 'OPEN' 1* 46.825 0.311 4332.346 1* 1* 'X' 22.123 / \n"
|
|
|
|
" 'I' 1 1 1 1 'OPEN' 1* 32.948 0.311 3047.839 1* 1* 'X' 22.100 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WCONHIST\n"
|
|
|
|
" 'P' 'OPEN' 'RESV' 6* 500 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WCONINJH\n"
|
|
|
|
" 'I' 'WATER' 1* 100 250 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WEFAC\n"
|
|
|
|
" 'P' 0.5 / \n"
|
|
|
|
" 'I' 0.9 / \n"
|
|
|
|
"/\n"
|
|
|
|
"DATES -- 2\n"
|
|
|
|
" 15 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
|
|
|
|
"DATES -- 3\n"
|
|
|
|
" 18 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WEFAC\n"
|
|
|
|
" 'P' 1.0 / \n"
|
|
|
|
"/\n"
|
|
|
|
;
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = parser.parseString(input);
|
2017-11-21 02:55:07 -06:00
|
|
|
EclipseGrid grid(10,10,10);
|
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule(deck, grid , eclipseProperties, runspec);
|
2019-03-23 10:11:37 -05:00
|
|
|
|
2017-11-21 02:55:07 -06:00
|
|
|
//1
|
2019-03-23 10:11:37 -05:00
|
|
|
BOOST_CHECK_EQUAL(schedule.getWell2("P", 1).getEfficiencyFactor(), 0.5);
|
|
|
|
BOOST_CHECK_EQUAL(schedule.getWell2("I", 1).getEfficiencyFactor(), 0.9);
|
2017-11-21 02:55:07 -06:00
|
|
|
|
|
|
|
//2
|
2019-03-23 10:11:37 -05:00
|
|
|
BOOST_CHECK_EQUAL(schedule.getWell2("P", 2).getEfficiencyFactor(), 0.5);
|
|
|
|
BOOST_CHECK_EQUAL(schedule.getWell2("I", 2).getEfficiencyFactor(), 0.9);
|
2017-11-21 02:55:07 -06:00
|
|
|
|
|
|
|
//3
|
2019-03-23 10:11:37 -05:00
|
|
|
BOOST_CHECK_EQUAL(schedule.getWell2("P", 3).getEfficiencyFactor(), 1.0);
|
|
|
|
BOOST_CHECK_EQUAL(schedule.getWell2("I", 3).getEfficiencyFactor(), 0.9);
|
2017-11-21 02:55:07 -06:00
|
|
|
}
|
2017-11-28 01:41:36 -06:00
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(historic_BHP_and_THP) {
|
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"19 JUN 2007 / \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"DATES -- 1\n"
|
|
|
|
" 10 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WELSPECS\n"
|
2019-03-23 10:11:37 -05:00
|
|
|
" 'P' 'OP' 9 9 1 'OIL' 1* / \n"
|
|
|
|
" 'P1' 'OP' 9 9 1 'OIL' 1* / \n"
|
|
|
|
" 'I' 'OP' 9 9 1 'WATER' 1* / \n"
|
2017-11-28 01:41:36 -06:00
|
|
|
"/\n"
|
|
|
|
"WCONHIST\n"
|
|
|
|
" P SHUT ORAT 6 500 0 0 0 1.2 1.1 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WCONPROD\n"
|
|
|
|
" P1 SHUT ORAT 6 500 0 0 0 3.2 3.1 / \n"
|
|
|
|
"/\n"
|
|
|
|
"WCONINJH\n"
|
|
|
|
" I WATER STOP 100 2.1 2.2 / \n"
|
|
|
|
"/\n"
|
|
|
|
;
|
|
|
|
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = parser.parseString(input);
|
2017-11-28 01:41:36 -06:00
|
|
|
EclipseGrid grid(10,10,10);
|
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule( deck, grid, eclipseProperties,runspec);
|
2017-11-28 01:41:36 -06:00
|
|
|
|
2018-05-13 21:18:07 -05:00
|
|
|
{
|
2019-03-23 10:11:37 -05:00
|
|
|
const auto& prod = schedule.getWell2("P", 1).getProductionProperties();
|
|
|
|
const auto& pro1 = schedule.getWell2("P1", 1).getProductionProperties();
|
|
|
|
const auto& inje = schedule.getWell2("I", 1).getInjectionProperties();
|
|
|
|
|
|
|
|
BOOST_CHECK_CLOSE( 1.1 * 1e5, prod.BHPH, 1e-5 );
|
|
|
|
BOOST_CHECK_CLOSE( 1.2 * 1e5, prod.THPH, 1e-5 );
|
|
|
|
BOOST_CHECK_CLOSE( 2.1 * 1e5, inje.BHPH, 1e-5 );
|
|
|
|
BOOST_CHECK_CLOSE( 2.2 * 1e5, inje.THPH, 1e-5 );
|
|
|
|
BOOST_CHECK_CLOSE( 0.0 * 1e5, pro1.BHPH, 1e-5 );
|
|
|
|
BOOST_CHECK_CLOSE( 0.0 * 1e5, pro1.THPH, 1e-5 );
|
|
|
|
|
|
|
|
{
|
|
|
|
const auto& wtest_config = schedule.wtestConfig(0);
|
|
|
|
BOOST_CHECK_EQUAL(wtest_config.size(), 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
{
|
|
|
|
const auto& wtest_config = schedule.wtestConfig(1);
|
|
|
|
BOOST_CHECK_EQUAL(wtest_config.size(), 0);
|
|
|
|
}
|
2018-05-13 21:18:07 -05:00
|
|
|
}
|
2017-11-28 01:41:36 -06:00
|
|
|
}
|
2018-02-06 12:13:42 -06:00
|
|
|
|
2019-03-23 10:11:37 -05:00
|
|
|
BOOST_AUTO_TEST_CASE(FilterCompletions2) {
|
|
|
|
EclipseGrid grid1(10,10,10);
|
|
|
|
std::vector<int> actnum(1000,1);
|
|
|
|
auto deck = createDeckWithWellsAndCompletionData();
|
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid1);
|
|
|
|
Runspec runspec (deck);
|
|
|
|
Schedule schedule(deck, grid1 , eclipseProperties, runspec);
|
|
|
|
{
|
|
|
|
const auto& c1_1 = schedule.getWell2("OP_1", 1).getConnections();
|
|
|
|
const auto& c1_3 = schedule.getWell2("OP_1", 3).getConnections();
|
|
|
|
BOOST_CHECK_EQUAL(2, c1_1.size());
|
|
|
|
BOOST_CHECK_EQUAL(9, c1_3.size());
|
|
|
|
}
|
|
|
|
actnum[grid1.getGlobalIndex(8,8,1)] = 0;
|
|
|
|
{
|
|
|
|
EclipseGrid grid2(grid1, actnum);
|
|
|
|
schedule.filterConnections(grid2);
|
|
|
|
|
|
|
|
const auto& c1_1 = schedule.getWell2("OP_1", 1).getConnections();
|
|
|
|
const auto& c1_3 = schedule.getWell2("OP_1", 3).getConnections();
|
|
|
|
BOOST_CHECK_EQUAL(1, c1_1.size());
|
|
|
|
BOOST_CHECK_EQUAL(8, c1_3.size());
|
|
|
|
|
|
|
|
BOOST_CHECK_EQUAL(2, c1_1.inputSize());
|
|
|
|
BOOST_CHECK_EQUAL(9, c1_3.inputSize());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2018-04-12 12:02:15 -05:00
|
|
|
|
2019-05-04 05:00:32 -05:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2018-04-12 12:02:15 -05:00
|
|
|
BOOST_AUTO_TEST_CASE(VFPINJ_TEST) {
|
|
|
|
const char *deckData = "\
|
|
|
|
START\n \
|
|
|
|
8 MAR 1998 /\n \
|
|
|
|
\n \
|
2019-03-18 07:32:14 -05:00
|
|
|
GRID \n\
|
|
|
|
PERMX \n\
|
|
|
|
1000*0.10/ \n\
|
|
|
|
COPY \n\
|
|
|
|
PERMX PERMY / \n\
|
|
|
|
PERMX PERMZ / \n\
|
|
|
|
/ \n \
|
2018-04-12 12:02:15 -05:00
|
|
|
SCHEDULE \n\
|
|
|
|
VFPINJ \n \
|
|
|
|
-- Table Depth Rate TAB UNITS BODY \n\
|
|
|
|
-- ----- ----- ----- ----- ------ ----- \n\
|
|
|
|
5 32.9 WAT THP METRIC BHP / \n\
|
|
|
|
-- Rate axis \n\
|
|
|
|
1 3 5 / \n\
|
|
|
|
-- THP axis \n\
|
|
|
|
7 11 / \n\
|
|
|
|
-- Table data with THP# <values 1-num_rates> \n\
|
|
|
|
1 1.5 2.5 3.5 / \n\
|
|
|
|
2 4.5 5.5 6.5 / \n\
|
|
|
|
TSTEP \n\
|
|
|
|
10 10/\n\
|
|
|
|
VFPINJ \n \
|
|
|
|
-- Table Depth Rate TAB UNITS BODY \n\
|
|
|
|
-- ----- ----- ----- ----- ------ ----- \n\
|
|
|
|
5 100 GAS THP METRIC BHP / \n\
|
|
|
|
-- Rate axis \n\
|
|
|
|
1 3 5 / \n\
|
|
|
|
-- THP axis \n\
|
|
|
|
7 11 / \n\
|
|
|
|
-- Table data with THP# <values 1-num_rates> \n\
|
|
|
|
1 1.5 2.5 3.5 / \n\
|
|
|
|
2 4.5 5.5 6.5 / \n\
|
|
|
|
--\n\
|
|
|
|
VFPINJ \n \
|
|
|
|
-- Table Depth Rate TAB UNITS BODY \n\
|
|
|
|
-- ----- ----- ----- ----- ------ ----- \n\
|
|
|
|
10 200 WAT THP METRIC BHP / \n\
|
|
|
|
-- Rate axis \n\
|
|
|
|
1 3 5 / \n\
|
|
|
|
-- THP axis \n\
|
|
|
|
7 11 / \n\
|
|
|
|
-- Table data with THP# <values 1-num_rates> \n\
|
|
|
|
1 1.5 2.5 3.5 / \n\
|
|
|
|
2 4.5 5.5 6.5 / \n";
|
|
|
|
|
|
|
|
|
|
|
|
Opm::Parser parser;
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = parser.parseString(deckData);
|
2018-04-12 12:02:15 -05:00
|
|
|
EclipseGrid grid1(10,10,10);
|
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid1);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule(deck, grid1 , eclipseProperties, runspec);
|
2018-04-12 12:02:15 -05:00
|
|
|
|
|
|
|
BOOST_CHECK( schedule.getEvents().hasEvent(ScheduleEvents::VFPINJ_UPDATE, 0));
|
|
|
|
BOOST_CHECK( !schedule.getEvents().hasEvent(ScheduleEvents::VFPINJ_UPDATE, 1));
|
|
|
|
BOOST_CHECK( schedule.getEvents().hasEvent(ScheduleEvents::VFPINJ_UPDATE, 2));
|
|
|
|
|
|
|
|
// No such table id
|
|
|
|
BOOST_CHECK_THROW(schedule.getVFPInjTable(77,0), std::invalid_argument);
|
|
|
|
|
|
|
|
// Table not defined at step 0
|
|
|
|
BOOST_CHECK_THROW(schedule.getVFPInjTable(10,0), std::invalid_argument);
|
|
|
|
|
|
|
|
const Opm::VFPInjTable& vfpinjTable2 = schedule.getVFPInjTable(5, 2);
|
|
|
|
BOOST_CHECK_EQUAL(vfpinjTable2.getTableNum(), 5);
|
|
|
|
BOOST_CHECK_EQUAL(vfpinjTable2.getDatumDepth(), 100);
|
|
|
|
BOOST_CHECK_EQUAL(vfpinjTable2.getFloType(), Opm::VFPInjTable::FLO_GAS);
|
|
|
|
|
|
|
|
const Opm::VFPInjTable& vfpinjTable3 = schedule.getVFPInjTable(10, 2);
|
|
|
|
BOOST_CHECK_EQUAL(vfpinjTable3.getTableNum(), 10);
|
|
|
|
BOOST_CHECK_EQUAL(vfpinjTable3.getDatumDepth(), 200);
|
|
|
|
BOOST_CHECK_EQUAL(vfpinjTable3.getFloType(), Opm::VFPInjTable::FLO_WAT);
|
|
|
|
|
|
|
|
const Opm::VFPInjTable& vfpinjTable = schedule.getVFPInjTable(5, 0);
|
|
|
|
BOOST_CHECK_EQUAL(vfpinjTable.getTableNum(), 5);
|
|
|
|
BOOST_CHECK_EQUAL(vfpinjTable.getDatumDepth(), 32.9);
|
|
|
|
BOOST_CHECK_EQUAL(vfpinjTable.getFloType(), Opm::VFPInjTable::FLO_WAT);
|
|
|
|
|
|
|
|
const auto vfp_tables0 = schedule.getVFPInjTables(0);
|
|
|
|
BOOST_CHECK_EQUAL( vfp_tables0.size(), 1);
|
|
|
|
|
|
|
|
const auto vfp_tables2 = schedule.getVFPInjTables(2);
|
|
|
|
BOOST_CHECK_EQUAL( vfp_tables2.size(), 2);
|
|
|
|
//Flo axis
|
|
|
|
{
|
|
|
|
const std::vector<double>& flo = vfpinjTable.getFloAxis();
|
|
|
|
BOOST_REQUIRE_EQUAL(flo.size(), 3);
|
|
|
|
|
|
|
|
//Unit of FLO is SM3/day, convert to SM3/second
|
|
|
|
double conversion_factor = 1.0 / (60*60*24);
|
|
|
|
BOOST_CHECK_EQUAL(flo[0], 1*conversion_factor);
|
|
|
|
BOOST_CHECK_EQUAL(flo[1], 3*conversion_factor);
|
|
|
|
BOOST_CHECK_EQUAL(flo[2], 5*conversion_factor);
|
|
|
|
}
|
|
|
|
|
|
|
|
//THP axis
|
|
|
|
{
|
|
|
|
const std::vector<double>& thp = vfpinjTable.getTHPAxis();
|
|
|
|
BOOST_REQUIRE_EQUAL(thp.size(), 2);
|
|
|
|
|
|
|
|
//Unit of THP is barsa => convert to pascal
|
|
|
|
double conversion_factor = 100000.0;
|
|
|
|
BOOST_CHECK_EQUAL(thp[0], 7*conversion_factor);
|
|
|
|
BOOST_CHECK_EQUAL(thp[1], 11*conversion_factor);
|
|
|
|
}
|
|
|
|
|
|
|
|
//The data itself
|
|
|
|
{
|
|
|
|
typedef Opm::VFPInjTable::array_type::size_type size_type;
|
|
|
|
const Opm::VFPInjTable::array_type& data = vfpinjTable.getTable();
|
|
|
|
const size_type* size = data.shape();
|
|
|
|
|
|
|
|
BOOST_CHECK_EQUAL(size[0], 2);
|
|
|
|
BOOST_CHECK_EQUAL(size[1], 3);
|
|
|
|
|
|
|
|
//Table given as BHP => barsa. Convert to pascal
|
|
|
|
double conversion_factor = 100000.0;
|
|
|
|
|
|
|
|
double index = 0.5;
|
|
|
|
for (size_type t=0; t<size[0]; ++t) {
|
|
|
|
for (size_type f=0; f<size[1]; ++f) {
|
|
|
|
index += 1.0;
|
|
|
|
BOOST_CHECK_EQUAL(data[t][f], index*conversion_factor);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-11-19 04:47:39 -06:00
|
|
|
// tests for the polymer injectivity case
|
|
|
|
BOOST_AUTO_TEST_CASE(POLYINJ_TEST) {
|
|
|
|
const char *deckData =
|
|
|
|
"START\n"
|
|
|
|
" 8 MAR 2018/\n"
|
2019-03-18 07:32:14 -05:00
|
|
|
"GRID\n"
|
|
|
|
"PERMX\n"
|
|
|
|
" 1000*0.25 /\n"
|
|
|
|
"COPY\n"
|
|
|
|
" PERMX PERMY /\n"
|
|
|
|
" PERMX PERMZ /\n"
|
|
|
|
"/\n"
|
2018-11-19 04:47:39 -06:00
|
|
|
"PROPS\n \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"WELSPECS\n"
|
2019-03-23 10:11:37 -05:00
|
|
|
"'INJE01' 'I' 1 1 1 'WATER' /\n"
|
2018-11-19 04:47:39 -06:00
|
|
|
"/\n"
|
2019-07-04 02:08:54 -05:00
|
|
|
"WCONINJE\n"
|
|
|
|
"'INJE01' 'WATER' 'OPEN' 'RATE' 800.00 1* 1000 /\n"
|
|
|
|
"/\n"
|
2018-11-19 04:47:39 -06:00
|
|
|
"TSTEP\n"
|
|
|
|
" 1/\n"
|
|
|
|
"WPOLYMER\n"
|
|
|
|
" 'INJE01' 1.0 0.0 /\n"
|
|
|
|
"/\n"
|
|
|
|
"WPMITAB\n"
|
|
|
|
" 'INJE01' 2 /\n"
|
|
|
|
"/\n"
|
|
|
|
"WSKPTAB\n"
|
|
|
|
" 'INJE01' 1 1 /\n"
|
|
|
|
"/\n"
|
|
|
|
"TSTEP\n"
|
|
|
|
" 2*1/\n"
|
|
|
|
"WPMITAB\n"
|
|
|
|
" 'INJE01' 3 /\n"
|
|
|
|
"/\n"
|
|
|
|
"WSKPTAB\n"
|
|
|
|
" 'INJE01' 2 2 /\n"
|
|
|
|
"/\n"
|
|
|
|
"TSTEP\n"
|
|
|
|
" 1 /\n";
|
|
|
|
|
|
|
|
Opm::Parser parser;
|
2019-01-03 11:05:19 -06:00
|
|
|
auto deck = parser.parseString(deckData);
|
2018-11-19 04:47:39 -06:00
|
|
|
EclipseGrid grid1(10,10,10);
|
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid1);
|
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule(deck, grid1 , eclipseProperties, runspec);
|
2018-11-19 04:47:39 -06:00
|
|
|
|
2019-03-23 10:11:37 -05:00
|
|
|
const auto& poly0 = schedule.getWell2("INJE01", 0).getPolymerProperties();
|
|
|
|
const auto& poly1 = schedule.getWell2("INJE01", 1).getPolymerProperties();
|
|
|
|
const auto& poly3 = schedule.getWell2("INJE01", 3).getPolymerProperties();
|
|
|
|
|
|
|
|
BOOST_CHECK_EQUAL(poly0.m_plymwinjtable, -1);
|
|
|
|
BOOST_CHECK_EQUAL(poly0.m_skprwattable, -1);
|
|
|
|
BOOST_CHECK_EQUAL(poly0.m_skprpolytable, -1);
|
|
|
|
|
|
|
|
BOOST_CHECK_EQUAL(poly1.m_plymwinjtable, 2);
|
|
|
|
BOOST_CHECK_EQUAL(poly1.m_skprwattable, 1);
|
|
|
|
BOOST_CHECK_EQUAL(poly1.m_skprpolytable, 1);
|
|
|
|
|
|
|
|
BOOST_CHECK_EQUAL(poly3.m_plymwinjtable, 3);
|
|
|
|
BOOST_CHECK_EQUAL(poly3.m_skprwattable, 2);
|
|
|
|
BOOST_CHECK_EQUAL(poly3.m_skprpolytable, 2);
|
2018-11-19 04:47:39 -06:00
|
|
|
}
|
2018-05-13 21:18:07 -05:00
|
|
|
|
2019-07-03 04:46:49 -05:00
|
|
|
// Test for WFOAM
|
|
|
|
BOOST_AUTO_TEST_CASE(WFOAM_TEST) {
|
|
|
|
const char *deckData =
|
|
|
|
"START\n"
|
|
|
|
" 8 MAR 2018/\n"
|
|
|
|
"GRID\n"
|
|
|
|
"PERMX\n"
|
|
|
|
" 1000*0.25 /\n"
|
|
|
|
"COPY\n"
|
|
|
|
" PERMX PERMY /\n"
|
|
|
|
" PERMX PERMZ /\n"
|
|
|
|
"/\n"
|
|
|
|
"PROPS\n \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"WELSPECS\n"
|
|
|
|
"'INJE01' 'I' 1 1 1 'WATER' /\n"
|
|
|
|
"/\n"
|
2019-07-04 02:08:54 -05:00
|
|
|
"WCONINJE\n"
|
|
|
|
"'INJE01' 'GAS' 'OPEN' 'RATE' 80000.00 1* 1000 /\n"
|
|
|
|
"/\n"
|
2019-07-03 04:46:49 -05:00
|
|
|
"TSTEP\n"
|
|
|
|
" 1/\n"
|
|
|
|
"WFOAM\n"
|
|
|
|
" 'INJE01' 0.2 /\n"
|
|
|
|
"/\n"
|
|
|
|
"TSTEP\n"
|
|
|
|
" 2*1/\n"
|
|
|
|
"WFOAM\n"
|
|
|
|
" 'INJE01' 0.3 /\n"
|
|
|
|
"/\n"
|
|
|
|
"TSTEP\n"
|
|
|
|
" 1 /\n";
|
|
|
|
|
|
|
|
Opm::Parser parser;
|
|
|
|
auto deck = parser.parseString(deckData);
|
|
|
|
EclipseGrid grid1(10,10,10);
|
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid1);
|
|
|
|
Runspec runspec (deck);
|
|
|
|
Schedule schedule(deck, grid1 , eclipseProperties, runspec);
|
|
|
|
|
|
|
|
const auto& f0 = schedule.getWell2("INJE01", 0).getFoamProperties();
|
|
|
|
const auto& f1 = schedule.getWell2("INJE01", 1).getFoamProperties();
|
|
|
|
const auto& f3 = schedule.getWell2("INJE01", 3).getFoamProperties();
|
|
|
|
|
|
|
|
BOOST_CHECK_EQUAL(f0.m_foamConcentration, 0.0);
|
|
|
|
BOOST_CHECK_EQUAL(f1.m_foamConcentration, 0.2);
|
|
|
|
BOOST_CHECK_EQUAL(f3.m_foamConcentration, 0.3);
|
|
|
|
}
|
|
|
|
|
2018-05-13 21:18:07 -05:00
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(WTEST_CONFIG) {
|
|
|
|
auto deck = createDeckWTEST();
|
|
|
|
EclipseGrid grid1(10,10,10);
|
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid1);
|
2018-10-17 06:35:25 -05:00
|
|
|
Runspec runspec (deck);
|
2019-01-03 11:05:19 -06:00
|
|
|
Schedule schedule(deck, grid1 , eclipseProperties, runspec);
|
2018-05-13 21:18:07 -05:00
|
|
|
|
|
|
|
const auto& wtest_config1 = schedule.wtestConfig(0);
|
|
|
|
BOOST_CHECK_EQUAL(wtest_config1.size(), 2);
|
|
|
|
BOOST_CHECK(wtest_config1.has("ALLOW"));
|
|
|
|
BOOST_CHECK(!wtest_config1.has("BAN"));
|
|
|
|
|
|
|
|
const auto& wtest_config2 = schedule.wtestConfig(1);
|
|
|
|
BOOST_CHECK_EQUAL(wtest_config2.size(), 3);
|
|
|
|
BOOST_CHECK(!wtest_config2.has("ALLOW"));
|
|
|
|
BOOST_CHECK(wtest_config2.has("BAN"));
|
|
|
|
BOOST_CHECK(wtest_config2.has("BAN", WellTestConfig::Reason::GROUP));
|
|
|
|
BOOST_CHECK(!wtest_config2.has("BAN", WellTestConfig::Reason::PHYSICAL));
|
|
|
|
}
|
2019-03-14 03:23:03 -05:00
|
|
|
|
|
|
|
|
|
|
|
bool has(const std::vector<std::string>& l, const std::string& s) {
|
|
|
|
auto f = std::find(l.begin(), l.end(), s);
|
|
|
|
return (f != l.end());
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2019-03-23 10:11:37 -05:00
|
|
|
BOOST_AUTO_TEST_CASE(WELL_STATIC) {
|
|
|
|
auto deck = createDeckWithWells();
|
|
|
|
EclipseGrid grid1(10,10,10);
|
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid1);
|
|
|
|
Runspec runspec (deck);
|
|
|
|
Schedule schedule(deck, grid1 , eclipseProperties, runspec);
|
|
|
|
BOOST_CHECK_THROW( schedule.getWell2("NO_SUCH_WELL", 0), std::invalid_argument);
|
|
|
|
BOOST_CHECK_THROW( schedule.getWell2("W_3", 0), std::invalid_argument);
|
|
|
|
|
|
|
|
auto ws = schedule.getWell2("W_3", 3);
|
|
|
|
{
|
|
|
|
// Make sure the copy constructor works.
|
|
|
|
Well2 ws_copy(ws);
|
|
|
|
}
|
|
|
|
BOOST_CHECK_EQUAL(ws.name(), "W_3");
|
|
|
|
|
|
|
|
BOOST_CHECK(!ws.updateHead(19, 50));
|
|
|
|
BOOST_CHECK(ws.updateHead(1,50));
|
|
|
|
BOOST_CHECK(!ws.updateHead(1,50));
|
|
|
|
BOOST_CHECK(ws.updateHead(1,1));
|
|
|
|
BOOST_CHECK(!ws.updateHead(1,1));
|
|
|
|
|
|
|
|
BOOST_CHECK(ws.updateRefDepth(1.0));
|
|
|
|
BOOST_CHECK(!ws.updateRefDepth(1.0));
|
|
|
|
|
2019-08-23 06:58:39 -05:00
|
|
|
ws.updateStatus(Well2::Status::OPEN);
|
|
|
|
BOOST_CHECK(!ws.updateStatus(Well2::Status::OPEN));
|
|
|
|
BOOST_CHECK(ws.updateStatus(Well2::Status::SHUT));
|
2019-03-23 10:11:37 -05:00
|
|
|
|
|
|
|
const auto& connections = ws.getConnections();
|
|
|
|
BOOST_CHECK_EQUAL(connections.size(), 0);
|
|
|
|
auto c2 = std::make_shared<WellConnections>(1,1);
|
|
|
|
c2->addConnection(1,1,1,
|
|
|
|
100,
|
2019-08-27 16:14:32 -05:00
|
|
|
Connection::State::OPEN,
|
2019-03-23 10:11:37 -05:00
|
|
|
10,
|
|
|
|
10,
|
|
|
|
10,
|
|
|
|
10,
|
|
|
|
10,
|
|
|
|
100);
|
|
|
|
|
|
|
|
BOOST_CHECK( ws.updateConnections(c2) );
|
|
|
|
BOOST_CHECK( !ws.updateConnections(c2) );
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-03-14 03:23:03 -05:00
|
|
|
BOOST_AUTO_TEST_CASE(WellNames) {
|
|
|
|
auto deck = createDeckWTEST();
|
|
|
|
EclipseGrid grid1(10,10,10);
|
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid1);
|
|
|
|
Runspec runspec (deck);
|
|
|
|
Schedule schedule(deck, grid1 , eclipseProperties, runspec);
|
|
|
|
|
|
|
|
auto names = schedule.wellNames("NO_SUCH_WELL", 0);
|
|
|
|
BOOST_CHECK_EQUAL(names.size(), 0);
|
|
|
|
|
|
|
|
auto w1names = schedule.wellNames("W1", 0);
|
|
|
|
BOOST_CHECK_EQUAL(w1names.size(), 1);
|
|
|
|
BOOST_CHECK_EQUAL(w1names[0], "W1");
|
|
|
|
|
|
|
|
auto i1names = schedule.wellNames("11", 0);
|
|
|
|
BOOST_CHECK_EQUAL(i1names.size(), 0);
|
|
|
|
|
|
|
|
auto listnamese = schedule.wellNames("*NO_LIST", 0);
|
|
|
|
BOOST_CHECK_EQUAL( listnamese.size(), 0);
|
|
|
|
|
|
|
|
auto listnames0 = schedule.wellNames("*ILIST", 0);
|
|
|
|
BOOST_CHECK_EQUAL( listnames0.size(), 0);
|
|
|
|
|
|
|
|
auto listnames1 = schedule.wellNames("*ILIST", 2);
|
|
|
|
BOOST_CHECK_EQUAL( listnames1.size(), 2);
|
|
|
|
BOOST_CHECK( has(listnames1, "I1"));
|
|
|
|
BOOST_CHECK( has(listnames1, "I2"));
|
|
|
|
|
|
|
|
auto pnames1 = schedule.wellNames("I*", 0);
|
|
|
|
BOOST_CHECK_EQUAL(pnames1.size(), 0);
|
|
|
|
|
|
|
|
auto pnames2 = schedule.wellNames("W*", 0);
|
|
|
|
BOOST_CHECK_EQUAL(pnames2.size(), 3);
|
|
|
|
BOOST_CHECK( has(pnames2, "W1"));
|
|
|
|
BOOST_CHECK( has(pnames2, "W2"));
|
|
|
|
BOOST_CHECK( has(pnames2, "W3"));
|
|
|
|
|
|
|
|
auto anames = schedule.wellNames("?", 0, {"W1", "W2"});
|
|
|
|
BOOST_CHECK_EQUAL(anames.size(), 2);
|
|
|
|
BOOST_CHECK(has(anames, "W1"));
|
|
|
|
BOOST_CHECK(has(anames, "W2"));
|
2019-03-18 04:44:11 -05:00
|
|
|
|
2019-03-24 01:53:30 -05:00
|
|
|
auto all_names0 = schedule.wellNames("*", 0);
|
|
|
|
BOOST_CHECK_EQUAL( all_names0.size(), 6);
|
|
|
|
BOOST_CHECK( has(all_names0, "W1"));
|
|
|
|
BOOST_CHECK( has(all_names0, "W2"));
|
|
|
|
BOOST_CHECK( has(all_names0, "W3"));
|
|
|
|
BOOST_CHECK( has(all_names0, "DEFAULT"));
|
|
|
|
BOOST_CHECK( has(all_names0, "ALLOW"));
|
|
|
|
|
2019-03-18 04:44:11 -05:00
|
|
|
auto all_names = schedule.wellNames("*", 2);
|
|
|
|
BOOST_CHECK_EQUAL( all_names.size(), 9);
|
|
|
|
BOOST_CHECK( has(all_names, "I1"));
|
|
|
|
BOOST_CHECK( has(all_names, "I2"));
|
|
|
|
BOOST_CHECK( has(all_names, "I3"));
|
|
|
|
BOOST_CHECK( has(all_names, "W1"));
|
|
|
|
BOOST_CHECK( has(all_names, "W2"));
|
|
|
|
BOOST_CHECK( has(all_names, "W3"));
|
|
|
|
BOOST_CHECK( has(all_names, "DEFAULT"));
|
|
|
|
BOOST_CHECK( has(all_names, "ALLOW"));
|
|
|
|
BOOST_CHECK( has(all_names, "BAN"));
|
2019-03-24 01:53:30 -05:00
|
|
|
|
|
|
|
auto abs_all = schedule.wellNames();
|
|
|
|
BOOST_CHECK_EQUAL(abs_all.size(), 9);
|
2019-03-14 03:23:03 -05:00
|
|
|
}
|
2019-04-03 11:46:29 -05:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(RFT_CONFIG) {
|
|
|
|
TimeMap tm(Opm::TimeMap::mkdate(2010, 1,1));
|
|
|
|
tm.addTStep(static_cast<time_t>(24 * 60 * 60));
|
|
|
|
tm.addTStep(static_cast<time_t>(24 * 60 * 60));
|
|
|
|
tm.addTStep(static_cast<time_t>(24 * 60 * 60));
|
|
|
|
tm.addTStep(static_cast<time_t>(24 * 60 * 60));
|
|
|
|
tm.addTStep(static_cast<time_t>(24 * 60 * 60));
|
|
|
|
|
|
|
|
RFTConfig conf(tm);
|
|
|
|
BOOST_CHECK_THROW( conf.rft("W1", 100), std::invalid_argument);
|
|
|
|
BOOST_CHECK_THROW( conf.plt("W1", 100), std::invalid_argument);
|
|
|
|
|
|
|
|
BOOST_CHECK(!conf.rft("W1", 2));
|
|
|
|
BOOST_CHECK(!conf.plt("W1", 2));
|
|
|
|
|
|
|
|
|
|
|
|
conf.setWellOpenRFT(2);
|
|
|
|
BOOST_CHECK(!conf.getWellOpenRFT("W1", 0));
|
|
|
|
|
|
|
|
|
2019-08-31 02:44:31 -05:00
|
|
|
conf.updateRFT("W1", 2, RFTConfig::RFT::YES);
|
2019-04-03 11:46:29 -05:00
|
|
|
BOOST_CHECK(conf.rft("W1", 2));
|
|
|
|
BOOST_CHECK(!conf.rft("W1", 1));
|
|
|
|
BOOST_CHECK(!conf.rft("W1", 3));
|
|
|
|
|
2019-08-31 02:44:31 -05:00
|
|
|
conf.updateRFT("W2", 2, RFTConfig::RFT::REPT);
|
|
|
|
conf.updateRFT("W2", 4, RFTConfig::RFT::NO);
|
2019-04-03 11:46:29 -05:00
|
|
|
BOOST_CHECK(!conf.rft("W2", 1));
|
|
|
|
BOOST_CHECK( conf.rft("W2", 2));
|
|
|
|
BOOST_CHECK( conf.rft("W2", 3));
|
|
|
|
BOOST_CHECK(!conf.rft("W2", 4));
|
|
|
|
|
|
|
|
|
|
|
|
conf.setWellOpenRFT("W3");
|
|
|
|
BOOST_CHECK(conf.getWellOpenRFT("W3", 2));
|
|
|
|
|
2019-08-31 02:44:31 -05:00
|
|
|
conf.updateRFT("W4", 2, RFTConfig::RFT::FOPN);
|
2019-04-03 11:46:29 -05:00
|
|
|
BOOST_CHECK(conf.getWellOpenRFT("W4", 2));
|
|
|
|
|
|
|
|
|
|
|
|
conf.addWellOpen("W10", 2);
|
|
|
|
conf.addWellOpen("W100", 3);
|
|
|
|
}
|
2019-06-23 03:20:46 -05:00
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(RFT_CONFIG2) {
|
|
|
|
auto deck = createDeckRFTConfig();
|
|
|
|
EclipseGrid grid1(10,10,10);
|
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid1);
|
|
|
|
Runspec runspec (deck);
|
|
|
|
Schedule schedule(deck, grid1 , eclipseProperties, runspec);
|
|
|
|
const auto& rft_config = schedule.rftConfig();
|
|
|
|
BOOST_CHECK_EQUAL(1, rft_config.firstRFTOutput());
|
|
|
|
}
|
2019-08-30 05:56:49 -05:00
|
|
|
|
|
|
|
|
|
|
|
BOOST_AUTO_TEST_CASE(nupcol) {
|
|
|
|
Opm::Parser parser;
|
|
|
|
std::string input =
|
|
|
|
"START -- 0 \n"
|
|
|
|
"19 JUN 2007 / \n"
|
|
|
|
"SCHEDULE\n"
|
|
|
|
"DATES\n -- 1\n"
|
|
|
|
" 10 OKT 2008 / \n"
|
|
|
|
"/\n"
|
|
|
|
"NUPCOL\n"
|
|
|
|
" 4 /\n"
|
|
|
|
"DATES\n -- 1\n"
|
|
|
|
" 10 OKT 2009 / \n"
|
|
|
|
"/\n"
|
|
|
|
"NUPCOL\n"
|
|
|
|
" 10 /\n"
|
|
|
|
"DATES\n -- 1\n"
|
|
|
|
" 10 OKT 2010 / \n"
|
|
|
|
"/\n"
|
|
|
|
|
|
|
|
;
|
|
|
|
|
|
|
|
auto deck = parser.parseString(input);
|
|
|
|
EclipseGrid grid(10,10,10);
|
|
|
|
TableManager table ( deck );
|
|
|
|
Eclipse3DProperties eclipseProperties ( deck , table, grid);
|
|
|
|
Runspec runspec (deck);
|
|
|
|
Schedule schedule( deck, grid, eclipseProperties,runspec);
|
|
|
|
|
|
|
|
{
|
|
|
|
BOOST_CHECK_EQUAL(schedule.getNupcol(0),3);
|
|
|
|
BOOST_CHECK_EQUAL(schedule.getNupcol(1),4);
|
|
|
|
BOOST_CHECK_EQUAL(schedule.getNupcol(2),10);
|
|
|
|
}
|
|
|
|
}
|