46 lines
1.8 KiB
C++
46 lines
1.8 KiB
C++
|
#include "linear_sensor.h"
|
||
|
|
||
|
#include <gtest/gtest.h>
|
||
|
|
||
|
class SensorLinear : public ::testing::Test {
|
||
|
protected:
|
||
|
// Maps (1, 4) -> (100, -100)
|
||
|
LinearSensor dut;
|
||
|
|
||
|
SensorLinear()
|
||
|
: dut(SensorType::Clt) {}
|
||
|
|
||
|
void SetUp() override {
|
||
|
dut.configure(1, 100, 4, -100, -110, 110);
|
||
|
}
|
||
|
};
|
||
|
|
||
|
#define test_point(in, out) \
|
||
|
{ \
|
||
|
dut.postRawValue(in); \
|
||
|
auto result = dut.get(); \
|
||
|
\
|
||
|
EXPECT_TRUE(result.Valid); \
|
||
|
EXPECT_FLOAT_EQ(result.Value, (out)); \
|
||
|
}
|
||
|
|
||
|
#define test_point_invalid(in) \
|
||
|
{ \
|
||
|
dut.postRawValue(in); \
|
||
|
EXPECT_FALSE(dut.get().Valid); \
|
||
|
}
|
||
|
|
||
|
TEST_F(SensorLinear, TestInRange) {
|
||
|
test_point(2.5, 0);
|
||
|
test_point(1, 100);
|
||
|
test_point(4, -100);
|
||
|
}
|
||
|
|
||
|
TEST_F(SensorLinear, TestOutOfRange) {
|
||
|
test_point(1, 100);
|
||
|
test_point_invalid(0.5);
|
||
|
|
||
|
test_point(4, -100);
|
||
|
test_point_invalid(4.5);
|
||
|
}
|