2019-01-13 19:52:22 -08:00
|
|
|
/*
|
2020-05-09 21:59:32 -07:00
|
|
|
* test_cam_vvt_input.cpp
|
2019-01-13 19:52:22 -08:00
|
|
|
*
|
|
|
|
* Created on: Jan 13, 2019
|
2020-01-07 21:02:40 -08:00
|
|
|
* @author Andrey Belomutskiy, (c) 2012-2020
|
2019-01-13 19:52:22 -08:00
|
|
|
*/
|
|
|
|
|
2021-08-03 19:05:01 -07:00
|
|
|
#include "pch.h"
|
|
|
|
|
2019-05-10 19:55:08 -07:00
|
|
|
extern WarningCodeState unitTestWarningCodeState;
|
|
|
|
|
2021-04-04 19:48:48 -07:00
|
|
|
#include "engine_sniffer.h"
|
|
|
|
extern WaveChart waveChart;
|
|
|
|
|
2021-02-08 13:16:26 -08:00
|
|
|
TEST(trigger, testNoStartUpWarningsNoSyncronizationTrigger) {
|
2021-11-16 13:52:11 -08:00
|
|
|
EngineTestHelper eth(TEST_ENGINE);
|
2019-05-10 19:55:08 -07:00
|
|
|
// one tooth does not need synchronization it just counts tooth
|
2021-11-16 01:15:29 -08:00
|
|
|
eth.setTriggerType(TT_ONE);
|
2022-01-20 20:19:48 -08:00
|
|
|
ASSERT_EQ( 0, round(Sensor::getOrZero(SensorType::Rpm))) << "testNoStartUpWarnings RPM";
|
2019-05-10 19:55:08 -07:00
|
|
|
|
|
|
|
eth.fireTriggerEvents2(/*count*/10, /*duration*/50);
|
2022-01-20 20:19:48 -08:00
|
|
|
ASSERT_EQ(1200, round(Sensor::getOrZero(SensorType::Rpm))) << "testNoStartUpWarnings RPM";
|
2019-05-10 19:55:08 -07:00
|
|
|
ASSERT_EQ( 0, unitTestWarningCodeState.recentWarnings.getCount()) << "warningCounter#testNoStartUpWarningsNoSyncronizationTrigger";
|
|
|
|
}
|
|
|
|
|
2021-02-08 13:16:26 -08:00
|
|
|
TEST(trigger, testNoStartUpWarnings) {
|
2021-11-16 13:52:11 -08:00
|
|
|
EngineTestHelper eth(TEST_ENGINE);
|
2019-05-10 20:12:36 -07:00
|
|
|
// for this test we need a trigger with isSynchronizationNeeded=true
|
|
|
|
engineConfiguration->trigger.customTotalToothCount = 3;
|
|
|
|
engineConfiguration->trigger.customSkippedToothCount = 1;
|
2021-11-16 01:15:29 -08:00
|
|
|
eth.setTriggerType(TT_TOOTHED_WHEEL);
|
2022-01-20 20:19:48 -08:00
|
|
|
ASSERT_EQ( 0, round(Sensor::getOrZero(SensorType::Rpm))) << "testNoStartUpWarnings RPM";
|
2019-05-10 19:55:08 -07:00
|
|
|
|
2019-05-10 20:12:36 -07:00
|
|
|
for (int i = 0;i < 10;i++) {
|
|
|
|
eth.fireRise(50);
|
|
|
|
eth.fireFall(50);
|
|
|
|
eth.fireRise(50);
|
|
|
|
eth.fireFall(150);
|
|
|
|
}
|
2019-05-10 19:55:08 -07:00
|
|
|
|
2022-01-20 20:19:48 -08:00
|
|
|
ASSERT_EQ(400, round(Sensor::getOrZero(SensorType::Rpm))) << "testNoStartUpWarnings RPM";
|
2019-05-10 19:55:08 -07:00
|
|
|
ASSERT_EQ( 0, unitTestWarningCodeState.recentWarnings.getCount()) << "warningCounter#testNoStartUpWarnings";
|
2019-05-10 20:12:36 -07:00
|
|
|
// now let's post something unneeded
|
2019-05-10 19:55:08 -07:00
|
|
|
eth.fireRise(50);
|
2019-05-10 20:12:36 -07:00
|
|
|
eth.fireFall(50);
|
|
|
|
eth.fireRise(50); // this is noise
|
|
|
|
eth.fireFall(50); // this is noise
|
2019-05-10 19:55:08 -07:00
|
|
|
eth.fireRise(50);
|
2019-05-10 20:12:36 -07:00
|
|
|
eth.fireFall(150);
|
|
|
|
for (int i = 0;i < 1;i++) {
|
|
|
|
eth.fireRise(50);
|
|
|
|
eth.fireFall(50);
|
|
|
|
eth.fireRise(50);
|
|
|
|
eth.fireFall(150);
|
|
|
|
}
|
2022-05-13 15:48:26 -07:00
|
|
|
EXPECT_EQ( 1, unitTestWarningCodeState.recentWarnings.getCount()) << "warningCounter#testNoStartUpWarnings CUSTOM_SYNC_COUNT_MISMATCH expected";
|
2022-09-04 06:15:24 -07:00
|
|
|
EXPECT_EQ(CUSTOM_PRIMARY_TOO_MANY_TEETH, unitTestWarningCodeState.recentWarnings.get(0).Code);
|
2019-05-10 19:55:08 -07:00
|
|
|
}
|
|
|
|
|
2021-02-08 13:16:26 -08:00
|
|
|
TEST(trigger, testNoisyInput) {
|
2021-11-16 13:52:11 -08:00
|
|
|
EngineTestHelper eth(TEST_ENGINE);
|
2019-05-10 18:56:33 -07:00
|
|
|
|
2022-01-20 20:19:48 -08:00
|
|
|
ASSERT_EQ( 0, round(Sensor::getOrZero(SensorType::Rpm))) << "testNoisyInput RPM";
|
2019-05-10 18:56:33 -07:00
|
|
|
|
|
|
|
eth.firePrimaryTriggerRise();
|
2019-05-10 19:55:08 -07:00
|
|
|
eth.firePrimaryTriggerFall();
|
2019-05-10 18:56:33 -07:00
|
|
|
eth.firePrimaryTriggerRise();
|
2019-05-10 19:55:08 -07:00
|
|
|
eth.firePrimaryTriggerFall();
|
2019-05-10 18:56:33 -07:00
|
|
|
eth.firePrimaryTriggerRise();
|
2019-05-10 19:55:08 -07:00
|
|
|
eth.firePrimaryTriggerFall();
|
2019-05-10 18:56:33 -07:00
|
|
|
eth.firePrimaryTriggerRise();
|
2019-05-10 19:55:08 -07:00
|
|
|
eth.firePrimaryTriggerFall();
|
|
|
|
// error condition since events happened too quick while time does not move
|
2022-01-20 21:21:45 -08:00
|
|
|
ASSERT_EQ(NOISY_RPM, Sensor::getOrZero(SensorType::Rpm)) << "testNoisyInput RPM should be noisy";
|
2019-05-10 20:20:42 -07:00
|
|
|
|
|
|
|
ASSERT_EQ( 2, unitTestWarningCodeState.recentWarnings.getCount()) << "warningCounter#testNoisyInput";
|
2022-09-04 06:15:24 -07:00
|
|
|
ASSERT_EQ(CUSTOM_PRIMARY_NOT_ENOUGH_TEETH, unitTestWarningCodeState.recentWarnings.get(0).Code) << "@0";
|
2022-08-16 22:12:25 -07:00
|
|
|
ASSERT_EQ(OBD_Crankshaft_Position_Sensor_A_Circuit_Malfunction, unitTestWarningCodeState.recentWarnings.get(1).Code) << "@0";
|
2019-05-10 20:20:42 -07:00
|
|
|
}
|
|
|
|
|
2021-02-08 13:16:26 -08:00
|
|
|
TEST(trigger, testCamInput) {
|
2019-05-10 20:20:42 -07:00
|
|
|
// setting some weird engine
|
2021-11-16 13:52:11 -08:00
|
|
|
EngineTestHelper eth(FORD_ESCORT_GT);
|
2019-05-10 20:20:42 -07:00
|
|
|
|
2020-02-04 22:08:39 -08:00
|
|
|
// changing to 'ONE TOOTH' trigger on CRANK with CAM/VVT
|
2022-04-02 23:21:37 -07:00
|
|
|
setCrankOperationMode();
|
2019-05-10 20:20:42 -07:00
|
|
|
engineConfiguration->useOnlyRisingEdgeForTrigger = true;
|
2021-02-08 18:50:31 -08:00
|
|
|
engineConfiguration->vvtMode[0] = VVT_FIRST_HALF;
|
2021-07-03 09:02:00 -07:00
|
|
|
engineConfiguration->vvtOffsets[0] = 360;
|
2021-11-16 01:15:29 -08:00
|
|
|
eth.setTriggerType(TT_ONE);
|
2022-04-28 14:32:39 -07:00
|
|
|
engineConfiguration->camInputs[0] = Gpio::A10; // we just need to indicate that we have CAM
|
2019-05-10 20:20:42 -07:00
|
|
|
|
2022-01-20 20:19:48 -08:00
|
|
|
ASSERT_EQ( 0, round(Sensor::getOrZero(SensorType::Rpm))) << "testCamInput RPM";
|
2019-05-10 18:56:33 -07:00
|
|
|
|
2019-05-10 21:21:37 -07:00
|
|
|
for (int i = 0; i < 5;i++) {
|
|
|
|
eth.fireRise(50);
|
|
|
|
}
|
2019-05-10 20:52:55 -07:00
|
|
|
|
2022-01-20 20:19:48 -08:00
|
|
|
ASSERT_EQ(1200, round(Sensor::getOrZero(SensorType::Rpm))) << "testCamInput RPM";
|
2019-05-10 20:52:55 -07:00
|
|
|
ASSERT_EQ(0, unitTestWarningCodeState.recentWarnings.getCount()) << "warningCounter#testCamInput";
|
2019-05-10 19:55:08 -07:00
|
|
|
|
2019-05-10 21:21:37 -07:00
|
|
|
for (int i = 0; i < 600;i++) {
|
2019-05-10 19:55:08 -07:00
|
|
|
eth.fireRise(50);
|
2019-05-10 20:52:55 -07:00
|
|
|
}
|
|
|
|
|
2020-02-04 22:08:39 -08:00
|
|
|
// asserting that lack of camshaft signal would be detecting
|
2019-05-10 21:21:37 -07:00
|
|
|
ASSERT_EQ(1, unitTestWarningCodeState.recentWarnings.getCount()) << "warningCounter#testCamInput #2";
|
2022-08-16 22:12:25 -07:00
|
|
|
ASSERT_EQ(OBD_Camshaft_Position_Sensor_Circuit_Range_Performance, unitTestWarningCodeState.recentWarnings.get(0).Code) << "@0";
|
2019-05-10 21:21:37 -07:00
|
|
|
unitTestWarningCodeState.recentWarnings.clear();
|
2019-05-10 20:52:55 -07:00
|
|
|
|
2019-05-10 21:21:37 -07:00
|
|
|
for (int i = 0; i < 600;i++) {
|
2020-02-04 22:08:39 -08:00
|
|
|
eth.moveTimeForwardUs(MS2US(10));
|
2022-09-10 23:57:35 -07:00
|
|
|
hwHandleVvtCamSignal(TriggerValue::FALL, getTimeNowNt(), 0);
|
2020-02-04 22:08:39 -08:00
|
|
|
eth.moveTimeForwardUs(MS2US(40));
|
|
|
|
eth.firePrimaryTriggerRise();
|
2019-05-10 20:52:55 -07:00
|
|
|
}
|
|
|
|
|
2020-02-04 22:08:39 -08:00
|
|
|
// asserting that error code has cleared
|
2019-05-10 20:52:55 -07:00
|
|
|
ASSERT_EQ(0, unitTestWarningCodeState.recentWarnings.getCount()) << "warningCounter#testCamInput #3";
|
2021-12-24 13:51:31 -08:00
|
|
|
EXPECT_NEAR_M3(-181, engine->triggerCentral.getVVTPosition(0, 0));
|
2019-01-13 19:52:22 -08:00
|
|
|
}
|
2020-01-29 22:47:34 -08:00
|
|
|
|
2021-07-12 13:29:07 -07:00
|
|
|
TEST(trigger, testNB2CamInput) {
|
2021-11-16 13:52:11 -08:00
|
|
|
EngineTestHelper eth(FRANKENSO_MAZDA_MIATA_2003);
|
2020-01-29 22:47:34 -08:00
|
|
|
|
2021-07-30 05:18:24 -07:00
|
|
|
engineConfiguration->isFasterEngineSpinUpEnabled = false;
|
2020-01-29 22:47:34 -08:00
|
|
|
|
2021-02-08 18:07:43 -08:00
|
|
|
engineConfiguration->useOnlyRisingEdgeForTrigger = true;
|
|
|
|
|
2022-01-20 20:19:48 -08:00
|
|
|
ASSERT_EQ( 0, round(Sensor::getOrZero(SensorType::Rpm)));
|
2022-04-02 23:13:56 -07:00
|
|
|
for (int i = 0; i < 6;i++) {
|
|
|
|
eth.fireRise(25 * 70 / 180);
|
|
|
|
eth.fireRise(25 * 110 / 180);
|
2022-01-20 20:19:48 -08:00
|
|
|
ASSERT_EQ( 0, round(Sensor::getOrZero(SensorType::Rpm)));
|
2020-01-29 22:47:34 -08:00
|
|
|
}
|
2022-04-02 23:13:56 -07:00
|
|
|
eth.fireRise(25 * 70 / 180);
|
|
|
|
eth.fireRise(25 * 110 / 180);
|
2020-02-14 10:02:27 -08:00
|
|
|
// first time we have RPM
|
2022-04-02 23:13:56 -07:00
|
|
|
ASSERT_EQ(1250, round(Sensor::getOrZero(SensorType::Rpm)));
|
2020-01-29 22:47:34 -08:00
|
|
|
|
2022-04-02 23:13:56 -07:00
|
|
|
int totalRevolutionCountBeforeVvtSync = 5;
|
2020-02-14 10:02:27 -08:00
|
|
|
// need to be out of VVT sync to see VVT sync in action
|
2022-05-13 15:48:26 -07:00
|
|
|
eth.fireRise(25 * 70 / 180);
|
|
|
|
eth.fireRise(25 * 110 / 180);
|
2022-09-07 19:24:28 -07:00
|
|
|
ASSERT_EQ(totalRevolutionCountBeforeVvtSync, engine->triggerCentral.triggerState.getCrankSynchronizationCounter());
|
2020-02-14 10:02:27 -08:00
|
|
|
ASSERT_TRUE((totalRevolutionCountBeforeVvtSync % SYMMETRICAL_CRANK_SENSOR_DIVIDER) != 0);
|
|
|
|
|
2020-05-09 22:21:54 -07:00
|
|
|
eth.moveTimeForwardUs(MS2US(3)); // shifting VVT phase a few angles
|
2020-02-14 10:02:27 -08:00
|
|
|
|
2022-09-10 23:57:35 -07:00
|
|
|
hwHandleVvtCamSignal(TriggerValue::RISE, getTimeNowNt(), 0);
|
2021-07-21 17:07:28 -07:00
|
|
|
|
|
|
|
// first gap - long
|
|
|
|
|
|
|
|
eth.moveTimeForwardUs(MS2US(130));
|
2022-09-10 23:57:35 -07:00
|
|
|
hwHandleVvtCamSignal(TriggerValue::FALL, getTimeNowNt(), 0);
|
2021-07-21 17:07:28 -07:00
|
|
|
eth.moveTimeForwardUs(MS2US( 30));
|
2022-09-10 23:57:35 -07:00
|
|
|
hwHandleVvtCamSignal(TriggerValue::RISE, getTimeNowNt(), 0);
|
2020-01-30 22:23:01 -08:00
|
|
|
|
2021-07-21 17:07:28 -07:00
|
|
|
// second gap - short
|
|
|
|
|
2021-04-06 22:21:28 -07:00
|
|
|
eth.moveTimeForwardUs(MS2US(10));
|
2022-09-10 23:57:35 -07:00
|
|
|
hwHandleVvtCamSignal(TriggerValue::FALL, getTimeNowNt(), 0);
|
2021-04-06 22:21:28 -07:00
|
|
|
eth.moveTimeForwardUs(MS2US(10));
|
2022-09-10 23:57:35 -07:00
|
|
|
hwHandleVvtCamSignal(TriggerValue::RISE, getTimeNowNt(), 0);
|
2020-01-30 22:23:01 -08:00
|
|
|
|
2021-03-25 04:39:23 -07:00
|
|
|
ASSERT_FLOAT_EQ(0, engine->triggerCentral.getVVTPosition(0, 0));
|
2022-09-07 19:24:28 -07:00
|
|
|
ASSERT_EQ(totalRevolutionCountBeforeVvtSync, engine->triggerCentral.triggerState.getCrankSynchronizationCounter());
|
2020-01-30 22:49:10 -08:00
|
|
|
|
2021-07-21 17:07:28 -07:00
|
|
|
// Third gap - long
|
|
|
|
|
|
|
|
eth.moveTimeForwardUs(MS2US(130));
|
2022-09-10 23:57:35 -07:00
|
|
|
hwHandleVvtCamSignal(TriggerValue::FALL, getTimeNowNt(), 0);
|
2021-04-06 22:21:28 -07:00
|
|
|
eth.moveTimeForwardUs(MS2US( 30));
|
2022-09-10 23:57:35 -07:00
|
|
|
hwHandleVvtCamSignal(TriggerValue::RISE, getTimeNowNt(), 0);
|
2020-01-30 22:49:10 -08:00
|
|
|
|
2022-08-12 05:08:23 -07:00
|
|
|
EXPECT_NEAR(290.5f, engine->triggerCentral.getVVTPosition(0, 0), EPS2D);
|
2020-01-31 10:45:15 -08:00
|
|
|
// actually position based on VVT!
|
2022-09-07 19:24:28 -07:00
|
|
|
ASSERT_EQ(totalRevolutionCountBeforeVvtSync + 3, engine->triggerCentral.triggerState.getCrankSynchronizationCounter());
|
2021-04-04 19:48:48 -07:00
|
|
|
|
2022-04-02 23:13:56 -07:00
|
|
|
EXPECT_EQ(40, waveChart.getSize());
|
2020-01-29 22:47:34 -08:00
|
|
|
}
|