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