rusefi-full/unit_tests/tests/ignition_injection/test_fuel_computer.cpp

81 lines
2.3 KiB
C++

#include "engine_test_helper.h"
// sneaky...
#define protected public
#include "fuel_computer.h"
#include "mocks.h"
#include "gtest/gtest.h"
using ::testing::FloatEq;
class MockFuelComputer : public FuelComputerBase {
public:
MOCK_METHOD(float, getStoichiometricRatio, (), (const, override));
MOCK_METHOD(float, getTargetLambda, (int rpm, float load), (const, override));
MOCK_METHOD(float, getTargetLambdaLoadAxis, (float defaultLoad), (const, override));
};
TEST(FuelComputer, getCycleFuel) {
WITH_ENGINE_TEST_HELPER(TEST_ENGINE);
MockFuelComputer dut;
INJECT_ENGINE_REFERENCE(&dut);
EXPECT_CALL(dut, getTargetLambdaLoadAxis(FloatEq(0.8f)))
.WillOnce(Return(0.8f));
EXPECT_CALL(dut, getStoichiometricRatio())
.WillOnce(Return(3.0f));
EXPECT_CALL(dut, getTargetLambda(1000, FloatEq(0.8f)))
.WillOnce(Return(5.0f));
auto result = dut.getCycleFuel(7.0f, 1000, 0.8f);
EXPECT_FLOAT_EQ(result, 7.0f / (5 * 3));
}
TEST(FuelComputer, LambdaLookup) {
MockVp3d lambdaTable;
FuelComputer dut(lambdaTable);
EXPECT_CALL(lambdaTable, getValue(1500, FloatEq(0.7f)))
.WillOnce(Return(0.85f));
EXPECT_FLOAT_EQ(dut.getTargetLambda(1500, 0.7f), 0.85f);
}
TEST(FuelComputer, FlexFuel) {
WITH_ENGINE_TEST_HELPER(TEST_ENGINE);
MockVp3d lambdaTable;
FuelComputer dut(lambdaTable);
INJECT_ENGINE_REFERENCE(&dut);
// easier values for testing
engineConfiguration->stoichRatioPrimary = 150;
engineConfiguration->stoichRatioSecondary = 100;
// No sensor -> returns primary
Sensor::resetMockValue(SensorType::FuelEthanolPercent);
EXPECT_FLOAT_EQ(15.0f, dut.getStoichiometricRatio());
// E0 -> primary afr
Sensor::setMockValue(SensorType::FuelEthanolPercent, 0);
EXPECT_FLOAT_EQ(15.0f, dut.getStoichiometricRatio());
// E50 -> half way between
Sensor::setMockValue(SensorType::FuelEthanolPercent, 50);
EXPECT_FLOAT_EQ(12.5f, dut.getStoichiometricRatio());
// E100 -> secondary afr
Sensor::setMockValue(SensorType::FuelEthanolPercent, 100);
EXPECT_FLOAT_EQ(10.0f, dut.getStoichiometricRatio());
// E(-10) -> clamp to primary
Sensor::setMockValue(SensorType::FuelEthanolPercent, -10);
EXPECT_FLOAT_EQ(15.0f, dut.getStoichiometricRatio());
// E110 -> clamp to secondary
Sensor::setMockValue(SensorType::FuelEthanolPercent, 110);
EXPECT_FLOAT_EQ(10.0f, dut.getStoichiometricRatio());
}