UASUnitTest.cc 10.7 KB
Newer Older
1
#include "UASUnitTest.h"
2
#include <stdio.h>
3
#include <QObject>
4 5 6
UASUnitTest::UASUnitTest()
{
}
7 8
//This function is called after every test
void UASUnitTest::init()
9
{
10
    mav = new MAVLinkProtocol();
11 12
    uas = new UAS(mav, UASID);
    uas->deleteSettings();
13
}
14 15
//this function is called after every test
void UASUnitTest::cleanup()
16
{
17 18
   delete mav;
   mav = NULL;
Jessica's avatar
Jessica committed
19
   if(uas != NULL){
20 21
   delete uas;
   uas = NULL;
Jessica's avatar
Jessica committed
22
   }
23 24 25 26 27 28 29 30 31 32 33 34
}

void UASUnitTest::getUASID_test()
{
    // Test a default ID of zero is assigned
    UAS* uas2 = new UAS(mav);
    QCOMPARE(uas2->getUASID(), 0);
    delete uas2;

    // Test that the chosen ID was assigned at construction
    QCOMPARE(uas->getUASID(), UASID);

35
    // Make sure that no other ID was set
36 37
    QEXPECT_FAIL("", "When you set an ID it does not use the default ID of 0", Continue);
    QCOMPARE(uas->getUASID(), 0);
38 39 40

    // Make sure that ID >= 0
    QCOMPARE(uas->getUASID(), 100);
41

42 43 44 45
}

void UASUnitTest::getUASName_test()
{
46 47
  // Test that the name is build as MAV + ID
  QCOMPARE(uas->getUASName(), "MAV " + QString::number(UASID));
48 49 50 51 52

}

void UASUnitTest::getUpTime_test()
{
53 54 55 56
    UAS* uas2 = new UAS(mav);
    // Test that the uptime starts at zero to a
    // precision of seconds
    QCOMPARE(floor(uas2->getUptime()/1000.0), 0.0);
57

58 59
    // Sleep for three seconds
    QTest::qSleep(3000);
60

61 62 63
    // Test that the up time is computed correctly to a
    // precision of seconds
    QCOMPARE(floor(uas2->getUptime()/1000.0), 3.0);
64

65
    delete uas2;
66 67 68 69
}

void UASUnitTest::getCommunicationStatus_test()
{
70 71
    // Verify that upon construction the Comm status is disconnected
    QCOMPARE(uas->getCommunicationStatus(), static_cast<int>(UASInterface::COMM_DISCONNECTED));
72 73 74 75 76
}

void UASUnitTest::filterVoltage_test()
{
    float verificar=uas->filterVoltage(0.4f);
77 78
    // Verify that upon construction the Comm status is disconnected
    QCOMPARE(verificar, 8.52f);
79 80 81
}
void UASUnitTest:: getAutopilotType_test()
{
82 83 84
    int type = uas->getAutopilotType();
    // Verify that upon construction the autopilot is set to -1
    QCOMPARE(type, -1);
85 86 87
}
void UASUnitTest::setAutopilotType_test()
{
88 89 90
    uas->setAutopilotType(2);
    // Verify that the autopilot is set
    QCOMPARE(uas->getAutopilotType(), 2);
91 92 93 94
}

void UASUnitTest::getStatusForCode_test()
{
95 96 97
    QString state, desc;
    state = "";
    desc = "";
98

99 100
    uas->getStatusForCode(MAV_STATE_UNINIT, state, desc);
    QVERIFY(state == "UNINIT");
101

102 103
    uas->getStatusForCode(MAV_STATE_UNINIT, state, desc);
    QVERIFY(state == "UNINIT");
104

105 106
    uas->getStatusForCode(MAV_STATE_BOOT, state, desc);
    QVERIFY(state == "BOOT");
107

108 109
    uas->getStatusForCode(MAV_STATE_CALIBRATING, state, desc);
    QVERIFY(state == "CALIBRATING");
110

111 112
    uas->getStatusForCode(MAV_STATE_ACTIVE, state, desc);
    QVERIFY(state == "ACTIVE");
113

114 115
    uas->getStatusForCode(MAV_STATE_STANDBY, state, desc);
    QVERIFY(state == "STANDBY");
116

117 118
    uas->getStatusForCode(MAV_STATE_CRITICAL, state, desc);
    QVERIFY(state == "CRITICAL");
119

120 121
    uas->getStatusForCode(MAV_STATE_EMERGENCY, state, desc);
    QVERIFY(state == "EMERGENCY");
122

123 124
    uas->getStatusForCode(MAV_STATE_POWEROFF, state, desc);
    QVERIFY(state == "SHUTDOWN");
125

126 127
    uas->getStatusForCode(5325, state, desc);
    QVERIFY(state == "UNKNOWN");
128

129 130 131 132
}

