summaryrefslogtreecommitdiffstats
path: root/tests/auto/qdbuspendingreply
diff options
context:
space:
mode:
authorLars Knoll <lars.knoll@nokia.com>2009-03-23 09:18:55 (GMT)
committerSimon Hausmann <simon.hausmann@nokia.com>2009-03-23 09:18:55 (GMT)
commite5fcad302d86d316390c6b0f62759a067313e8a9 (patch)
treec2afbf6f1066b6ce261f14341cf6d310e5595bc1 /tests/auto/qdbuspendingreply
downloadQt-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/.gitignore1
-rw-r--r--tests/auto/qdbuspendingreply/qdbuspendingreply.pro4
-rw-r--r--tests/auto/qdbuspendingreply/tst_qdbuspendingreply.cpp572
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