71 lines
1.3 KiB
C++
71 lines
1.3 KiB
C++
#include "functional_sensor.h"
|
|
#include "global.h"
|
|
|
|
#include <gtest/gtest.h>
|
|
|
|
struct DoublerFunc final : public SensorConverter {
|
|
SensorResult convert(float input) const {
|
|
if (input <= 0) {
|
|
return unexpected;
|
|
}
|
|
|
|
return input * 2;
|
|
}
|
|
};
|
|
|
|
class SensorConverted : public ::testing::Test {
|
|
protected:
|
|
SensorConverted()
|
|
: dut(SensorType::Clt, MS2NT(50)) {}
|
|
|
|
void SetUp() override {
|
|
dut.setFunction(func);
|
|
Sensor::resetRegistry();
|
|
}
|
|
|
|
void TearDown() override {
|
|
Sensor::resetRegistry();
|
|
}
|
|
|
|
FunctionalSensor dut;
|
|
DoublerFunc func;
|
|
};
|
|
|
|
TEST_F(SensorConverted, TestValid) {
|
|
ASSERT_TRUE(dut.Register());
|
|
|
|
// Should be invalid - not set yet
|
|
{
|
|
auto s = Sensor::get(SensorType::Clt);
|
|
EXPECT_FALSE(s.Valid);
|
|
}
|
|
|
|
dut.postRawValue(25, getTimeNowNt());
|
|
|
|
// Should be valid, with a value of 25*2 = 50
|
|
{
|
|
auto s = Sensor::get(SensorType::Clt);
|
|
EXPECT_TRUE(s.Valid);
|
|
EXPECT_FLOAT_EQ(s.Value, 50);
|
|
}
|
|
}
|
|
|
|
TEST_F(SensorConverted, TestInvalid) {
|
|
ASSERT_TRUE(dut.Register());
|
|
|
|
// Should be invalid - not set yet
|
|
{
|
|
auto s = Sensor::get(SensorType::Clt);
|
|
EXPECT_FALSE(s.Valid);
|
|
}
|
|
|
|
dut.postRawValue(-25, 0);
|
|
|
|
// Should be invalid, with a value of -25*2 = 0
|
|
{
|
|
auto s = Sensor::get(SensorType::Clt);
|
|
EXPECT_FALSE(s.Valid);
|
|
EXPECT_FLOAT_EQ(s.Value, 0);
|
|
}
|
|
}
|