Update package 2 #22
@ -32,8 +32,18 @@ public:
|
|||||||
return readResult;
|
return readResult;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Can be used to suppress commit on destruction.
|
||||||
|
*/
|
||||||
|
void setNoCommitMode(bool commit) {
|
||||||
|
this->noCommit = commit;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Default destructor which will take care of commiting changed values.
|
||||||
|
*/
|
||||||
~PoolReadHelper() {
|
~PoolReadHelper() {
|
||||||
if(readObject != nullptr) {
|
if(readObject != nullptr and not noCommit) {
|
||||||
readObject->commit(timeoutType, mutexTimeout);
|
readObject->commit(timeoutType, mutexTimeout);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -42,6 +52,7 @@ public:
|
|||||||
private:
|
private:
|
||||||
ReadCommitIF* readObject = nullptr;
|
ReadCommitIF* readObject = nullptr;
|
||||||
ReturnValue_t readResult = HasReturnvaluesIF::RETURN_OK;
|
ReturnValue_t readResult = HasReturnvaluesIF::RETURN_OK;
|
||||||
|
bool noCommit = false;
|
||||||
MutexIF::TimeoutType timeoutType = MutexIF::TimeoutType::WAITING;
|
MutexIF::TimeoutType timeoutType = MutexIF::TimeoutType::WAITING;
|
||||||
uint32_t mutexTimeout = 20;
|
uint32_t mutexTimeout = 20;
|
||||||
};
|
};
|
||||||
|
@ -173,7 +173,7 @@ ReturnValue_t LocalPoolDataSetBase::unlockDataPool() {
|
|||||||
ReturnValue_t LocalPoolDataSetBase::serializeLocalPoolIds(uint8_t** buffer,
|
ReturnValue_t LocalPoolDataSetBase::serializeLocalPoolIds(uint8_t** buffer,
|
||||||
size_t* size, size_t maxSize,SerializeIF::Endianness streamEndianness,
|
size_t* size, size_t maxSize,SerializeIF::Endianness streamEndianness,
|
||||||
bool serializeFillCount) const {
|
bool serializeFillCount) const {
|
||||||
// Serialize as uint8_t
|
/* Serialize fill count as uint8_t */
|
||||||
uint8_t fillCount = this->fillCount;
|
uint8_t fillCount = this->fillCount;
|
||||||
if(serializeFillCount) {
|
if(serializeFillCount) {
|
||||||
SerializeAdapter::serialize(&fillCount, buffer, size, maxSize,
|
SerializeAdapter::serialize(&fillCount, buffer, size, maxSize,
|
||||||
|
@ -18,7 +18,40 @@ TEST_CASE("LocalDataSet" , "[LocDataSetTest]") {
|
|||||||
LocalPoolStaticTestDataSet localSet;
|
LocalPoolStaticTestDataSet localSet;
|
||||||
|
|
||||||
SECTION("BasicTest") {
|
SECTION("BasicTest") {
|
||||||
|
/* Test some basic functions */
|
||||||
|
CHECK(localSet.getLocalPoolIdsSerializedSize(false) == 3 * sizeof(lp_id_t));
|
||||||
|
CHECK(localSet.getLocalPoolIdsSerializedSize(true) ==
|
||||||
|
3 * sizeof(lp_id_t) + sizeof(uint8_t));
|
||||||
|
CHECK(localSet.getSid() == lpool::testSid);
|
||||||
|
CHECK(localSet.getCreatorObjectId() == objects::TEST_LOCAL_POOL_OWNER_BASE);
|
||||||
|
size_t maxSize = localSet.getLocalPoolIdsSerializedSize(true);
|
||||||
|
uint8_t localPoolIdBuff[maxSize];
|
||||||
|
/* Skip size field */
|
||||||
|
lp_id_t* lpIds = reinterpret_cast<lp_id_t*>(localPoolIdBuff + 1);
|
||||||
|
size_t serSize = 0;
|
||||||
|
uint8_t *localPoolIdBuffPtr = reinterpret_cast<uint8_t*>(localPoolIdBuff);
|
||||||
|
|
||||||
|
/* Test local pool ID serialization */
|
||||||
|
CHECK(localSet.serializeLocalPoolIds(&localPoolIdBuffPtr, &serSize,
|
||||||
|
maxSize, SerializeIF::Endianness::MACHINE) == retval::CATCH_OK);
|
||||||
|
CHECK(serSize == maxSize);
|
||||||
|
CHECK(localPoolIdBuff[0] == 3);
|
||||||
|
CHECK(lpIds[0] == localSet.localPoolVarUint8.getDataPoolId());
|
||||||
|
CHECK(lpIds[1] == localSet.localPoolVarFloat.getDataPoolId());
|
||||||
|
CHECK(lpIds[2] == localSet.localPoolUint16Vec.getDataPoolId());
|
||||||
|
/* Now serialize without fill count */
|
||||||
|
lpIds = reinterpret_cast<lp_id_t*>(localPoolIdBuff);
|
||||||
|
localPoolIdBuffPtr = localPoolIdBuff;
|
||||||
|
serSize = 0;
|
||||||
|
CHECK(localSet.serializeLocalPoolIds(&localPoolIdBuffPtr, &serSize,
|
||||||
|
maxSize, SerializeIF::Endianness::MACHINE, false) == retval::CATCH_OK);
|
||||||
|
CHECK(serSize == maxSize - sizeof(uint8_t));
|
||||||
|
CHECK(lpIds[0] == localSet.localPoolVarUint8.getDataPoolId());
|
||||||
|
CHECK(lpIds[1] == localSet.localPoolVarFloat.getDataPoolId());
|
||||||
|
CHECK(lpIds[2] == localSet.localPoolUint16Vec.getDataPoolId());
|
||||||
|
|
||||||
{
|
{
|
||||||
|
/* Test read operation. Values should be all zeros */
|
||||||
PoolReadHelper readHelper(&localSet);
|
PoolReadHelper readHelper(&localSet);
|
||||||
REQUIRE(readHelper.getReadResult() == retval::CATCH_OK);
|
REQUIRE(readHelper.getReadResult() == retval::CATCH_OK);
|
||||||
CHECK(not localSet.isValid());
|
CHECK(not localSet.isValid());
|
||||||
@ -31,6 +64,7 @@ TEST_CASE("LocalDataSet" , "[LocDataSetTest]") {
|
|||||||
CHECK(localSet.localPoolUint16Vec.value[2] == 0);
|
CHECK(localSet.localPoolUint16Vec.value[2] == 0);
|
||||||
CHECK(not localSet.localPoolVarUint8.isValid());
|
CHECK(not localSet.localPoolVarUint8.isValid());
|
||||||
|
|
||||||
|
/* Now set new values, commit should be done by read helper automatically */
|
||||||
localSet.localPoolVarUint8 = 232;
|
localSet.localPoolVarUint8 = 232;
|
||||||
localSet.localPoolVarFloat = -2324.322;
|
localSet.localPoolVarFloat = -2324.322;
|
||||||
localSet.localPoolUint16Vec.value[0] = 232;
|
localSet.localPoolUint16Vec.value[0] = 232;
|
||||||
@ -51,6 +85,27 @@ TEST_CASE("LocalDataSet" , "[LocDataSetTest]") {
|
|||||||
CHECK(localSet.localPoolUint16Vec.value[1] == 23923);
|
CHECK(localSet.localPoolUint16Vec.value[1] == 23923);
|
||||||
CHECK(localSet.localPoolUint16Vec.value[2] == 1);
|
CHECK(localSet.localPoolUint16Vec.value[2] == 1);
|
||||||
CHECK(localSet.localPoolVarUint8.isValid());
|
CHECK(localSet.localPoolVarUint8.isValid());
|
||||||
|
|
||||||
|
localSet.setValidityBufferGeneration(false);
|
||||||
|
maxSize = localSet.getSerializedSize();
|
||||||
|
CHECK(maxSize == sizeof(uint8_t) + sizeof(uint16_t) * 3 + sizeof(float));
|
||||||
|
serSize = 0;
|
||||||
|
uint8_t buffer[maxSize];
|
||||||
|
uint8_t* buffPtr = buffer;
|
||||||
|
CHECK(localSet.serialize(&buffPtr, &serSize, maxSize,
|
||||||
|
SerializeIF::Endianness::MACHINE) == retval::CATCH_OK);
|
||||||
|
uint8_t rawUint8 = buffer[0];
|
||||||
|
CHECK(rawUint8 == 232);
|
||||||
|
float rawFloat = 0.0;
|
||||||
|
std::memcpy(&rawFloat, buffer + sizeof(uint8_t), sizeof(float));
|
||||||
|
CHECK(rawFloat == Catch::Approx(-2324.322));
|
||||||
|
|
||||||
|
uint16_t rawUint16Vec[3];
|
||||||
|
std::memcpy(&rawUint16Vec, buffer + sizeof(uint8_t) + sizeof(float),
|
||||||
|
3 * sizeof(uint16_t));
|
||||||
|
CHECK(rawUint16Vec[0] == 232);
|
||||||
|
CHECK(rawUint16Vec[1] == 23923);
|
||||||
|
CHECK(rawUint16Vec[2] == 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Common fault test cases */
|
/* Common fault test cases */
|
||||||
|
Loading…
Reference in New Issue
Block a user