-
kongr45gpen authoredkongr45gpen authored
ErrorHandler.cpp 4.22 KiB
#include <catch2/catch.hpp>
#include <ErrorHandler.hpp>
#include "Services/ServiceTests.hpp"
TEST_CASE("Error: Failed Acceptance", "[errors]") {
Message failedMessage(38, 32, Message::TC, 47);
ErrorHandler::reportError(failedMessage, ErrorHandler::MessageTooShort);
REQUIRE(ServiceTests::hasOneMessage());
Message report = ServiceTests::get(0);
// Check that a TM[1,2] message was returned
CHECK(report.serviceType == 1);
CHECK(report.messageType == 2);
CHECK(report.packetType == Message::TM);
REQUIRE(report.dataSize == 6);
CHECK(report.readBits(3) == CCSDS_PACKET_VERSION);
CHECK(report.readBits(1) == static_cast<uint16_t>(Message::TC));
CHECK(report.readBits(1) == 0);
CHECK(report.readBits(11) == 47);
CHECK(report.readBits(2) == ECSS_SEQUENCE_FLAGS);
CHECK(report.readBits(14) == failedMessage.packetSequenceCount);
CHECK(report.readEnum16() == ErrorHandler::MessageTooShort);
}
TEST_CASE("Error: Failed Execution Start", "[errors]") {
Message failedMessage(38, 32, Message::TC, 56);
ErrorHandler::reportError(failedMessage, ErrorHandler::UnknownExecutionStartError);
REQUIRE(ServiceTests::hasOneMessage());
Message report = ServiceTests::get(0);
// Check that a TM[1,3] message was returned
CHECK(report.serviceType == 1);
CHECK(report.messageType == 4);
CHECK(report.packetType == Message::TM);
REQUIRE(report.dataSize == 6);
CHECK(report.readBits(3) == CCSDS_PACKET_VERSION);
CHECK(report.readBits(1) == static_cast<uint16_t>(Message::TC));
CHECK(report.readBits(1) == 0);
CHECK(report.readBits(11) == 56);
CHECK(report.readBits(2) == ECSS_SEQUENCE_FLAGS);
CHECK(report.readBits(14) == failedMessage.packetSequenceCount);
CHECK(report.readEnum16() == ErrorHandler::UnknownExecutionStartError);
}
TEST_CASE("Error: Failed Execution Progress", "[errors]") {
Message failedMessage(38, 32, Message::TC, 56);
ErrorHandler::reportProgressError(failedMessage, ErrorHandler::UnknownExecutionProgressError, 0);
REQUIRE(ServiceTests::hasOneMessage());
Message report = ServiceTests::get(0);
// Check that a TM[1,6] message was returned
CHECK(report.serviceType == 1);
CHECK(report.messageType == 6);
CHECK(report.packetType == Message::TM);
REQUIRE(report.dataSize == 7);
CHECK(report.readBits(3) == CCSDS_PACKET_VERSION);
CHECK(report.readBits(1) == static_cast<uint16_t>(Message::TC));
CHECK(report.readBits(1) == 0);
CHECK(report.readBits(11) == 56);
CHECK(report.readBits(2) == ECSS_SEQUENCE_FLAGS);
CHECK(report.readBits(14) == failedMessage.packetSequenceCount);
CHECK(report.readEnum16() == ErrorHandler::UnknownExecutionProgressError);
CHECK(report.readByte() == 0); // stepID
}
TEST_CASE("Error: Failed Execution Completion", "[errors]") {
Message failedMessage(38, 32, Message::TC, 56);
ErrorHandler::reportError(failedMessage, ErrorHandler::UnknownExecutionCompletionError);
REQUIRE(ServiceTests::hasOneMessage());
Message report = ServiceTests::get(0);
// Check that a TM[1,8] message was returned
CHECK(report.serviceType == 1);
CHECK(report.messageType == 8);
CHECK(report.packetType == Message::TM);
REQUIRE(report.dataSize == 6);
CHECK(report.readBits(3) == CCSDS_PACKET_VERSION);
CHECK(report.readBits(1) == static_cast<uint16_t>(Message::TC));
CHECK(report.readBits(1) == 0);
CHECK(report.readBits(11) == 56);
CHECK(report.readBits(2) == ECSS_SEQUENCE_FLAGS);
CHECK(report.readBits(14) == failedMessage.packetSequenceCount);
CHECK(report.readEnum16() == ErrorHandler::UnknownExecutionCompletionError);
}
TEST_CASE("Error: Failed Routing", "[errors]") {
Message failedMessage(38, 32, Message::TC, 71);
ErrorHandler::reportError(failedMessage, ErrorHandler::UnknownRoutingError);
REQUIRE(ServiceTests::hasOneMessage());
Message report = ServiceTests::get(0);
// Check that a TM[1,8] message was returned
CHECK(report.serviceType == 1);
CHECK(report.messageType == 10);
CHECK(report.packetType == Message::TM);
REQUIRE(report.dataSize == 6);
CHECK(report.readBits(3) == CCSDS_PACKET_VERSION);
CHECK(report.readBits(1) == static_cast<uint16_t>(Message::TC));
CHECK(report.readBits(1) == 0);
CHECK(report.readBits(11) == 71);
CHECK(report.readBits(2) == ECSS_SEQUENCE_FLAGS);
CHECK(report.readBits(14) == failedMessage.packetSequenceCount);
CHECK(report.readEnum16() == ErrorHandler::UnknownRoutingError);
}