mirror of
https://github.com/OPM/ResInsight.git
synced 2025-01-21 05:53:25 -06:00
751ebf7eb6
* #6365 StimPlan XML: Parse formation dip and fracture orientation. * #6365 Fracture: Use formation dip and fracture orientation from XML. * #6365 Fracture: Compare case insensitive, use enum class Co-authored-by: Magne Sjaastad <magne.sjaastad@ceetronsolutions.com>
90 lines
3.9 KiB
C++
90 lines
3.9 KiB
C++
#include "gtest/gtest.h"
|
|
|
|
#include "RiaTestDataDirectory.h"
|
|
|
|
#include "RifStimPlanXmlReader.h"
|
|
#include "RigStimPlanFractureDefinition.h"
|
|
|
|
static const QString CASE_REAL_TEST_DATA_DIRECTORY = QString( "%1/RifStimPlanXmlReader/" ).arg( TEST_DATA_DIR );
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
TEST( RifStimPlanXmlReaderTest, LoadFile )
|
|
{
|
|
QString fileName = CASE_REAL_TEST_DATA_DIRECTORY + "small_fracture.xml";
|
|
|
|
double conductivityScaleFactor = 1.0;
|
|
RiaDefines::EclipseUnitSystem unit = RiaDefines::EclipseUnitSystem::UNITS_METRIC;
|
|
QString errorMessage;
|
|
RifStimPlanXmlReader::MirrorMode mode = RifStimPlanXmlReader::MirrorMode::MIRROR_AUTO;
|
|
|
|
cvf::ref<RigStimPlanFractureDefinition> fractureData;
|
|
|
|
fractureData =
|
|
RifStimPlanXmlReader::readStimPlanXMLFile( fileName, conductivityScaleFactor, mode, unit, &errorMessage );
|
|
|
|
EXPECT_TRUE( errorMessage.isEmpty() );
|
|
EXPECT_TRUE( fractureData.notNull() );
|
|
|
|
size_t xSamplesIncludingMirrorValues = 7;
|
|
EXPECT_EQ( xSamplesIncludingMirrorValues, fractureData->xCount() );
|
|
EXPECT_EQ( size_t( 5 ), fractureData->yCount() );
|
|
EXPECT_EQ( size_t( 1 ), fractureData->timeSteps().size() );
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
TEST( RifStimPlanXmlReaderTest, LoadFileNewFormat )
|
|
{
|
|
QString fileName = CASE_REAL_TEST_DATA_DIRECTORY + "contour_Metric.xml";
|
|
|
|
double conductivityScaleFactor = 1.0;
|
|
RiaDefines::EclipseUnitSystem unit = RiaDefines::EclipseUnitSystem::UNITS_METRIC;
|
|
QString errorMessage;
|
|
RifStimPlanXmlReader::MirrorMode mode = RifStimPlanXmlReader::MirrorMode::MIRROR_AUTO;
|
|
|
|
cvf::ref<RigStimPlanFractureDefinition> fractureData;
|
|
|
|
fractureData =
|
|
RifStimPlanXmlReader::readStimPlanXMLFile( fileName, conductivityScaleFactor, mode, unit, &errorMessage );
|
|
|
|
EXPECT_TRUE( errorMessage.isEmpty() );
|
|
EXPECT_TRUE( fractureData.notNull() );
|
|
|
|
size_t xSamplesIncludingMirrorValues = 49;
|
|
EXPECT_EQ( xSamplesIncludingMirrorValues, fractureData->xCount() );
|
|
EXPECT_EQ( size_t( 23 ), fractureData->yCount() );
|
|
EXPECT_EQ( size_t( 1 ), fractureData->timeSteps().size() );
|
|
|
|
EXPECT_DOUBLE_EQ( 2773.680, fractureData->topPerfTvd() );
|
|
EXPECT_DOUBLE_EQ( 2773.680, fractureData->bottomPerfTvd() );
|
|
EXPECT_DOUBLE_EQ( 2804.160, fractureData->topPerfMd() );
|
|
EXPECT_DOUBLE_EQ( 2804.770, fractureData->bottomPerfMd() );
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
TEST( RifStimPlanXmlReaderTest, LoadFileNewFormatExtraParameters )
|
|
{
|
|
QString fileName = CASE_REAL_TEST_DATA_DIRECTORY + "contour_with_extra_parameters.xml";
|
|
|
|
double conductivityScaleFactor = 1.0;
|
|
RiaDefines::EclipseUnitSystem unit = RiaDefines::EclipseUnitSystem::UNITS_METRIC;
|
|
QString errorMessage;
|
|
RifStimPlanXmlReader::MirrorMode mode = RifStimPlanXmlReader::MirrorMode::MIRROR_AUTO;
|
|
|
|
cvf::ref<RigStimPlanFractureDefinition> fractureData;
|
|
|
|
fractureData =
|
|
RifStimPlanXmlReader::readStimPlanXMLFile( fileName, conductivityScaleFactor, mode, unit, &errorMessage );
|
|
|
|
EXPECT_TRUE( errorMessage.isEmpty() );
|
|
EXPECT_TRUE( fractureData.notNull() );
|
|
|
|
EXPECT_DOUBLE_EQ( 12.34, fractureData->formationDip() );
|
|
EXPECT_EQ( fractureData->orientation(), RigStimPlanFractureDefinition::Orientation::TRANSVERSE );
|
|
}
|