2019-09-24 18:11:41 -07:00
|
|
|
#include "linear_func.h"
|
2019-09-22 06:56:06 -07:00
|
|
|
#include "unit_test_framework.h"
|
2019-09-21 11:33:38 -07:00
|
|
|
|
2019-09-24 18:11:41 -07:00
|
|
|
class LinearFuncTest : public ::testing::Test {
|
2019-09-21 11:33:38 -07:00
|
|
|
protected:
|
|
|
|
// Maps (1, 4) -> (100, -100)
|
2019-09-24 18:11:41 -07:00
|
|
|
LinearFunc dut;
|
2019-09-21 11:33:38 -07:00
|
|
|
|
|
|
|
void SetUp() override {
|
|
|
|
dut.configure(1, 100, 4, -100, -110, 110);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
#define test_point(in, out) \
|
|
|
|
{ \
|
2019-09-24 18:11:41 -07:00
|
|
|
auto result = dut.convert(in); \
|
2019-09-21 11:33:38 -07:00
|
|
|
\
|
|
|
|
EXPECT_TRUE(result.Valid); \
|
2019-09-22 06:56:06 -07:00
|
|
|
ASSERT_NEAR(result.Value, (out), EPS4D) << "Not " << out << " for " << in; \
|
2019-09-21 11:33:38 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
#define test_point_invalid(in) \
|
2019-09-24 18:11:41 -07:00
|
|
|
{ EXPECT_FALSE(dut.convert(in).Valid); }
|
2019-09-21 11:33:38 -07:00
|
|
|
|
2019-09-24 18:11:41 -07:00
|
|
|
TEST_F(LinearFuncTest, TestInRange) {
|
2019-09-21 11:33:38 -07:00
|
|
|
test_point(2.5, 0);
|
|
|
|
test_point(1, 100);
|
|
|
|
test_point(4, -100);
|
|
|
|
}
|
|
|
|
|
2019-09-24 18:11:41 -07:00
|
|
|
TEST_F(LinearFuncTest, TestOutOfRange) {
|
2019-09-21 11:33:38 -07:00
|
|
|
test_point(1, 100);
|
|
|
|
test_point_invalid(0.5);
|
|
|
|
|
|
|
|
test_point(4, -100);
|
|
|
|
test_point_invalid(4.5);
|
|
|
|
}
|