forked from rusefi/rusefi
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathtest_nitrous_afr_condition.cpp
More file actions
97 lines (84 loc) · 3.55 KB
/
Copy pathtest_nitrous_afr_condition.cpp
File metadata and controls
97 lines (84 loc) · 3.55 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
//
// Created by kifir on 11/28/24.
//
#include "pch.h"
#include "engine_configuration_defaults.h"
#include "util/test_base.h"
namespace {
struct AfrConditionTestData {
const std::optional<float> lambda1;
const bool expectedAfrCondition;
const char* const context;
};
class NitrousAfrConditionTest : public TestBase<> {
protected:
static constexpr float TEST_DEFAULT_LAMBDA1 = engine_configuration_defaults::NITROUS_MAXIMUM_AFR / STOICH_RATIO;
static constexpr float TEST_MAXIMUM_AFR = 12.3;
static constexpr float TEST_LAMBDA1 = TEST_MAXIMUM_AFR / STOICH_RATIO;
void checkAfrCondition(const std::vector<AfrConditionTestData>& testData);
};
void NitrousAfrConditionTest::checkAfrCondition(const std::vector<AfrConditionTestData>& testData) {
for (const AfrConditionTestData& item: testData) {
updateLambda1(item.lambda1, &TestBase::periodicSlowCallback);
EXPECT_EQ(getModule<NitrousController>().isNitrousAfrCondition, item.expectedAfrCondition)
<< item.context;
}
}
TEST_F(NitrousAfrConditionTest, checkDefault) {
checkAfrCondition({
{ {}, false, "default" },
{ { 0.0f }, false, "0.0" },
{ { TEST_LAMBDA1 - EPS5D }, false, "TEST_LAMBDA1 - EPS5D" },
{ { TEST_LAMBDA1 }, false, "TEST_LAMBDA1" },
{ { TEST_LAMBDA1 + EPS5D }, false, "TEST_LAMBDA1 + EPS5D" },
});
}
TEST_F(NitrousAfrConditionTest, checkDefaultWithDisabledNitrousControl) {
setUpEngineConfiguration(EngineConfig().setNitrousControlEnabled({ false }));
checkAfrCondition({
{ {}, false, "default" },
{ { 0.0f }, false, "0.0" },
{ { TEST_LAMBDA1 - EPS5D }, false, "TEST_LAMBDA1 - EPS5D" },
{ { TEST_LAMBDA1 }, false, "TEST_LAMBDA1" },
{ { TEST_LAMBDA1 + EPS5D }, false, "TEST_LAMBDA1 + EPS5D" },
});
}
TEST_F(NitrousAfrConditionTest, checkDefaultWithEnabledNitrousControl) {
setUpEngineConfiguration(EngineConfig().setNitrousControlEnabled({ true }));
checkAfrCondition({
{ {}, false, "default" },
{ { 0.0f }, true, "0.0" },
{ { TEST_DEFAULT_LAMBDA1 - EPS5D }, true, "TEST_DEFAULT_LAMBDA1 - EPS5D" },
{ { TEST_DEFAULT_LAMBDA1 }, true, "TEST_DEFAULT_LAMBDA1" },
{ { TEST_DEFAULT_LAMBDA1 + EPS5D }, false, "TEST_DEFAULT_LAMBDA1 + EPS5D" },
});
}
TEST_F(NitrousAfrConditionTest, checkZeroMaximumAfr) {
setUpEngineConfiguration(
EngineConfig()
.setNitrousControlEnabled({ true })
.setNitrousMaximumAfr(0.0f)
);
checkAfrCondition({
{ {}, true, "default" },
{ { 0.0f }, true, "0.0" },
{ { TEST_LAMBDA1 - EPS5D }, true, "TEST_LAMBDA1 - EPS5D" },
{ { TEST_LAMBDA1 }, true, "TEST_LAMBDA1" },
{ { TEST_LAMBDA1 + EPS5D }, true, "TEST_LAMBDA1 + EPS5D" },
});
}
TEST_F(NitrousAfrConditionTest, checkMaximumAfr) {
setUpEngineConfiguration(
EngineConfig()
.setNitrousControlEnabled({ true })
.setNitrousMaximumAfr({ TEST_MAXIMUM_AFR })
);
checkAfrCondition({
{ {}, false, "default" },
{ { 0.0f }, true, "0.0" },
{ { TEST_LAMBDA1 - EPS5D }, true, "TEST_LAMBDA1 - EPS5D" },
{ { TEST_LAMBDA1 }, true, "TEST_LAMBDA1" },
{ { TEST_LAMBDA1 + EPS5D }, false, "TEST_LAMBDA1 + EPS5D" },
});
}
}