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() { void Engine::resetEngineSnifferIfInTestMode() {
#if EFI_ENGINE_SNIFFER #if EFI_ENGINE_SNIFFER
if (isTestMode) { if (isTestMode) {
// TODO: what is the exact reasoning for the exact engine sniffer pause time I wonder
waveChart.pauseEngineSnifferUntilNt = getTimeNowNt() + MS2NT(300);
waveChart.reset(); waveChart.reset();
} }
#endif /* EFI_ENGINE_SNIFFER */ #endif /* EFI_ENGINE_SNIFFER */
@ -144,7 +146,7 @@ void Engine::periodicSlowCallback(DECLARE_ENGINE_PARAMETER_SIGNATURE) {
#if (BOARD_TLE8888_COUNT > 0) #if (BOARD_TLE8888_COUNT > 0)
if (CONFIG(useTLE8888_cranking_hack) && ENGINE(rpmCalculator).isCranking(PASS_ENGINE_PARAMETER_SIGNATURE)) { if (CONFIG(useTLE8888_cranking_hack) && ENGINE(rpmCalculator).isCranking(PASS_ENGINE_PARAMETER_SIGNATURE)) {
efitick_t nowNt = getTimeNowNt(); efitick_t nowNt = getTimeNowNt();
if (nowNt - tle8888CrankingResetTime > US2NT(MS2US(300))) { if (nowNt - tle8888CrankingResetTime > MS2NT(300)) {
requestTLE8888initialization(); requestTLE8888initialization();
// let's reset TLE8888 every 300ms while cranking since that's the best we can do to deal with undervoltage reset // 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! // 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); incrementGlobalConfigurationVersion(PASS_ENGINE_PARAMETER_SIGNATURE);
doPrintConfiguration(); doPrintConfiguration();
scheduleMsg(&logger, "Do you need to also invoke set operation_mode X?"); scheduleMsg(&logger, "Do you need to also invoke set operation_mode X?");
engine->resetEngineSnifferIfInTestMode();
} }
static void setDebugMode(int value) { static void setDebugMode(int value) {
@ -625,6 +626,7 @@ static void setWholePhaseMapCmd(float value) {
static void setWholeTimingMapCmd(float value) { static void setWholeTimingMapCmd(float value) {
scheduleMsg(&logger, "Setting whole timing advance map to %.2f", value); scheduleMsg(&logger, "Setting whole timing advance map to %.2f", value);
setWholeTimingMap(value); setWholeTimingMap(value);
engine->resetEngineSnifferIfInTestMode();
} }
static void setWholeVeCmd(float value) { 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"); scheduleMsg(&logger, "WARNING: setting VE map not in SD mode is pointless");
} }
setMap(config->veTable, value); setMap(config->veTable, value);
engine->resetEngineSnifferIfInTestMode();
} }
static void setWholeFuelMapCmd(float value) { 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"); scheduleMsg(&logger, "WARNING: setting fuel map in SD mode is pointless");
} }
setWholeFuelMap(value PASS_CONFIG_PARAMETER_SUFFIX); setWholeFuelMap(value PASS_CONFIG_PARAMETER_SUFFIX);
engine->resetEngineSnifferIfInTestMode();
} }
#if EFI_PROD_CODE #if EFI_PROD_CODE

View File

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

View File

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

View File

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