// SPDX-FileCopyrightText: 2021 Linus Jahn // // SPDX-License-Identifier: LGPL-2.1-or-later #ifndef CLIENTTESTING_H #define CLIENTTESTING_H #include "QXmppClient.h" #include "QXmppClientExtension.h" // needed for qDeleteAll(d->extensions) #include "QXmppClient_p.h" #include "QXmppOutgoingClient.h" #include "util.h" class TestClient : public QXmppClient { Q_OBJECT public: TestClient(bool enableDebug = false) : QXmppClient(), debugEnabled(enableDebug) { // clear extensions qDeleteAll(d->extensions); d->extensions.clear(); // enable stream management (so IQ requests are not stopped) d->stream->enableStreamManagement(true); // setup logging (for expect()) logger()->setLoggingType(QXmppLogger::SignalLogging); connect(logger(), &QXmppLogger::message, this, &TestClient::onLoggerMessage); resetIdCount(); } ~TestClient() override { } template void inject(const String &xml) { d->stream->handleIqResponse(xmlToDom(xml)); QCoreApplication::processEvents(); resetIdCount(); } void expect(QString &&packet) { QVERIFY2(!m_sentPackets.empty(), "No packet was sent!"); QCOMPARE(m_sentPackets.takeFirst(), packet.replace(u'\'', u'"')); resetIdCount(); } QString takePacket() { [this]() { QVERIFY(!m_sentPackets.isEmpty()); }(); return m_sentPackets.takeFirst(); } QString takeLastPacket() { [this]() { QVERIFY(!m_sentPackets.isEmpty()); }(); return m_sentPackets.takeLast(); } void ignore() { m_sentPackets.takeFirst(); resetIdCount(); } void resetIdCount() { QXmppStanza::s_uniqeIdNo = 0; } private: void onLoggerMessage(QXmppLogger::MessageType type, const QString &text) { if (type != QXmppLogger::SentMessage || text == QLatin1String("")) { return; } if (debugEnabled) { qDebug() << "LOG" << text; } m_sentPackets << text; } bool debugEnabled; QList m_sentPackets; }; #endif // CLIENTTESTING_H