void UASUnitTest::getLocalX_test()
{
133
   QCOMPARE(uas->getLocalX(), 0.0);
134 135 136
}
void UASUnitTest::getLocalY_test()
{
137
    QCOMPARE(uas->getLocalY(), 0.0);
138 139 140
}
void UASUnitTest::getLocalZ_test()
{
141
    QCOMPARE(uas->getLocalZ(), 0.0);
142 143 144 145 146 147
}
void UASUnitTest::getLatitude_test()
{  QCOMPARE(uas->getLatitude(), 0.0);
}
void UASUnitTest::getLongitude_test()
{
148
    QCOMPARE(uas->getLongitude(), 0.0);
149 150 151
}
void UASUnitTest::getAltitude_test()
{
152
    QCOMPARE(uas->getAltitude(), 0.0);
153 154 155
}
void UASUnitTest::getRoll_test()
{
156
    QCOMPARE(uas->getRoll(), 0.0);
157 158 159
}
void UASUnitTest::getPitch_test()
{
160
    QCOMPARE(uas->getPitch(), 0.0);
161 162 163
}
void UASUnitTest::getYaw_test()
{
164 165
    QCOMPARE(uas->getYaw(), 0.0);
}
166 167

void UASUnitTest::getSelected_test()
168
{
169
    QCOMPARE(uas->getSelected(), false);
170 171
}

172
void UASUnitTest::getSystemType_test()
173 174 175
{    //check that system type is set to MAV_TYPE_GENERIC when initialized
    QCOMPARE(uas->getSystemType(), 0);
    uas->setSystemType(13);
176
    QCOMPARE(uas->getSystemType(), 13);
177 178
}

179
void UASUnitTest::getAirframe_test()
180
{
181
    //when uas is constructed, airframe is set to QGC_AIRFRAME_GENERIC which is 0
182
    QCOMPARE(uas->getAirframe(), 0);
183
}
184

185 186
void UASUnitTest::setAirframe_test()
{
187 188 189 190 191 192 193 194 195 196 197
    //check at construction, that airframe=0 (GENERIC)
    QVERIFY(uas->getAirframe() == 0);

    //check that set airframe works
    uas->setAirframe(11);
    QVERIFY(uas->getAirframe() == 11);

    //check that setAirframe will not assign a number to airframe, that is 
    //not defined in the enum 
    uas->setAirframe(12);
    QVERIFY(uas->getAirframe() == 11);
198
}
199
void UASUnitTest::getWaypointList_test()
200
{
201
    QVector<Waypoint*> kk = uas->getWaypointManager()->getWaypointEditableList();
202 203
    QCOMPARE(kk.count(), 0);

204 205
    Waypoint* wp = new Waypoint(0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,false, false, MAV_FRAME_GLOBAL, MAV_CMD_MISSION_START, "blah");
    uas->getWaypointManager()->addWaypointEditable(wp, true);
206

207
    kk = uas->getWaypointManager()->getWaypointEditableList();
208 209 210
    QCOMPARE(kk.count(), 1);

    wp = new Waypoint();
211
    uas->getWaypointManager()->addWaypointEditable(wp, false);
212

213
    kk = uas->getWaypointManager()->getWaypointEditableList();
214 215 216
    QCOMPARE(kk.count(), 2);

    uas->getWaypointManager()->removeWaypoint(1);
217
    kk = uas->getWaypointManager()->getWaypointEditableList();
218 219 220
    QCOMPARE(kk.count(), 1);

    uas->getWaypointManager()->removeWaypoint(0);
221
    kk = uas->getWaypointManager()->getWaypointEditableList();
222 223 224
    QCOMPARE(kk.count(), 0);

    qDebug()<<"disconnect SIGNAL waypointListChanged";
225

226 227 228 229
}

