mirror of
https://github.com/OPM/ResInsight.git
synced 2025-01-27 08:47:00 -06:00
80 lines
2.2 KiB
C++
80 lines
2.2 KiB
C++
#include "gtest/gtest.h"
|
|
|
|
#include "RimSummaryCalculation.h"
|
|
|
|
#include "expressionparser/ExpressionParser.h"
|
|
|
|
#include <numeric>
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
TEST(RicExpressionParserTest, BasicUsage)
|
|
{
|
|
std::vector<double> a(10);
|
|
std::iota(a.begin(), a.end(), 10);
|
|
|
|
std::vector<double> b(10);
|
|
std::iota(b.begin(), b.end(), 100);
|
|
|
|
std::vector<double> c(10);
|
|
|
|
ExpressionParser parser;
|
|
parser.assignVector("a", a);
|
|
parser.assignVector("b", b);
|
|
parser.assignVector("c", c);
|
|
|
|
QString expr = "c := a + b";
|
|
EXPECT_TRUE(parser.evaluate(expr));
|
|
|
|
EXPECT_DOUBLE_EQ(c[0], 110.0);
|
|
EXPECT_DOUBLE_EQ(c[9], 128.0);
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
TEST(RicExpressionParserTest, DetectVariables)
|
|
{
|
|
QString expr = "c := a + (x / y)";
|
|
|
|
std::vector<QString> variables = ExpressionParser::detectReferencedVariables(expr);
|
|
|
|
EXPECT_STREQ(variables[0].toStdString().data(), "c");
|
|
EXPECT_STREQ(variables[1].toStdString().data(), "a");
|
|
EXPECT_STREQ(variables[2].toStdString().data(), "x");
|
|
EXPECT_STREQ(variables[3].toStdString().data(), "y");
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
TEST(RicExpressionParserTest, FindLeftHandSide)
|
|
{
|
|
{
|
|
QString expr = "c := a";
|
|
|
|
QString s = RimSummaryCalculation::findLeftHandSide(expr);
|
|
|
|
EXPECT_STREQ(s.toStdString().data(), "c");
|
|
}
|
|
|
|
{
|
|
QString expr = "c:=a";
|
|
|
|
QString s = RimSummaryCalculation::findLeftHandSide(expr);
|
|
|
|
EXPECT_STREQ(s.toStdString().data(), "c");
|
|
}
|
|
|
|
{
|
|
QString expr = "\na:=b\n\nc:=a";
|
|
|
|
QString s = RimSummaryCalculation::findLeftHandSide(expr);
|
|
|
|
EXPECT_STREQ(s.toStdString().data(), "c");
|
|
}
|
|
}
|
|
|