2024-05-02 09:12:36 -07:00
|
|
|
#include "pch.h"
|
|
|
|
|
|
|
|
#include "logicdata_csv_reader.h"
|
|
|
|
|
2024-07-04 12:37:43 -07:00
|
|
|
static void runCoyoteIntakeCam(bool invertPrimaryTriggerSignal, int warningCount, int rpm) {
|
2024-05-02 09:12:36 -07:00
|
|
|
CsvReader reader(1, /* vvtCount */ 0);
|
|
|
|
|
|
|
|
reader.open("tests/trigger/resources/ford-coyote-intake-cam.csv");
|
|
|
|
|
|
|
|
EngineTestHelper eth(engine_type_e::TEST_ENGINE);
|
2024-07-04 12:37:43 -07:00
|
|
|
eth.setTriggerType(invertPrimaryTriggerSignal ? trigger_type_e::TT_DEV : trigger_type_e::TT_VVT_FORD_COYOTE);
|
2024-05-02 09:12:36 -07:00
|
|
|
engineConfiguration->isFasterEngineSpinUpEnabled = true;
|
|
|
|
engineConfiguration->alwaysInstantRpm = true;
|
2024-07-04 12:37:43 -07:00
|
|
|
reader.flipOnRead = invertPrimaryTriggerSignal;
|
|
|
|
|
2024-05-02 09:12:36 -07:00
|
|
|
|
2024-07-04 12:37:43 -07:00
|
|
|
printf("Reading intake %d...\n", invertPrimaryTriggerSignal);
|
2024-05-02 09:12:36 -07:00
|
|
|
while (reader.haveMore()) {
|
|
|
|
reader.processLine(ð);
|
|
|
|
}
|
|
|
|
|
2024-07-04 12:37:43 -07:00
|
|
|
ASSERT_EQ( warningCount, eth.recentWarnings()->getCount())<< "warningCounter#intakeCam";
|
|
|
|
ASSERT_EQ( rpm, round(Sensor::getOrZero(SensorType::Rpm)))<< reader.lineIndex();
|
2024-05-02 09:12:36 -07:00
|
|
|
}
|
|
|
|
|
2024-07-04 12:37:43 -07:00
|
|
|
TEST(fordCoyote, intakeCam) {
|
|
|
|
runCoyoteIntakeCam(false, 1, 1093);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(fordCoyote, intakeCamInverted) {
|
|
|
|
runCoyoteIntakeCam(true, 3, 1018);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void runCoyoteExhaustCam(bool invertPrimaryTriggerSignal, int warningCount, int rpm) {
|
2024-05-02 09:12:36 -07:00
|
|
|
CsvReader reader(1, /* vvtCount */ 0);
|
|
|
|
|
|
|
|
reader.open("tests/trigger/resources/ford-coyote-exhaust-cam.csv");
|
|
|
|
|
|
|
|
EngineTestHelper eth(engine_type_e::TEST_ENGINE);
|
2024-07-04 12:37:43 -07:00
|
|
|
eth.setTriggerType(invertPrimaryTriggerSignal ? trigger_type_e::TT_DEV : trigger_type_e::TT_VVT_FORD_COYOTE);
|
2024-05-02 09:12:36 -07:00
|
|
|
engineConfiguration->isFasterEngineSpinUpEnabled = true;
|
2024-07-04 12:37:43 -07:00
|
|
|
reader.flipOnRead = invertPrimaryTriggerSignal;
|
2024-05-02 09:12:36 -07:00
|
|
|
engineConfiguration->alwaysInstantRpm = true;
|
|
|
|
|
2024-07-04 12:37:43 -07:00
|
|
|
printf("Reading exhaust...\n");
|
2024-05-02 09:12:36 -07:00
|
|
|
while (reader.haveMore()) {
|
|
|
|
reader.processLine(ð);
|
|
|
|
}
|
|
|
|
|
2024-07-04 12:37:43 -07:00
|
|
|
ASSERT_EQ(warningCount, eth.recentWarnings()->getCount())<< "warningCounter#exhaustCam";
|
|
|
|
ASSERT_EQ(rpm, round(Sensor::getOrZero(SensorType::Rpm)))<< reader.lineIndex();
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(fordCoyote, exhaustCam) {
|
|
|
|
runCoyoteExhaustCam(false, 1, 1093);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(fordCoyote, exhaustCamInverted) {
|
|
|
|
runCoyoteExhaustCam(true, 2, 1046);
|
2024-05-02 09:12:36 -07:00
|
|
|
}
|