mirror of
https://github.com/subsurface/subsurface.git
synced 2025-01-19 14:25:27 +00:00
bd9a443793
Refactored the parsing logic to make it more solid (no more guessing) and more flexible (support more formats). Added a test for checking that. Fixed a few warnings. [Dirk Hohndel: some changes to coding style] Signed-off-by: Patrick Valsecchi <patrick@thus.ch> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
95 lines
2.3 KiB
C++
95 lines
2.3 KiB
C++
#include <dive.h>
|
|
#include "testgpscoords.h"
|
|
|
|
//unit under test
|
|
extern bool parseGpsText(const QString &gps_text, double *latitude, double *longitude);
|
|
|
|
|
|
void TestGpsCoords::testISO6709DParse()
|
|
{
|
|
testParseOK("52°49'02.388\"N 1°36'17.388\"E",
|
|
coord2double(52, 49, 2.388), coord2double(1, 36, 17.388));
|
|
}
|
|
|
|
void TestGpsCoords::testNegativeISO6709DParse()
|
|
{
|
|
testParseOK("52°49'02.388\"S 1°36'17.388\"W",
|
|
coord2double(-52, -49, -2.388), coord2double(-1, -36, -17.388));
|
|
}
|
|
|
|
void TestGpsCoords::testSpaceISO6709DParse()
|
|
{
|
|
testParseOK("52 ° 49 ' 02.388 \" N 1 ° 36 ' 17.388 \" E",
|
|
coord2double(52, 49, 2.388), coord2double(1, 36, 17.388));
|
|
}
|
|
|
|
void TestGpsCoords::testSecondsParse()
|
|
{
|
|
testParseOK("N52°49'02.388\" E1°36'17.388\"",
|
|
coord2double(52, 49, 2.388), coord2double(1, 36, 17.388));
|
|
}
|
|
|
|
void TestGpsCoords::testSpaceSecondsParse()
|
|
{
|
|
testParseOK(" N 52 ° 49 ' 02.388 \" E 1 ° 36 ' 17.388 \"",
|
|
coord2double(52, 49, 2.388), coord2double(1, 36, 17.388));
|
|
}
|
|
|
|
void TestGpsCoords::testNegativeSecondsParse()
|
|
{
|
|
testParseOK("-52°49'02.388\" -1°36'17.388\"",
|
|
coord2double(-52, -49, -2.388), coord2double(-1, -36, -17.388));
|
|
}
|
|
|
|
void TestGpsCoords::testMinutesParse()
|
|
{
|
|
testParseOK("N52°49.03' E1d36.23'",
|
|
coord2double(52, 49.03), coord2double(1, 36.23));
|
|
}
|
|
|
|
void TestGpsCoords::testSpaceMinutesParse()
|
|
{
|
|
testParseOK(" N 52 ° 49.03 ' E 1 ° 36.23 ' ",
|
|
coord2double(52, 49.03), coord2double(1, 36.23));
|
|
}
|
|
|
|
void TestGpsCoords::testMinutesInversedParse()
|
|
{
|
|
testParseOK("2° 53.836' N 73° 32.839' E",
|
|
coord2double(2, 53.836), coord2double(73, 32.839));
|
|
}
|
|
|
|
void TestGpsCoords::testDecimalParse()
|
|
{
|
|
testParseOK("N52.83° E1.61",
|
|
coord2double(52.83), coord2double(1.61));
|
|
}
|
|
|
|
void TestGpsCoords::testDecimalInversedParse()
|
|
{
|
|
testParseOK("52.83N 1.61E",
|
|
coord2double(52.83), coord2double(1.61));
|
|
}
|
|
|
|
void TestGpsCoords::testSpaceDecimalParse()
|
|
{
|
|
testParseOK(" N 52.83 E 1.61 ",
|
|
coord2double(52.83), coord2double(1.61));
|
|
}
|
|
|
|
|
|
void TestGpsCoords::testParseOK(const QString &txt, double expectedLat,
|
|
double expectedLon)
|
|
{
|
|
double actualLat, actualLon;
|
|
QVERIFY(parseGpsText(txt, &actualLat, &actualLon));
|
|
QCOMPARE(actualLat, expectedLat);
|
|
QCOMPARE(actualLon, expectedLon);
|
|
}
|
|
|
|
double TestGpsCoords::coord2double(double deg, double min, double sec)
|
|
{
|
|
return deg + min / 60.0 + sec / 3600.0;
|
|
}
|
|
|
|
QTEST_MAIN(TestGpsCoords)
|