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
|
// Copyright (C) 2019 Ford Motor Company
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only
#include "mytestserver.h"
#include "rep_subclass_source.h"
#include <QCoreApplication>
#include <QtTest/QtTest>
class tst_Server_Process : public QObject
{
Q_OBJECT
private Q_SLOTS:
void testRun()
{
const auto runMode = qEnvironmentVariable("RunMode");
const auto objectMode = qEnvironmentVariable("ObjectMode");
QRemoteObjectHost srcNode(QUrl(QStringLiteral("tcp://127.0.0.1:65217")));
MyTestServer myTestServer;
SubClassSimpleSource subclass;
QStringListModel model;
const MyPOD initialValue(42, 3.14f, QStringLiteral("SubClass"));
if (objectMode == QLatin1String("ObjectPointer")) {
subclass.setMyPOD(initialValue);
model.setStringList(QStringList() << "Track1" << "Track2" << "Track3");
myTestServer.setSubClass(&subclass);
myTestServer.setTracks(&model);
}
srcNode.enableRemoting(&myTestServer);
qDebug() << "Waiting for incoming connections";
QSignalSpy waitForStartedSpy(&myTestServer, &MyTestServer::startedChanged);
QVERIFY(waitForStartedSpy.isValid());
QVERIFY(waitForStartedSpy.wait());
QCOMPARE(waitForStartedSpy.value(0).value(0).toBool(), true);
// wait for delivery of events
QTest::qWait(200);
qDebug() << "Client connected";
if (runMode != QLatin1String("Baseline")) {
qDebug() << "Server quitting" << runMode;
if (runMode == QLatin1String("ServerRestartFatal"))
qFatal("Fatal");
QCoreApplication::exit();
return;
}
emit myTestServer.advance();
// wait for quit
bool quit = false;
connect(&myTestServer, &MyTestServer::quitApp, this, [&quit] { quit = true; });
QTRY_VERIFY_WITH_TIMEOUT(quit, 5000);
// wait for delivery of events
QTest::qWait(200);
qDebug() << "Done. Shutting down.";
}
};
QTEST_MAIN(tst_Server_Process)
#include "main.moc"
|