rusefi/unit_tests/tests/ignition_injection/test_fuel_wall_wetting.cpp

97 lines
2.8 KiB
C++
Raw Normal View History

/*
* @file test_fuel_wall_wetting.cpp
*
* See also test_accel_enrichment.cpp
*
* @date Oct 16, 2019
2020-01-07 21:02:40 -08:00
* @author Andrey Belomutskiy, (c) 2012-2020
*/
#include "pch.h"
struct MockWallController : public IWallFuelController {
MOCK_METHOD(bool, getEnable, (), (const, override));
MOCK_METHOD(float, getAlpha, (), (const, override));
MOCK_METHOD(float, getBeta, (), (const, override));
};
2019-10-16 19:10:38 -07:00
TEST(fuel, testWallWettingEnrichmentMath) {
EngineTestHelper eth(engine_type_e::FORD_ASPIRE_1996);
MockWallController wallController;
// WW is enabled!
EXPECT_CALL(wallController, getEnable()).WillRepeatedly(Return(true));
// 1/2 of fuel remains on walls
EXPECT_CALL(wallController, getAlpha()).WillRepeatedly(Return(0.5f));
// 1/4 of fuel is lands on walls
EXPECT_CALL(wallController, getBeta()).WillRepeatedly(Return(0.25f));
// install our mock in to the engine
engine->engineModules.get<WallFuelController>().set(&wallController);
2020-07-20 00:04:05 -07:00
WallFuel wallFuel;
2019-10-16 19:10:38 -07:00
// each invocation of 'adjust' changes WallWetting internal state
EXPECT_NEAR(1.3333, wallFuel.adjust(1), EPS4D);
EXPECT_NEAR(1.1111, wallFuel.adjust(1), EPS4D);
EXPECT_NEAR(1.0370, wallFuel.adjust(1), EPS4D);
EXPECT_NEAR(1.0123, wallFuel.adjust(1), EPS4D);
// get to steady state
for (size_t i = 0; i < 50; i++) {
wallFuel.adjust(1);
}
EXPECT_NEAR(1, wallFuel.adjust(1), EPS4D);
// now run half the fuel
EXPECT_NEAR(0.3333, wallFuel.adjust(0.5), EPS4D);
EXPECT_NEAR(0.4444, wallFuel.adjust(0.5), EPS4D);
EXPECT_NEAR(0.4815, wallFuel.adjust(0.5), EPS4D);
EXPECT_NEAR(0.4938, wallFuel.adjust(0.5), EPS4D);
for (size_t i = 0; i < 50; i++) {
wallFuel.adjust(0.5);
}
EXPECT_NEAR(0.5, wallFuel.adjust(0.5), EPS4D);
2019-10-16 19:10:38 -07:00
}
2019-10-16 19:10:38 -07:00
TEST(fuel, testWallWettingEnrichmentScheduling) {
EngineTestHelper eth(engine_type_e::FORD_ASPIRE_1996);
engineConfiguration->isFasterEngineSpinUpEnabled = false;
2019-10-16 19:10:38 -07:00
setCrankOperationMode();
2019-10-16 19:10:38 -07:00
eth.setTriggerType(trigger_type_e::TT_HALF_MOON);
2019-10-16 19:10:38 -07:00
eth.fireTriggerEvents2(/* count */ 4, 25 /* ms */);
2022-01-20 19:58:12 -08:00
ASSERT_EQ( 1200, Sensor::getOrZero(SensorType::Rpm)) << "RPM";
2019-10-16 19:10:38 -07:00
2019-10-16 21:06:54 -07:00
int expectedInvocationCounter = 1;
for (int i = 0; i < 4; i++) {
2023-10-12 20:15:54 -07:00
ASSERT_EQ(expectedInvocationCounter, engine->injectionEvents.elements[i].getWallFuel().invocationCounter);
2019-10-16 21:06:54 -07:00
}
// Cylinder 5 doesn't exist - shouldn't have been called!
2023-10-12 20:15:54 -07:00
ASSERT_EQ(0, engine->injectionEvents.elements[5].getWallFuel().invocationCounter);
eth.engine.periodicFastCallback();
eth.engine.periodicFastCallback();
eth.engine.periodicFastCallback();
2019-10-16 21:06:54 -07:00
// still same 1 per cylinder - wall wetting is NOT invoked from 'periodicFastCallback'
for (int i = 0; i < 4; i++) {
2023-10-12 20:15:54 -07:00
ASSERT_EQ(expectedInvocationCounter, engine->injectionEvents.elements[i].getWallFuel().invocationCounter);
2019-10-16 21:06:54 -07:00
}
// Cylinder 5 doesn't exist - shouldn't have been called!
2023-10-12 20:15:54 -07:00
ASSERT_EQ(0, engine->injectionEvents.elements[5].getWallFuel().invocationCounter);
}