2018-01-09 08:39:17 -06:00
|
|
|
#include "gtest/gtest.h"
|
|
|
|
|
|
|
|
#include "RiaTestDataDirectory.h"
|
|
|
|
|
|
|
|
#include "RifElementPropertyTableReader.h"
|
|
|
|
|
|
|
|
#include <QString>
|
|
|
|
#include <numeric>
|
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
static const QString TEST_DATA_DIRECTORY = QString( "%1/RifElementPropertyTableReader/" ).arg( TEST_DATA_DIR );
|
2018-01-09 08:39:17 -06:00
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
///
|
2018-01-09 08:39:17 -06:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
TEST( RicElementPropertyTableReaderTest, BasicUsage )
|
2018-01-09 08:39:17 -06:00
|
|
|
{
|
2020-02-12 04:43:15 -06:00
|
|
|
RifElementPropertyMetadata metadata =
|
|
|
|
RifElementPropertyTableReader::readMetadata( TEST_DATA_DIRECTORY + "ELASTIC_TABLE.inp" );
|
2018-01-09 08:39:17 -06:00
|
|
|
|
|
|
|
RifElementPropertyTable table;
|
2019-09-06 03:40:57 -05:00
|
|
|
RifElementPropertyTableReader::readData( &metadata, &table );
|
2018-01-09 08:39:17 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
EXPECT_TRUE( table.hasData );
|
2018-01-09 08:39:17 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
EXPECT_EQ( 2, metadata.dataColumns.size() );
|
|
|
|
EXPECT_STREQ( "MODULUS", metadata.dataColumns[0].toStdString().c_str() );
|
|
|
|
EXPECT_STREQ( "RATIO", metadata.dataColumns[1].toStdString().c_str() );
|
2018-01-09 08:39:17 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
EXPECT_EQ( 2, table.data.size() );
|
|
|
|
EXPECT_EQ( 4320, table.elementIds.size() );
|
|
|
|
EXPECT_EQ( 4320, table.data[0].size() );
|
|
|
|
EXPECT_EQ( 4320, table.data[1].size() );
|
2018-01-09 08:39:17 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
///
|
2018-01-09 08:39:17 -06:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
2019-09-06 03:40:57 -05:00
|
|
|
TEST( RicElementPropertyTableReaderTest, ParseFailed )
|
2018-01-09 08:39:17 -06:00
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
2020-02-12 04:43:15 -06:00
|
|
|
RifElementPropertyMetadata metadata =
|
|
|
|
RifElementPropertyTableReader::readMetadata( TEST_DATA_DIRECTORY + "ELASTIC_TABLE_error.inp" );
|
2018-01-09 08:39:17 -06:00
|
|
|
|
|
|
|
RifElementPropertyTable table;
|
2019-09-06 03:40:57 -05:00
|
|
|
RifElementPropertyTableReader::readData( &metadata, &table );
|
2018-01-09 08:39:17 -06:00
|
|
|
|
2019-09-06 03:40:57 -05:00
|
|
|
EXPECT_TRUE( false );
|
2018-01-09 08:39:17 -06:00
|
|
|
}
|
2019-09-06 03:40:57 -05:00
|
|
|
catch ( FileParseException e )
|
2018-01-09 08:39:17 -06:00
|
|
|
{
|
2019-09-06 03:40:57 -05:00
|
|
|
EXPECT_TRUE( e.message.startsWith( "Number of columns mismatch" ) );
|
2018-01-09 08:39:17 -06:00
|
|
|
}
|
|
|
|
}
|