File indexing completed on 2024-09-15 11:53:24

0001 // SPDX-License-Identifier: LGPL-2.1-or-later
0002 //
0003 // SPDX-FileCopyrightText: 2008 Patrick Spendrin <ps_ml@gmx.de>
0004 //
0005 
0006 #include "MarbleDirs.h"
0007 #include "GeoDataParser.h"
0008 #include "GeoDataGeometry.h"
0009 #include "GeoDataDocument.h"
0010 #include "GeoDataPlacemark.h"
0011 #include "GeoDataTypes.h"
0012 #include "GeoWriter.h"
0013 
0014 #include <QCoreApplication>
0015 #include <QString>
0016 #include <QBuffer>
0017 #include <QByteArray>
0018 #include <QDebug>
0019 #include <QTest>
0020 
0021 namespace Marble
0022 {
0023 
0024 class TestGeoDataPack : public QObject
0025 {
0026     Q_OBJECT
0027     private Q_SLOTS:
0028         void initTestCase();
0029         void saveKMLToCache();
0030         void loadKMLFromCache();
0031         void saveCitiesToCache();
0032         void loadCitiesFromCache();
0033 
0034     private:
0035         QString content;
0036         QElapsedTimer timer;
0037 };
0038 
0039 void TestGeoDataPack::initTestCase()
0040 {
0041     MarbleDirs::setMarbleDataPath( DATA_PATH );
0042     MarbleDirs::setMarblePluginPath( PLUGIN_PATH );
0043     timer.start();
0044 
0045     content = QString( 
0046 "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"
0047 "<kml xmlns=\"http://www.opengis.net/kml/2.2\">\n"
0048 "  <Document>\n"
0049 "    <Placemark>\n"
0050 "      <name>Empty</name>\n"
0051 "    </Placemark>\n"
0052 "    <Placemark>\n"
0053 "      <name>LinearRingTest.kml</name>\n"
0054 "      <Polygon>\n"
0055 "        <outerBoundaryIs>\n"
0056 "          <LinearRing>\n"
0057 "            <coordinates>\n"
0058 "              -122.365662,37.826988,0\n"
0059 "              -122.365202,37.826302,0\n"
0060 "              -122.364581,37.82655,0\n"
0061 "              -122.365038,37.827237,0\n"
0062 "              -122.365662,37.826988,0\n"
0063 "            </coordinates>\n"
0064 "          </LinearRing>\n"
0065 "        </outerBoundaryIs>\n"
0066 "      </Polygon>\n"
0067 "    </Placemark>\n"
0068 "  </Document>\n"
0069 "</kml>" );
0070 }
0071 
0072 void TestGeoDataPack::saveKMLToCache()
0073 {
0074     GeoDataParser parser( GeoData_KML );
0075     
0076     QByteArray array( content.toUtf8() );
0077     QBuffer buffer( &array );
0078     buffer.open( QIODevice::ReadOnly );
0079     if ( !parser.read( &buffer ) ) {
0080         qWarning( "Could not parse data!" );
0081         QFAIL( "Could not parse data!" );
0082         return;
0083     }
0084     GeoDocument* document = parser.releaseDocument();
0085     QVERIFY( document );
0086     qDebug() << " parse Timer " << timer.elapsed();
0087     GeoDataDocument *dataDocument = static_cast<GeoDataDocument*>( document );
0088     QString path = QString( "%1/%2.cache" );
0089     path = path.arg( QCoreApplication::applicationDirPath() );
0090     path = path.arg( QString( "KMLTest" ) );
0091 
0092     QFile cacheFile( path );
0093     if ( cacheFile.open( QIODevice::WriteOnly ) ) {
0094         QDataStream stream ( &cacheFile );
0095         dataDocument->pack( stream );
0096         cacheFile.close();
0097         qDebug( "Saved kml document to cache: %s", path.toLatin1().data() );
0098     }
0099     qDebug() << "write Timer " << timer.elapsed();
0100     delete document;
0101 }
0102 
0103 void TestGeoDataPack::loadKMLFromCache()
0104 {
0105     GeoDataDocument *cacheDocument = new GeoDataDocument();
0106     QString path = QString( "%1/%2.cache" );
0107     path = path.arg( QCoreApplication::applicationDirPath() );
0108     path = path.arg( QString( "KMLTest" ) );
0109 
0110     QFile cacheFile( path );
0111     if ( cacheFile.open( QIODevice::ReadOnly ) ) {
0112         QDataStream stream ( &cacheFile );
0113         cacheDocument->unpack( stream );
0114         cacheFile.close();
0115         qDebug( "Loaded kml document from cache: %s", path.toLatin1().data() );
0116     }
0117     QVERIFY( cacheDocument );
0118     qDebug() << "read Timer " << timer.elapsed();
0119 
0120     GeoDataParser parser( GeoData_KML );
0121     QByteArray array( content.toUtf8() );
0122     QBuffer buffer( &array );
0123     buffer.open( QIODevice::ReadOnly );
0124     if ( !parser.read( &buffer ) ) {
0125         qWarning( "Could not parse data!" );
0126         QFAIL( "Could not parse data!" );
0127         return;
0128     }
0129     GeoDocument* document = parser.releaseDocument();
0130     QVERIFY( document );
0131     qDebug() << "parse Timer " << timer.elapsed();
0132     GeoDataDocument *dataDocument = static_cast<GeoDataDocument*>( document );
0133     QCOMPARE(*cacheDocument, *dataDocument);
0134     qDebug() << "compare Timer " << timer.elapsed();
0135 
0136     delete document;
0137     delete cacheDocument;
0138 }
0139 
0140 void TestGeoDataPack::saveCitiesToCache()
0141 {
0142     GeoDataParser parser( GeoData_KML );
0143     
0144     QFile citiesFile( CITIES_PATH );
0145     citiesFile.open( QIODevice::ReadOnly );
0146     if ( !parser.read( &citiesFile ) ) {
0147         qWarning( "Could not parse data!" );
0148         QFAIL( "Could not parse data!" );
0149         return;
0150     }
0151     GeoDocument* document = parser.releaseDocument();
0152     QVERIFY( document );
0153     qDebug() << "read Timer " << timer.elapsed();
0154     GeoDataDocument *dataDocument = static_cast<GeoDataDocument*>( document );
0155     QString path = QString( "%1/%2.cache" );
0156     path = path.arg( QCoreApplication::applicationDirPath() );
0157     path = path.arg( QString( "CitiesTest" ) );
0158 
0159     QFile cacheFile( path );
0160     if ( cacheFile.open( QIODevice::WriteOnly ) ) {
0161         QDataStream stream ( &cacheFile );
0162         dataDocument->pack( stream );
0163         cacheFile.close();
0164         qDebug( "Saved kml document to cache: %s", path.toLatin1().data() );
0165     }
0166     QVERIFY( cacheFile.size() > 0 );
0167     qDebug() << "write Timer " << timer.elapsed();
0168     delete document;
0169 }
0170 
0171 void TestGeoDataPack::loadCitiesFromCache()
0172 {
0173     GeoDataDocument *cacheDocument = new GeoDataDocument();
0174     QString path = QString( "%1/%2.cache" );
0175     path = path.arg( QCoreApplication::applicationDirPath() );
0176     path = path.arg( QString( "CitiesTest" ) );
0177 
0178     QFile cacheFile( path );
0179     if ( cacheFile.open( QIODevice::ReadOnly ) ) {
0180         QDataStream stream ( &cacheFile );
0181         cacheDocument->unpack( stream );
0182         cacheFile.close();
0183         qDebug( "Loaded kml document from cache: %s", path.toLatin1().data() );
0184     }
0185     QVERIFY( cacheDocument );
0186     qDebug() << "read Timer " << timer.elapsed();
0187 
0188     GeoDataParser parser( GeoData_KML );
0189     QFile citiesFile( CITIES_PATH );
0190     citiesFile.open( QIODevice::ReadOnly );
0191     if ( !parser.read( &citiesFile ) ) {
0192         qWarning( "Could not parse data!" );
0193         QFAIL( "Could not parse data!" );
0194         return;
0195     }
0196     GeoDocument* document = parser.releaseDocument();
0197     QVERIFY( document );
0198     qDebug() << "parse Timer " << timer.elapsed();
0199 
0200 // commented out as it timeouts the test on build.kde.org
0201 //    GeoDataDocument *dataDocument = static_cast<GeoDataDocument*>( document );
0202 //    QVERIFY( compareDocuments( cacheDocument, dataDocument ) );
0203 //    qDebug() << "compare Timer " << timer.elapsed();
0204 
0205     delete cacheDocument;
0206 //    delete dataDocument;
0207 }
0208 
0209 }
0210 
0211 QTEST_MAIN( Marble::TestGeoDataPack )
0212 
0213 #include "TestGeoDataPack.moc"