aboutsummaryrefslogtreecommitdiff
path: root/src/modules
diff options
context:
space:
mode:
authorDon Gagne <don@thegagnes.com>2014-09-12 10:54:23 -0700
committerDon Gagne <don@thegagnes.com>2014-09-12 10:54:23 -0700
commit46a9f616eba368bb864f4faf8e920dad7fd4ecc5 (patch)
treefb833de277564d2838dd0d21fdb1b1f90501057c /src/modules
parentdbefa77943fb7f05f391933e82aa4ddf35755851 (diff)
downloadpx4-firmware-46a9f616eba368bb864f4faf8e920dad7fd4ecc5.tar.gz
px4-firmware-46a9f616eba368bb864f4faf8e920dad7fd4ecc5.tar.bz2
px4-firmware-46a9f616eba368bb864f4faf8e920dad7fd4ecc5.zip
Fix List command test
Return order from List command is not repeatable
Diffstat (limited to 'src/modules')
-rw-r--r--src/modules/mavlink/mavlink_tests/mavlink_ftp_test.cpp46
1 files changed, 30 insertions, 16 deletions
diff --git a/src/modules/mavlink/mavlink_tests/mavlink_ftp_test.cpp b/src/modules/mavlink/mavlink_tests/mavlink_ftp_test.cpp
index c9566f7db..022041c74 100644
--- a/src/modules/mavlink/mavlink_tests/mavlink_ftp_test.cpp
+++ b/src/modules/mavlink/mavlink_tests/mavlink_ftp_test.cpp
@@ -168,27 +168,20 @@ bool MavlinkFtpTest::_list_test(void)
char response2[] = "Ddev|Detc|Dfs|Dobj";
struct _testCase {
- const char *dir;
- char *response;
- bool success;
+ const char *dir; ///< Directory to run List command on
+ char *response; ///< Expected response entries from List command
+ int response_count; ///< Number of directories that should be returned
+ bool success; ///< true: List command should succeed, false: List command should fail
};
struct _testCase rgTestCases[] = {
- { "/bogus", nullptr, false },
- { "/etc/unit_test_data/mavlink_tests", response1, true },
- { "/", response2, true },
+ { "/bogus", nullptr, 0, false },
+ { "/etc/unit_test_data/mavlink_tests", response1, 4, true },
+ { "/", response2, 4, true },
};
for (size_t i=0; i<sizeof(rgTestCases)/sizeof(rgTestCases[0]); i++) {
const struct _testCase *test = &rgTestCases[i];
- uint8_t expected_data_size = strlen(test->response) + 1;
-
- char *ptr = strtok (test->response, "|");
- while (ptr != nullptr)
- {
- ptr = strtok (nullptr, "|");
- }
-
payload.opcode = MavlinkFTP::kCmdListDirectory;
payload.offset = 0;
@@ -203,8 +196,29 @@ bool MavlinkFtpTest::_list_test(void)
if (test->success) {
ut_compare("Didn't get Ack back", reply->opcode, MavlinkFTP::kRspAck);
- ut_compare("Incorrect payload size", reply->size, expected_data_size);
- ut_compare("Ack payload contents incorrect", memcmp(reply->data, test->response, expected_data_size), 0);
+ ut_compare("Incorrect payload size", reply->size, strlen(test->response) + 1);
+
+ // The return order of directories from the List command is not repeatable. So we can't do a direct comparison
+ // to a hardcoded return result string.
+
+ // Convert null terminators to seperator char so we can use strok to parse returned data
+ for (uint8_t j=0; j<reply->size-1; j++) {
+ if (reply->data[j] == 0) {
+ reply->data[j] = '|';
+ }
+ }
+
+ // Loop over returned directory entries trying to find then in the response list
+ char *dir;
+ int response_count = 0;
+ dir = strtok((char *)&reply->data[0], "|");
+ while (dir != nullptr) {
+ ut_assert("Returned directory not found in expected response", strstr(test->response, dir));
+ response_count++;
+ dir = strtok(nullptr, "|");
+ }
+
+ ut_compare("Incorrect number of directory entires returned", test->response_count, response_count);
} else {
ut_compare("Didn't get Nak back", reply->opcode, MavlinkFTP::kRspNak);
ut_compare("Incorrect payload size", reply->size, 2);