functional testing should not be that darn slow #1076

hopefully progress?
This commit is contained in:
rusefi 2019-12-21 23:27:54 -05:00
parent c55bf7a4c7
commit 73a4a92891
5 changed files with 18 additions and 2 deletions

View File

@ -61,6 +61,8 @@ FsioState::FsioState() {
void Engine::resetEngineSnifferIfInTestMode() {
#if EFI_ENGINE_SNIFFER
if (isTestMode) {
// TODO: what is the exact reasoning for the exact engine sniffer pause time I wonder
waveChart.pauseEngineSnifferUntilNt = getTimeNowNt() + MS2NT(300);
waveChart.reset();
}
#endif /* EFI_ENGINE_SNIFFER */
@ -144,7 +146,7 @@ void Engine::periodicSlowCallback(DECLARE_ENGINE_PARAMETER_SIGNATURE) {
#if (BOARD_TLE8888_COUNT > 0)
if (CONFIG(useTLE8888_cranking_hack) && ENGINE(rpmCalculator).isCranking(PASS_ENGINE_PARAMETER_SIGNATURE)) {
efitick_t nowNt = getTimeNowNt();
if (nowNt - tle8888CrankingResetTime > US2NT(MS2US(300))) {
if (nowNt - tle8888CrankingResetTime > MS2NT(300)) {
requestTLE8888initialization();
// let's reset TLE8888 every 300ms while cranking since that's the best we can do to deal with undervoltage reset
// PS: oh yes, it's a horrible design! Please suggest something better!

View File

@ -545,6 +545,7 @@ static void setTriggerType(int value) {
incrementGlobalConfigurationVersion(PASS_ENGINE_PARAMETER_SIGNATURE);
doPrintConfiguration();
scheduleMsg(&logger, "Do you need to also invoke set operation_mode X?");
engine->resetEngineSnifferIfInTestMode();
}
static void setDebugMode(int value) {
@ -625,6 +626,7 @@ static void setWholePhaseMapCmd(float value) {
static void setWholeTimingMapCmd(float value) {
scheduleMsg(&logger, "Setting whole timing advance map to %.2f", value);
setWholeTimingMap(value);
engine->resetEngineSnifferIfInTestMode();
}
static void setWholeVeCmd(float value) {
@ -633,6 +635,7 @@ static void setWholeVeCmd(float value) {
scheduleMsg(&logger, "WARNING: setting VE map not in SD mode is pointless");
}
setMap(config->veTable, value);
engine->resetEngineSnifferIfInTestMode();
}
static void setWholeFuelMapCmd(float value) {
@ -641,6 +644,7 @@ static void setWholeFuelMapCmd(float value) {
scheduleMsg(&logger, "WARNING: setting fuel map in SD mode is pointless");
}
setWholeFuelMap(value PASS_CONFIG_PARAMETER_SUFFIX);
engine->resetEngineSnifferIfInTestMode();
}
#if EFI_PROD_CODE

View File

@ -165,6 +165,9 @@ void WaveChart::publish() {
* @brief Register an event for digital sniffer
*/
void WaveChart::addEvent3(const char *name, const char * msg) {
if (getTimeNowNt() < pauseEngineSnifferUntilNt) {
return;
}
#if EFI_TEXT_LOGGING
if (!ENGINE(isEngineChartEnabled)) {
return;

View File

@ -28,6 +28,8 @@ public:
void publish();
bool isFull() const;
bool isStartedTooLongAgo() const;
efitick_t pauseEngineSnifferUntilNt = 0;
private:
Logging logging;
char timeBuffer[_MAX_FILLER + 2];

View File

@ -122,6 +122,11 @@ public class TestingUtils {
return EngineChartParser.unpackToMap(getNextWaveChart());
}
static EngineChart nextChart1() {
return EngineChartParser.unpackToMap(getNextWaveChart());
}
static String getNextWaveChart() {
IoUtil.sendCommand(Fields.CMD_RESET_ENGINE_SNIFFER);
String result = getEngineChart();