continue tests
This commit is contained in:
parent
2e4cdb7366
commit
7b97c8a182
@ -319,6 +319,13 @@ ReturnValue_t cfdp::DestHandler::startTransaction(MetadataPduReader& reader, Met
|
|||||||
params.sourceFileName = tp.sourceName.data();
|
params.sourceFileName = tp.sourceName.data();
|
||||||
params.msgsToUserArray = dynamic_cast<MessageToUserTlv*>(userTlvVec.data());
|
params.msgsToUserArray = dynamic_cast<MessageToUserTlv*>(userTlvVec.data());
|
||||||
params.msgsToUserLen = info.getOptionsLen();
|
params.msgsToUserLen = info.getOptionsLen();
|
||||||
|
FilesystemParams fparams(tp.destName.data());
|
||||||
|
// TODO: Filesystem errors?
|
||||||
|
if (dp.user.vfs.fileExists(fparams)) {
|
||||||
|
dp.user.vfs.truncateFile(fparams);
|
||||||
|
} else {
|
||||||
|
dp.user.vfs.createFile(fparams);
|
||||||
|
}
|
||||||
dp.user.metadataRecvdIndication(params);
|
dp.user.metadataRecvdIndication(params);
|
||||||
return OK;
|
return OK;
|
||||||
}
|
}
|
||||||
|
@ -14,6 +14,8 @@ class EofPduCreator : public FileDirectiveCreator {
|
|||||||
ReturnValue_t serialize(uint8_t** buffer, size_t* size, size_t maxSize,
|
ReturnValue_t serialize(uint8_t** buffer, size_t* size, size_t maxSize,
|
||||||
Endianness streamEndianness) const override;
|
Endianness streamEndianness) const override;
|
||||||
|
|
||||||
|
using FileDirectiveCreator::serialize;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
EofInfo& info;
|
EofInfo& info;
|
||||||
};
|
};
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
|
|
||||||
#include "fsfw/cfdp.h"
|
#include "fsfw/cfdp.h"
|
||||||
#include "fsfw/cfdp/pdu/MetadataPduCreator.h"
|
#include "fsfw/cfdp/pdu/MetadataPduCreator.h"
|
||||||
|
#include "fsfw/cfdp/pdu/EofPduCreator.h"
|
||||||
#include "mocks/AcceptsTmMock.h"
|
#include "mocks/AcceptsTmMock.h"
|
||||||
#include "mocks/EventReportingProxyMock.h"
|
#include "mocks/EventReportingProxyMock.h"
|
||||||
#include "mocks/FilesystemMock.h"
|
#include "mocks/FilesystemMock.h"
|
||||||
@ -63,21 +64,33 @@ TEST_CASE("CFDP Dest Handler", "[cfdp]") {
|
|||||||
std::string destNameString = "hello-cpy.txt";
|
std::string destNameString = "hello-cpy.txt";
|
||||||
StringLv srcName(srcNameString);
|
StringLv srcName(srcNameString);
|
||||||
StringLv destName(destNameString);
|
StringLv destName(destNameString);
|
||||||
|
FileSize cfdpFileSize(0);
|
||||||
MetadataInfo info(false, cfdp::ChecksumTypes::NULL_CHECKSUM, size, srcName, destName);
|
MetadataInfo info(false, cfdp::ChecksumTypes::NULL_CHECKSUM, size, srcName, destName);
|
||||||
auto seqNum = TransactionSeqNum(UnsignedByteField<uint16_t>(1));
|
auto seqNum = TransactionSeqNum(UnsignedByteField<uint16_t>(1));
|
||||||
PduConfig conf(remoteId, localId, TransmissionModes::UNACKNOWLEDGED, seqNum);
|
PduConfig conf(remoteId, localId, TransmissionModes::UNACKNOWLEDGED, seqNum);
|
||||||
MetadataPduCreator metadataPdu(conf, info);
|
MetadataPduCreator metadataCreator(conf, info);
|
||||||
store_address_t storeId;
|
store_address_t storeId;
|
||||||
uint8_t* ptr;
|
uint8_t* ptr;
|
||||||
CHECK(tcStore.getFreeElement(&storeId, metadataPdu.getSerializedSize(), &ptr) == OK);
|
REQUIRE(tcStore.getFreeElement(&storeId, metadataCreator.getSerializedSize(), &ptr) == OK);
|
||||||
size_t serLen = 0;
|
size_t serLen = 0;
|
||||||
CHECK(metadataPdu.serialize(ptr, serLen, metadataPdu.getSerializedSize()) == OK);
|
REQUIRE(metadataCreator.serialize(ptr, serLen, metadataCreator.getSerializedSize()) == OK);
|
||||||
PacketInfo packetInfo(metadataPdu.getPduType(), metadataPdu.getDirectiveCode(), storeId);
|
PacketInfo packetInfo(metadataCreator.getPduType(), metadataCreator.getDirectiveCode(), storeId);
|
||||||
packetInfoList.push_back(packetInfo);
|
packetInfoList.push_back(packetInfo);
|
||||||
destHandler.performStateMachine();
|
destHandler.performStateMachine();
|
||||||
CHECK(res.result == OK);
|
REQUIRE(res.result == OK);
|
||||||
CHECK(res.callStatus == CallStatus::CALL_AGAIN);
|
REQUIRE(res.callStatus == CallStatus::CALL_AGAIN);
|
||||||
|
// Assert that the packet was deleted after handling
|
||||||
|
REQUIRE(not tcStore.hasDataAtId(storeId));
|
||||||
destHandler.performStateMachine();
|
destHandler.performStateMachine();
|
||||||
|
REQUIRE(fsMock.fileMap.find("hello-cpy.txt") != fsMock.fileMap.end());
|
||||||
|
REQUIRE(res.result == OK);
|
||||||
|
REQUIRE(res.callStatus == CallStatus::CALL_AFTER_DELAY);
|
||||||
|
REQUIRE(res.state == CfdpStates::BUSY_CLASS_1_NACKED);
|
||||||
|
REQUIRE(res.step == DestHandler::TransactionStep::RECEIVING_FILE_DATA_PDUS);
|
||||||
|
EofInfo eofInfo(cfdp::ConditionCode::NO_ERROR, 0, cfdpFileSize);
|
||||||
|
EofPduCreator eofCreator(conf, eofInfo);
|
||||||
|
REQUIRE(tcStore.getFreeElement(&storeId, eofCreator.getSerializedSize(), &ptr) == OK);
|
||||||
|
REQUIRE(eofCreator.serialize(ptr, serLen, eofCreator.getSerializedSize()) == OK);
|
||||||
}
|
}
|
||||||
|
|
||||||
SECTION("Small File Transfer") {}
|
SECTION("Small File Transfer") {}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user