void UASUnitTest::getWaypoint_test()
{
Jessica's avatar
Jessica committed
230
    Waypoint* wp = new Waypoint(0,5.6,2.0,3.0,0.0,0.0,0.0,0.0,false, false, MAV_FRAME_GLOBAL, MAV_CMD_MISSION_START, "blah");
231

232
    uas->getWaypointManager()->addWaypointEditable(wp, true);
233

234
    QVector<Waypoint*> wpList = uas->getWaypointManager()->getWaypointEditableList();
235 236 237 238

    QCOMPARE(wpList.count(), 1);
    QCOMPARE(static_cast<quint16>(0), static_cast<Waypoint*>(wpList.at(0))->getId());

Jessica's avatar
Jessica committed
239
    Waypoint*  wp3 = new Waypoint(1, 5.6, 2.0, 3.0);
Jessica's avatar
Jessica committed
240
    uas->getWaypointManager()->addWaypointEditable(wp3, true);
Jessica's avatar
Jessica committed
241
    wpList = uas->getWaypointManager()->getWaypointEditableList();
242 243
    Waypoint* wp2 = static_cast<Waypoint*>(wpList.at(0));

Jessica's avatar
Jessica committed
244
    QCOMPARE(wpList.count(), 2);
Jessica's avatar
Jessica committed
245 246 247
    QCOMPARE(wp3->getX(), wp2->getX());
    QCOMPARE(wp3->getY(), wp2->getY());
    QCOMPARE(wp3->getZ(), wp2->getZ());
Jessica's avatar
Jessica committed
248
    QCOMPARE(wpList.at(1)->getId(), static_cast<quint16>(1));
Jessica's avatar
Jessica committed
249 250
    QCOMPARE(wp3->getFrame(), MAV_FRAME_GLOBAL);
    QCOMPARE(wp3->getFrame(), wp2->getFrame());
Jessica's avatar
Jessica committed
251

Jessica's avatar
Jessica committed
252 253
    delete wp3;
    delete wp;
254 255
}

256
void UASUnitTest::signalWayPoint_test()
257
{
Jessica's avatar
Jessica committed
258 259
    QSignalSpy spy(uas->getWaypointManager(), SIGNAL(waypointEditableListChanged()));

Jessica's avatar
Jessica committed
260
    Waypoint* wp = new Waypoint(0,1.0,0.0,0.0,0.0,0.0,0.0,0.0,false, false, MAV_FRAME_GLOBAL, MAV_CMD_MISSION_START, "blah");
261
    uas->getWaypointManager()->addWaypointEditable(wp, true);
262

Jessica's avatar
Jessica committed
263

264
    QCOMPARE(spy.count(), 1); // 1 listChanged for add wayPoint
265 266
    uas->getWaypointManager()->removeWaypoint(0);
    QCOMPARE(spy.count(), 2); // 2 listChanged for remove wayPoint
Jessica's avatar
Jessica committed
267

268 269 270 271 272
    QSignalSpy spyDestroyed(uas->getWaypointManager(), SIGNAL(destroyed()));
    QVERIFY(spyDestroyed.isValid());
    QCOMPARE( spyDestroyed.count(), 0 );

    delete uas;// delete(destroyed) uas for validating
Jessica's avatar
Jessica committed
273
    uas = NULL;
274 275
    QCOMPARE(spyDestroyed.count(), 1);// count destroyed uas should are 1
    uas = new UAS(mav,UASID);
Jessica's avatar
Jessica committed
276
    QSignalSpy spy2(uas->getWaypointManager(), SIGNAL(waypointEditableListChanged()));
277
    QCOMPARE(spy2.count(), 0);
Jessica's avatar
Jessica committed
278
    Waypoint* wp2 = new Waypoint(0,0.0,0.0,0.0,0.0,0.0,0.0,0.0,false, false, MAV_FRAME_GLOBAL, MAV_CMD_MISSION_START, "blah");
279

Jessica's avatar
Jessica committed
280
    uas->getWaypointManager()->addWaypointEditable(wp2, true);
281 282 283
    QCOMPARE(spy2.count(), 1);

    uas->getWaypointManager()->clearWaypointList();
284
    QVector<Waypoint*> wpList = uas->getWaypointManager()->getWaypointEditableList();
285
    QCOMPARE(wpList.count(), 1);
286

Jessica's avatar
Jessica committed
287
    delete wp2;
288 289
}

