2021-08-03 19:05:01 -07:00
|
|
|
#include "pch.h"
|
|
|
|
|
2020-12-26 14:30:46 -08:00
|
|
|
#include "limp_manager.h"
|
|
|
|
|
|
|
|
TEST(limp, testFatalError) {
|
|
|
|
LimpManager dut;
|
|
|
|
|
|
|
|
// Everything should work by default
|
|
|
|
ASSERT_TRUE(dut.allowElectronicThrottle());
|
|
|
|
ASSERT_TRUE(dut.allowIgnition());
|
|
|
|
ASSERT_TRUE(dut.allowInjection());
|
|
|
|
ASSERT_TRUE(dut.allowTriggerInput());
|
|
|
|
|
|
|
|
dut.fatalError();
|
|
|
|
|
|
|
|
// Fatal error should kill everything
|
|
|
|
EXPECT_FALSE(dut.allowElectronicThrottle());
|
|
|
|
EXPECT_FALSE(dut.allowIgnition());
|
|
|
|
EXPECT_FALSE(dut.allowInjection());
|
|
|
|
EXPECT_FALSE(dut.allowTriggerInput());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(limp, revLimit) {
|
2021-11-16 13:52:11 -08:00
|
|
|
EngineTestHelper eth(TEST_ENGINE);
|
2020-12-26 14:30:46 -08:00
|
|
|
|
|
|
|
engineConfiguration->rpmHardLimit = 2500;
|
|
|
|
|
|
|
|
LimpManager dut;
|
|
|
|
|
|
|
|
// Under rev limit, inj/ign allowed
|
2021-06-16 14:20:28 -07:00
|
|
|
dut.updateState(2000, 0);
|
2020-12-26 14:30:46 -08:00
|
|
|
EXPECT_TRUE(dut.allowIgnition());
|
|
|
|
EXPECT_TRUE(dut.allowInjection());
|
|
|
|
|
|
|
|
// Over rev limit, no injection
|
2021-06-16 14:20:28 -07:00
|
|
|
dut.updateState(3000, 0);
|
2020-12-26 14:30:46 -08:00
|
|
|
EXPECT_FALSE(dut.allowIgnition());
|
|
|
|
EXPECT_FALSE(dut.allowInjection());
|
|
|
|
|
|
|
|
// Now recover back to under limit
|
2021-06-16 14:20:28 -07:00
|
|
|
dut.updateState(2000, 0);
|
2020-12-26 14:30:46 -08:00
|
|
|
EXPECT_TRUE(dut.allowIgnition());
|
|
|
|
EXPECT_TRUE(dut.allowInjection());
|
|
|
|
}
|
|
|
|
|
2022-06-22 13:49:24 -07:00
|
|
|
TEST(limp, revLimitCltBased) {
|
|
|
|
EngineTestHelper eth(TEST_ENGINE);
|
|
|
|
|
|
|
|
engineConfiguration->rpmHardLimit = 2500;
|
|
|
|
|
|
|
|
// Configure CLT-based rev limit curve
|
|
|
|
engineConfiguration->useCltBasedRpmLimit = true;
|
|
|
|
copyArray(engineConfiguration->cltRevLimitRpmBins, { 10, 20, 30, 40 });
|
|
|
|
copyArray(engineConfiguration->cltRevLimitRpm, { 1000, 2000, 3000, 4000 });
|
|
|
|
|
|
|
|
LimpManager dut;
|
|
|
|
|
|
|
|
// Check low temperature first
|
|
|
|
Sensor::setMockValue(SensorType::Clt, 10);
|
|
|
|
|
|
|
|
// Under rev limit, inj/ign allowed
|
|
|
|
dut.updateState(900, 0);
|
|
|
|
EXPECT_TRUE(dut.allowIgnition());
|
|
|
|
EXPECT_TRUE(dut.allowInjection());
|
|
|
|
|
|
|
|
// Over rev limit, no injection
|
|
|
|
dut.updateState(1100, 0);
|
|
|
|
EXPECT_FALSE(dut.allowIgnition());
|
|
|
|
EXPECT_FALSE(dut.allowInjection());
|
|
|
|
|
|
|
|
// Now recover back to under limit
|
|
|
|
dut.updateState(900, 0);
|
|
|
|
EXPECT_TRUE(dut.allowIgnition());
|
|
|
|
EXPECT_TRUE(dut.allowInjection());
|
|
|
|
|
|
|
|
|
|
|
|
// Check middle temperature
|
|
|
|
Sensor::setMockValue(SensorType::Clt, 35);
|
|
|
|
|
|
|
|
// Under rev limit, inj/ign allowed
|
|
|
|
dut.updateState(3400, 0);
|
|
|
|
EXPECT_TRUE(dut.allowIgnition());
|
|
|
|
EXPECT_TRUE(dut.allowInjection());
|
|
|
|
|
|
|
|
// Over rev limit, no injection
|
|
|
|
dut.updateState(3600, 0);
|
|
|
|
EXPECT_FALSE(dut.allowIgnition());
|
|
|
|
EXPECT_FALSE(dut.allowInjection());
|
|
|
|
|
|
|
|
// Now recover back to under limit
|
|
|
|
dut.updateState(3400, 0);
|
|
|
|
EXPECT_TRUE(dut.allowIgnition());
|
|
|
|
EXPECT_TRUE(dut.allowInjection());
|
|
|
|
}
|
|
|
|
|
2020-12-26 14:30:46 -08:00
|
|
|
TEST(limp, boostCut) {
|
2021-11-16 13:52:11 -08:00
|
|
|
EngineTestHelper eth(TEST_ENGINE);
|
2020-12-26 14:30:46 -08:00
|
|
|
|
|
|
|
// Cut above 100kPa
|
|
|
|
engineConfiguration->boostCutPressure = 100;
|
|
|
|
|
|
|
|
LimpManager dut;
|
|
|
|
|
|
|
|
// Below threshold, injection allowed
|
2021-01-02 16:13:10 -08:00
|
|
|
Sensor::setMockValue(SensorType::Map, 80);
|
2021-06-16 14:20:28 -07:00
|
|
|
dut.updateState(1000, 0);
|
2020-12-26 14:30:46 -08:00
|
|
|
EXPECT_TRUE(dut.allowInjection());
|
|
|
|
|
2022-09-05 17:56:32 -07:00
|
|
|
// Above rising threshold, injection cut
|
|
|
|
Sensor::setMockValue(SensorType::Map, 105);
|
2021-06-16 14:20:28 -07:00
|
|
|
dut.updateState(1000, 0);
|
2020-12-26 14:30:46 -08:00
|
|
|
EXPECT_FALSE(dut.allowInjection());
|
|
|
|
|
2022-09-05 17:56:32 -07:00
|
|
|
// Below rising threshold, but should have hysteresis, so not cut yet
|
|
|
|
Sensor::setMockValue(SensorType::Map, 95);
|
|
|
|
dut.updateState(1000, 0);
|
|
|
|
EXPECT_FALSE(dut.allowInjection());
|
|
|
|
|
|
|
|
// Below falling threshold, fuel restored
|
|
|
|
Sensor::setMockValue(SensorType::Map, 79);
|
2021-06-16 14:20:28 -07:00
|
|
|
dut.updateState(1000, 0);
|
2020-12-26 14:30:46 -08:00
|
|
|
EXPECT_TRUE(dut.allowInjection());
|
|
|
|
|
|
|
|
// SPECIAL CASE: threshold of 0 means never boost cut
|
|
|
|
engineConfiguration->boostCutPressure = 0;
|
2021-01-02 16:13:10 -08:00
|
|
|
Sensor::setMockValue(SensorType::Map, 500);
|
2021-06-16 14:20:28 -07:00
|
|
|
dut.updateState(1000, 0);
|
2020-12-26 14:30:46 -08:00
|
|
|
EXPECT_TRUE(dut.allowInjection());
|
|
|
|
}
|
2021-06-16 14:20:28 -07:00
|
|
|
|
|
|
|
extern int timeNowUs;
|
|
|
|
|
|
|
|
TEST(limp, oilPressureFailureCase) {
|
2021-11-16 13:52:11 -08:00
|
|
|
EngineTestHelper eth(TEST_ENGINE);
|
2021-06-16 14:20:28 -07:00
|
|
|
engineConfiguration->minOilPressureAfterStart = 200;
|
|
|
|
|
|
|
|
LimpManager dut;
|
|
|
|
|
|
|
|
// Low oil pressure!
|
|
|
|
Sensor::setMockValue(SensorType::OilPressure, 50);
|
|
|
|
|
|
|
|
// Start the engine
|
2021-11-17 00:54:21 -08:00
|
|
|
engine->rpmCalculator.setRpmValue(1000);
|
2021-06-16 14:20:28 -07:00
|
|
|
|
|
|
|
// update & check: injection should be allowed
|
|
|
|
dut.updateState(1000, getTimeNowNt());
|
|
|
|
EXPECT_TRUE(dut.allowInjection());
|
|
|
|
|
|
|
|
// 4.5 seconds later, should still be allowed (even though pressure is low)
|
|
|
|
timeNowUs += 4.5e6;
|
|
|
|
dut.updateState(1000, getTimeNowNt());
|
|
|
|
EXPECT_TRUE(dut.allowInjection());
|
|
|
|
|
|
|
|
// 1 second later (5.5 since start), injection should cut
|
|
|
|
timeNowUs += 1.0e6;
|
|
|
|
dut.updateState(1000, getTimeNowNt());
|
|
|
|
ASSERT_FALSE(dut.allowInjection());
|
|
|
|
|
|
|
|
// But then oil pressure arrives!
|
|
|
|
// Injection still isn't allowed, since now we're late.
|
|
|
|
Sensor::setMockValue(SensorType::OilPressure, 250);
|
|
|
|
dut.updateState(1000, getTimeNowNt());
|
|
|
|
ASSERT_FALSE(dut.allowInjection());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(limp, oilPressureSuccessCase) {
|
2021-11-16 13:52:11 -08:00
|
|
|
EngineTestHelper eth(TEST_ENGINE);
|
2021-06-16 14:20:28 -07:00
|
|
|
engineConfiguration->minOilPressureAfterStart = 200;
|
|
|
|
|
|
|
|
LimpManager dut;
|
|
|
|
|
|
|
|
// Low oil pressure!
|
|
|
|
Sensor::setMockValue(SensorType::OilPressure, 50);
|
|
|
|
|
|
|
|
// Start the engine
|
2021-11-17 00:54:21 -08:00
|
|
|
engine->rpmCalculator.setRpmValue(1000);
|
2021-06-16 14:20:28 -07:00
|
|
|
|
|
|
|
// update & check: injection should be allowed
|
|
|
|
dut.updateState(1000, getTimeNowNt());
|
|
|
|
EXPECT_TRUE(dut.allowInjection());
|
|
|
|
|
|
|
|
// 4.5 seconds later, should still be allowed (even though pressure is low)
|
|
|
|
timeNowUs += 4.5e6;
|
|
|
|
dut.updateState(1000, getTimeNowNt());
|
|
|
|
EXPECT_TRUE(dut.allowInjection());
|
|
|
|
|
|
|
|
// But then oil pressure arrives!
|
|
|
|
Sensor::setMockValue(SensorType::OilPressure, 250);
|
|
|
|
dut.updateState(1000, getTimeNowNt());
|
|
|
|
ASSERT_TRUE(dut.allowInjection());
|
|
|
|
|
|
|
|
// 1 second later (5.5 since start), injection should be allowed since we saw pressure before the timeout
|
|
|
|
timeNowUs += 1.0e6;
|
|
|
|
dut.updateState(1000, getTimeNowNt());
|
|
|
|
ASSERT_TRUE(dut.allowInjection());
|
|
|
|
|
|
|
|
// Later, we lose oil pressure, but engine should stay running
|
|
|
|
timeNowUs += 10e6;
|
|
|
|
Sensor::setMockValue(SensorType::OilPressure, 10);
|
|
|
|
dut.updateState(1000, getTimeNowNt());
|
|
|
|
ASSERT_TRUE(dut.allowInjection());
|
|
|
|
}
|