2021-08-03 19:05:01 -07:00
|
|
|
#include "pch.h"
|
|
|
|
|
2019-09-21 11:33:38 -07:00
|
|
|
#include "stored_value_sensor.h"
|
|
|
|
|
|
|
|
class SensorBasic : public ::testing::Test {
|
|
|
|
protected:
|
|
|
|
void SetUp() override {
|
|
|
|
Sensor::resetRegistry();
|
|
|
|
}
|
|
|
|
|
|
|
|
void TearDown() override {
|
|
|
|
Sensor::resetRegistry();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
TEST_F(SensorBasic, Registry) {
|
|
|
|
// Create a sensor - but don't register it
|
|
|
|
MockSensor dut(SensorType::Tps1);
|
|
|
|
|
|
|
|
// Expect not to find it
|
|
|
|
{
|
|
|
|
auto s = Sensor::getSensorOfType(SensorType::Tps1);
|
|
|
|
EXPECT_FALSE(s);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Register the sensor now
|
|
|
|
EXPECT_TRUE(dut.Register());
|
|
|
|
|
|
|
|
// It should now get us back our sensor
|
|
|
|
{
|
|
|
|
auto s = Sensor::getSensorOfType(SensorType::Tps1);
|
|
|
|
EXPECT_EQ(s, &dut);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Reset - it should now be gone!
|
|
|
|
Sensor::resetRegistry();
|
|
|
|
|
|
|
|
{
|
|
|
|
auto s = Sensor::getSensorOfType(SensorType::Tps1);
|
|
|
|
EXPECT_FALSE(s);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(SensorBasic, DoubleRegister) {
|
|
|
|
// Create a sensor, register it
|
|
|
|
MockSensor dut(SensorType::Tps1);
|
|
|
|
ASSERT_TRUE(dut.Register());
|
|
|
|
|
|
|
|
// And then do it again!
|
|
|
|
MockSensor dut2(SensorType::Tps1);
|
2020-12-06 12:00:30 -08:00
|
|
|
EXPECT_FATAL_ERROR(dut2.Register());
|
2019-09-21 11:33:38 -07:00
|
|
|
|
|
|
|
// Make sure that we get the first DUT back - not the second
|
|
|
|
auto shouldBeDut = Sensor::getSensorOfType(SensorType::Tps1);
|
|
|
|
EXPECT_EQ(shouldBeDut, &dut);
|
|
|
|
EXPECT_NE(shouldBeDut, &dut2);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(SensorBasic, SensorNotInitialized) {
|
|
|
|
auto result = Sensor::get(SensorType::Clt);
|
|
|
|
|
|
|
|
EXPECT_FALSE(result.Valid);
|
|
|
|
}
|
|
|
|
|
2023-02-23 02:12:20 -08:00
|
|
|
TEST_F(SensorBasic, DoubleUnRegister) {
|
|
|
|
// Create a sensor, register it
|
|
|
|
MockSensor dut(SensorType::Tps1);
|
|
|
|
ASSERT_TRUE(dut.Register());
|
|
|
|
Sensor::setMockValue(SensorType::Tps1, 25);
|
|
|
|
ASSERT_TRUE(Sensor::get(SensorType::Tps1).Valid);
|
|
|
|
|
|
|
|
dut.unregister();
|
|
|
|
ASSERT_TRUE(Sensor::get(SensorType::Tps1).Valid);// huh? is that a bug?
|
|
|
|
|
|
|
|
dut.unregister();
|
|
|
|
ASSERT_TRUE(Sensor::get(SensorType::Tps1).Valid);// huh? is that a bug?
|
|
|
|
}
|
|
|
|
|
2019-09-21 11:33:38 -07:00
|
|
|
TEST_F(SensorBasic, SensorInitialized) {
|
|
|
|
MockSensor dut(SensorType::Clt);
|
|
|
|
ASSERT_TRUE(dut.Register());
|
|
|
|
|
|
|
|
// Check before init - make sure it isn't set yet
|
|
|
|
auto result = Sensor::get(SensorType::Clt);
|
|
|
|
ASSERT_FALSE(result.Valid);
|
|
|
|
|
|
|
|
// Set a value
|
|
|
|
dut.set(75);
|
|
|
|
|
|
|
|
// Make sure now it's set
|
|
|
|
auto result2 = Sensor::get(SensorType::Clt);
|
|
|
|
EXPECT_TRUE(result2.Valid);
|
|
|
|
EXPECT_FLOAT_EQ(result2.Value, 75);
|
|
|
|
}
|
2020-04-02 05:04:12 -07:00
|
|
|
|
|
|
|
TEST_F(SensorBasic, HasSensor) {
|
|
|
|
MockSensor dut(SensorType::Clt);
|
|
|
|
|
|
|
|
// Check that we don't have the sensor
|
|
|
|
ASSERT_FALSE(Sensor::hasSensor(SensorType::Clt));
|
|
|
|
|
|
|
|
// Register it
|
|
|
|
ASSERT_TRUE(dut.Register());
|
|
|
|
|
|
|
|
// Now we should!
|
|
|
|
ASSERT_TRUE(Sensor::hasSensor(SensorType::Clt));
|
2021-03-12 20:32:41 -08:00
|
|
|
|
|
|
|
// Check that we can have the sensor report that it's missing
|
|
|
|
dut.setHasSensor(false);
|
|
|
|
ASSERT_FALSE(Sensor::hasSensor(SensorType::Clt));
|
2020-04-02 05:04:12 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_F(SensorBasic, HasSensorMock) {
|
|
|
|
// Check that we don't have the sensor
|
|
|
|
ASSERT_FALSE(Sensor::hasSensor(SensorType::Clt));
|
|
|
|
|
|
|
|
// Mock the sensor - this should count as having it
|
|
|
|
Sensor::setMockValue(SensorType::Clt, 25);
|
|
|
|
|
|
|
|
// Now we should!
|
|
|
|
ASSERT_TRUE(Sensor::hasSensor(SensorType::Clt));
|
|
|
|
}
|
2021-10-20 19:21:42 -07:00
|
|
|
|
|
|
|
|
|
|
|
TEST_F(SensorBasic, FindByName) {
|
|
|
|
ASSERT_EQ(SensorType::Clt, findSensorTypeByName("Clt"));
|
2022-07-27 02:41:21 -07:00
|
|
|
ASSERT_EQ(SensorType::Clt, findSensorTypeByName("cLT"));
|
2021-10-20 19:21:42 -07:00
|
|
|
}
|