diff options
author | Lars Knoll <lars.knoll@nokia.com> | 2009-03-23 09:18:55 (GMT) |
---|---|---|
committer | Simon Hausmann <simon.hausmann@nokia.com> | 2009-03-23 09:18:55 (GMT) |
commit | e5fcad302d86d316390c6b0f62759a067313e8a9 (patch) | |
tree | c2afbf6f1066b6ce261f14341cf6d310e5595bc1 /tests/auto/qdbuspendingreply | |
download | Qt-e5fcad302d86d316390c6b0f62759a067313e8a9.zip Qt-e5fcad302d86d316390c6b0f62759a067313e8a9.tar.gz Qt-e5fcad302d86d316390c6b0f62759a067313e8a9.tar.bz2 |
Long live Qt 4.5!
Diffstat (limited to 'tests/auto/qdbuspendingreply')
-rw-r--r-- | tests/auto/qdbuspendingreply/.gitignore | 1 | ||||
-rw-r--r-- | tests/auto/qdbuspendingreply/qdbuspendingreply.pro | 4 | ||||
-rw-r--r-- | tests/auto/qdbuspendingreply/tst_qdbuspendingreply.cpp | 572 |
3 files changed, 577 insertions, 0 deletions
diff --git a/tests/auto/qdbuspendingreply/.gitignore b/tests/auto/qdbuspendingreply/.gitignore new file mode 100644 index 0000000..d2537ac --- /dev/null +++ b/tests/auto/qdbuspendingreply/.gitignore @@ -0,0 +1 @@ +tst_qdbuspendingreply diff --git a/tests/auto/qdbuspendingreply/qdbuspendingreply.pro b/tests/auto/qdbuspendingreply/qdbuspendingreply.pro new file mode 100644 index 0000000..94e7acf --- /dev/null +++ b/tests/auto/qdbuspendingreply/qdbuspendingreply.pro @@ -0,0 +1,4 @@ +load(qttest_p4) +QT = core +contains(QT_CONFIG, dbus):QT += dbus +SOURCES += tst_qdbuspendingreply.cpp diff --git a/tests/auto/qdbuspendingreply/tst_qdbuspendingreply.cpp b/tests/auto/qdbuspendingreply/tst_qdbuspendingreply.cpp new file mode 100644 index 0000000..7247168 --- /dev/null +++ b/tests/auto/qdbuspendingreply/tst_qdbuspendingreply.cpp @@ -0,0 +1,572 @@ +/**************************************************************************** +** +** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies). +** Contact: Qt Software Information (qt-info@nokia.com) +** +** This file is part of the test suite of the Qt Toolkit. +** +** $QT_BEGIN_LICENSE:LGPL$ +** No Commercial Usage +** This file contains pre-release code and may not be distributed. +** You may use this file in accordance with the terms and conditions +** contained in the either Technology Preview License Agreement or the +** Beta Release License Agreement. +** +** GNU Lesser General Public License Usage +** Alternatively, 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.0, 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. +** +** If you are unsure which license is appropriate for your use, please +** contact the sales department at qt-sales@nokia.com. +** $QT_END_LICENSE$ +** +****************************************************************************/ +#include <QtCore/QObject> +#include <QtCore/QVariant> +#include <QtCore/QList> +#include <QtCore/QVector> +#include <QtTest/QtTest> +#ifndef QT_NO_DBUS +#include <QtDBus> + +typedef QMap<int,QString> IntStringMap; +Q_DECLARE_METATYPE(IntStringMap) + +struct MyStruct +{ + int i; + QString s; + + MyStruct() : i(1), s("String") { } + bool operator==(const MyStruct &other) const + { return i == other.i && s == other.s; } +}; +Q_DECLARE_METATYPE(MyStruct) + +QDBusArgument &operator<<(QDBusArgument &arg, const MyStruct &ms) +{ + arg.beginStructure(); + arg << ms.i << ms.s; + arg.endStructure(); + return arg; +} + +const QDBusArgument &operator>>(const QDBusArgument &arg, MyStruct &ms) +{ + arg.beginStructure(); + arg >> ms.i >> ms.s; + arg.endStructure(); + return arg; +} + +class TypesInterface; +class tst_QDBusPendingReply: public QObject +{ + Q_OBJECT + QDBusInterface *iface; + TypesInterface *adaptor; +public: + tst_QDBusPendingReply(); + +private slots: + void initTestCase() + { + qDBusRegisterMetaType<IntStringMap>(); + qDBusRegisterMetaType<MyStruct>(); + } + + void init(); + void simpleTypes(); + void complexTypes(); + void wrongTypes(); + void multipleTypes(); + + void synchronousSimpleTypes(); + + void errors(); +}; + +class TypesInterface: public QDBusAbstractAdaptor +{ + Q_OBJECT + Q_CLASSINFO("D-Bus Interface", "com.trolltech.Qt.Autotests.TypesInterface") +public: + TypesInterface(QObject *parent) + : QDBusAbstractAdaptor(parent) + { } + +public slots: + void retrieveVoid() + { } + + bool retrieveBool() + { + return true; + } + + uchar retrieveUChar() + { + return 'A'; + } + + short retrieveShort() + { + return -47; + } + + ushort retrieveUShort() + { + return 42U; + } + + int retrieveInt() + { + return -470000; + } + + void retrieveIntInt(int &i1, int &i2) + { + i1 = -424242; + i2 = 434343; + } + + uint retrieveUInt() + { + return 42424242; + } + + qlonglong retrieveLongLong() + { + return -(Q_INT64_C(1) << 32); + } + + qulonglong retrieveULongLong() + { + return Q_INT64_C(1) << 32; + } + + double retrieveDouble() + { + return 1.5; + } + + QString retrieveString() + { + return "This string you should see"; + } + + QDBusObjectPath retrieveObjectPath() + { + return QDBusObjectPath("/"); + } + + QDBusSignature retrieveSignature() + { + return QDBusSignature("g"); + } + + QDBusVariant retrieveVariant() + { + return QDBusVariant(retrieveString()); + } + + QStringList retrieveStringList() + { + return QStringList() << "one" << "two"; + } + + QByteArray retrieveByteArray() + { + return "Hello, World"; + } + + QVariantList retrieveList() + { + return QVariantList() << retrieveInt() << retrieveString() + << retrieveByteArray(); + } + + QVariantMap retrieveMap() + { + QVariantMap map; + map["one"] = 1; + map["two"] = 2U; + map["string"] = retrieveString(); + map["stringlist"] = retrieveStringList(); + return map; + } + + IntStringMap retrieveIntStringMap() + { + IntStringMap map; + map[1] = "1"; + map[2] = "2"; + map[-1231456] = "foo"; + return map; + } + + MyStruct retrieveStruct() + { + return MyStruct(); + } + + void sendError(const QDBusMessage &msg) + { + msg.setDelayedReply(true); + QDBusConnection::sessionBus() + .send(msg.createErrorReply("local.AnErrorName", "You've got an error!")); + } +}; + +tst_QDBusPendingReply::tst_QDBusPendingReply() +{ + adaptor = new TypesInterface(this); + QDBusConnection::sessionBus().registerObject("/", this); + + iface = new QDBusInterface(QDBusConnection::sessionBus().baseService(), "/", + "com.trolltech.Qt.Autotests.TypesInterface", + QDBusConnection::sessionBus(), + this); +} + +void tst_QDBusPendingReply::init() +{ + QVERIFY(iface); + QVERIFY(iface->isValid()); +} + +void tst_QDBusPendingReply::simpleTypes() +{ + QDBusPendingReply<> rvoid = iface->asyncCall("retrieveVoid"); + rvoid.waitForFinished(); + QVERIFY(rvoid.isFinished()); + QVERIFY(!rvoid.isError()); + + QDBusPendingReply<bool> rbool = iface->asyncCall("retrieveBool"); + rbool.waitForFinished(); + QVERIFY(rbool.isFinished()); + QCOMPARE(rbool.argumentAt<0>(), adaptor->retrieveBool()); + + QDBusPendingReply<uchar> ruchar = iface->asyncCall("retrieveUChar"); + ruchar.waitForFinished(); + QVERIFY(ruchar.isFinished()); + QCOMPARE(ruchar.argumentAt<0>(), adaptor->retrieveUChar()); + + QDBusPendingReply<short> rshort = iface->asyncCall("retrieveShort"); + rshort.waitForFinished(); + QVERIFY(rshort.isFinished()); + QCOMPARE(rshort.argumentAt<0>(), adaptor->retrieveShort()); + + QDBusPendingReply<ushort> rushort = iface->asyncCall("retrieveUShort"); + rushort.waitForFinished(); + QVERIFY(rushort.isFinished()); + QCOMPARE(rushort.argumentAt<0>(), adaptor->retrieveUShort()); + + QDBusPendingReply<int> rint = iface->asyncCall("retrieveInt"); + rint.waitForFinished(); + QVERIFY(rint.isFinished()); + QCOMPARE(rint.argumentAt<0>(), adaptor->retrieveInt()); + + QDBusPendingReply<uint> ruint = iface->asyncCall("retrieveUInt"); + ruint.waitForFinished(); + QVERIFY(ruint.isFinished()); + QCOMPARE(ruint.argumentAt<0>(), adaptor->retrieveUInt()); + + QDBusPendingReply<qlonglong> rqlonglong = iface->asyncCall("retrieveLongLong"); + rqlonglong.waitForFinished(); + QVERIFY(rqlonglong.isFinished()); + QCOMPARE(rqlonglong.argumentAt<0>(), adaptor->retrieveLongLong()); + + QDBusPendingReply<qulonglong> rqulonglong = iface->asyncCall("retrieveULongLong"); + rqulonglong.waitForFinished(); + QVERIFY(rqulonglong.isFinished()); + QCOMPARE(rqulonglong.argumentAt<0>(), adaptor->retrieveULongLong()); + + QDBusPendingReply<double> rdouble = iface->asyncCall("retrieveDouble"); + rdouble.waitForFinished(); + QVERIFY(rdouble.isFinished()); + QCOMPARE(rdouble.argumentAt<0>(), adaptor->retrieveDouble()); + + QDBusPendingReply<QString> rstring = iface->asyncCall("retrieveString"); + rstring.waitForFinished(); + QVERIFY(rstring.isFinished()); + QCOMPARE(rstring.argumentAt<0>(), adaptor->retrieveString()); + + QDBusPendingReply<QDBusObjectPath> robjectpath = iface->asyncCall("retrieveObjectPath"); + robjectpath.waitForFinished(); + QVERIFY(robjectpath.isFinished()); + QCOMPARE(robjectpath.argumentAt<0>().path(), adaptor->retrieveObjectPath().path()); + + QDBusPendingReply<QDBusSignature> rsignature = iface->asyncCall("retrieveSignature"); + rsignature.waitForFinished(); + QVERIFY(rsignature.isFinished()); + QCOMPARE(rsignature.argumentAt<0>().signature(), adaptor->retrieveSignature().signature()); + + QDBusPendingReply<QDBusVariant> rdbusvariant = iface->asyncCall("retrieveVariant"); + rdbusvariant.waitForFinished(); + QVERIFY(rdbusvariant.isFinished()); + QCOMPARE(rdbusvariant.argumentAt<0>().variant(), adaptor->retrieveVariant().variant()); + + QDBusPendingReply<QVariant> rvariant = iface->asyncCall("retrieveVariant"); + rvariant.waitForFinished(); + QVERIFY(rvariant.isFinished()); + QCOMPARE(rvariant.argumentAt<0>(), adaptor->retrieveVariant().variant()); + + QDBusPendingReply<QByteArray> rbytearray = iface->asyncCall("retrieveByteArray"); + rbytearray.waitForFinished(); + QVERIFY(rbytearray.isFinished()); + QCOMPARE(rbytearray.argumentAt<0>(), adaptor->retrieveByteArray()); + + QDBusPendingReply<QStringList> rstringlist = iface->asyncCall("retrieveStringList"); + rstringlist.waitForFinished(); + QVERIFY(rstringlist.isFinished()); + QCOMPARE(rstringlist.argumentAt<0>(), adaptor->retrieveStringList()); +} + +void tst_QDBusPendingReply::complexTypes() +{ + QDBusPendingReply<QVariantList> rlist = iface->asyncCall("retrieveList"); + rlist.waitForFinished(); + QVERIFY(rlist.isFinished()); + QCOMPARE(rlist.argumentAt<0>(), adaptor->retrieveList()); + + QDBusPendingReply<QVariantMap> rmap = iface->asyncCall("retrieveMap"); + rmap.waitForFinished(); + QVERIFY(rmap.isFinished()); + QCOMPARE(rmap.argumentAt<0>(), adaptor->retrieveMap()); + + QDBusPendingReply<IntStringMap> rismap = iface->asyncCall("retrieveIntStringMap"); + rismap.waitForFinished(); + QVERIFY(rismap.isFinished()); + QCOMPARE(rismap.argumentAt<0>(), adaptor->retrieveIntStringMap()); + + QDBusPendingReply<MyStruct> rstruct = iface->asyncCall("retrieveStruct"); + rstruct.waitForFinished(); + QVERIFY(rstruct.isFinished()); + QCOMPARE(rstruct.argumentAt<0>(), adaptor->retrieveStruct()); +} + +#define VERIFY_WRONG_TYPE(error) \ + QVERIFY(error.isValid()); \ + QCOMPARE(error.type(), QDBusError::InvalidSignature) + +void tst_QDBusPendingReply::wrongTypes() +{ + QDBusError error; + + QDBusPendingReply<bool> rbool = iface->asyncCall("retrieveInt"); + rbool.waitForFinished(); + QVERIFY(rbool.isFinished()); + QVERIFY(rbool.isError()); + error = rbool.error(); + VERIFY_WRONG_TYPE(error); + + rbool = iface->asyncCall("retrieveShort"); + rbool.waitForFinished(); + QVERIFY(rbool.isFinished()); + QVERIFY(rbool.isError()); + error = rbool.error(); + VERIFY_WRONG_TYPE(error); + + rbool = iface->asyncCall("retrieveStruct"); + rbool.waitForFinished(); + QVERIFY(rbool.isFinished()); + QVERIFY(rbool.isError()); + error = rbool.error(); + VERIFY_WRONG_TYPE(error); + + QDBusPendingReply<short> rshort = iface->asyncCall("retrieveInt"); + rshort.waitForFinished(); + QVERIFY(rshort.isFinished()); + QVERIFY(rshort.isError()); + error = rshort.error(); + VERIFY_WRONG_TYPE(error); + + rshort = iface->asyncCall("retrieveBool"); + rshort.waitForFinished(); + QVERIFY(rshort.isFinished()); + QVERIFY(rshort.isError()); + error = rshort.error(); + VERIFY_WRONG_TYPE(error); + + rshort = iface->asyncCall("retrieveStruct"); + rshort.waitForFinished(); + QVERIFY(rshort.isFinished()); + QVERIFY(rshort.isError()); + error = rshort.error(); + VERIFY_WRONG_TYPE(error); + + QDBusPendingReply<MyStruct> rstruct = iface->asyncCall("retrieveInt"); + rstruct.waitForFinished(); + QVERIFY(rstruct.isFinished()); + QVERIFY(rstruct.isError()); + error = rstruct.error(); + VERIFY_WRONG_TYPE(error); + + rstruct = iface->asyncCall("retrieveShort"); + rstruct.waitForFinished(); + QVERIFY(rstruct.isFinished()); + QVERIFY(rstruct.isError()); + error = rstruct.error(); + VERIFY_WRONG_TYPE(error); + + rstruct = iface->asyncCall("retrieveIntStringMap"); + rstruct.waitForFinished(); + QVERIFY(rstruct.isFinished()); + QVERIFY(rstruct.isError()); + error = rstruct.error(); + VERIFY_WRONG_TYPE(error); +} + +void tst_QDBusPendingReply::multipleTypes() +{ + QDBusPendingReply<int, int> rintint = iface->asyncCall("retrieveIntInt"); + rintint.waitForFinished(); + QVERIFY(rintint.isFinished()); + QVERIFY(!rintint.isError()); + + int i1, i2; + adaptor->retrieveIntInt(i1, i2); + QCOMPARE(rintint.argumentAt<0>(), i1); + QCOMPARE(rintint.argumentAt<1>(), i2); +} + +void tst_QDBusPendingReply::synchronousSimpleTypes() +{ + QDBusPendingReply<bool> rbool = iface->call("retrieveBool"); + rbool.waitForFinished(); + QVERIFY(rbool.isFinished()); + QCOMPARE(rbool.argumentAt<0>(), adaptor->retrieveBool()); + + QDBusPendingReply<uchar> ruchar = iface->call("retrieveUChar"); + ruchar.waitForFinished(); + QVERIFY(ruchar.isFinished()); + QCOMPARE(ruchar.argumentAt<0>(), adaptor->retrieveUChar()); + + QDBusPendingReply<short> rshort = iface->call("retrieveShort"); + rshort.waitForFinished(); + QVERIFY(rshort.isFinished()); + QCOMPARE(rshort.argumentAt<0>(), adaptor->retrieveShort()); + + QDBusPendingReply<ushort> rushort = iface->call("retrieveUShort"); + rushort.waitForFinished(); + QVERIFY(rushort.isFinished()); + QCOMPARE(rushort.argumentAt<0>(), adaptor->retrieveUShort()); + + QDBusPendingReply<int> rint = iface->call("retrieveInt"); + rint.waitForFinished(); + QVERIFY(rint.isFinished()); + QCOMPARE(rint.argumentAt<0>(), adaptor->retrieveInt()); + + QDBusPendingReply<uint> ruint = iface->call("retrieveUInt"); + ruint.waitForFinished(); + QVERIFY(ruint.isFinished()); + QCOMPARE(ruint.argumentAt<0>(), adaptor->retrieveUInt()); + + QDBusPendingReply<qlonglong> rqlonglong = iface->call("retrieveLongLong"); + rqlonglong.waitForFinished(); + QVERIFY(rqlonglong.isFinished()); + QCOMPARE(rqlonglong.argumentAt<0>(), adaptor->retrieveLongLong()); + + QDBusPendingReply<qulonglong> rqulonglong = iface->call("retrieveULongLong"); + rqulonglong.waitForFinished(); + QVERIFY(rqulonglong.isFinished()); + QCOMPARE(rqulonglong.argumentAt<0>(), adaptor->retrieveULongLong()); + + QDBusPendingReply<double> rdouble = iface->call("retrieveDouble"); + rdouble.waitForFinished(); + QVERIFY(rdouble.isFinished()); + QCOMPARE(rdouble.argumentAt<0>(), adaptor->retrieveDouble()); + + QDBusPendingReply<QString> rstring = iface->call("retrieveString"); + rstring.waitForFinished(); + QVERIFY(rstring.isFinished()); + QCOMPARE(rstring.argumentAt<0>(), adaptor->retrieveString()); + + QDBusPendingReply<QDBusObjectPath> robjectpath = iface->call("retrieveObjectPath"); + robjectpath.waitForFinished(); + QVERIFY(robjectpath.isFinished()); + QCOMPARE(robjectpath.argumentAt<0>().path(), adaptor->retrieveObjectPath().path()); + + QDBusPendingReply<QDBusSignature> rsignature = iface->call("retrieveSignature"); + rsignature.waitForFinished(); + QVERIFY(rsignature.isFinished()); + QCOMPARE(rsignature.argumentAt<0>().signature(), adaptor->retrieveSignature().signature()); + + QDBusPendingReply<QDBusVariant> rdbusvariant = iface->call("retrieveVariant"); + rdbusvariant.waitForFinished(); + QVERIFY(rdbusvariant.isFinished()); + QCOMPARE(rdbusvariant.argumentAt<0>().variant(), adaptor->retrieveVariant().variant()); + + QDBusPendingReply<QByteArray> rbytearray = iface->call("retrieveByteArray"); + rbytearray.waitForFinished(); + QVERIFY(rbytearray.isFinished()); + QCOMPARE(rbytearray.argumentAt<0>(), adaptor->retrieveByteArray()); + + QDBusPendingReply<QStringList> rstringlist = iface->call("retrieveStringList"); + rstringlist.waitForFinished(); + QVERIFY(rstringlist.isFinished()); + QCOMPARE(rstringlist.argumentAt<0>(), adaptor->retrieveStringList()); +} + +#define VERIFY_ERROR(error) \ + QVERIFY(error.isValid()); \ + QCOMPARE(error.name(), QString("local.AnErrorName")); \ + QCOMPARE(error.type(), QDBusError::Other) + +void tst_QDBusPendingReply::errors() +{ + QDBusError error; + + QDBusPendingReply<> rvoid = iface->asyncCall("sendError"); + rvoid.waitForFinished(); + QVERIFY(rvoid.isFinished()); + QVERIFY(rvoid.isError()); + error = rvoid.error(); + VERIFY_ERROR(error); + + QDBusPendingReply<int> rint = iface->asyncCall("sendError"); + rint.waitForFinished(); + QVERIFY(rint.isFinished()); + QVERIFY(rint.isError()); + error = rint.error(); + VERIFY_ERROR(error); + + QDBusPendingReply<int,int> rintint = iface->asyncCall("sendError"); + rintint.waitForFinished(); + QVERIFY(rintint.isFinished()); + QVERIFY(rintint.isError()); + error = rintint.error(); + VERIFY_ERROR(error); + + QDBusPendingReply<QString> rstring = iface->asyncCall("sendError"); + rstring.waitForFinished(); + QVERIFY(rstring.isFinished()); + QVERIFY(rstring.isError()); + error = rstring.error(); + VERIFY_ERROR(error); +} + +QTEST_MAIN(tst_QDBusPendingReply) + +#include "tst_qdbuspendingreply.moc" +#else +QTEST_NOOP_MAIN +#endif |