blob: e07fb707f9a8ac648ce2b40f255837865bcad816 [file] [log] [blame]
/****************************************************************************
**
** Copyright (C) 2016 The Qt Company Ltd.
** Contact: https://www.qt.io/licensing/
**
** This file is part of the test suite of the Qt Toolkit.
**
** $QT_BEGIN_LICENSE:GPL-EXCEPT$
** Commercial License Usage
** Licensees holding valid commercial Qt licenses may use this file in
** accordance with the commercial license agreement provided with the
** Software or, alternatively, in accordance with the terms contained in
** a written agreement between you and The Qt Company. For licensing terms
** and conditions see https://www.qt.io/terms-conditions. For further
** information use the contact form at https://www.qt.io/contact-us.
**
** GNU General Public License Usage
** Alternatively, this file may be used under the terms of the GNU
** General Public License version 3 as published by the Free Software
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
** included in the packaging of this file. Please review the following
** information to ensure the GNU General Public License requirements will
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
**
** $QT_END_LICENSE$
**
****************************************************************************/
//TESTED_COMPONENT=src/location
#include "qnmeapositioninfosourceproxyfactory.h"
#include "../qgeopositioninfosource/testqgeopositioninfosource_p.h"
#include "../utils/qlocationtestutils_p.h"
#include <QtPositioning/qnmeapositioninfosource.h>
#include <QSignalSpy>
#include <QTest>
Q_DECLARE_METATYPE(QNmeaPositionInfoSource::UpdateMode)
class DummyNmeaPositionInfoSource : public QNmeaPositionInfoSource
{
Q_OBJECT
public:
DummyNmeaPositionInfoSource(QNmeaPositionInfoSource::UpdateMode mode, QObject *parent = 0);
protected:
virtual bool parsePosInfoFromNmeaData(const char *data,
int size,
QGeoPositionInfo *posInfo,
bool *hasFix);
private:
int callCount;
};
DummyNmeaPositionInfoSource::DummyNmeaPositionInfoSource(QNmeaPositionInfoSource::UpdateMode mode, QObject *parent) :
QNmeaPositionInfoSource(mode, parent),
callCount(0)
{
}
bool DummyNmeaPositionInfoSource::parsePosInfoFromNmeaData(const char* data,
int size,
QGeoPositionInfo *posInfo,
bool *hasFix)
{
Q_UNUSED(data);
Q_UNUSED(size);
posInfo->setCoordinate(QGeoCoordinate(callCount * 1.0, callCount * 1.0, callCount * 1.0));
posInfo->setTimestamp(QDateTime::currentDateTime().toUTC());
*hasFix = true;
++callCount;
return true;
}
class tst_DummyNmeaPositionInfoSource : public QObject
{
Q_OBJECT
public:
tst_DummyNmeaPositionInfoSource();
private slots:
void initTestCase();
void testOverloadedParseFunction();
};
tst_DummyNmeaPositionInfoSource::tst_DummyNmeaPositionInfoSource() {}
void tst_DummyNmeaPositionInfoSource::initTestCase()
{
}
void tst_DummyNmeaPositionInfoSource::testOverloadedParseFunction()
{
DummyNmeaPositionInfoSource source(QNmeaPositionInfoSource::RealTimeMode);
QNmeaPositionInfoSourceProxyFactory factory;
QNmeaPositionInfoSourceProxy *proxy = static_cast<QNmeaPositionInfoSourceProxy*>(factory.createProxy(&source));
QSignalSpy spy(proxy->source(), SIGNAL(positionUpdated(QGeoPositionInfo)));
QGeoPositionInfo pos;
proxy->source()->startUpdates();
proxy->feedBytes(QString("The parser converts\n").toLatin1());
QTRY_VERIFY_WITH_TIMEOUT((spy.count() == 1), 10000);
pos = spy.at(0).at(0).value<QGeoPositionInfo>();
QVERIFY((pos.coordinate().latitude() == 0.0)
&& (pos.coordinate().longitude() == 0.0)
&& (pos.coordinate().altitude() == 0.0));
spy.clear();
proxy->feedBytes(QString("any data it receives\n").toLatin1());
QTRY_VERIFY_WITH_TIMEOUT((spy.count() == 1), 10000);
pos = spy.at(0).at(0).value<QGeoPositionInfo>();
QVERIFY((pos.coordinate().latitude() == 1.0)
&& (pos.coordinate().longitude() == 1.0)
&& (pos.coordinate().altitude() == 1.0));
spy.clear();
proxy->feedBytes(QString("into positions\n").toLatin1());
QTRY_VERIFY_WITH_TIMEOUT((spy.count() == 1), 10000);
pos = spy.at(0).at(0).value<QGeoPositionInfo>();
QVERIFY((pos.coordinate().latitude() == 2.0)
&& (pos.coordinate().longitude() == 2.0)
&& (pos.coordinate().altitude() == 2.0));
spy.clear();
}
#include "tst_dummynmeapositioninfosource.moc"
QTEST_GUILESS_MAIN(tst_DummyNmeaPositionInfoSource);