From 946249abbdd477ac7cfbdb1e0bfbcd34b7c93bb8 Mon Sep 17 00:00:00 2001 From: Jeremy Lainé Date: Fri, 16 Jul 2010 08:53:42 +0000 Subject: add tests for Jingle IQs --- source/tests.cpp | 96 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ source/tests.h | 11 +++++++ 2 files changed, 107 insertions(+) (limited to 'source') diff --git a/source/tests.cpp b/source/tests.cpp index f2d91b5b..1f49b274 100644 --- a/source/tests.cpp +++ b/source/tests.cpp @@ -29,6 +29,7 @@ #include #include "QXmppBind.h" +#include "QXmppJingleIq.h" #include "QXmppMessage.h" #include "QXmppPresence.h" #include "QXmppSession.h" @@ -227,6 +228,98 @@ void TestPackets::testSession() serializePacket(session, xml); } +void TestJingle::testSession() +{ + const QByteArray xml( + "" + "" + "" + "" + "" + "" + "" + ""); + + QXmppJingleIq session; + parsePacket(session, xml); + QCOMPARE(session.action(), QXmppJingleIq::SessionInitiate); + QCOMPARE(session.initiator(), QLatin1String("romeo@montague.lit/orchard")); + QCOMPARE(session.sid(), QLatin1String("a73sjjvkla37jfea")); + QCOMPARE(session.content().creator(), QLatin1String("initiator")); + QCOMPARE(session.content().name(), QLatin1String("this-is-a-stub")); + QCOMPARE(session.reason().text(), QString()); + QCOMPARE(session.reason().type(), QXmppJingleIq::Reason::None); + serializePacket(session, xml); +} + +void TestJingle::testTerminate() +{ + const QByteArray xml( + "" + "" + "" + "" + "" + "" + ""); + + QXmppJingleIq session; + parsePacket(session, xml); + QCOMPARE(session.action(), QXmppJingleIq::SessionTerminate); + QCOMPARE(session.initiator(), QString()); + QCOMPARE(session.sid(), QLatin1String("a73sjjvkla37jfea")); + QCOMPARE(session.reason().text(), QString()); + QCOMPARE(session.reason().type(), QXmppJingleIq::Reason::Success); + serializePacket(session, xml); +} + +void TestJingle::testPayloadType() +{ + const QByteArray xml(""); + QXmppJinglePayloadType payload; + parsePacket(payload, xml); + QCOMPARE(payload.id(), static_cast(103)); + QCOMPARE(payload.name(), QLatin1String("L16")); + QCOMPARE(payload.channels(), static_cast(2)); + QCOMPARE(payload.clockrate(), 16000u); + serializePacket(payload, xml); +} + +void TestJingle::testRinging() +{ + const QByteArray xml( + "" + "" + "" + "" + ""); + + QXmppJingleIq iq; + parsePacket(iq, xml); + QCOMPARE(iq.ringing(), true); + serializePacket(iq, xml); +} + int main(int argc, char *argv[]) { QCoreApplication app(argc, argv); @@ -240,6 +333,9 @@ int main(int argc, char *argv[]) TestPackets testPackets; errors += QTest::qExec(&testPackets); + TestJingle testJingle; + errors += QTest::qExec(&testJingle); + if (errors) { qWarning() << "Total failed tests:" << errors; diff --git a/source/tests.h b/source/tests.h index efba1961..06bdc91c 100644 --- a/source/tests.h +++ b/source/tests.h @@ -48,3 +48,14 @@ private slots: void testSession(); }; +class TestJingle : public QObject +{ + Q_OBJECT + +private slots: + void testSession(); + void testTerminate(); + void testPayloadType(); + void testRinging(); +}; + -- cgit v1.2.3