diff --git a/src/Vehicle/SendMavCommandWithSignallingTest.cc b/src/Vehicle/SendMavCommandWithSignallingTest.cc index ff1c26ecd5f..e1b40a4057c 100644 --- a/src/Vehicle/SendMavCommandWithSignallingTest.cc +++ b/src/Vehicle/SendMavCommandWithSignallingTest.cc @@ -38,6 +38,16 @@ void SendMavCommandWithSignallingTest::_testCaseWorker(TestCase_t& testCase) QCOMPARE(spyResult.wait(10000), true); QList arguments = spyResult.takeFirst(); + + // Gimbal controler requests MAVLINK_MSG_ID_GIMBAL_MANAGER_INFORMATION on vehicle connection, + // and that messes with this test, as it receives response to that command instead. So if we + // are taking the response to that MAV_CMD_REQUEST_MESSAGE, we discard it and take the next + while (arguments.at(2).toInt() == MAV_CMD_REQUEST_MESSAGE) { + qDebug() << "Received response to MAV_CMD_REQUEST_MESSAGE(512), ignoring, waiting for: " << testCase.command; + QCOMPARE(spyResult.wait(10000), true); + arguments = spyResult.takeFirst(); + } + QCOMPARE(arguments.count(), 5); QCOMPARE(arguments.at(0).toInt(), vehicle->id()); QCOMPARE(arguments.at(1).toInt(), MAV_COMP_ID_AUTOPILOT1);