2021-08-03 19:05:01 -07:00
|
|
|
#include "pch.h"
|
|
|
|
|
2020-12-04 17:28:48 -08:00
|
|
|
#include "dynoview.h"
|
|
|
|
|
|
|
|
void printResults(DynoView *dut) {
|
|
|
|
#ifdef DBG_TESTS
|
|
|
|
std::cerr.precision(32);
|
|
|
|
std::cerr << "Acceleration m/s " << dut->getAcceleration() << std::endl;
|
|
|
|
std::cerr << "Car force in N " << dut->getEngineForce() << std::endl;
|
|
|
|
std::cerr << "Car power in KW "<< dut->getEnginePower() << std::endl;
|
|
|
|
std::cerr << "Car HP " << dut->getEngineHP() << std::endl;
|
|
|
|
std::cerr << "Car Torque at wheel Nm " << dut->getEngineTorque() << std::endl;
|
|
|
|
#else
|
|
|
|
(void)dut;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
TEST(DynoView, VSS_T1) {
|
2021-11-16 13:52:11 -08:00
|
|
|
EngineTestHelper eth(TEST_ENGINE);
|
2020-12-04 17:28:48 -08:00
|
|
|
|
|
|
|
DynoView dut;
|
|
|
|
|
2021-11-16 13:46:54 -08:00
|
|
|
// Test Speed threshold
|
2020-12-04 17:28:48 -08:00
|
|
|
engineConfiguration->vehicleWeight = 900;
|
|
|
|
eth.moveTimeForwardMs(50);
|
|
|
|
|
2021-08-12 12:16:51 -07:00
|
|
|
Sensor::setMockValue(SensorType::VehicleSpeed, 18.0);
|
2020-12-04 17:28:48 -08:00
|
|
|
dut.update(ICU);
|
|
|
|
|
2021-03-11 21:43:48 -08:00
|
|
|
eth.moveTimeForwardAndInvokeEventsSec(20);
|
2021-08-12 12:16:51 -07:00
|
|
|
Sensor::setMockValue(SensorType::VehicleSpeed, 126.0);
|
2020-12-04 17:28:48 -08:00
|
|
|
dut.update(ICU);
|
|
|
|
|
|
|
|
ASSERT_EQ(1.5, dut.getAcceleration());
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(DynoView, algo) {
|
2021-11-16 13:52:11 -08:00
|
|
|
EngineTestHelper eth(TEST_ENGINE);
|
2020-12-04 17:28:48 -08:00
|
|
|
|
|
|
|
DynoView dut;
|
|
|
|
|
2021-11-16 13:46:54 -08:00
|
|
|
// Test Speed threshold
|
2020-12-04 17:28:48 -08:00
|
|
|
engineConfiguration->vehicleWeight = 900;
|
|
|
|
|
|
|
|
//to capture vss
|
2021-08-12 12:16:51 -07:00
|
|
|
Sensor::setMockValue(SensorType::VehicleSpeed, 35*3.6);
|
2020-12-04 17:28:48 -08:00
|
|
|
dut.update(ICU);
|
|
|
|
|
|
|
|
dut.setAcceleration(1.5);
|
|
|
|
dut.updateHP();
|
|
|
|
|
|
|
|
ASSERT_EQ(1.5, dut.getAcceleration());
|
|
|
|
ASSERT_EQ(1350, dut.getEngineForce());
|
|
|
|
ASSERT_EQ(47, dut.getEnginePower());
|
|
|
|
ASSERT_EQ(63, dut.getEngineHP());
|
|
|
|
|
|
|
|
printResults(&dut);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(DynoView, VSS_fast) {
|
2021-11-16 13:52:11 -08:00
|
|
|
EngineTestHelper eth(TEST_ENGINE);
|
2020-12-04 17:28:48 -08:00
|
|
|
|
|
|
|
DynoView dut;
|
|
|
|
|
2021-11-16 13:46:54 -08:00
|
|
|
// Test Speed threshold
|
2020-12-04 17:28:48 -08:00
|
|
|
engineConfiguration->vehicleWeight = 900; //kg
|
2022-01-20 19:26:05 -08:00
|
|
|
Sensor::setMockValue(SensorType::Rpm, 2200);
|
2020-12-04 17:28:48 -08:00
|
|
|
eth.moveTimeForwardMs(50);
|
|
|
|
|
2021-08-12 12:16:51 -07:00
|
|
|
Sensor::setMockValue(SensorType::VehicleSpeed, 50.0);
|
2020-12-04 17:28:48 -08:00
|
|
|
dut.update(CAN);
|
|
|
|
|
|
|
|
//delay 50ms
|
|
|
|
eth.moveTimeForwardMs(50);
|
2021-08-12 12:16:51 -07:00
|
|
|
Sensor::setMockValue(SensorType::VehicleSpeed, 50.252);
|
2020-12-04 17:28:48 -08:00
|
|
|
dut.update(CAN);
|
|
|
|
|
|
|
|
ASSERT_EQ(1259, dut.getEngineForce());
|
|
|
|
printResults(&dut);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
TEST(DynoView, VSS_Torque) {
|
2021-11-16 13:52:11 -08:00
|
|
|
EngineTestHelper eth(TEST_ENGINE);
|
2020-12-04 17:28:48 -08:00
|
|
|
|
|
|
|
DynoView dut;
|
|
|
|
|
2021-11-16 13:46:54 -08:00
|
|
|
// Test Speed threshold
|
2020-12-04 17:28:48 -08:00
|
|
|
engineConfiguration->vehicleWeight = 900; //kg
|
2022-01-20 19:26:05 -08:00
|
|
|
Sensor::setMockValue(SensorType::Rpm, 2200);
|
2020-12-04 17:28:48 -08:00
|
|
|
eth.moveTimeForwardMs(50);
|
|
|
|
|
2021-08-12 12:16:51 -07:00
|
|
|
Sensor::setMockValue(SensorType::VehicleSpeed, 80.0);
|
2020-12-04 17:28:48 -08:00
|
|
|
dut.update(CAN);
|
|
|
|
|
|
|
|
//delay 50ms
|
|
|
|
eth.moveTimeForwardMs(50);
|
2021-08-12 12:16:51 -07:00
|
|
|
Sensor::setMockValue(SensorType::VehicleSpeed, 80.504);
|
2020-12-04 17:28:48 -08:00
|
|
|
dut.update(CAN);
|
|
|
|
|
|
|
|
ASSERT_EQ(242, dut.getEngineTorque());
|
|
|
|
printResults(&dut);
|
|
|
|
}
|
|
|
|
|