rusefi/unit_tests/tests/sensor/redundant.cpp

219 lines
3.9 KiB
C++

#include "redundant_sensor.h"
#include <gtest/gtest.h>
#include "mock/mock_sensor.h"
class SensorRedundant : public ::testing::Test
{
protected:
RedundantSensor dut;
MockSensor m1, m2;
SensorRedundant()
: dut(SensorType::Tps1, SensorType::Tps1Primary, SensorType::Tps1Secondary)
, m1(SensorType::Tps1Primary)
, m2(SensorType::Tps1Secondary)
{
}
void SetUp() override
{
Sensor::resetRegistry();
// Other tests verify registry function - don't re-test it here
ASSERT_TRUE(dut.Register());
ASSERT_TRUE(m1.Register());
ASSERT_TRUE(m2.Register());
dut.configure(5.0f, false);
}
void TearDown() override
{
Sensor::resetRegistry();
}
};
TEST_F(SensorRedundant, SetOnlyOneSensor)
{
// Don't set any sensors - expect invalid
{
auto result = dut.get();
EXPECT_FALSE(result.Valid);
}
// Set one sensor
m1.set(24.0f);
// Should still be invalid - only one is set!
{
auto result = dut.get();
EXPECT_FALSE(result.Valid);
}
}
TEST_F(SensorRedundant, SetTwoSensors)
{
// Don't set any sensors - expect invalid
{
auto result = dut.get();
EXPECT_FALSE(result.Valid);
}
// Set one sensor
m1.set(24.0f);
// Set the other sensor
m2.set(26.0f);
// Should now be valid - and the average of the two input
{
auto result = dut.get();
EXPECT_TRUE(result.Valid);
EXPECT_FLOAT_EQ(result.Value, 25.0f);
}
}
TEST_F(SensorRedundant, DifferenceNone)
{
// Set both sensors to the same value
m1.set(10);
m2.set(10);
// Expect valid, and 10 output
{
auto result = dut.get();
EXPECT_TRUE(result.Valid);
EXPECT_FLOAT_EQ(result.Value, 10.0f);
}
}
TEST_F(SensorRedundant, DifferenceNearLimit)
{
// Set both sensors to nearly the limit (4.998 apart)
m1.set(7.501f);
m2.set(12.499f);
// Expect valid, and 10 output
{
auto result = dut.get();
EXPECT_TRUE(result.Valid);
EXPECT_FLOAT_EQ(result.Value, 10.0f);
}
}
TEST_F(SensorRedundant, DifferenceOverLimit)
{
// Set both sensors barely over the limit (5.002 apart)
m1.set(7.499f);
m2.set(12.501f);
// Expect invalid
{
auto result = dut.get();
EXPECT_FALSE(result.Valid);
}
}
TEST_F(SensorRedundant, DifferenceOverLimitSwapped)
{
// Now try it the other way (m1 > m2)
m1.set(12.501f);
m2.set(7.499f);
// Expect invalid
{
auto result = dut.get();
EXPECT_FALSE(result.Valid);
}
}
class SensorRedundantIgnoreSecond : public ::testing::Test
{
protected:
RedundantSensor dut;
MockSensor m1, m2;
SensorRedundantIgnoreSecond()
: dut(SensorType::Tps1, SensorType::Tps1Primary, SensorType::Tps1Secondary)
, m1(SensorType::Tps1Primary)
, m2(SensorType::Tps1Secondary)
{
}
void SetUp() override
{
Sensor::resetRegistry();
// Other tests verify registry function - don't re-test it here
ASSERT_TRUE(dut.Register());
ASSERT_TRUE(m1.Register());
ASSERT_TRUE(m2.Register());
dut.configure(5.0f, true);
}
void TearDown() override
{
Sensor::resetRegistry();
}
};
TEST_F(SensorRedundantIgnoreSecond, OnlyFirst)
{
// Don't set any sensors - expect invalid
{
auto result = dut.get();
EXPECT_FALSE(result.Valid);
}
// Set one sensor
m1.set(44.0f);
// Should be valid - we don't care about second sensor
{
auto result = dut.get();
EXPECT_TRUE(result.Valid);
EXPECT_FLOAT_EQ(result.Value, 44.0f);
}
}
TEST_F(SensorRedundantIgnoreSecond, OnlySecond)
{
// Don't set any sensors - expect invalid
{
auto result = dut.get();
EXPECT_FALSE(result.Valid);
}
// Set second sensor only
m2.set(66.0f);
// Should be invalid - should ignore second sensor
{
auto result = dut.get();
EXPECT_FALSE(result.Valid);
}
}
TEST_F(SensorRedundantIgnoreSecond, SetBothIgnoreSecond)
{
// Don't set any sensors - expect invalid
{
auto result = dut.get();
EXPECT_FALSE(result.Valid);
}
// Set both sensors
m1.set(74.0f);
m2.set(76.0f);
// Should be valid, but only get the value from m1
{
auto result = dut.get();
EXPECT_TRUE(result.Valid);
EXPECT_FLOAT_EQ(result.Value, 74.0f);
}
}