rusefi-full/unit_tests/tests/sensor/func_sensor.cpp

71 lines
1.2 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, 0);
// 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);
}
}