From d884c70db4f2e737294be814b7e287ec0e0f0a16 Mon Sep 17 00:00:00 2001 From: Alex Campbell Date: Fri, 23 Jul 2021 10:56:33 -0400 Subject: [PATCH] Fix #1650, Make state global and limit delay loop. --- modules/cfe_testcase/src/fs_util_test.c | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/modules/cfe_testcase/src/fs_util_test.c b/modules/cfe_testcase/src/fs_util_test.c index f4d17834b..0fee6ebdc 100644 --- a/modules/cfe_testcase/src/fs_util_test.c +++ b/modules/cfe_testcase/src/fs_util_test.c @@ -110,6 +110,8 @@ void TestFileName(void) /* FT helper stub compatible with background file write DataGetter */ bool FS_DataGetter(void *Meta, uint32 RecordNum, void **Buffer, size_t *BufSize) { + *Buffer = NULL; + *BufSize = 0; return true; } @@ -119,6 +121,8 @@ void FS_OnEvent(void *Meta, CFE_FS_FileWriteEvent_t Event, int32 Status, uint32 { } +CFE_FS_FileWriteMetaData_t State; + void TestFileDump(void) { CFE_FS_FileWriteMetaData_t State; @@ -128,24 +132,24 @@ void TestFileDump(void) State.OnEvent = FS_OnEvent; strncpy(State.FileName, "/ram/FT.bin", sizeof(State.FileName)); strncpy(State.Description, "FT", sizeof(State.Description)); + int count = 0; + int MaxWait = 20; UtPrintf("Testing: CFE_FS_BackgroundFileDumpRequest, CFE_FS_BackgroundFileDumpIsPending"); UtAssert_INT32_EQ(CFE_FS_BackgroundFileDumpIsPending(&State), false); UtAssert_INT32_EQ(CFE_FS_BackgroundFileDumpRequest(&State), CFE_SUCCESS); - - State.IsPending = true; UtAssert_INT32_EQ(CFE_FS_BackgroundFileDumpIsPending(&State), true); /* Wait for background task to complete */ - while(CFE_FS_BackgroundFileDumpIsPending(&State)) + while (CFE_FS_BackgroundFileDumpIsPending(&State) && count < MaxWait) { OS_TaskDelay(100); + count++; } UtAssert_INT32_EQ(CFE_FS_BackgroundFileDumpRequest(NULL), CFE_FS_BAD_ARGUMENT); UtAssert_INT32_EQ(CFE_FS_BackgroundFileDumpIsPending(NULL), false); - } void FSUtilTestSetup(void)