summaryrefslogtreecommitdiff
path: root/tests/auto/qgeojson/tst_qgeojson.cpp
blob: 453f3f81be6e8557effe8536788966b09b43664f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
// Copyright (C) 2016 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0

#include <QtTest/QtTest>
#include <QtPositioning/QGeoCoordinate>
#include <QtCore/QJsonDocument>
#include <QtCore/QVariant>
#include <QtCore/QList>
#include <QtLocation/private/qgeojson_p.h>

QT_USE_NAMESPACE

class tst_QGeoJson : public QObject
{
    Q_OBJECT

private Q_SLOTS:
    void testGeojson();

private:
    QString testDataDir;
};

void tst_QGeoJson::testGeojson()
{
    QJsonDocument originalDocument;
    QJsonDocument processedDocument;
    QVariantList modelList;

    QString exampleGeometries[] = {
        QStringLiteral("01-point.json"),
        QStringLiteral("02-linestring.json"),
        QStringLiteral("03-multipoint.json"),
        QStringLiteral("04-polygon.json"),
        QStringLiteral("05-multilinestring.json"),
        QStringLiteral("06-multipolygon.json"),
        QStringLiteral("07-geometrycollection.json"),
        QStringLiteral("08-feature.json"),
        QStringLiteral("09-featurecollection.json"),
        QStringLiteral("10-countries.json"),
        QStringLiteral("11-full.json")
    };

    testDataDir = QFileInfo(QFINDTESTDATA("01-point.json")).absolutePath();
    if (testDataDir.isEmpty())
        testDataDir = QCoreApplication::applicationDirPath();
    for (int i = 0; i < 11; ++i) {
        modelList.clear();

        QFile file(testDataDir +  QStringLiteral("/") + exampleGeometries[i]);
        file.open(QFile::ReadOnly);

        QByteArray testJson = file.readAll();
        originalDocument = QJsonDocument::fromJson(testJson);

        modelList = QGeoJson::importGeoJson(originalDocument);
        processedDocument = QGeoJson::exportGeoJson(modelList);

        QVERIFY2(processedDocument == originalDocument, qPrintable("Test failed in file: " + exampleGeometries[i]));
    }
}

QTEST_MAIN(tst_QGeoJson)
#include "tst_qgeojson.moc"