290
void UASUnitTest::signalUASLink_test()
291
{
292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345
    QSignalSpy spy(uas, SIGNAL(modeChanged(int,QString,QString)));
    uas->setMode(2);
    QCOMPARE(spy.count(), 0);// not solve for UAS not receiving message from UAS

    QSignalSpy spyS(LinkManager::instance(), SIGNAL(newLink(LinkInterface*)));
    SerialLink* link = new SerialLink();
    LinkManager::instance()->add(link);
    LinkManager::instance()->addProtocol(link, mav);
    QCOMPARE(spyS.count(), 1);

    LinkManager::instance()->add(link);
    LinkManager::instance()->addProtocol(link, mav);
    QCOMPARE(spyS.count(), 1);// not add SerialLink, exist in list

    SerialLink* link2 = new SerialLink();
    LinkManager::instance()->add(link2);
    LinkManager::instance()->addProtocol(link2, mav);
    QCOMPARE(spyS.count(), 2);// add SerialLink, not exist in list

    QList<LinkInterface*> links = LinkManager::instance()->getLinks();
    foreach(LinkInterface* link, links)
    {
        qDebug()<< link->getName();
        qDebug()<< QString::number(link->getId());
        qDebug()<< QString::number(link->getNominalDataRate());
        QVERIFY(link != NULL);
        uas->addLink(link);
    }

    SerialLink* ff = static_cast<SerialLink*>(uas->getLinks()->at(0));

    QCOMPARE(ff->isConnected(), false);

    QCOMPARE(ff->isRunning(), false);

    QCOMPARE(ff->isFinished(), false);

    QCOMPARE(links.count(), uas->getLinks()->count());
    QCOMPARE(uas->getLinks()->count(), 2);

    LinkInterface* ff99 = static_cast<LinkInterface*>(links.at(1));
    LinkManager::instance()->removeLink(ff99);

    QCOMPARE(LinkManager::instance()->getLinks().count(), 1);
    QCOMPARE(uas->getLinks()->count(), 2);


    QCOMPARE(static_cast<LinkInterface*>(LinkManager::instance()->getLinks().at(0))->getId(),
             static_cast<LinkInterface*>(uas->getLinks()->at(0))->getId());

    link = new SerialLink();
    LinkManager::instance()->add(link);
    LinkManager::instance()->addProtocol(link, mav);
    QCOMPARE(spyS.count(), 3);
346

347 348
}

349
void UASUnitTest::signalIdUASLink_test()
350
{
351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369
    SerialLink* myLink = new SerialLink();
    myLink->setPortName("COM 17");
    LinkManager::instance()->add(myLink);
    LinkManager::instance()->addProtocol(myLink, mav);

    myLink = new SerialLink();
    myLink->setPortName("COM 18");
    LinkManager::instance()->add(myLink);
    LinkManager::instance()->addProtocol(myLink, mav);

    QCOMPARE(LinkManager::instance()->getLinks().count(), 4);

    QList<LinkInterface*> links = LinkManager::instance()->getLinks();

    LinkInterface* a = static_cast<LinkInterface*>(links.at(2));
    LinkInterface* b = static_cast<LinkInterface*>(links.at(3));

    QCOMPARE(a->getName(), QString("serial port COM 17"));
    QCOMPARE(b->getName(), QString("serial port COM 18"));
370

371
}