summaryrefslogtreecommitdiffstats
path: root/tests/auto/qbluetoothservicediscoveryagent
diff options
context:
space:
mode:
authorMichael Zanetti <michael.zanetti@nokia.com>2011-09-07 12:02:00 +0200
committerQt by Nokia <qt-info@nokia.com>2011-10-07 03:31:39 +0200
commitbd4df1e8e148cee77f76830a43ddc044b7a6903c (patch)
treec6a5aedafa2670e0b193843bd0271306eefdecd7 /tests/auto/qbluetoothservicediscoveryagent
parent5788b49130e1b2648beab531016d1e61cf3d5444 (diff)
re-added autotests
Change-Id: Ic2be21fd11e2fdb96185fe9269cebbe08b6de87a Reviewed-on: http://codereview.qt-project.org/4783 Reviewed-by: Qt Sanity Bot <qt_sanity_bot@ovi.com> Reviewed-by: Alex <alex.blasche@nokia.com>
Diffstat (limited to 'tests/auto/qbluetoothservicediscoveryagent')
-rw-r--r--tests/auto/qbluetoothservicediscoveryagent/qbluetoothservicediscoveryagent.pro7
-rw-r--r--tests/auto/qbluetoothservicediscoveryagent/tst_qbluetoothservicediscoveryagent.cpp346
2 files changed, 353 insertions, 0 deletions
diff --git a/tests/auto/qbluetoothservicediscoveryagent/qbluetoothservicediscoveryagent.pro b/tests/auto/qbluetoothservicediscoveryagent/qbluetoothservicediscoveryagent.pro
new file mode 100644
index 00000000..eee23d89
--- /dev/null
+++ b/tests/auto/qbluetoothservicediscoveryagent/qbluetoothservicediscoveryagent.pro
@@ -0,0 +1,7 @@
+SOURCES += tst_qbluetoothservicediscoveryagent.cpp
+TARGET = tst_qbluetoothservicediscoveryagent
+CONFIG += testcase
+
+QT = core bluetooth testlib
+
+symbian: TARGET.CAPABILITY = ReadDeviceData LocalServices WriteDeviceData
diff --git a/tests/auto/qbluetoothservicediscoveryagent/tst_qbluetoothservicediscoveryagent.cpp b/tests/auto/qbluetoothservicediscoveryagent/tst_qbluetoothservicediscoveryagent.cpp
new file mode 100644
index 00000000..0e5355f3
--- /dev/null
+++ b/tests/auto/qbluetoothservicediscoveryagent/tst_qbluetoothservicediscoveryagent.cpp
@@ -0,0 +1,346 @@
+/****************************************************************************
+**
+** Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies).
+** All rights reserved.
+** Contact: Nokia Corporation (qt-info@nokia.com)
+**
+** This file is part of the Qt Mobility Components.
+**
+** $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$
+**
+****************************************************************************/
+
+#include <QtTest/QtTest>
+
+#include <QDebug>
+#include <QVariant>
+#include <QStringList>
+
+#include <qbluetoothaddress.h>
+#include <qbluetoothdevicediscoveryagent.h>
+#include <qbluetoothservicediscoveryagent.h>
+#include <qbluetoothlocaldevice.h>
+
+Q_DECLARE_METATYPE(QBluetoothDeviceInfo)
+Q_DECLARE_METATYPE(QBluetoothServiceDiscoveryAgent::Error)
+
+// Maximum time to for bluetooth device scan
+const int MaxScanTime = 5 * 60 * 1000; // 5 minutes in ms
+
+class tst_QBluetoothServiceDiscoveryAgent : public QObject
+{
+ Q_OBJECT
+
+public:
+ tst_QBluetoothServiceDiscoveryAgent();
+ ~tst_QBluetoothServiceDiscoveryAgent();
+
+public slots:
+ void deviceDiscoveryDebug(const QBluetoothDeviceInfo &info);
+ void serviceDiscoveryDebug(const QBluetoothServiceInfo &info);
+ void serviceError(const QBluetoothServiceDiscoveryAgent::Error err);
+
+private slots:
+ void initTestCase();
+
+ void tst_serviceDiscovery_data();
+ void tst_serviceDiscovery();
+
+private:
+ QList<QBluetoothDeviceInfo> devices;
+};
+
+tst_QBluetoothServiceDiscoveryAgent::tst_QBluetoothServiceDiscoveryAgent()
+{
+ // start Bluetooth if not started
+ QBluetoothLocalDevice *device = new QBluetoothLocalDevice();
+ device->powerOn();
+ delete device;
+ // wait for the device to switch bluetooth mode.
+ QTest::qWait(1000);
+ qRegisterMetaType<QBluetoothDeviceInfo>("QBluetoothDeviceInfo");
+ qRegisterMetaType<QBluetoothServiceInfo>("QBluetoothServiceInfo");
+ qRegisterMetaType<QList<QBluetoothUuid> >("QList<QBluetoothUuid>");
+ qRegisterMetaType<QBluetoothServiceDiscoveryAgent::Error>("QBluetoothServiceDiscoveryAgent::Error");
+ qRegisterMetaType<QBluetoothDeviceDiscoveryAgent::Error>("QBluetoothDeviceDiscoveryAgent::Error");
+
+}
+
+tst_QBluetoothServiceDiscoveryAgent::~tst_QBluetoothServiceDiscoveryAgent()
+{
+}
+
+void tst_QBluetoothServiceDiscoveryAgent::deviceDiscoveryDebug(const QBluetoothDeviceInfo &info)
+{
+ qDebug() << "Discovered device:" << info.address().toString() << info.name();
+}
+
+
+void tst_QBluetoothServiceDiscoveryAgent::serviceError(const QBluetoothServiceDiscoveryAgent::Error err)
+{
+ qDebug() << "Service discovery error" << err;
+}
+
+void tst_QBluetoothServiceDiscoveryAgent::initTestCase()
+{
+#if 1
+ QBluetoothDeviceDiscoveryAgent discoveryAgent;
+
+ QSignalSpy finishedSpy(&discoveryAgent, SIGNAL(finished()));
+ QSignalSpy errorSpy(&discoveryAgent, SIGNAL(error(QBluetoothDeviceDiscoveryAgent::Error)));
+ QSignalSpy discoveredSpy(&discoveryAgent, SIGNAL(deviceDiscovered(const QBluetoothDeviceInfo&)));
+// connect(&discoveryAgent, SIGNAL(deviceDiscovered(const QBluetoothDeviceInfo&)),
+// this, SLOT(deviceDiscoveryDebug(const QBluetoothDeviceInfo&)));
+
+ discoveryAgent.start();
+
+ // Wait for up to MaxScanTime for the scan to finish
+ int scanTime = MaxScanTime;
+ while (finishedSpy.count() == 0 && scanTime > 0) {
+ QTest::qWait(1000);
+ scanTime -= 1000;
+ }
+// qDebug() << "Scan time left:" << scanTime;
+
+ // Expect finished signal with no error
+ QVERIFY(finishedSpy.count() == 1);
+ QVERIFY(errorSpy.isEmpty());
+
+ devices = discoveryAgent.discoveredDevices();
+#else
+ devices.append(QBluetoothDeviceInfo(QBluetoothAddress(Q_UINT64_C(0x001e3a81ba69)), "Yuna", 0));
+#endif
+}
+
+void tst_QBluetoothServiceDiscoveryAgent::serviceDiscoveryDebug(const QBluetoothServiceInfo &info)
+{
+ qDebug() << "Discovered service on"
+ << info.device().name() << info.device().address().toString();
+ qDebug() << "\tService name:" << info.serviceName() << "cached" << info.device().isCached();
+ qDebug() << "\tDescription:"
+ << info.attribute(QBluetoothServiceInfo::ServiceDescription).toString();
+ qDebug() << "\tProvider:" << info.attribute(QBluetoothServiceInfo::ServiceProvider).toString();
+ qDebug() << "\tL2CAP protocol service multiplexer:" << info.protocolServiceMultiplexer();
+ qDebug() << "\tRFCOMM server channel:" << info.serverChannel();
+}
+
+static void dumpAttributeVariant(const QVariant &var, const QString indent)
+{
+ if (!var.isValid()) {
+ qDebug("%sEmpty", indent.toLocal8Bit().constData());
+ return;
+ }
+
+ if (var.userType() == qMetaTypeId<QBluetoothServiceInfo::Sequence>()) {
+ qDebug("%sSequence", indent.toLocal8Bit().constData());
+ const QBluetoothServiceInfo::Sequence *sequence = static_cast<const QBluetoothServiceInfo::Sequence *>(var.data());
+ foreach (const QVariant &v, *sequence)
+ dumpAttributeVariant(v, indent + '\t');
+ } else if (var.userType() == qMetaTypeId<QBluetoothServiceInfo::Alternative>()) {
+ qDebug("%sAlternative", indent.toLocal8Bit().constData());
+ const QBluetoothServiceInfo::Alternative *alternative = static_cast<const QBluetoothServiceInfo::Alternative *>(var.data());
+ foreach (const QVariant &v, *alternative)
+ dumpAttributeVariant(v, indent + '\t');
+ } else if (var.userType() == qMetaTypeId<QBluetoothUuid>()) {
+ QBluetoothUuid uuid = var.value<QBluetoothUuid>();
+ switch (uuid.minimumSize()) {
+ case 0:
+ qDebug("%suuid NULL", indent.toLocal8Bit().constData());
+ break;
+ case 2:
+ qDebug("%suuid %04x", indent.toLocal8Bit().constData(), uuid.toUInt16());
+ break;
+ case 4:
+ qDebug("%suuid %08x", indent.toLocal8Bit().constData(), uuid.toUInt32());
+ break;
+ case 16: {
+ qDebug("%suuid %s", indent.toLocal8Bit().constData(), QByteArray(reinterpret_cast<const char *>(uuid.toUInt128().data), 16).toHex().constData());
+ break;
+ }
+ default:
+ qDebug("%suuid ???", indent.toLocal8Bit().constData());
+ }
+ } else {
+ switch (var.userType()) {
+ case QVariant::UInt:
+ qDebug("%suint %u", indent.toLocal8Bit().constData(), var.toUInt());
+ break;
+ case QVariant::Int:
+ qDebug("%sint %d", indent.toLocal8Bit().constData(), var.toInt());
+ break;
+ case QVariant::String:
+ qDebug("%sstring %s", indent.toLocal8Bit().constData(), var.toString().toLocal8Bit().constData());
+ break;
+ case QVariant::Bool:
+ qDebug("%sbool %d", indent.toLocal8Bit().constData(), var.toBool());
+ break;
+ case QVariant::Url:
+ qDebug("%surl %s", indent.toLocal8Bit().constData(), var.toUrl().toString().toLocal8Bit().constData());
+ break;
+ default:
+ qDebug("%sunknown", indent.toLocal8Bit().constData());
+ }
+ }
+}
+
+static void dumpServiceInfoAttributes(const QBluetoothServiceInfo &info)
+{
+ foreach (quint16 id, info.attributes()) {
+ dumpAttributeVariant(info.attribute(id), QString("\t"));
+ }
+}
+
+
+void tst_QBluetoothServiceDiscoveryAgent::tst_serviceDiscovery_data()
+{
+ if (devices.isEmpty())
+ QSKIP("This test requires an in-range bluetooth device", SkipAll);
+
+ QTest::addColumn<QBluetoothDeviceInfo>("deviceInfo");
+ QTest::addColumn<QList<QBluetoothUuid> >("uuidFilter");
+ QTest::addColumn<QBluetoothServiceDiscoveryAgent::Error>("serviceDiscoveryError");
+
+ // Only need to test the first 5 live devices
+ int max = 5;
+ foreach (const QBluetoothDeviceInfo &info, devices) {
+ if (info.isCached())
+ continue;
+ QTest::newRow("default filter") << info << QList<QBluetoothUuid>()
+ << QBluetoothServiceDiscoveryAgent::NoError;
+ if (!--max)
+ break;
+ //QTest::newRow("public browse group") << info << (QList<QBluetoothUuid>() << QBluetoothUuid::PublicBrowseGroup);
+ //QTest::newRow("l2cap") << info << (QList<QBluetoothUuid>() << QBluetoothUuid::L2cap);
+ }
+ QTest::newRow("all devices") << QBluetoothDeviceInfo() << QList<QBluetoothUuid>()
+ << QBluetoothServiceDiscoveryAgent::NoError;
+}
+
+
+void tst_QBluetoothServiceDiscoveryAgent::tst_serviceDiscovery()
+{
+ // Not all devices respond to SDP, so allow for a failure
+ static int expected_failures = 0;
+
+ if (devices.isEmpty())
+ QSKIP("This test requires an in-range bluetooth device", SkipAll);
+
+ QFETCH(QBluetoothDeviceInfo, deviceInfo);
+ QFETCH(QList<QBluetoothUuid>, uuidFilter);
+ QFETCH(QBluetoothServiceDiscoveryAgent::Error, serviceDiscoveryError);
+
+ qDebug() << "Doing address" << deviceInfo.address().toString();
+ QBluetoothServiceDiscoveryAgent discoveryAgent(deviceInfo.address());
+
+ QVERIFY(!discoveryAgent.isActive());
+
+ QVERIFY(discoveryAgent.discoveredServices().isEmpty());
+
+ QVERIFY(discoveryAgent.uuidFilter().isEmpty());
+
+ discoveryAgent.setUuidFilter(uuidFilter);
+
+ QVERIFY(discoveryAgent.uuidFilter() == uuidFilter);
+
+ QSignalSpy finishedSpy(&discoveryAgent, SIGNAL(finished()));
+ QSignalSpy errorSpy(&discoveryAgent, SIGNAL(error(QBluetoothServiceDiscoveryAgent::Error)));
+ QSignalSpy discoveredSpy(&discoveryAgent, SIGNAL(serviceDiscovered(QBluetoothServiceInfo)));
+// connect(&discoveryAgent, SIGNAL(serviceDiscovered(QBluetoothServiceInfo)),
+// this, SLOT(serviceDiscoveryDebug(QBluetoothServiceInfo)));
+ connect(&discoveryAgent, SIGNAL(error(QBluetoothServiceDiscoveryAgent::Error)),
+ this, SLOT(serviceError(QBluetoothServiceDiscoveryAgent::Error)));
+
+ discoveryAgent.start();
+
+ QVERIFY(discoveryAgent.isActive());
+
+ // Wait for up to MaxScanTime for the scan to finish
+ int scanTime = MaxScanTime;
+ while (finishedSpy.count() == 0 && scanTime > 0) {
+ QTest::qWait(1000);
+ scanTime -= 1000;
+ }
+
+ if (discoveryAgent.error() && expected_failures++ < 2){
+ qDebug() << "Device failed to respond to SDP, skipping device" << discoveryAgent.error() << discoveryAgent.errorString();
+ return;
+ }
+
+ QVERIFY(discoveryAgent.error() == serviceDiscoveryError);
+ QVERIFY(discoveryAgent.errorString() == QString());
+
+ // Expect finished signal with no error
+ QVERIFY(finishedSpy.count() == 1);
+ QVERIFY(errorSpy.isEmpty());
+
+ //if (discoveryAgent.discoveredServices().count() && expected_failures++ <2){
+ if (discoveredSpy.isEmpty() && expected_failures++ < 2){
+ qDebug() << "Device failed to return any results, skipping device" << discoveryAgent.discoveredServices().count();
+ return;
+ }
+
+ // All returned QBluetoothServiceInfo should be valid.
+ while (!discoveredSpy.isEmpty()) {
+ const QVariant v = discoveredSpy.takeFirst().at(0);
+
+ // Work around limitation in QMetaType and moc.
+ // QBluetoothServiceInfo is registered with metatype as QBluetoothServiceInfo
+ // moc sees it as the unqualified QBluetoothServiceInfo.
+ if (qstrcmp(v.typeName(), "QBluetoothServiceInfo") == 0) {
+ const QBluetoothServiceInfo info =
+ *reinterpret_cast<const QBluetoothServiceInfo*>(v.constData());
+
+ QVERIFY(info.isValid());
+
+#if 0
+ qDebug() << info.device().name() << info.device().address().toString();
+ qDebug() << "\tService name:" << info.serviceName();
+ if (info.protocolServiceMultiplexer() >= 0)
+ qDebug() << "\tL2CAP protocol service multiplexer:" << info.protocolServiceMultiplexer();
+ if (info.serverChannel() >= 0)
+ qDebug() << "\tRFCOMM server channel:" << info.serverChannel();
+ //dumpServiceInfoAttributes(info);
+#endif
+ }
+ }
+
+ QVERIFY(discoveryAgent.discoveredServices().count() != 0);
+ discoveryAgent.clear();
+ QVERIFY(discoveryAgent.discoveredServices().count() == 0);
+
+ discoveryAgent.stop();
+ QVERIFY(!discoveryAgent.isActive());
+}
+
+QTEST_MAIN(tst_QBluetoothServiceDiscoveryAgent)
+
+#include "tst_qbluetoothservicediscoveryagent.moc"