2021-11-01 20:33:59 -07:00
|
|
|
#include "pch.h"
|
|
|
|
|
|
|
|
#include "knock_logic.h"
|
|
|
|
|
2022-04-18 05:03:16 -07:00
|
|
|
struct MockKnockController : public KnockController {
|
|
|
|
float getKnockThreshold() const override {
|
|
|
|
// Knock threshold of 20dBv
|
|
|
|
return 20;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2021-11-01 20:33:59 -07:00
|
|
|
TEST(Knock, Retards) {
|
2021-11-16 13:52:11 -08:00
|
|
|
EngineTestHelper eth(TEST_ENGINE);
|
2021-11-01 20:33:59 -07:00
|
|
|
|
|
|
|
// Aggression of 10%
|
2022-04-28 05:16:02 -07:00
|
|
|
engineConfiguration->knockRetardAggression = 10;
|
2021-11-01 20:33:59 -07:00
|
|
|
// Maximum 8 degrees retarded
|
2021-11-17 00:54:21 -08:00
|
|
|
engineConfiguration->knockRetardMaximum = 8;
|
2021-11-01 20:33:59 -07:00
|
|
|
|
2022-04-18 05:03:16 -07:00
|
|
|
MockKnockController dut;
|
|
|
|
dut.onFastCallback();
|
2021-11-01 20:33:59 -07:00
|
|
|
|
|
|
|
// No retard unless we knock
|
|
|
|
ASSERT_FLOAT_EQ(dut.getKnockRetard(), 0);
|
|
|
|
|
|
|
|
// Send some weak knocks, should yield no response
|
|
|
|
for (size_t i = 0; i < 10; i++) {
|
|
|
|
dut.onKnockSenseCompleted(0, 10, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
EXPECT_FLOAT_EQ(dut.getKnockRetard(), 0);
|
|
|
|
|
|
|
|
// Send a strong knock!
|
|
|
|
dut.onKnockSenseCompleted(0, 30, 0);
|
|
|
|
|
|
|
|
// Should retard 10% of the distance between current timing and "maximum"
|
|
|
|
EXPECT_FLOAT_EQ(dut.getKnockRetard(), 2);
|
|
|
|
|
|
|
|
// Send tons of strong knocks, make sure we don't go over the configured limit
|
|
|
|
for (size_t i = 0; i < 100; i++) {
|
|
|
|
dut.onKnockSenseCompleted(0, 30, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
EXPECT_FLOAT_EQ(dut.getKnockRetard(), 8);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(Knock, Reapply) {
|
2021-11-16 13:52:11 -08:00
|
|
|
EngineTestHelper eth(TEST_ENGINE);
|
2021-11-01 20:33:59 -07:00
|
|
|
|
2022-04-18 05:03:16 -07:00
|
|
|
MockKnockController dut;
|
|
|
|
dut.onFastCallback();
|
2021-11-01 20:33:59 -07:00
|
|
|
|
|
|
|
// Aggression of 10%
|
2022-04-28 05:16:02 -07:00
|
|
|
engineConfiguration->knockRetardAggression = 10;
|
2021-11-01 20:33:59 -07:00
|
|
|
// Maximum 8 degrees retarded
|
2021-11-17 00:54:21 -08:00
|
|
|
engineConfiguration->knockRetardMaximum = 8;
|
2021-11-01 20:33:59 -07:00
|
|
|
// Apply 1 degree/second
|
2022-04-28 05:16:02 -07:00
|
|
|
engineConfiguration->knockRetardReapplyRate = 1;
|
2021-11-01 20:33:59 -07:00
|
|
|
|
|
|
|
// Send a strong knock!
|
|
|
|
dut.onKnockSenseCompleted(0, 30, 0);
|
|
|
|
|
|
|
|
// Should retard 10% of the distance between current timing and "maximum"
|
|
|
|
EXPECT_FLOAT_EQ(dut.getKnockRetard(), 2);
|
|
|
|
|
|
|
|
constexpr auto fastPeriodSec = FAST_CALLBACK_PERIOD_MS / 1000.0f;
|
|
|
|
|
|
|
|
// call the fast callback, should reapply 1 degree * callback period
|
2022-04-18 05:03:16 -07:00
|
|
|
dut.onFastCallback();
|
2021-11-01 20:33:59 -07:00
|
|
|
EXPECT_FLOAT_EQ(dut.getKnockRetard(), 2 - 1.0f * fastPeriodSec);
|
|
|
|
|
|
|
|
// 10 updates total
|
|
|
|
for (size_t i = 0; i < 9; i++) {
|
2022-04-18 05:03:16 -07:00
|
|
|
dut.onFastCallback();
|
2021-11-01 20:33:59 -07:00
|
|
|
}
|
|
|
|
EXPECT_FLOAT_EQ(dut.getKnockRetard(), 2 - 10 * 1.0f * fastPeriodSec);
|
|
|
|
|
|
|
|
// Spend a long time without knock
|
|
|
|
for (size_t i = 0; i < 1000; i++) {
|
2022-04-18 05:03:16 -07:00
|
|
|
dut.onFastCallback();
|
2021-11-01 20:33:59 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
// Should have no knock retard
|
|
|
|
EXPECT_FLOAT_EQ(dut.getKnockRetard(), 0);
|
|
|
|
}
|