1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126
|
/****************************************************************************
**
** Copyright (C) 2019 Ford Motor Company
** Contact: https://www.qt.io/licensing/
**
** This file is part of the QtRemoteObjects module of the Qt Toolkit.
**
** $QT_BEGIN_LICENSE:GPL-EXCEPT$
** Commercial License Usage
** Licensees holding valid commercial Qt licenses may use this file in
** accordance with the commercial license agreement provided with the
** Software or, alternatively, in accordance with the terms contained in
** a written agreement between you and The Qt Company. For licensing terms
** and conditions see https://www.qt.io/terms-conditions. For further
** information use the contact form at https://www.qt.io/contact-us.
**
** GNU General Public License Usage
** Alternatively, this file may be used under the terms of the GNU
** General Public License version 3 as published by the Free Software
** Foundation with exceptions as appearing in the file LICENSE.GPL3-EXCEPT
** included in the packaging of this file. Please review the following
** information to ensure the GNU General Public License requirements will
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
**
** $QT_END_LICENSE$
**
****************************************************************************/
#include "rep_subclass_replica.h"
#include "../shared.h"
#include <QCoreApplication>
#include <QtRemoteObjects/qremoteobjectnode.h>
#include <QtTest/QtTest>
class tst_Client_Process : public QObject
{
Q_OBJECT
private Q_SLOTS:
void initTestCase()
{
m_repNode.reset(new QRemoteObjectNode);
m_repNode->connectToNode(QUrl(QStringLiteral("tcp://127.0.0.1:65213")));
m_rep.reset(m_repNode->acquire<ParentClassReplica>());
const auto objectMode = qEnvironmentVariable("ObjectMode");
qDebug() << "Waiting to connect, mode =" << objectMode;
QVERIFY(m_rep->waitForSource());
}
void testSubClass()
{
const auto objectMode = qEnvironmentVariable("ObjectMode");
qDebug() << "Starting test" << objectMode;
if (objectMode == QLatin1String("ObjectPointer")) {
QSignalSpy tracksSpy(m_rep->tracks(), &QAbstractItemModelReplica::initialized);
QVERIFY(m_rep->subClass() != nullptr);
QCOMPARE(m_rep->subClass()->myPOD(), initialValue);
QCOMPARE(m_rep->subClass()->i(), initialI);
QVERIFY(m_rep->tracks() != nullptr);
QVERIFY(tracksSpy.count() || tracksSpy.wait());
QCOMPARE(m_rep->myEnum(), ParentClassReplica::bar);
QCOMPARE(m_rep->date(), Qt::RFC2822Date);
QCOMPARE(m_rep->nsEnum(), NS::Bravo);
QCOMPARE(m_rep->ns2Enum(), NS2::NamespaceEnum::Bravo);
QCOMPARE(m_rep->variant(), QVariant::fromValue(42.0f));
} else {
QVERIFY(m_rep->subClass() == nullptr);
QVERIFY(m_rep->tracks() == nullptr);
QCOMPARE(m_rep->myEnum(), ParentClassReplica::foo);
QCOMPARE(m_rep->date(), Qt::ISODate);
QCOMPARE(m_rep->nsEnum(), NS::Alpha);
QCOMPARE(m_rep->ns2Enum(), NS2::NamespaceEnum::Alpha);
QCOMPARE(m_rep->variant(), QVariant());
}
QPoint p(1, 2);
auto enumReply = m_rep->enumSlot(p, ParentClassReplica::bar);
QVERIFY(enumReply.waitForFinished());
QCOMPARE(enumReply.error(), QRemoteObjectPendingCall::NoError);
QCOMPARE(enumReply.returnValue(), QVariant::fromValue(ParentClassReplica::foobar));
qDebug() << "Verified expected initial states, sending start.";
QSignalSpy enumSpy(m_rep.data(), &ParentClassReplica::enum2);
QSignalSpy advanceSpy(m_rep.data(), SIGNAL(advance()));
auto reply = m_rep->start();
QVERIFY(reply.waitForFinished());
QVERIFY(reply.error() == QRemoteObjectPendingCall::NoError);
QCOMPARE(reply.returnValue(), QVariant::fromValue(true));
QVERIFY(enumSpy.wait());
QCOMPARE(enumSpy.count(), 1);
const auto arguments = enumSpy.takeFirst();
QCOMPARE(arguments.at(0), QVariant::fromValue(ParentClassReplica::foo));
QCOMPARE(arguments.at(1), QVariant::fromValue(ParentClassReplica::bar));
QVERIFY(advanceSpy.count() || advanceSpy.wait());
QVERIFY(m_rep->subClass() != nullptr);
QCOMPARE(m_rep->subClass()->myPOD(), updatedValue);
QCOMPARE(m_rep->subClass()->i(), updatedI);
QVERIFY(m_rep->tracks() != nullptr);
QCOMPARE(m_rep->myEnum(), ParentClassReplica::foobar);
QCOMPARE(m_rep->date(), Qt::ISODateWithMs);
QCOMPARE(m_rep->nsEnum(), NS::Charlie);
QCOMPARE(m_rep->ns2Enum(), NS2::NamespaceEnum::Charlie);
QCOMPARE(m_rep->variant(), QVariant::fromValue(podValue));
qDebug() << "Verified expected final states, cleaning up.";
}
void cleanupTestCase()
{
auto reply = m_rep->quit();
// Don't verify the wait result, depending on the timing of the server and proxy
// closing it may return false. We just need this process to stay alive long
// enough for the packets to be sent.
reply.waitForFinished(5000);
}
private:
QScopedPointer<QRemoteObjectNode> m_repNode;
QScopedPointer<ParentClassReplica> m_rep;
};
QTEST_MAIN(tst_Client_Process)
#include "main.moc"
|