summaryrefslogtreecommitdiff
path: root/tests/auto/qgeopositioninfo/tst_qgeopositioninfo.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'tests/auto/qgeopositioninfo/tst_qgeopositioninfo.cpp')
-rw-r--r--tests/auto/qgeopositioninfo/tst_qgeopositioninfo.cpp399
1 files changed, 399 insertions, 0 deletions
diff --git a/tests/auto/qgeopositioninfo/tst_qgeopositioninfo.cpp b/tests/auto/qgeopositioninfo/tst_qgeopositioninfo.cpp
new file mode 100644
index 00000000..a27c0246
--- /dev/null
+++ b/tests/auto/qgeopositioninfo/tst_qgeopositioninfo.cpp
@@ -0,0 +1,399 @@
+/****************************************************************************
+**
+** Copyright (C) 2011 Nokia Corporation and/or its subsidiary(-ies).
+** All rights reserved.
+** Contact: Nokia Corporation (qt-info@nokia.com)
+**
+** This file is part of the test suite of the Qt Toolkit.
+**
+** $QT_BEGIN_LICENSE:LGPL$
+** GNU Lesser General Public License Usage
+** This file may be used under the terms of the GNU Lesser General Public
+** License version 2.1 as published by the Free Software Foundation and
+** appearing in the file LICENSE.LGPL included in the packaging of this
+** file. Please review the following information to ensure the GNU Lesser
+** General Public License version 2.1 requirements will be met:
+** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
+**
+** In addition, as a special exception, Nokia gives you certain additional
+** rights. These rights are described in the Nokia Qt LGPL Exception
+** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
+**
+** GNU General Public License Usage
+** Alternatively, this file may be used under the terms of the GNU General
+** Public License version 3.0 as published by the Free Software Foundation
+** and appearing in the file LICENSE.GPL included in the packaging of this
+** file. Please review the following information to ensure the GNU General
+** Public License version 3.0 requirements will be met:
+** http://www.gnu.org/copyleft/gpl.html.
+**
+** Other Usage
+** Alternatively, this file may be used in accordance with the terms and
+** conditions contained in a signed written agreement between you and Nokia.
+**
+**
+**
+**
+**
+** $QT_END_LICENSE$
+**
+****************************************************************************/
+
+//TESTED_COMPONENT=src/location
+
+#include <qgeopositioninfo.h>
+
+#include <QMetaType>
+#include <QObject>
+#include <QDebug>
+#include <QTest>
+
+#include <float.h>
+
+QT_USE_NAMESPACE
+Q_DECLARE_METATYPE(QGeoCoordinate)
+Q_DECLARE_METATYPE(QGeoPositionInfo)
+Q_DECLARE_METATYPE(QGeoPositionInfo::Attribute)
+
+QByteArray tst_qgeopositioninfo_debug;
+
+void tst_qgeopositioninfo_messageHandler(QtMsgType type, const char *msg)
+{
+ switch (type) {
+ case QtDebugMsg :
+ tst_qgeopositioninfo_debug = QByteArray(msg);
+ break;
+ default:
+ break;
+ }
+}
+
+QList<qreal> tst_qgeopositioninfo_qrealTestValues()
+{
+ QList<qreal> values;
+
+// the following platforms use float for qreal
+#if !defined(QT_NO_FPU) && !defined(QT_ARCH_ARM) && !defined(QT_ARCH_WINDOWSCE) && !defined(QT_ARCH_SYMBIAN)
+ if (qreal(DBL_MIN) == DBL_MIN)
+ values << DBL_MIN;
+#endif
+
+ values << FLT_MIN;
+ values << -1.0 << 0.0 << 1.0;
+ values << FLT_MAX;
+
+// the following platforms use float for qreal
+#if !defined(QT_NO_FPU) && !defined(QT_ARCH_ARM) && !defined(QT_ARCH_WINDOWSCE) && !defined(QT_ARCH_SYMBIAN)
+ if (qreal(DBL_MAX) == DBL_MAX)
+ values << DBL_MAX;
+#endif
+
+ return values;
+}
+
+QList<QGeoPositionInfo::Attribute> tst_qgeopositioninfo_getAttributes()
+{
+ QList<QGeoPositionInfo::Attribute> attributes;
+ attributes << QGeoPositionInfo::Direction
+ << QGeoPositionInfo::GroundSpeed
+ << QGeoPositionInfo::VerticalSpeed
+ << QGeoPositionInfo::MagneticVariation
+ << QGeoPositionInfo::HorizontalAccuracy
+ << QGeoPositionInfo::VerticalAccuracy;
+ return attributes;
+}
+
+
+class tst_QGeoPositionInfo : public QObject
+{
+ Q_OBJECT
+
+private:
+ QGeoPositionInfo infoWithAttribute(QGeoPositionInfo::Attribute attribute, qreal value)
+ {
+ QGeoPositionInfo info;
+ info.setAttribute(attribute, value);
+ return info;
+ }
+
+ void addTestData_info()
+ {
+ QTest::addColumn<QGeoPositionInfo>("info");
+
+ QTest::newRow("invalid") << QGeoPositionInfo();
+
+ QTest::newRow("coord") << QGeoPositionInfo(QGeoCoordinate(-27.3422,150.2342), QDateTime());
+ QTest::newRow("datetime") << QGeoPositionInfo(QGeoCoordinate(), QDateTime::currentDateTime());
+
+ QList<QGeoPositionInfo::Attribute> attributes = tst_qgeopositioninfo_getAttributes();
+ QList<qreal> values = tst_qgeopositioninfo_qrealTestValues();
+ for (int i=0; i<attributes.count(); i++) {
+ for (int j=0; j<values.count(); j++) {
+ QTest::newRow(qPrintable(QString("Attribute %1 = %2").arg(attributes[i]).arg(values[j])))
+ << infoWithAttribute(attributes[i], values[j]);
+ }
+ }
+ }
+
+private slots:
+ void constructor()
+ {
+ QGeoPositionInfo info;
+ QVERIFY(!info.isValid());
+ QVERIFY(!info.coordinate().isValid());
+ QVERIFY(info.timestamp().isNull());
+ }
+
+ void constructor_coord_dateTime()
+ {
+ QFETCH(QGeoCoordinate, coord);
+ QFETCH(QDateTime, dateTime);
+ QFETCH(bool, valid);
+
+ QGeoPositionInfo info(coord, dateTime);
+ QCOMPARE(info.coordinate(), coord);
+ QCOMPARE(info.timestamp(), dateTime);
+ QCOMPARE(info.isValid(), valid);
+ }
+
+ void constructor_coord_dateTime_data()
+ {
+ QTest::addColumn<QGeoCoordinate>("coord");
+ QTest::addColumn<QDateTime>("dateTime");
+ QTest::addColumn<bool>("valid");
+
+ QTest::newRow("both null") << QGeoCoordinate() << QDateTime() << false;
+ QTest::newRow("both valid") << QGeoCoordinate(1,1) << QDateTime::currentDateTime() << true;
+ QTest::newRow("valid coord") << QGeoCoordinate(1,1) << QDateTime() << false;
+ QTest::newRow("valid datetime") << QGeoCoordinate() << QDateTime::currentDateTime() << false;
+ QTest::newRow("valid time but not date == invalid")
+ << QGeoCoordinate() << QDateTime(QDate(), QTime::currentTime()) << false;
+ QTest::newRow("valid date but not time == valid due to QDateTime constructor")
+ << QGeoCoordinate() << QDateTime(QDate::currentDate(), QTime()) << false;
+ }
+
+ void constructor_copy()
+ {
+ QFETCH(QGeoPositionInfo, info);
+
+ QCOMPARE(QGeoPositionInfo(info), info);
+ }
+
+ void constructor_copy_data()
+ {
+ addTestData_info();
+ }
+
+ void operator_assign()
+ {
+ QFETCH(QGeoPositionInfo, info);
+
+ QGeoPositionInfo info2 = info;
+ QCOMPARE(info2, info);
+ }
+
+ void operator_assign_data()
+ {
+ addTestData_info();
+ }
+
+ void operator_equals()
+ {
+ QFETCH(QGeoPositionInfo, info);
+
+ QVERIFY(info == info);
+ if (info.isValid())
+ QCOMPARE(info == QGeoPositionInfo(), false);
+ }
+
+ void operator_equals_data()
+ {
+ addTestData_info();
+ }
+
+ void operator_notEquals()
+ {
+ QFETCH(QGeoPositionInfo, info);
+
+ QCOMPARE(info != info, false);
+ if (info.isValid())
+ QCOMPARE(info != QGeoPositionInfo(), true);
+ }
+
+ void operator_notEquals_data()
+ {
+ addTestData_info();
+ }
+
+ void setDateTime()
+ {
+ QFETCH(QDateTime, dateTime);
+
+ QGeoPositionInfo info;
+ info.setTimestamp(dateTime);
+ QCOMPARE(info.timestamp(), dateTime);
+ }
+
+ void setDateTime_data()
+ {
+ QTest::addColumn<QDateTime>("dateTime");
+ QTest::newRow("invalid") << QDateTime();
+ QTest::newRow("now") << QDateTime::currentDateTime();
+ }
+
+ void dateTime()
+ {
+ QGeoPositionInfo info;
+ QVERIFY(info.timestamp().isNull());
+ }
+
+ void setCoordinate()
+ {
+
+ QFETCH(QGeoCoordinate, coord);
+
+ QGeoPositionInfo info;
+ info.setCoordinate(coord);
+ QCOMPARE(info.coordinate(), coord);
+ }
+
+ void setCoordinate_data()
+ {
+ QTest::addColumn<QGeoCoordinate>("coord");
+
+ QTest::newRow("invalid") << QGeoCoordinate();
+ QTest::newRow("valid") << QGeoCoordinate(30,30);
+ }
+
+ void attribute()
+ {
+ QFETCH(QGeoPositionInfo::Attribute, attribute);
+ QFETCH(qreal, value);
+
+ QGeoPositionInfo info;
+ QCOMPARE(info.attribute(attribute), qreal(-1.0));
+
+ info.setAttribute(attribute, value);
+ QCOMPARE(info.attribute(attribute), value);
+
+ info.removeAttribute(attribute);
+ QCOMPARE(info.attribute(attribute), qreal(-1.0));
+ }
+
+ void attribute_data()
+ {
+ QTest::addColumn<QGeoPositionInfo::Attribute>("attribute");
+ QTest::addColumn<qreal>("value");
+
+ QList<QGeoPositionInfo::Attribute> attributes = tst_qgeopositioninfo_getAttributes();
+ QList<qreal> values = tst_qgeopositioninfo_qrealTestValues();
+ for (int i=0; i<attributes.count(); i++) {
+ for (int j=0; j<values.count(); j++) {
+ QTest::newRow(qPrintable(QString("Attribute %1 = %2").arg(attributes[i]).arg(values[j])))
+ << attributes[i] << values[j];
+ }
+ }
+ }
+
+ void hasAttribute()
+ {
+ QFETCH(QGeoPositionInfo::Attribute, attribute);
+ QFETCH(qreal, value);
+
+ QGeoPositionInfo info;
+ QVERIFY(!info.hasAttribute(attribute));
+
+ info.setAttribute(attribute, value);
+ QVERIFY(info.hasAttribute(attribute));
+
+ info.removeAttribute(attribute);
+ QVERIFY(!info.hasAttribute(attribute));
+ }
+
+ void hasAttribute_data()
+ {
+ attribute_data();
+ }
+
+ void removeAttribute()
+ {
+ QFETCH(QGeoPositionInfo::Attribute, attribute);
+ QFETCH(qreal, value);
+
+ QGeoPositionInfo info;
+ QVERIFY(!info.hasAttribute(attribute));
+
+ info.setAttribute(attribute, value);
+ QVERIFY(info.hasAttribute(attribute));
+
+ info.removeAttribute(attribute);
+ QVERIFY(!info.hasAttribute(attribute));
+
+ info.setAttribute(attribute, value);
+ QVERIFY(info.hasAttribute(attribute));
+ }
+
+ void removeAttribute_data()
+ {
+ attribute_data();
+ }
+
+ void datastream()
+ {
+ QFETCH(QGeoPositionInfo, info);
+
+ QByteArray ba;
+ QDataStream out(&ba, QIODevice::WriteOnly);
+ out << info;
+
+ QDataStream in(&ba, QIODevice::ReadOnly);
+ QGeoPositionInfo inInfo;
+ in >> inInfo;
+ QCOMPARE(inInfo, info);
+ }
+
+ void datastream_data()
+ {
+ addTestData_info();
+ }
+
+ void debug()
+ {
+ QFETCH(QGeoPositionInfo, info);
+ QFETCH(QByteArray, debugStringEnd);
+
+ qInstallMsgHandler(tst_qgeopositioninfo_messageHandler);
+ qDebug() << info;
+ qInstallMsgHandler(0);
+
+ // use endsWith() so we don't depend on QDateTime's debug() implementation
+ QVERIFY(tst_qgeopositioninfo_debug.endsWith(debugStringEnd));
+ }
+
+ void debug_data()
+ {
+ QTest::addColumn<QGeoPositionInfo>("info");
+ QTest::addColumn<QByteArray>("debugStringEnd");
+
+ QTest::newRow("no values") << QGeoPositionInfo()
+ << QString("QGeoCoordinate(?, ?))").toLatin1();
+
+ QGeoCoordinate coord(1, 1);
+ QTest::newRow("coord, time") << QGeoPositionInfo(coord, QDateTime::currentDateTime())
+ << QByteArray("QGeoCoordinate(1, 1))");
+
+ QGeoPositionInfo info;
+ info.setAttribute(QGeoPositionInfo::Direction, 1.1);
+ info.setAttribute(QGeoPositionInfo::GroundSpeed, 2.1);
+ info.setAttribute(QGeoPositionInfo::VerticalSpeed, 3.1);
+ info.setAttribute(QGeoPositionInfo::MagneticVariation, 4.1);
+ info.setAttribute(QGeoPositionInfo::HorizontalAccuracy, 5.1);
+ info.setAttribute(QGeoPositionInfo::VerticalAccuracy, 6.1);
+ QTest::newRow("all attributes") << info
+ << QByteArray("QGeoCoordinate(?, ?), Direction=1.1, GroundSpeed=2.1, VerticalSpeed=3.1, MagneticVariation=4.1, HorizontalAccuracy=5.1, VerticalAccuracy=6.1)");
+ }
+};
+
+
+QTEST_APPLESS_MAIN(tst_QGeoPositionInfo)
+#include "tst_qgeopositioninfo.moc"