124 lines
5.1 KiB
C++
124 lines
5.1 KiB
C++
/*
|
|
* test_fasterEngineSpinningUp.cpp
|
|
*
|
|
* Created on: Mar 6, 2018
|
|
*/
|
|
|
|
#include "engine_math.h"
|
|
#include "engine_test_helper.h"
|
|
|
|
TEST(cranking, testFasterEngineSpinningUp) {
|
|
printf("*************************************************** testFasterEngineSpinningUp\r\n");
|
|
|
|
WITH_ENGINE_TEST_HELPER(TEST_ENGINE);
|
|
// turn on FasterEngineSpinUp mode
|
|
engineConfiguration->bc.isFasterEngineSpinUpEnabled = true;
|
|
|
|
|
|
// todo: it's depressing that this unit test does not survive a bit of idle time in the beginning
|
|
// todo: uncomment
|
|
//eth.moveTimeForwardMs(1000 /*ms*/);
|
|
eth.firePrimaryTriggerRise();
|
|
|
|
// set ignition mode
|
|
engineConfiguration->ignitionMode = IM_INDIVIDUAL_COILS;
|
|
// set cranking threshold (used below)
|
|
engineConfiguration->cranking.rpm = 999;
|
|
// set sequential injection mode to test auto-change to simultaneous when spinning-up
|
|
setupSimpleTestEngineWithMafAndTT_ONE_trigger(ð, IM_SEQUENTIAL);
|
|
|
|
// check if it's true
|
|
ASSERT_EQ(IM_SEQUENTIAL, engine->getCurrentInjectionMode(PASS_ENGINE_PARAMETER_SIGNATURE));
|
|
ASSERT_EQ(IM_INDIVIDUAL_COILS, getCurrentIgnitionMode(PASS_ENGINE_PARAMETER_SIGNATURE));
|
|
// check if the engine has the right state
|
|
ASSERT_EQ(STOPPED, engine->rpmCalculator.getState());
|
|
// check RPM
|
|
ASSERT_EQ( 0, GET_RPM()) << "RPM=0";
|
|
// the queue should be empty, no trigger events yet
|
|
ASSERT_EQ(0, engine->executor.size()) << "plain#1";
|
|
|
|
// check all events starting from now
|
|
int timeStartUs = eth.getTimeNowUs();
|
|
// advance 1 revolution
|
|
// because we have trivial TT_ONE trigger here synchronization would happen with just one rise front
|
|
eth.fireRise(200);
|
|
|
|
// check if the mode is changed
|
|
ASSERT_EQ(SPINNING_UP, engine->rpmCalculator.getState());
|
|
// due to isFasterEngineSpinUp=true, we should have already detected RPM!
|
|
ASSERT_EQ( 300, GET_RPM()) << "spinning-RPM#1";
|
|
// two simultaneous injections
|
|
ASSERT_EQ(4, engine->executor.size()) << "plain#2";
|
|
// test if they are simultaneous
|
|
ASSERT_EQ(IM_SIMULTANEOUS, engine->getCurrentInjectionMode(PASS_ENGINE_PARAMETER_SIGNATURE));
|
|
// test if ignition mode is temporary changed to wasted spark, if set to individual coils
|
|
ASSERT_EQ(IM_WASTED_SPARK, getCurrentIgnitionMode(PASS_ENGINE_PARAMETER_SIGNATURE));
|
|
// check real events
|
|
eth.assertEvent5(&engine->executor, "inj start#1", 0, (void*)startSimultaniousInjection, timeStartUs, MS2US(200) + 97975);
|
|
eth.assertEvent5(&engine->executor, "inj end#1", 1, (void*)endSimultaniousInjection, timeStartUs, MS2US(200) + 100000);
|
|
|
|
// skip the rest of the cycle
|
|
eth.fireFall(200);
|
|
|
|
// now clear and advance more
|
|
eth.clearQueue();
|
|
|
|
eth.fireRise(200);
|
|
|
|
// check if the mode is changed when fully synched
|
|
ASSERT_EQ(CRANKING, engine->rpmCalculator.getState());
|
|
// check RPM
|
|
ASSERT_EQ( 200, GET_RPM()) << "RPM#2";
|
|
// test if they are simultaneous in cranking mode too
|
|
ASSERT_EQ(IM_SIMULTANEOUS, engine->getCurrentInjectionMode(PASS_ENGINE_PARAMETER_SIGNATURE));
|
|
// test if ignition mode is restored to ind.coils
|
|
ASSERT_EQ(IM_INDIVIDUAL_COILS, getCurrentIgnitionMode(PASS_ENGINE_PARAMETER_SIGNATURE));
|
|
// two simultaneous injections
|
|
ASSERT_EQ( 4, engine->executor.size()) << "plain#2";
|
|
// check real events
|
|
eth.assertEvent5(&engine->executor, "inj start#2", 0, (void*)startSimultaniousInjection, eth.getTimeNowUs(), 147975);
|
|
eth.assertEvent5(&engine->executor, "inj end#2", 1, (void*)endSimultaniousInjection, eth.getTimeNowUs(), 150000);
|
|
|
|
// skip, clear & advance 1 more revolution at higher RPM
|
|
eth.fireFall(60);
|
|
|
|
eth.clearQueue();
|
|
timeStartUs = eth.getTimeNowUs();
|
|
eth.fireTriggerEventsWithDuration(60);
|
|
|
|
// check if the mode is now changed to 'running' at higher RPM
|
|
ASSERT_EQ(RUNNING, engine->rpmCalculator.getState());
|
|
// check RPM
|
|
ASSERT_EQ( 1000, GET_RPM()) << "RPM#3";
|
|
// check if the injection mode is back to sequential now
|
|
ASSERT_EQ(IM_SEQUENTIAL, engine->getCurrentInjectionMode(PASS_ENGINE_PARAMETER_SIGNATURE));
|
|
// 4 sequential injections for the full cycle
|
|
ASSERT_EQ( 8, engine->executor.size()) << "plain#3";
|
|
|
|
// check real events for sequential injection
|
|
// Note: See addFuelEvents() fix inside setRpmValue()!
|
|
eth.assertEvent5(&engine->executor, "inj start#3", 0, (void*)seTurnPinHigh, timeStartUs, MS2US(60) + 27974);
|
|
eth.assertEvent5(&engine->executor, "inj end#3", 1, (void*)seTurnPinLow, timeStartUs, MS2US(60) + 27974 + 3000);
|
|
}
|
|
|
|
static void doTestFasterEngineSpinningUp60_2(int startUpDelayMs, int expectedRpm) {
|
|
WITH_ENGINE_TEST_HELPER(TEST_ENGINE);
|
|
// turn on FasterEngineSpinUp mode
|
|
engineConfiguration->bc.isFasterEngineSpinUpEnabled = true;
|
|
|
|
setupSimpleTestEngineWithMaf(ð, IM_SEQUENTIAL, TT_TOOTHED_WHEEL_60_2);
|
|
eth.moveTimeForwardMs(startUpDelayMs);
|
|
|
|
eth.fireTriggerEvents2(30 /* count */, 1 /*ms*/);
|
|
eth.fireTriggerEvents2(1, 4);
|
|
EXPECT_EQ(expectedRpm, GET_RPM()) << "test RPM with " + std::to_string(startUpDelayMs) + " startUpDelayMs";
|
|
}
|
|
|
|
TEST(cranking, testFasterEngineSpinningUp60_2) {
|
|
// I do not get it. Startup delay is affecting instance RPM?
|
|
// todo: is this feature implementation issue or test framework issue?
|
|
doTestFasterEngineSpinningUp60_2(0, 220);
|
|
doTestFasterEngineSpinningUp60_2(100, 89);
|
|
doTestFasterEngineSpinningUp60_2(1000, 0);
|
|
}
|