2021-08-03 19:05:01 -07:00
|
|
|
#include "pch.h"
|
2021-11-10 04:29:40 -08:00
|
|
|
#include "tunerstudio.h"
|
2020-11-15 09:27:47 -08:00
|
|
|
#include "tunerstudio_io.h"
|
|
|
|
|
2021-03-28 06:06:36 -07:00
|
|
|
static uint8_t st5TestBuffer[16000];
|
|
|
|
|
2021-11-10 04:29:40 -08:00
|
|
|
class BufferTsChannel : public TsChannelBase {
|
2021-03-28 06:06:36 -07:00
|
|
|
public:
|
2021-11-10 04:29:40 -08:00
|
|
|
BufferTsChannel() : TsChannelBase("Test") { }
|
2021-09-18 12:33:14 -07:00
|
|
|
|
2021-10-18 16:59:08 -07:00
|
|
|
void write(const uint8_t* buffer, size_t size, bool /*isLastWriteInTransaction*/) override {
|
2021-03-28 06:06:36 -07:00
|
|
|
memcpy(&st5TestBuffer[writeIdx], buffer, size);
|
|
|
|
writeIdx += size;
|
|
|
|
}
|
|
|
|
|
|
|
|
size_t readTimeout(uint8_t* buffer, size_t size, int timeout) override {
|
|
|
|
// nothing to do here
|
|
|
|
return size;
|
|
|
|
}
|
|
|
|
|
|
|
|
void reset() {
|
|
|
|
writeIdx = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
size_t writeIdx = 0;
|
|
|
|
};
|
2020-11-15 09:27:47 -08:00
|
|
|
|
|
|
|
#define CODE 2
|
|
|
|
#define PAYLOAD "123"
|
|
|
|
#define SIZE strlen(PAYLOAD)
|
|
|
|
|
2021-11-10 04:29:40 -08:00
|
|
|
static void assertCrcPacket(BufferTsChannel& dut) {
|
2021-03-28 06:06:36 -07:00
|
|
|
ASSERT_EQ(dut.writeIdx, SIZE + 7);
|
2020-11-15 09:27:47 -08:00
|
|
|
|
|
|
|
// todo: proper uint16 comparison
|
|
|
|
ASSERT_EQ(st5TestBuffer[0], 0);
|
|
|
|
ASSERT_EQ(st5TestBuffer[1], SIZE + 1);
|
|
|
|
|
|
|
|
ASSERT_EQ(st5TestBuffer[2], CODE);
|
|
|
|
|
|
|
|
ASSERT_EQ(memcmp(&st5TestBuffer[3], PAYLOAD, SIZE), 0);
|
|
|
|
|
|
|
|
|
|
|
|
// todo: proper uint32 comparison
|
|
|
|
ASSERT_EQ(st5TestBuffer[6], 252);
|
|
|
|
ASSERT_EQ(st5TestBuffer[7], 68);
|
|
|
|
ASSERT_EQ(st5TestBuffer[8], 173);
|
|
|
|
ASSERT_EQ(st5TestBuffer[9], 87);
|
2020-11-15 09:36:07 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST(binary, testWriteCrc) {
|
2021-11-10 04:29:40 -08:00
|
|
|
BufferTsChannel test;
|
2020-11-15 09:27:47 -08:00
|
|
|
|
2020-11-15 13:59:02 -08:00
|
|
|
// Let it pick which impl (small vs large) to use
|
2021-03-28 06:06:36 -07:00
|
|
|
test.reset();
|
2021-02-19 17:48:21 -08:00
|
|
|
test.writeCrcPacket(CODE, (const uint8_t*)PAYLOAD, SIZE);
|
2021-03-28 06:06:36 -07:00
|
|
|
assertCrcPacket(test);
|
2020-11-15 09:36:07 -08:00
|
|
|
|
2020-11-15 13:59:02 -08:00
|
|
|
// Force the large impl
|
2021-03-28 06:06:36 -07:00
|
|
|
test.reset();
|
2021-02-19 17:48:21 -08:00
|
|
|
test.writeCrcPacket(CODE, (const uint8_t*)PAYLOAD, SIZE);
|
2021-03-28 06:06:36 -07:00
|
|
|
assertCrcPacket(test);
|
2020-11-15 09:36:07 -08:00
|
|
|
|
2020-11-15 13:59:02 -08:00
|
|
|
// Force the small impl
|
2021-03-28 06:06:36 -07:00
|
|
|
test.reset();
|
2021-02-19 17:48:21 -08:00
|
|
|
test.writeCrcPacket(CODE, (const uint8_t*)PAYLOAD, SIZE);
|
2021-03-28 06:06:36 -07:00
|
|
|
assertCrcPacket(test);
|
2020-11-15 09:27:47 -08:00
|
|
|
}
|
2021-11-10 04:29:40 -08:00
|
|
|
|
|
|
|
TEST(TunerstudioCommands, writeChunkEngineConfig) {
|
|
|
|
WITH_ENGINE_TEST_HELPER(TEST_ENGINE);
|
|
|
|
MockTsChannel channel;
|
|
|
|
|
|
|
|
uint8_t* configBytes = reinterpret_cast<uint8_t*>(config);
|
|
|
|
|
|
|
|
// Contains zero before the write
|
|
|
|
configBytes[100] = 0;
|
|
|
|
EXPECT_EQ(configBytes[100], 0);
|
|
|
|
|
|
|
|
// two step - writes to the engineConfiguration section require a burn
|
|
|
|
uint8_t val = 50;
|
2021-11-16 01:15:29 -08:00
|
|
|
handleWriteChunkCommand(&channel, TS_CRC, 100, 1, &val);
|
2021-11-10 04:29:40 -08:00
|
|
|
|
|
|
|
// hasn't changed yet
|
|
|
|
EXPECT_EQ(configBytes[100], 0);
|
|
|
|
|
2021-11-16 01:15:29 -08:00
|
|
|
handleBurnCommand(&channel, TS_CRC);
|
2021-11-10 04:29:40 -08:00
|
|
|
|
|
|
|
EXPECT_EQ(configBytes[100], 50);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(TunerstudioCommands, writeChunkOutsideEngineConfig) {
|
|
|
|
WITH_ENGINE_TEST_HELPER(TEST_ENGINE);
|
|
|
|
MockTsChannel channel;
|
|
|
|
|
|
|
|
uint8_t* configBytes = reinterpret_cast<uint8_t*>(config);
|
|
|
|
|
|
|
|
size_t offset = sizeof(engine_configuration_s) + 100;
|
|
|
|
|
|
|
|
// Contains zero before the write
|
|
|
|
configBytes[offset] = 0;
|
|
|
|
EXPECT_EQ(configBytes[offset], 0);
|
|
|
|
|
|
|
|
// one step - writes past engineConfiguration don't need a burn
|
|
|
|
uint8_t val = 50;
|
2021-11-16 01:15:29 -08:00
|
|
|
handleWriteChunkCommand(&channel, TS_CRC, offset, 1, &val);
|
2021-11-10 04:29:40 -08:00
|
|
|
|
|
|
|
EXPECT_EQ(configBytes[offset], 50);
|
|
|
|
}
|