2020-04-05 06:10:08 -07:00
|
|
|
#include "unit_test_framework.h"
|
|
|
|
#include "init.h"
|
|
|
|
#include "sensor.h"
|
|
|
|
#include "functional_sensor.h"
|
|
|
|
|
|
|
|
#include "engine_test_helper.h"
|
|
|
|
#include <gtest/gtest.h>
|
|
|
|
|
|
|
|
static void postToFuncSensor(Sensor* s, float value) {
|
|
|
|
static_cast<FunctionalSensor*>(s)->postRawValue(value, getTimeNowNt());
|
|
|
|
}
|
|
|
|
|
|
|
|
#define EXPECT_POINT_VALID(s, raw, expect) \
|
|
|
|
{\
|
|
|
|
postToFuncSensor(s, raw); \
|
|
|
|
auto res = s->get(); \
|
|
|
|
EXPECT_TRUE(res.Valid); \
|
2020-04-07 13:07:09 -07:00
|
|
|
EXPECT_NEAR(res.Value, expect, EPS2D); \
|
2020-04-05 06:10:08 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
#define EXPECT_POINT_INVALID(s, raw) \
|
|
|
|
{\
|
|
|
|
postToFuncSensor(s, raw); \
|
|
|
|
auto res = s->get(); \
|
|
|
|
EXPECT_FALSE(res.Valid); \
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(SensorInit, Tps) {
|
|
|
|
WITH_ENGINE_TEST_HELPER(TEST_ENGINE);
|
|
|
|
|
|
|
|
CONFIG(tpsMin) = 200; // 1 volt
|
|
|
|
CONFIG(tpsMax) = 800; // 4 volts
|
|
|
|
|
2020-08-31 05:02:29 -07:00
|
|
|
initTps(PASS_CONFIG_PARAMETER_SIGNATURE);
|
2020-04-05 06:10:08 -07:00
|
|
|
|
|
|
|
// Ensure the sensors were registered
|
2020-05-18 11:32:00 -07:00
|
|
|
auto s = const_cast<Sensor*>(Sensor::getSensorOfType(SensorType::Tps1Primary));
|
2020-04-05 06:10:08 -07:00
|
|
|
ASSERT_NE(nullptr, s);
|
|
|
|
|
|
|
|
// Test in range
|
|
|
|
EXPECT_POINT_VALID(s, 1.0f, 0.0f); // closed throttle
|
|
|
|
EXPECT_POINT_VALID(s, 2.5f, 50.0f); // half throttle
|
|
|
|
EXPECT_POINT_VALID(s, 4.0f, 100.0f) // full throttle
|
|
|
|
|
|
|
|
// Test out of range
|
|
|
|
EXPECT_POINT_INVALID(s, 0.0f);
|
|
|
|
EXPECT_POINT_INVALID(s, 5.0f);
|
2020-05-18 11:32:00 -07:00
|
|
|
|
|
|
|
// Test that the passthru (redundant sensor) is working
|
|
|
|
EXPECT_POINT_VALID(s, 2.5f, 50.0f);
|
|
|
|
EXPECT_NEAR(50.0f, Sensor::get(SensorType::Tps1).value_or(-1), EPS2D);
|
2020-04-05 06:10:08 -07:00
|
|
|
}
|
|
|
|
|
2020-12-05 21:41:49 -08:00
|
|
|
TEST(SensorInit, TpsValuesTooClose) {
|
|
|
|
WITH_ENGINE_TEST_HELPER(TEST_ENGINE);
|
|
|
|
|
|
|
|
// Should fail, 0.49 volts apart
|
|
|
|
CONFIG(tpsMin) = 200; // 1.00 volt
|
|
|
|
CONFIG(tpsMax) = 298; // 1.49 volts
|
|
|
|
EXPECT_FATAL_ERROR(initTps(PASS_CONFIG_PARAMETER_SIGNATURE));
|
|
|
|
Sensor::resetRegistry();
|
|
|
|
|
|
|
|
// Should fail, -0.49 volts apart
|
|
|
|
CONFIG(tpsMin) = 298; // 1.49 volt
|
|
|
|
CONFIG(tpsMax) = 200; // 1.00 volts
|
|
|
|
EXPECT_FATAL_ERROR(initTps(PASS_CONFIG_PARAMETER_SIGNATURE));
|
|
|
|
Sensor::resetRegistry();
|
|
|
|
|
|
|
|
// Should succeed, 0.51 volts apart
|
|
|
|
CONFIG(tpsMin) = 200; // 1.00 volt
|
|
|
|
CONFIG(tpsMax) = 302; // 1.51 volts
|
|
|
|
EXPECT_NO_FATAL_ERROR(initTps(PASS_CONFIG_PARAMETER_SIGNATURE));
|
|
|
|
Sensor::resetRegistry();
|
|
|
|
|
|
|
|
// Should succeed, -0.51 volts apart
|
|
|
|
CONFIG(tpsMin) = 302; // 1.51 volt
|
|
|
|
CONFIG(tpsMax) = 200; // 1.00 volts
|
|
|
|
EXPECT_NO_FATAL_ERROR(initTps(PASS_CONFIG_PARAMETER_SIGNATURE));
|
|
|
|
Sensor::resetRegistry();
|
|
|
|
|
|
|
|
// With no pin, it should be ok that they are the same
|
|
|
|
// Should succeed, -0.51 volts apart
|
2020-12-06 20:19:57 -08:00
|
|
|
CONFIG(tps1_1AdcChannel) = EFI_ADC_NONE;
|
2020-12-05 21:41:49 -08:00
|
|
|
CONFIG(tpsMin) = 200; // 1.00 volt
|
|
|
|
CONFIG(tpsMax) = 200; // 1.00 volts
|
|
|
|
EXPECT_NO_FATAL_ERROR(initTps(PASS_CONFIG_PARAMETER_SIGNATURE));
|
|
|
|
Sensor::resetRegistry();
|
2020-12-06 20:19:57 -08:00
|
|
|
|
|
|
|
// Test a random bogus pin index, shouldn't fail
|
|
|
|
CONFIG(tps1_1AdcChannel) = static_cast<adc_channel_e>(175);
|
|
|
|
CONFIG(tpsMin) = 200; // 1.00 volt
|
|
|
|
CONFIG(tpsMax) = 200; // 1.00 volt
|
|
|
|
EXPECT_NO_FATAL_ERROR(initTps(PASS_CONFIG_PARAMETER_SIGNATURE));
|
|
|
|
Sensor::resetRegistry();
|
|
|
|
|
|
|
|
// Reconfiguration should also work without error
|
|
|
|
EXPECT_NO_FATAL_ERROR(reconfigureTps(PASS_CONFIG_PARAMETER_SIGNATURE));
|
2020-12-05 21:41:49 -08:00
|
|
|
}
|
|
|
|
|
2020-04-05 06:10:08 -07:00
|
|
|
TEST(SensorInit, Pedal) {
|
|
|
|
WITH_ENGINE_TEST_HELPER(TEST_ENGINE);
|
|
|
|
|
|
|
|
CONFIG(throttlePedalPositionAdcChannel) = EFI_ADC_0;
|
|
|
|
CONFIG(throttlePedalUpVoltage) = 1;
|
|
|
|
CONFIG(throttlePedalWOTVoltage) = 4;
|
|
|
|
|
2020-08-31 05:02:29 -07:00
|
|
|
initTps(PASS_CONFIG_PARAMETER_SIGNATURE);
|
2020-04-05 06:10:08 -07:00
|
|
|
|
|
|
|
// Ensure the sensors were registered
|
2020-05-23 16:48:32 -07:00
|
|
|
auto s = const_cast<Sensor*>(Sensor::getSensorOfType(SensorType::AcceleratorPedalPrimary));
|
2020-04-05 06:10:08 -07:00
|
|
|
ASSERT_NE(nullptr, s);
|
|
|
|
|
|
|
|
// Test in range
|
|
|
|
EXPECT_POINT_VALID(s, 1.0f, 0.0f); // closed throttle
|
|
|
|
EXPECT_POINT_VALID(s, 2.5f, 50.0f); // half throttle
|
|
|
|
EXPECT_POINT_VALID(s, 4.0f, 100.0f) // full throttle
|
|
|
|
|
|
|
|
// Test out of range
|
|
|
|
EXPECT_POINT_INVALID(s, 0.0f);
|
|
|
|
EXPECT_POINT_INVALID(s, 5.0f);
|
2020-05-23 16:48:32 -07:00
|
|
|
|
|
|
|
// Test that the passthru (redundant sensor) is working
|
|
|
|
EXPECT_POINT_VALID(s, 2.5f, 50.0f);
|
|
|
|
EXPECT_NEAR(50.0f, Sensor::get(SensorType::AcceleratorPedal).value_or(-1), EPS2D);
|
2020-04-05 06:10:08 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(SensorInit, DriverIntentNoPedal) {
|
|
|
|
WITH_ENGINE_TEST_HELPER(TEST_ENGINE);
|
|
|
|
|
|
|
|
// We have no pedal - so we should get the TPS
|
|
|
|
CONFIG(throttlePedalPositionAdcChannel) = EFI_ADC_NONE;
|
|
|
|
|
2020-08-31 05:02:29 -07:00
|
|
|
initTps(PASS_CONFIG_PARAMETER_SIGNATURE);
|
2020-04-05 06:10:08 -07:00
|
|
|
|
|
|
|
// Ensure a sensor got set
|
|
|
|
ASSERT_TRUE(Sensor::hasSensor(SensorType::DriverThrottleIntent));
|
|
|
|
|
|
|
|
// Set values so we can identify which one got proxied
|
|
|
|
Sensor::setMockValue(SensorType::Tps1, 25);
|
|
|
|
Sensor::setMockValue(SensorType::AcceleratorPedal, 75);
|
|
|
|
|
|
|
|
// Should get the TPS
|
|
|
|
EXPECT_EQ(Sensor::get(SensorType::DriverThrottleIntent).Value, 25);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2020-04-07 13:07:09 -07:00
|
|
|
TEST(SensorInit, DriverIntentWithPedal) {
|
2020-04-05 06:10:08 -07:00
|
|
|
WITH_ENGINE_TEST_HELPER(TEST_ENGINE);
|
|
|
|
|
|
|
|
// We have a pedal, so we should get it
|
|
|
|
CONFIG(throttlePedalPositionAdcChannel) = EFI_ADC_0;
|
|
|
|
|
2020-08-31 05:02:29 -07:00
|
|
|
initTps(PASS_CONFIG_PARAMETER_SIGNATURE);
|
2020-04-05 06:10:08 -07:00
|
|
|
|
|
|
|
// Ensure a sensor got set
|
|
|
|
ASSERT_TRUE(Sensor::hasSensor(SensorType::DriverThrottleIntent));
|
|
|
|
|
|
|
|
// Set values so we can identify which one got proxied
|
|
|
|
Sensor::setMockValue(SensorType::Tps1, 25);
|
|
|
|
Sensor::setMockValue(SensorType::AcceleratorPedal, 75);
|
|
|
|
|
|
|
|
// Should get the pedal
|
|
|
|
EXPECT_EQ(Sensor::get(SensorType::DriverThrottleIntent).Value, 75);
|
|
|
|
}
|
2020-04-06 06:00:26 -07:00
|
|
|
|
|
|
|
TEST(SensorInit, OilPressure) {
|
|
|
|
WITH_ENGINE_TEST_HELPER(TEST_ENGINE);
|
|
|
|
|
|
|
|
CONFIG(oilPressure.hwChannel) = EFI_ADC_0;
|
|
|
|
CONFIG(oilPressure.v1) = 1;
|
|
|
|
CONFIG(oilPressure.v2) = 4;
|
|
|
|
CONFIG(oilPressure.value1) = 0;
|
|
|
|
CONFIG(oilPressure.value2) = 1000;
|
|
|
|
|
2020-08-31 05:02:29 -07:00
|
|
|
initOilPressure(PASS_CONFIG_PARAMETER_SIGNATURE);
|
2020-04-06 06:00:26 -07:00
|
|
|
|
|
|
|
// Ensure the sensors were registered
|
|
|
|
auto s = const_cast<Sensor*>(Sensor::getSensorOfType(SensorType::OilPressure));
|
|
|
|
ASSERT_NE(nullptr, s);
|
|
|
|
|
|
|
|
// Test in range
|
|
|
|
EXPECT_POINT_VALID(s, 1.0f, 0.0f); // minimum
|
|
|
|
EXPECT_POINT_VALID(s, 2.5f, 500.0f); // mid
|
|
|
|
EXPECT_POINT_VALID(s, 4.0f, 1000.0f) // maximium
|
|
|
|
|
|
|
|
// Test out of range
|
|
|
|
EXPECT_POINT_INVALID(s, 0.0f);
|
|
|
|
EXPECT_POINT_INVALID(s, 5.0f);
|
|
|
|
}
|
2020-04-07 13:07:09 -07:00
|
|
|
|
|
|
|
TEST(SensorInit, Clt) {
|
|
|
|
WITH_ENGINE_TEST_HELPER(TEST_ENGINE);
|
|
|
|
|
|
|
|
// 2003 neon sensor
|
|
|
|
CONFIG(clt.config) = {0, 30, 100, 32500, 7550, 700, 2700};
|
|
|
|
|
2020-08-31 04:54:45 -07:00
|
|
|
initThermistors(PASS_CONFIG_PARAMETER_SIGNATURE);
|
2020-04-07 13:07:09 -07:00
|
|
|
|
|
|
|
// Ensure the sensors were registered
|
|
|
|
auto s = const_cast<Sensor*>(Sensor::getSensorOfType(SensorType::Clt));
|
|
|
|
ASSERT_NE(nullptr, s);
|
|
|
|
|
|
|
|
// Test in range
|
|
|
|
EXPECT_POINT_VALID(s, 4.61648f, 0.0f); // minimum - 0C
|
|
|
|
EXPECT_POINT_VALID(s, 3.6829f, 30.0f); // mid - 30C
|
|
|
|
EXPECT_POINT_VALID(s, 1.0294f, 100.0f) // maximium - 100C
|
|
|
|
|
|
|
|
// Test out of range
|
|
|
|
EXPECT_POINT_INVALID(s, 0.0f);
|
|
|
|
EXPECT_POINT_INVALID(s, 5.0f);
|
|
|
|
}
|
2020-09-01 13:22:31 -07:00
|
|
|
|
|
|
|
TEST(SensorInit, Lambda) {
|
|
|
|
WITH_ENGINE_TEST_HELPER(TEST_ENGINE);
|
|
|
|
|
|
|
|
initLambda(PASS_ENGINE_PARAMETER_SIGNATURE);
|
|
|
|
|
2020-12-09 17:26:23 -08:00
|
|
|
auto s = Sensor::getSensorOfType(SensorType::Lambda1);
|
2020-09-01 13:22:31 -07:00
|
|
|
ASSERT_NE(nullptr, s);
|
|
|
|
}
|
2020-12-30 05:43:49 -08:00
|
|
|
|
|
|
|
TEST(SensorInit, Map) {
|
|
|
|
WITH_ENGINE_TEST_HELPER(TEST_ENGINE);
|
|
|
|
|
|
|
|
initMap(PASS_ENGINE_PARAMETER_SIGNATURE);
|
|
|
|
|
|
|
|
auto s = Sensor::getSensorOfType(SensorType::Map);
|
|
|
|
ASSERT_NE(nullptr, s);
|
|
|
|
|
|
|
|
engine->mockMapValue = 55;
|
|
|
|
EXPECT_FLOAT_EQ(55.0f, Sensor::get(SensorType::Map).value_or(0));
|
|
|
|
}
|