Line | Branch | Decision | Exec | Source |
---|---|---|---|---|
1 | // Mitsubishi 4B11 trigger pattern | |||
2 | // Crank: 36-2-1 | |||
3 | // Cam: Single tooth (half moon) | |||
4 | ||||
5 | #include "pch.h" | |||
6 | ||||
7 | #include "engine_csv_reader.h" | |||
8 | ||||
9 | 4 | TEST(real4b11, running) { | ||
10 | extern bool unitTestTaskPrecisionHack; | |||
11 | 1 | unitTestTaskPrecisionHack = true; | ||
12 |
1/1✓ Branch 2 taken 1 time.
|
1 | EngineCsvReader reader(1, /* vvtCount */ 0); | |
13 | ||||
14 |
1/1✓ Branch 1 taken 1 time.
|
1 | reader.open("tests/trigger/resources/4b11-running.csv"); | |
15 |
1/1✓ Branch 2 taken 1 time.
|
1 | EngineTestHelper eth(engine_type_e::TEST_ENGINE); | |
16 | 1 | engineConfiguration->isFasterEngineSpinUpEnabled = true; | ||
17 | 1 | engineConfiguration->alwaysInstantRpm = true; | ||
18 | ||||
19 |
1/1✓ Branch 1 taken 1 time.
|
1 | eth.setTriggerType(trigger_type_e::TT_36_2_1); | |
20 | ||||
21 |
3/3✓ Branch 1 taken 2048 times.
✓ Branch 3 taken 2047 times.
✓ Branch 4 taken 1 time.
|
0/1? Decision couldn't be analyzed.
|
2048 | while (reader.haveMore()) { |
22 |
1/1✓ Branch 1 taken 2047 times.
|
2047 | reader.processLine(ð); | |
23 | ||||
24 | // Expect that all teeth are in the correct spot | |||
25 |
1/1✓ Branch 2 taken 2047 times.
|
2047 | float angleError = getTriggerCentral()->triggerToothAngleError; | |
26 |
3/15✓ Branch 2 taken 2047 times.
✗ Branch 3 not taken.
✓ Branch 4 taken 2047 times.
✗ Branch 5 not taken.
✗ Branch 9 not taken.
✓ Branch 10 taken 2047 times.
✗ Branch 13 not taken.
✗ Branch 16 not taken.
✗ Branch 19 not taken.
✗ Branch 22 not taken.
✗ Branch 26 not taken.
✗ Branch 29 not taken.
✗ Branch 34 not taken.
✗ Branch 38 not taken.
✗ Branch 41 not taken.
|
2047 | EXPECT_TRUE(angleError < 3 && angleError > -3) << "tooth angle of " << angleError << " at timestamp " << (getTimeNowNt() / 1e8); | |
27 | ||||
28 |
1/1✓ Branch 1 taken 2047 times.
|
2047 | reader.assertFirstRpm(1436, 30); | |
29 | } | |||
30 | ||||
31 |
4/9✓ Branch 3 taken 1 time.
✓ Branch 8 taken 1 time.
✗ Branch 13 not taken.
✓ Branch 14 taken 1 time.
✗ Branch 17 not taken.
✗ Branch 22 not taken.
✗ Branch 25 not taken.
✓ Branch 32 taken 1 time.
✗ Branch 33 not taken.
|
1 | ASSERT_EQ(0u, eth.recentWarnings()->getCount()); | |
32 | 1 | } | ||
33 | ||||
34 | 4 | TEST(real4b11, runningDoubledEdge) { | ||
35 | extern bool unitTestTaskPrecisionHack; | |||
36 | 1 | unitTestTaskPrecisionHack = true; | ||
37 |
1/1✓ Branch 2 taken 1 time.
|
1 | EngineCsvReader reader(1, /* vvtCount */ 0); | |
38 | ||||
39 | // This log has an extra duplicate edge at 5.393782 seconds (hand added) | |||
40 |
1/1✓ Branch 1 taken 1 time.
|
1 | reader.open("tests/trigger/resources/4b11-running-doubled-edge.csv"); | |
41 |
1/1✓ Branch 2 taken 1 time.
|
1 | EngineTestHelper eth(engine_type_e::TEST_ENGINE); | |
42 | 1 | engineConfiguration->isFasterEngineSpinUpEnabled = true; | ||
43 | 1 | engineConfiguration->alwaysInstantRpm = true; | ||
44 | ||||
45 |
1/1✓ Branch 1 taken 1 time.
|
1 | eth.setTriggerType(trigger_type_e::TT_36_2_1); | |
46 | ||||
47 |
3/3✓ Branch 1 taken 2050 times.
✓ Branch 3 taken 2049 times.
✓ Branch 4 taken 1 time.
|
0/1? Decision couldn't be analyzed.
|
2050 | while (reader.haveMore()) { |
48 |
1/1✓ Branch 1 taken 2049 times.
|
2049 | reader.processLine(ð); | |
49 |
1/1✓ Branch 1 taken 2049 times.
|
2049 | reader.assertFirstRpm(1436, 30); | |
50 | } | |||
51 | ||||
52 | // Should get a warning for the doubled edge, but NOT one for a trigger error! | |||
53 |
4/9✓ Branch 3 taken 1 time.
✓ Branch 8 taken 1 time.
✗ Branch 13 not taken.
✓ Branch 14 taken 1 time.
✗ Branch 17 not taken.
✗ Branch 22 not taken.
✗ Branch 25 not taken.
✓ Branch 32 taken 1 time.
✗ Branch 33 not taken.
|
1 | ASSERT_EQ(1u, eth.recentWarnings()->getCount()); | |
54 |
4/9✓ Branch 2 taken 1 time.
✓ Branch 7 taken 1 time.
✗ Branch 11 not taken.
✓ Branch 12 taken 1 time.
✗ Branch 15 not taken.
✗ Branch 20 not taken.
✗ Branch 23 not taken.
✓ Branch 30 taken 1 time.
✗ Branch 31 not taken.
|
1 | ASSERT_EQ(ObdCode::CUSTOM_PRIMARY_DOUBLED_EDGE, eth.recentWarnings()->get(0).Code); | |
55 | 1 | } | ||
56 |