Commit e68c93dc authored by Don Gagne's avatar Don Gagne

Merge pull request #3133 from DonLakeFlyer/MissionItemFixes

Mission item fixes
parents 99126254 246de5bc
...@@ -203,6 +203,10 @@ bool MissionItem::load(const QJsonObject& json, QString& errorString) ...@@ -203,6 +203,10 @@ bool MissionItem::load(const QJsonObject& json, QString& errorString)
return false; return false;
} }
// Make sure to set these first since they can signal other changes
setFrame((MAV_FRAME)json[_jsonFrameKey].toInt());
setCommand((MAV_CMD)json[_jsonCommandKey].toInt());
QGeoCoordinate coordinate; QGeoCoordinate coordinate;
if (!JsonHelper::toQGeoCoordinate(json[_jsonCoordinateKey], coordinate, true /* altitudeRequired */, errorString)) { if (!JsonHelper::toQGeoCoordinate(json[_jsonCoordinateKey], coordinate, true /* altitudeRequired */, errorString)) {
return false; return false;
...@@ -213,8 +217,6 @@ bool MissionItem::load(const QJsonObject& json, QString& errorString) ...@@ -213,8 +217,6 @@ bool MissionItem::load(const QJsonObject& json, QString& errorString)
setIsCurrentItem(false); setIsCurrentItem(false);
setSequenceNumber(json[_jsonIdKey].toInt()); setSequenceNumber(json[_jsonIdKey].toInt());
setFrame((MAV_FRAME)json[_jsonFrameKey].toInt());
setCommand((MAV_CMD)json[_jsonCommandKey].toInt());
setParam1(json[_jsonParam1Key].toDouble()); setParam1(json[_jsonParam1Key].toDouble());
setParam2(json[_jsonParam2Key].toDouble()); setParam2(json[_jsonParam2Key].toDouble());
setParam3(json[_jsonParam3Key].toDouble()); setParam3(json[_jsonParam3Key].toDouble());
......
...@@ -25,6 +25,7 @@ ...@@ -25,6 +25,7 @@
#include "LinkManager.h" #include "LinkManager.h"
#include "MultiVehicleManager.h" #include "MultiVehicleManager.h"
#include "MissionItem.h" #include "MissionItem.h"
#include "SimpleMissionItem.h"
#if 0 #if 0
const MissionItemTest::TestCase_t MissionItemTest::_rgTestCases[] = { const MissionItemTest::TestCase_t MissionItemTest::_rgTestCases[] = {
...@@ -236,16 +237,10 @@ void MissionItemTest::_testFactSignals(void) ...@@ -236,16 +237,10 @@ void MissionItemTest::_testFactSignals(void)
QCOMPARE(arguments.at(0).toDouble(), 8.0); QCOMPARE(arguments.at(0).toDouble(), 8.0);
} }
void MissionItemTest::_testLoadFromStream(void) void MissionItemTest::_checkExpectedMissionItem(const MissionItem& missionItem)
{ {
MissionItem missionItem;
QString testString("10\t1\t3\t80\t10\t20\t30\t40\t-10\t-20\t-30\t1\r\n");
QTextStream testStream(&testString, QIODevice::ReadOnly);
QVERIFY(missionItem.load(testStream));
QCOMPARE(missionItem.sequenceNumber(), 10); QCOMPARE(missionItem.sequenceNumber(), 10);
QCOMPARE(missionItem.isCurrentItem(), true); QCOMPARE(missionItem.isCurrentItem(), false);
QCOMPARE(missionItem.frame(), (MAV_FRAME)3); QCOMPARE(missionItem.frame(), (MAV_FRAME)3);
QCOMPARE(missionItem.command(), (MAV_CMD)80); QCOMPARE(missionItem.command(), (MAV_CMD)80);
QCOMPARE(missionItem.param1(), 10.0); QCOMPARE(missionItem.param1(), 10.0);
...@@ -258,6 +253,30 @@ void MissionItemTest::_testLoadFromStream(void) ...@@ -258,6 +253,30 @@ void MissionItemTest::_testLoadFromStream(void)
QCOMPARE(missionItem.autoContinue(), true); QCOMPARE(missionItem.autoContinue(), true);
} }
void MissionItemTest::_testLoadFromStream(void)
{
MissionItem missionItem;
QString testString("10\t0\t3\t80\t10\t20\t30\t40\t-10\t-20\t-30\t1\r\n");
QTextStream testStream(&testString, QIODevice::ReadOnly);
QVERIFY(missionItem.load(testStream));
_checkExpectedMissionItem(missionItem);
}
void MissionItemTest::_testSimpleLoadFromStream(void)
{
// We specifically test SimpleMissionItem loading as well since it has additional
// signalling which can affect values.
SimpleMissionItem simpleMissionItem(NULL);
QString testString("10\t0\t3\t80\t10\t20\t30\t40\t-10\t-20\t-30\t1\r\n");
QTextStream testStream(&testString, QIODevice::ReadOnly);
QVERIFY(simpleMissionItem.load(testStream));
_checkExpectedMissionItem(simpleMissionItem.missionItem());
}
void MissionItemTest::_testLoadFromJson(void) void MissionItemTest::_testLoadFromJson(void)
{ {
MissionItem missionItem; MissionItem missionItem;
...@@ -335,18 +354,34 @@ void MissionItemTest::_testLoadFromJson(void) ...@@ -335,18 +354,34 @@ void MissionItemTest::_testLoadFromJson(void)
// Test good load // Test good load
QVERIFY(missionItem.load(jsonObject, errorString)); QVERIFY(missionItem.load(jsonObject, errorString));
QCOMPARE(missionItem.sequenceNumber(), 10); _checkExpectedMissionItem(missionItem);
QCOMPARE(missionItem.isCurrentItem(), false); }
QCOMPARE(missionItem.frame(), (MAV_FRAME)3);
QCOMPARE(missionItem.command(), (MAV_CMD)80); void MissionItemTest::_testSimpleLoadFromJson(void)
QCOMPARE(missionItem.param1(), 10.0); {
QCOMPARE(missionItem.param2(), 20.0); // We specifically test SimpleMissionItem loading as well since it has additional
QCOMPARE(missionItem.param3(), 30.0); // signalling which can affect values.
QCOMPARE(missionItem.param4(), 40.0);
QCOMPARE(missionItem.param5(), -10.0); SimpleMissionItem simpleMissionItem(NULL);
QCOMPARE(missionItem.param6(), -20.0); QString errorString;
QCOMPARE(missionItem.param7(), -30.0); QJsonArray coordinateArray = { -10.0, -20.0, -30.0 };
QCOMPARE(missionItem.autoContinue(), true); QJsonObject jsonObject
{
{ "autoContinue", true },
{ "command", 80 },
{ "frame", 3 },
{ "id", 10 },
{ "param1", 10 },
{ "param2", 20 },
{ "param3", 30 },
{ "param4", 40 },
{ "type", "missionItem" },
{ "coordinate", coordinateArray },
};
QVERIFY(simpleMissionItem.load(jsonObject, errorString));
_checkExpectedMissionItem(simpleMissionItem.missionItem());
} }
void MissionItemTest::_testSaveToJson(void) void MissionItemTest::_testSaveToJson(void)
......
...@@ -26,6 +26,7 @@ ...@@ -26,6 +26,7 @@
#include "UnitTest.h" #include "UnitTest.h"
#include "MultiSignalSpy.h" #include "MultiSignalSpy.h"
#include "MissionItem.h"
/// Unit test for the MissionItem Object /// Unit test for the MissionItem Object
class MissionItemTest : public UnitTest class MissionItemTest : public UnitTest
...@@ -40,8 +41,13 @@ private slots: ...@@ -40,8 +41,13 @@ private slots:
void _testSignals(void); void _testSignals(void);
void _testFactSignals(void); void _testFactSignals(void);
void _testLoadFromStream(void); void _testLoadFromStream(void);
void _testSimpleLoadFromStream(void);
void _testLoadFromJson(void); void _testLoadFromJson(void);
void _testSimpleLoadFromJson(void);
void _testSaveToJson(void); void _testSaveToJson(void);
private:
void _checkExpectedMissionItem(const MissionItem& missionItem);
}; };
#endif #endif
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment