2021-08-03 19:05:01 -07:00
|
|
|
#include "pch.h"
|
|
|
|
|
2021-03-14 16:31:46 -07:00
|
|
|
#include "vvt.h"
|
|
|
|
|
|
|
|
using ::testing::StrictMock;
|
|
|
|
using ::testing::Return;
|
|
|
|
|
2022-01-20 19:31:07 -08:00
|
|
|
TEST(Vvt, TestSetPoint) {
|
2023-05-31 22:31:28 -07:00
|
|
|
EngineTestHelper eth(engine_type_e::TEST_ENGINE);
|
2021-03-14 16:31:46 -07:00
|
|
|
|
|
|
|
// Set up a mock target map
|
|
|
|
StrictMock<MockVp3d> targetMap;
|
|
|
|
EXPECT_CALL(targetMap, getValue(4321, 55))
|
|
|
|
.WillOnce(Return(20));
|
|
|
|
|
|
|
|
// Mock necessary inputs
|
|
|
|
engine->engineState.fuelingLoad = 55;
|
2022-01-20 19:31:07 -08:00
|
|
|
Sensor::setMockValue(SensorType::Rpm, 4321);
|
2021-03-14 16:31:46 -07:00
|
|
|
|
2023-10-07 09:34:32 -07:00
|
|
|
VvtController dut(0);
|
2023-07-19 22:16:29 -07:00
|
|
|
dut.init(&targetMap, nullptr);
|
2021-03-14 16:31:46 -07:00
|
|
|
|
|
|
|
// Test dut
|
|
|
|
EXPECT_EQ(20, dut.getSetpoint().value_or(0));
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(Vvt, observePlant) {
|
2023-05-31 22:31:28 -07:00
|
|
|
EngineTestHelper eth(engine_type_e::TEST_ENGINE);
|
2021-03-14 16:31:46 -07:00
|
|
|
|
|
|
|
engine->triggerCentral.vvtPosition[0][0] = 23;
|
|
|
|
|
2023-10-07 09:34:32 -07:00
|
|
|
VvtController dut(0);
|
2023-07-19 22:16:29 -07:00
|
|
|
dut.init(nullptr, nullptr);
|
2021-03-14 16:31:46 -07:00
|
|
|
|
|
|
|
EXPECT_EQ(23, dut.observePlant().value_or(0));
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(Vvt, openLoop) {
|
2023-10-07 09:34:32 -07:00
|
|
|
VvtController dut(0);
|
2021-03-14 16:31:46 -07:00
|
|
|
|
|
|
|
// No open loop for now
|
|
|
|
EXPECT_EQ(dut.getOpenLoop(10), 0);
|
|
|
|
}
|
2022-08-20 17:12:32 -07:00
|
|
|
|
|
|
|
TEST(Vvt, ClosedLoopNotInverted) {
|
2023-05-31 22:31:28 -07:00
|
|
|
EngineTestHelper eth(engine_type_e::TEST_ENGINE);
|
2022-08-20 17:12:32 -07:00
|
|
|
|
2023-10-07 09:54:45 -07:00
|
|
|
VvtController dut(/* second cam on second bank*/3);
|
|
|
|
int camIndex = 1;
|
|
|
|
ASSERT_EQ(dut.getCamIndex(), camIndex);
|
2023-07-19 22:16:29 -07:00
|
|
|
dut.init(nullptr, nullptr);
|
2022-08-20 17:12:32 -07:00
|
|
|
|
2023-10-07 09:54:45 -07:00
|
|
|
engineConfiguration->auxPid[camIndex].pFactor = 1.5f;
|
|
|
|
engineConfiguration->auxPid[camIndex].iFactor = 0;
|
|
|
|
engineConfiguration->auxPid[camIndex].dFactor = 0;
|
|
|
|
engineConfiguration->auxPid[camIndex].offset = 0;
|
2022-08-20 17:12:32 -07:00
|
|
|
|
|
|
|
// Target of 30 with position 20 should yield positive duty, P=1.5 means 15% duty for 10% error
|
|
|
|
EXPECT_EQ(dut.getClosedLoop(30, 20).value_or(0), 15);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(Vvt, ClosedLoopInverted) {
|
2023-05-31 22:31:28 -07:00
|
|
|
EngineTestHelper eth(engine_type_e::TEST_ENGINE);
|
2022-08-20 17:12:32 -07:00
|
|
|
|
2023-10-07 09:54:45 -07:00
|
|
|
VvtController dut(/*first cam on second bank*/2);
|
2023-10-07 09:34:32 -07:00
|
|
|
int camIndex = 0;
|
2023-10-07 09:54:45 -07:00
|
|
|
ASSERT_EQ(dut.getCamIndex(), camIndex);
|
2023-07-19 22:16:29 -07:00
|
|
|
dut.init(nullptr, nullptr);
|
2022-08-20 17:12:32 -07:00
|
|
|
|
|
|
|
engineConfiguration->invertVvtControlIntake = true;
|
2023-10-07 09:34:32 -07:00
|
|
|
engineConfiguration->auxPid[camIndex].pFactor = 1.5f;
|
|
|
|
engineConfiguration->auxPid[camIndex].iFactor = 0;
|
|
|
|
engineConfiguration->auxPid[camIndex].dFactor = 0;
|
|
|
|
engineConfiguration->auxPid[camIndex].offset = 0;
|
2022-08-20 17:12:32 -07:00
|
|
|
|
|
|
|
// Target of -30 with position -20 should yield positive duty, P=1.5 means 15% duty for 10% error
|
|
|
|
EXPECT_EQ(dut.getClosedLoop(-30, -20).value_or(0), 15);
|
|
|
|
}
|