2020-11-19 05:15:56 -08:00
|
|
|
#include "engine_test_helper.h"
|
2020-11-19 18:14:38 -08:00
|
|
|
#include "engine_controller.h"
|
2020-11-19 05:15:56 -08:00
|
|
|
#include "launch_control.h"
|
2020-11-19 18:14:38 -08:00
|
|
|
#include "vehicle_speed.h"
|
2020-11-19 05:15:56 -08:00
|
|
|
|
|
|
|
#include <gtest/gtest.h>
|
|
|
|
|
|
|
|
TEST(LaunchControl, TpsCondition) {
|
|
|
|
WITH_ENGINE_TEST_HELPER(TEST_ENGINE);
|
|
|
|
|
|
|
|
LaunchControlBase dut;
|
|
|
|
INJECT_ENGINE_REFERENCE(&dut);
|
|
|
|
|
|
|
|
engineConfiguration->launchTpsTreshold = 10;
|
|
|
|
|
|
|
|
// Should return false with failed sensor
|
|
|
|
Sensor::resetMockValue(SensorType::DriverThrottleIntent);
|
|
|
|
EXPECT_FALSE(dut.isInsideTpsCondition());
|
|
|
|
|
|
|
|
// Should return false when throttle is closed
|
|
|
|
Sensor::setMockValue(SensorType::DriverThrottleIntent, 5.0f);
|
|
|
|
EXPECT_FALSE(dut.isInsideTpsCondition());
|
|
|
|
|
|
|
|
// Should return true when throttle is opened past the threshold
|
|
|
|
Sensor::setMockValue(SensorType::DriverThrottleIntent, 20.0f);
|
|
|
|
EXPECT_TRUE(dut.isInsideTpsCondition());
|
|
|
|
}
|
2020-11-19 18:14:38 -08:00
|
|
|
|
|
|
|
|
|
|
|
TEST(LaunchControl, VSSCondition) {
|
|
|
|
WITH_ENGINE_TEST_HELPER(TEST_ENGINE);
|
|
|
|
|
|
|
|
LaunchControlBase dut;
|
|
|
|
INJECT_ENGINE_REFERENCE(&dut);
|
|
|
|
|
|
|
|
// Test Speed trashold
|
2020-12-01 10:03:42 -08:00
|
|
|
engineConfiguration->launchActivationMode = ALWAYS_ACTIVE_LAUNCH;
|
2020-11-19 18:14:38 -08:00
|
|
|
engineConfiguration->launchSpeedTreshold = 30;
|
|
|
|
engineConfiguration->launchDisableBySpeed = 1;
|
|
|
|
setMockVehicleSpeed(10);
|
|
|
|
EXPECT_TRUE(dut.isInsideSpeedCondition());
|
|
|
|
|
|
|
|
setMockVehicleSpeed(40);
|
|
|
|
EXPECT_FALSE(dut.isInsideSpeedCondition());
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(LaunchControl, RPMCondition) {
|
|
|
|
WITH_ENGINE_TEST_HELPER(TEST_ENGINE);
|
|
|
|
|
|
|
|
LaunchControlBase dut;
|
|
|
|
INJECT_ENGINE_REFERENCE(&dut);
|
|
|
|
|
|
|
|
engineConfiguration->launchRpm = 3000;
|
|
|
|
|
|
|
|
EXPECT_FALSE(dut.isInsideRPMCondition(2900));
|
|
|
|
|
|
|
|
EXPECT_TRUE(dut.isInsideRPMCondition(3100));
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(LaunchControl, SwitchInputCondition) {
|
|
|
|
WITH_ENGINE_TEST_HELPER(TEST_ENGINE);
|
|
|
|
|
|
|
|
LaunchControlBase dut;
|
|
|
|
INJECT_ENGINE_REFERENCE(&dut);
|
|
|
|
|
|
|
|
//activation based on VSS
|
2020-12-01 10:03:42 -08:00
|
|
|
engineConfiguration->launchActivationMode = ALWAYS_ACTIVE_LAUNCH;
|
2020-11-19 18:14:38 -08:00
|
|
|
EXPECT_TRUE(dut.isInsideSwitchCondition());
|
|
|
|
|
|
|
|
//active by switch
|
2020-12-01 10:03:42 -08:00
|
|
|
engineConfiguration->launchActivationMode = SWITCH_INPUT_LAUNCH;
|
2020-11-19 18:14:38 -08:00
|
|
|
engineConfiguration->launchActivatePin = GPIOG_1;
|
|
|
|
setMockState(engineConfiguration->launchActivatePin, true);
|
|
|
|
EXPECT_TRUE(dut.isInsideSwitchCondition());
|
|
|
|
|
|
|
|
setMockState(engineConfiguration->launchActivatePin, false);
|
|
|
|
EXPECT_FALSE(dut.isInsideSwitchCondition());
|
|
|
|
|
|
|
|
//by clutch
|
2020-12-01 10:03:42 -08:00
|
|
|
engineConfiguration->launchActivationMode = CLUTCH_INPUT_LAUNCH;
|
2020-11-19 18:14:38 -08:00
|
|
|
engineConfiguration->clutchDownPin = GPIOG_2;
|
|
|
|
engineConfiguration->clutchDownPinMode = PI_PULLUP;
|
|
|
|
setMockState(engineConfiguration->clutchDownPin, true);
|
|
|
|
EXPECT_TRUE(dut.isInsideSwitchCondition());
|
|
|
|
|
|
|
|
setMockState(engineConfiguration->clutchDownPin, false);
|
|
|
|
EXPECT_FALSE(dut.isInsideSwitchCondition());
|
|
|
|
|
|
|
|
engineConfiguration->clutchDownPinMode = PI_PULLDOWN;
|
|
|
|
setMockState(engineConfiguration->clutchDownPin, false);
|
|
|
|
EXPECT_TRUE(dut.isInsideSwitchCondition());
|
|
|
|
|
|
|
|
setMockState(engineConfiguration->clutchDownPin, true);
|
|
|
|
EXPECT_FALSE(dut.isInsideSwitchCondition());
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(LaunchControl, CombinedCondition) {
|
|
|
|
WITH_ENGINE_TEST_HELPER(TEST_ENGINE);
|
|
|
|
|
|
|
|
LaunchControlBase dut;
|
|
|
|
INJECT_ENGINE_REFERENCE(&dut);
|
|
|
|
|
|
|
|
//check VSS normal usage
|
|
|
|
engineConfiguration->launchActivationMode=ALWAYS_ACTIVE_LAUNCH;
|
|
|
|
engineConfiguration->launchSpeedTreshold = 30;
|
|
|
|
engineConfiguration->launchDisableBySpeed = 1;
|
|
|
|
engineConfiguration->launchRpm = 3000;
|
|
|
|
engineConfiguration->launchTpsTreshold = 10;
|
|
|
|
//valid TPS
|
|
|
|
Sensor::setMockValue(SensorType::DriverThrottleIntent, 20.0f);
|
|
|
|
|
|
|
|
setMockVehicleSpeed(10);
|
|
|
|
engine->rpmCalculator.mockRpm = 1200;
|
|
|
|
|
|
|
|
EXPECT_FALSE(dut.isLaunchConditionMet(1200));
|
|
|
|
|
|
|
|
engine->rpmCalculator.mockRpm = 3200;
|
|
|
|
EXPECT_TRUE(dut.isLaunchConditionMet(3200));
|
|
|
|
|
|
|
|
setMockVehicleSpeed(40);
|
|
|
|
EXPECT_FALSE(dut.isLaunchConditionMet(3200));
|
|
|
|
|
|
|
|
}
|
2020-12-01 10:03:42 -08:00
|
|
|
|
|
|
|
TEST(LaunchControl, CompleteRun) {
|
|
|
|
bool spark, fuel;
|
|
|
|
WITH_ENGINE_TEST_HELPER(TEST_ENGINE);
|
|
|
|
|
|
|
|
LoggingWithStorage logger("test");
|
|
|
|
|
|
|
|
initLaunchControl(&logger,PASS_ENGINE_PARAMETER_SIGNATURE);
|
|
|
|
|
|
|
|
//load default config
|
|
|
|
setDefaultLaunchParameters(PASS_CONFIG_PARAMETER_SIGNATURE);
|
|
|
|
|
|
|
|
//check VSS normal usage
|
|
|
|
engineConfiguration->launchActivationMode = ALWAYS_ACTIVE_LAUNCH;
|
|
|
|
engineConfiguration->launchSpeedTreshold = 30;
|
|
|
|
engineConfiguration->launchDisableBySpeed = 1;
|
|
|
|
engineConfiguration->launchRpm = 3000;
|
|
|
|
engineConfiguration->launchTpsTreshold = 10;
|
|
|
|
engineConfiguration->launchControlEnabled = 1;
|
|
|
|
//valid TPS
|
|
|
|
Sensor::setMockValue(SensorType::DriverThrottleIntent, 20.0f);
|
|
|
|
|
|
|
|
setMockVehicleSpeed(10);
|
|
|
|
engine->rpmCalculator.mockRpm = 1200;
|
|
|
|
|
|
|
|
//update condition check
|
|
|
|
updateLaunchConditions(PASS_ENGINE_PARAMETER_SIGNATURE);
|
|
|
|
|
|
|
|
//check if we have some sort of cut? we should not have at this point
|
|
|
|
spark = false;
|
|
|
|
fuel = false;
|
|
|
|
applyLaunchControlLimiting(&spark, &fuel PASS_ENGINE_PARAMETER_SUFFIX);
|
|
|
|
EXPECT_FALSE(spark);
|
|
|
|
EXPECT_FALSE(fuel);
|
|
|
|
|
|
|
|
|
|
|
|
engine->rpmCalculator.mockRpm = 3510;
|
|
|
|
//update condition check
|
|
|
|
updateLaunchConditions(PASS_ENGINE_PARAMETER_SIGNATURE);
|
|
|
|
|
|
|
|
|
|
|
|
//we have a 3 seconds delay to actually enable it!
|
|
|
|
eth.smartMoveTimeForwardSeconds(1);
|
|
|
|
updateLaunchConditions(PASS_ENGINE_PARAMETER_SIGNATURE);
|
|
|
|
spark = false;
|
|
|
|
fuel = false;
|
|
|
|
applyLaunchControlLimiting(&spark, &fuel PASS_ENGINE_PARAMETER_SUFFIX);
|
|
|
|
|
|
|
|
EXPECT_FALSE(spark);
|
|
|
|
EXPECT_FALSE(fuel);
|
|
|
|
|
|
|
|
eth.smartMoveTimeForwardSeconds(3);
|
|
|
|
updateLaunchConditions(PASS_ENGINE_PARAMETER_SIGNATURE);
|
|
|
|
spark = false;
|
|
|
|
fuel = false;
|
|
|
|
applyLaunchControlLimiting(&spark, &fuel PASS_ENGINE_PARAMETER_SUFFIX);
|
|
|
|
|
|
|
|
EXPECT_TRUE(spark);
|
|
|
|
EXPECT_FALSE(fuel);
|
|
|
|
|
|
|
|
setMockVehicleSpeed(40);
|
|
|
|
updateLaunchConditions(PASS_ENGINE_PARAMETER_SIGNATURE);
|
|
|
|
spark = false;
|
|
|
|
fuel = false;
|
|
|
|
applyLaunchControlLimiting(&spark, &fuel PASS_ENGINE_PARAMETER_SUFFIX);
|
|
|
|
EXPECT_FALSE(spark);
|
|
|
|
EXPECT_FALSE(fuel);
|
|
|
|
|
|
|
|
}
|