2022-07-26 13:59:09 +02:00
|
|
|
#include <catch2/catch_test_macros.hpp>
|
|
|
|
|
2022-07-26 16:49:46 +02:00
|
|
|
#include "fsfw/ipc/QueueFactory.h"
|
2022-07-26 17:41:10 +02:00
|
|
|
#include "fsfw/storagemanager/LocalPool.h"
|
2022-07-26 19:08:12 +02:00
|
|
|
#include "fsfw/storagemanager/PoolManager.h"
|
2024-12-12 16:15:02 +01:00
|
|
|
#include "mock/AcceptsTmMock.h"
|
|
|
|
#include "mock/CdsShortTimestamperMock.h"
|
|
|
|
#include "mock/InternalErrorReporterMock.h"
|
|
|
|
#include "mock/MessageQueueMock.h"
|
|
|
|
#include "mock/PusDistributorMock.h"
|
|
|
|
#include "mock/PusServiceBaseMock.h"
|
|
|
|
#include "mock/PusVerificationReporterMock.h"
|
2022-07-26 13:59:09 +02:00
|
|
|
|
2022-07-26 14:10:24 +02:00
|
|
|
TEST_CASE("Pus Service Base", "[pus-service-base]") {
|
2022-07-26 18:46:28 +02:00
|
|
|
uint16_t apid = 2;
|
2022-07-26 14:10:24 +02:00
|
|
|
auto verificationReporter = PusVerificationReporterMock();
|
2024-12-12 16:15:02 +01:00
|
|
|
auto msgQueue = MessageQueueMock(1, MessageQueueIF::NO_QUEUE);
|
2022-07-26 16:49:46 +02:00
|
|
|
auto tmReceiver = AcceptsTmMock(2);
|
2022-07-26 18:46:28 +02:00
|
|
|
auto psbParams = PsbParams(0, apid, 17);
|
2022-07-26 17:41:10 +02:00
|
|
|
|
|
|
|
LocalPool::LocalPoolConfig cfg = {{5, 32}, {2, 64}};
|
|
|
|
LocalPool pool(objects::NO_OBJECT, cfg);
|
|
|
|
|
2022-07-26 16:49:46 +02:00
|
|
|
psbParams.verifReporter = &verificationReporter;
|
|
|
|
psbParams.reqQueue = &msgQueue;
|
|
|
|
psbParams.tmReceiver = &tmReceiver;
|
2022-07-26 17:41:10 +02:00
|
|
|
psbParams.tcPool = &pool;
|
2022-07-26 16:49:46 +02:00
|
|
|
auto psb = PsbMock(psbParams);
|
2022-07-26 17:41:10 +02:00
|
|
|
|
|
|
|
store_address_t storeId;
|
|
|
|
TmTcMessage tmtcMsg;
|
|
|
|
|
|
|
|
// Components to create valid PUS packets
|
|
|
|
auto packetId = PacketId(ccsds::PacketType::TC, true, 0x02);
|
|
|
|
auto spParams =
|
|
|
|
SpacePacketParams(packetId, PacketSeqCtrl(ccsds::SequenceFlags::UNSEGMENTED, 0x34), 0x00);
|
|
|
|
auto pusParams = PusTcParams(17, 1);
|
|
|
|
PusTcCreator creator(spParams, pusParams);
|
|
|
|
|
2022-08-16 01:08:26 +02:00
|
|
|
REQUIRE(psb.initialize() == returnvalue::OK);
|
2022-07-26 16:49:46 +02:00
|
|
|
|
|
|
|
SECTION("State") {
|
|
|
|
REQUIRE(psb.getIdentifier() == 17);
|
|
|
|
REQUIRE(psb.getObjectId() == 0);
|
2022-07-26 18:46:28 +02:00
|
|
|
REQUIRE(psb.getRequestQueue() == msgQueue.getId());
|
|
|
|
auto psbParamsLocal = psb.getParams();
|
|
|
|
REQUIRE(psbParamsLocal.errReporter == nullptr);
|
2022-07-26 16:49:46 +02:00
|
|
|
}
|
|
|
|
|
2022-07-26 17:41:10 +02:00
|
|
|
SECTION("Perform Service") {
|
|
|
|
REQUIRE(psb.performServiceCallCnt == 0);
|
2022-08-16 01:08:26 +02:00
|
|
|
REQUIRE(psb.performOperation(0) == returnvalue::OK);
|
2022-07-26 17:41:10 +02:00
|
|
|
REQUIRE(psb.performServiceCallCnt == 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
SECTION("Send Request with Successful Handling") {
|
|
|
|
REQUIRE(psb.performServiceCallCnt == 0);
|
|
|
|
uint8_t* dataPtr;
|
2022-08-16 01:08:26 +02:00
|
|
|
REQUIRE(pool.getFreeElement(&storeId, creator.getSerializedSize(), &dataPtr) ==
|
|
|
|
returnvalue::OK);
|
2022-07-27 21:29:05 +02:00
|
|
|
size_t serLen = 0;
|
2022-08-16 01:08:26 +02:00
|
|
|
REQUIRE(creator.serializeBe(dataPtr, serLen, creator.getSerializedSize()) == returnvalue::OK);
|
2022-07-26 17:41:10 +02:00
|
|
|
tmtcMsg.setStorageId(storeId);
|
|
|
|
msgQueue.addReceivedMessage(tmtcMsg);
|
2022-08-16 01:08:26 +02:00
|
|
|
REQUIRE(psb.performOperation(0) == returnvalue::OK);
|
2022-07-26 17:41:10 +02:00
|
|
|
uint8_t subservice = 0;
|
|
|
|
REQUIRE(psb.getAndPopNextSubservice(subservice));
|
|
|
|
REQUIRE(subservice == 1);
|
|
|
|
REQUIRE(psb.performServiceCallCnt == 1);
|
|
|
|
// PSB should take care of freeing the pool slot
|
|
|
|
REQUIRE(not pool.hasDataAtId(storeId));
|
|
|
|
REQUIRE(verificationReporter.successCallCount() == 1);
|
|
|
|
REQUIRE(verificationReporter.failCallCount() == 0);
|
|
|
|
auto verifParams = verificationReporter.getNextSuccessCallParams();
|
|
|
|
REQUIRE(verifParams.tcPacketId == creator.getPacketIdRaw());
|
|
|
|
REQUIRE(verifParams.tcPsc == creator.getPacketSeqCtrlRaw());
|
|
|
|
}
|
|
|
|
|
|
|
|
SECTION("Send Request with Failed Handling") {
|
|
|
|
uint8_t* dataPtr;
|
2022-08-16 01:08:26 +02:00
|
|
|
REQUIRE(pool.getFreeElement(&storeId, creator.getSerializedSize(), &dataPtr) ==
|
|
|
|
returnvalue::OK);
|
2022-07-27 21:29:05 +02:00
|
|
|
size_t serLen = 0;
|
2022-08-16 01:08:26 +02:00
|
|
|
REQUIRE(creator.serializeBe(dataPtr, serLen, creator.getSerializedSize()) == returnvalue::OK);
|
2022-07-26 17:41:10 +02:00
|
|
|
tmtcMsg.setStorageId(storeId);
|
2022-07-26 16:49:46 +02:00
|
|
|
msgQueue.addReceivedMessage(tmtcMsg);
|
2022-07-26 17:41:10 +02:00
|
|
|
psb.makeNextHandleReqCallFail(3);
|
2022-08-16 01:08:26 +02:00
|
|
|
REQUIRE(psb.performOperation(0) == returnvalue::OK);
|
2022-07-26 17:41:10 +02:00
|
|
|
uint8_t subservice = 0;
|
|
|
|
REQUIRE(psb.getAndPopNextSubservice(subservice));
|
|
|
|
REQUIRE(subservice == 1);
|
|
|
|
REQUIRE(psb.performServiceCallCnt == 1);
|
|
|
|
// PSB should take care of freeing the pool slot
|
|
|
|
REQUIRE(not pool.hasDataAtId(storeId));
|
|
|
|
REQUIRE(verificationReporter.successCallCount() == 0);
|
|
|
|
REQUIRE(verificationReporter.failCallCount() == 1);
|
|
|
|
auto verifParams = verificationReporter.getNextFailCallParams();
|
|
|
|
REQUIRE(verifParams.tcPacketId == creator.getPacketIdRaw());
|
|
|
|
REQUIRE(verifParams.tcPsc == creator.getPacketSeqCtrlRaw());
|
2022-07-26 16:49:46 +02:00
|
|
|
}
|
2022-07-26 18:46:28 +02:00
|
|
|
|
|
|
|
SECTION("Invalid Packet Sent") {
|
|
|
|
tmtcMsg.setStorageId(store_address_t::invalid());
|
|
|
|
msgQueue.addReceivedMessage(tmtcMsg);
|
2022-08-16 01:08:26 +02:00
|
|
|
REQUIRE(psb.performOperation(0) == returnvalue::OK);
|
2022-07-26 18:46:28 +02:00
|
|
|
REQUIRE(verificationReporter.failCallCount() == 1);
|
|
|
|
auto verifParams = verificationReporter.getNextFailCallParams();
|
|
|
|
REQUIRE(verifParams.tcPacketId == 0);
|
|
|
|
REQUIRE(verifParams.tcPsc == 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
SECTION("Set Verif Reporter") {
|
|
|
|
auto verificationReporter2 = PusVerificationReporterMock();
|
|
|
|
psb.setVerificationReporter(verificationReporter2);
|
|
|
|
auto& p = psb.getParams();
|
|
|
|
REQUIRE(p.verifReporter == &verificationReporter2);
|
|
|
|
}
|
|
|
|
|
|
|
|
SECTION("Set Request Queue") {
|
2024-12-12 16:15:02 +01:00
|
|
|
auto msgQueueMock = MessageQueueMock(2, MessageQueueIF::NO_QUEUE);
|
2022-07-26 18:46:28 +02:00
|
|
|
psb.setRequestQueue(msgQueueMock);
|
|
|
|
auto& p = psb.getParams();
|
|
|
|
REQUIRE(p.reqQueue == &msgQueueMock);
|
|
|
|
}
|
|
|
|
|
|
|
|
SECTION("Set TM Receiver") {
|
|
|
|
auto tmReceiver2 = AcceptsTmMock(3);
|
|
|
|
psb.setTmReceiver(tmReceiver2);
|
|
|
|
auto& p = psb.getParams();
|
|
|
|
REQUIRE(p.tmReceiver == &tmReceiver2);
|
|
|
|
}
|
|
|
|
|
|
|
|
SECTION("Set TC Store") {
|
|
|
|
LocalPool tcStore2(5, cfg);
|
|
|
|
psb.setTcPool(tcStore2);
|
|
|
|
auto& p = psb.getParams();
|
|
|
|
REQUIRE(p.tcPool == &tcStore2);
|
|
|
|
}
|
|
|
|
|
|
|
|
SECTION("Set error reporter") {
|
|
|
|
auto errReporter = InternalErrorReporterMock();
|
|
|
|
psb.setErrorReporter(errReporter);
|
|
|
|
auto& p = psb.getParams();
|
|
|
|
REQUIRE(p.errReporter == &errReporter);
|
|
|
|
}
|
|
|
|
SECTION("Owner Queue") {
|
|
|
|
// This will cause the initialize function to create a new owner queue
|
|
|
|
psbParams.reqQueue = nullptr;
|
|
|
|
psbParams.objectId = 1;
|
|
|
|
auto mockWithOwnerQueue = PsbMock(psbParams);
|
|
|
|
REQUIRE(mockWithOwnerQueue.getRequestQueue() == MessageQueueIF::NO_QUEUE);
|
2022-08-16 01:08:26 +02:00
|
|
|
REQUIRE(mockWithOwnerQueue.initialize() == returnvalue::OK);
|
2022-07-26 18:46:28 +02:00
|
|
|
REQUIRE(mockWithOwnerQueue.getRequestQueue() != MessageQueueIF::NO_QUEUE);
|
|
|
|
}
|
|
|
|
|
|
|
|
SECTION("TM Store Helper Initializer") {
|
|
|
|
TmStoreHelper storeHelper(0);
|
|
|
|
psb.initializeTmStoreHelper(storeHelper);
|
|
|
|
REQUIRE(storeHelper.getApid() == apid);
|
|
|
|
}
|
|
|
|
|
|
|
|
SECTION("TM Send Helper Initializer") {
|
|
|
|
TmSendHelper sendHelper;
|
|
|
|
psb.initializeTmSendHelper(sendHelper);
|
|
|
|
REQUIRE(sendHelper.getMsgQueue() == &msgQueue);
|
|
|
|
REQUIRE(sendHelper.getDefaultDestination() == msgQueue.getDefaultDestination());
|
|
|
|
}
|
|
|
|
|
2022-07-26 18:58:36 +02:00
|
|
|
SECTION("TM Store And Send Helper Initializer") {
|
|
|
|
TmStoreHelper storeHelper(0);
|
|
|
|
TmSendHelper sendHelper;
|
|
|
|
psb.initializeTmHelpers(sendHelper, storeHelper);
|
|
|
|
REQUIRE(sendHelper.getMsgQueue() == &msgQueue);
|
|
|
|
REQUIRE(sendHelper.getDefaultDestination() == msgQueue.getDefaultDestination());
|
|
|
|
REQUIRE(storeHelper.getApid() == apid);
|
|
|
|
}
|
|
|
|
|
2022-07-26 18:46:28 +02:00
|
|
|
SECTION("TM Send Helper Initializer With Error Reporter") {
|
|
|
|
TmSendHelper sendHelper;
|
|
|
|
auto errReporter = InternalErrorReporterMock();
|
|
|
|
psb.setErrorReporter(errReporter);
|
|
|
|
psb.initializeTmSendHelper(sendHelper);
|
|
|
|
REQUIRE(sendHelper.getMsgQueue() == &msgQueue);
|
|
|
|
REQUIRE(sendHelper.getDefaultDestination() == msgQueue.getDefaultDestination());
|
|
|
|
REQUIRE(sendHelper.getInternalErrorReporter() == &errReporter);
|
|
|
|
}
|
|
|
|
|
|
|
|
SECTION("Auto Initialize PUS Distributor") {
|
|
|
|
psbParams.objectId = 1;
|
|
|
|
object_id_t distributorId = 3;
|
|
|
|
auto psb2 = PsbMock(psbParams);
|
|
|
|
auto pusDistrib = PusDistributorMock(distributorId);
|
|
|
|
PsbMock::setStaticPusDistributor(distributorId);
|
|
|
|
REQUIRE(PsbMock::getStaticPusDistributor() == distributorId);
|
2022-08-16 01:08:26 +02:00
|
|
|
REQUIRE(psb2.initialize() == returnvalue::OK);
|
2022-07-26 18:46:28 +02:00
|
|
|
REQUIRE(pusDistrib.registerCallCount == 1);
|
2022-08-01 14:23:52 +02:00
|
|
|
REQUIRE(pusDistrib.registeredServies.front() == &psb2);
|
2022-07-26 18:46:28 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
SECTION("Auto Initialize Packet Destination") {
|
|
|
|
psbParams.tmReceiver = nullptr;
|
|
|
|
psbParams.objectId = 1;
|
|
|
|
object_id_t destId = 3;
|
|
|
|
auto psb2 = PsbMock(psbParams);
|
|
|
|
auto packetDest = AcceptsTmMock(destId, 2);
|
|
|
|
PsbMock::setStaticTmDest(destId);
|
|
|
|
REQUIRE(PsbMock::getStaticTmDest() == destId);
|
2022-08-16 01:08:26 +02:00
|
|
|
REQUIRE(psb2.initialize() == returnvalue::OK);
|
2022-07-26 18:46:28 +02:00
|
|
|
auto& p = psb2.getParams();
|
|
|
|
REQUIRE(p.tmReceiver == &packetDest);
|
|
|
|
}
|
2022-07-26 18:58:36 +02:00
|
|
|
|
|
|
|
SECTION("Auto Initialize Verification Reporter") {
|
|
|
|
psbParams.verifReporter = nullptr;
|
|
|
|
psbParams.objectId = 1;
|
2022-08-16 17:17:45 +02:00
|
|
|
object_id_t reporterId = objects::VERIFICATION_REPORTER;
|
2022-07-26 18:58:36 +02:00
|
|
|
PusVerificationReporterMock otherReporter(reporterId);
|
|
|
|
auto psb2 = PsbMock(psbParams);
|
2022-08-16 01:08:26 +02:00
|
|
|
REQUIRE(psb2.initialize() == returnvalue::OK);
|
2022-07-26 18:58:36 +02:00
|
|
|
auto& p = psb2.getParams();
|
|
|
|
REQUIRE(p.verifReporter == &otherReporter);
|
|
|
|
}
|
|
|
|
|
2022-07-26 19:08:12 +02:00
|
|
|
SECTION("Auto Initialize TC Pool") {
|
|
|
|
PoolManager tcStoreGlobal(objects::TC_STORE, cfg);
|
|
|
|
psbParams.tcPool = nullptr;
|
|
|
|
psbParams.objectId = 1;
|
|
|
|
auto psb2 = PsbMock(psbParams);
|
2022-08-16 01:08:26 +02:00
|
|
|
REQUIRE(psb2.initialize() == returnvalue::OK);
|
2022-07-26 19:08:12 +02:00
|
|
|
auto& p = psb2.getParams();
|
|
|
|
REQUIRE(p.tcPool == &tcStoreGlobal);
|
|
|
|
}
|
2022-07-26 18:58:36 +02:00
|
|
|
|
2022-07-26 19:08:12 +02:00
|
|
|
SECTION("Invalid Verification Reporter") {
|
|
|
|
psbParams.verifReporter = nullptr;
|
|
|
|
psbParams.objectId = 1;
|
|
|
|
auto psb2 = PsbMock(psbParams);
|
|
|
|
REQUIRE(psb2.initialize() == ObjectManagerIF::CHILD_INIT_FAILED);
|
|
|
|
}
|
|
|
|
|
|
|
|
SECTION("Invalid TC Store") {
|
|
|
|
psbParams.tcPool = nullptr;
|
|
|
|
psbParams.objectId = 1;
|
|
|
|
auto psb2 = PsbMock(psbParams);
|
|
|
|
REQUIRE(psb2.initialize() == ObjectManagerIF::CHILD_INIT_FAILED);
|
|
|
|
}
|
2022-07-26 17:41:10 +02:00
|
|
|
}
|