2020-05-17 12:56:37 -07:00
|
|
|
#include "log_field.h"
|
2020-10-15 13:00:13 -07:00
|
|
|
#include "buffered_writer.h"
|
2020-05-17 12:56:37 -07:00
|
|
|
|
|
|
|
#include <gmock/gmock.h>
|
|
|
|
|
2020-10-15 13:00:13 -07:00
|
|
|
using ::testing::_;
|
2020-05-17 12:56:37 -07:00
|
|
|
using ::testing::ElementsAre;
|
2020-10-15 13:00:13 -07:00
|
|
|
using ::testing::StrictMock;
|
|
|
|
|
|
|
|
class MockWriter : public Writer {
|
|
|
|
public:
|
|
|
|
MOCK_METHOD(size_t, write, (const char* buffer, size_t count), (override));
|
|
|
|
MOCK_METHOD(size_t, flush, (), (override));
|
|
|
|
};
|
2020-05-17 12:56:37 -07:00
|
|
|
|
|
|
|
TEST(BinaryLogField, FieldHeader) {
|
|
|
|
scaled_channel<int8_t, 10> channel;
|
2023-01-20 18:01:40 -08:00
|
|
|
LogField field(channel, "name", "units", 2, "category");
|
2020-05-17 12:56:37 -07:00
|
|
|
|
2023-01-20 18:01:40 -08:00
|
|
|
char buffer[89];
|
2020-10-15 13:00:13 -07:00
|
|
|
StrictMock<MockWriter> bufWriter;
|
2023-01-20 18:01:40 -08:00
|
|
|
EXPECT_CALL(bufWriter, write(_, 89))
|
2020-10-15 13:00:13 -07:00
|
|
|
.WillOnce([&] (const char* buf, size_t count) {
|
|
|
|
memcpy(buffer, buf, count);
|
|
|
|
return 0;
|
|
|
|
});
|
2020-05-17 12:56:37 -07:00
|
|
|
|
2023-01-20 18:01:40 -08:00
|
|
|
// Should write 89 bytes
|
2020-10-15 13:00:13 -07:00
|
|
|
field.writeHeader(bufWriter);
|
2020-05-17 12:56:37 -07:00
|
|
|
|
|
|
|
// Expect correctly written header
|
|
|
|
EXPECT_THAT(buffer, ElementsAre(
|
|
|
|
1, // type: int8_t
|
|
|
|
// name - 34 bytes, 0 padded
|
|
|
|
'n', 'a', 'm', 'e', 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
|
|
// units - 10 bytes, 0 padded
|
|
|
|
'u', 'n', 'i', 't', 's', 0, 0, 0, 0, 0,
|
|
|
|
// display style: float
|
|
|
|
0,
|
|
|
|
// Scale = 0.1 (float)
|
|
|
|
0x3d, 0xcc, 0xcc, 0xcd,
|
|
|
|
// Transform - we always use 0
|
|
|
|
0, 0, 0, 0,
|
|
|
|
// Digits - 2, as configured
|
2023-01-20 18:01:40 -08:00
|
|
|
2,
|
|
|
|
'c', 'a', 't', 'e', 'g', 'o', 'r', 'y', 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0
|
2020-05-17 12:56:37 -07:00
|
|
|
));
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(BinaryLogField, Value) {
|
|
|
|
scaled_channel<uint32_t, 1> testValue = 12345678;
|
|
|
|
LogField lf(testValue, "test", "unit", 0);
|
|
|
|
|
|
|
|
char buffer[6];
|
|
|
|
memset(buffer, 0xAA, sizeof(buffer));
|
|
|
|
|
|
|
|
// Should write 4 bytes
|
|
|
|
EXPECT_EQ(4, lf.writeData(buffer));
|
|
|
|
|
|
|
|
// Check that big endian data was written, and bytes after weren't touched
|
|
|
|
EXPECT_THAT(buffer, ElementsAre(0x00, 0xbc, 0x61, 0x4e, 0xAA, 0xAA));
|
|
|
|
}
|