2022-07-22 16:06:31 +02:00
|
|
|
#ifndef FSFW_TESTS_CDSSHORTTIMESTAMPERMOCK_H
|
|
|
|
#define FSFW_TESTS_CDSSHORTTIMESTAMPERMOCK_H
|
|
|
|
|
|
|
|
#include <array>
|
|
|
|
|
|
|
|
#include "fsfw/timemanager/TimeStamperIF.h"
|
|
|
|
|
2022-07-22 18:22:35 +02:00
|
|
|
class CdsShortTimestamperMock : public TimeStamperIF, public TimeReaderIF {
|
2022-07-22 16:06:31 +02:00
|
|
|
public:
|
|
|
|
unsigned int serializeCallCount = 0;
|
2022-07-22 18:22:35 +02:00
|
|
|
unsigned int deserializeCallCount = 0;
|
|
|
|
ReturnValue_t lastDeserializeResult = HasReturnvaluesIF::RETURN_OK;
|
2022-07-22 16:06:31 +02:00
|
|
|
ReturnValue_t lastSerializeResult = HasReturnvaluesIF::RETURN_OK;
|
|
|
|
unsigned int getSizeCallCount = 0;
|
|
|
|
std::array<uint8_t, 7> valueToStamp{};
|
|
|
|
|
|
|
|
CdsShortTimestamperMock() = default;
|
|
|
|
|
|
|
|
explicit CdsShortTimestamperMock(std::array<uint8_t, 7> valueToStamp)
|
|
|
|
: valueToStamp(valueToStamp) {}
|
|
|
|
|
|
|
|
ReturnValue_t serialize(uint8_t **buffer, size_t *size, size_t maxSize,
|
|
|
|
Endianness streamEndianness) const override {
|
|
|
|
auto &thisNonConst = const_cast<CdsShortTimestamperMock &>(*this);
|
|
|
|
thisNonConst.serializeCallCount += 1;
|
|
|
|
if (*size + getSerializedSize() > maxSize) {
|
|
|
|
thisNonConst.lastSerializeResult = SerializeIF::BUFFER_TOO_SHORT;
|
|
|
|
return lastSerializeResult;
|
|
|
|
}
|
|
|
|
std::copy(valueToStamp.begin(), valueToStamp.end(), *buffer);
|
|
|
|
thisNonConst.lastSerializeResult = HasReturnvaluesIF::RETURN_OK;
|
|
|
|
*buffer += getSerializedSize();
|
|
|
|
*size += getSerializedSize();
|
|
|
|
return lastSerializeResult;
|
|
|
|
}
|
|
|
|
[[nodiscard]] size_t getSerializedSize() const override {
|
|
|
|
auto &thisNonConst = const_cast<CdsShortTimestamperMock &>(*this);
|
|
|
|
thisNonConst.getSizeCallCount += 1;
|
|
|
|
return valueToStamp.size();
|
|
|
|
}
|
|
|
|
ReturnValue_t deSerialize(const uint8_t **buffer, size_t *size,
|
|
|
|
Endianness streamEndianness) override {
|
2022-07-22 18:22:35 +02:00
|
|
|
deserializeCallCount += 1;
|
|
|
|
if (*size < 7) {
|
|
|
|
lastDeserializeResult = SerializeIF::STREAM_TOO_SHORT;
|
|
|
|
return lastDeserializeResult;
|
|
|
|
}
|
|
|
|
std::copy(*buffer, *buffer + getSerializedSize(), valueToStamp.begin());
|
|
|
|
return lastDeserializeResult;
|
2022-07-22 16:06:31 +02:00
|
|
|
}
|
2022-07-22 18:22:35 +02:00
|
|
|
|
2022-07-22 16:06:31 +02:00
|
|
|
[[nodiscard]] size_t getTimestampSize() const override { return getSerializedSize(); }
|
|
|
|
ReturnValue_t addTimeStamp(uint8_t *buffer, uint8_t maxSize) override { return 0; }
|
|
|
|
|
|
|
|
void reset() {
|
|
|
|
serializeCallCount = 0;
|
|
|
|
getSizeCallCount = 0;
|
|
|
|
}
|
2022-07-22 18:22:35 +02:00
|
|
|
ReturnValue_t readTimeStamp(const uint8_t *buffer, size_t maxSize) override {
|
|
|
|
return deSerialize(&buffer, &maxSize, SerializeIF::Endianness::NETWORK);
|
|
|
|
}
|
|
|
|
size_t getTimestampLen() override { return getSerializedSize(); }
|
|
|
|
timeval &getTime() override { return dummyTime; }
|
2022-07-22 16:06:31 +02:00
|
|
|
|
|
|
|
private:
|
2022-07-22 18:22:35 +02:00
|
|
|
timeval dummyTime{};
|
2022-07-22 16:06:31 +02:00
|
|
|
};
|
|
|
|
#endif // FSFW_TESTS_CDSSHORTTIMESTAMPERMOCK_H
|