| /**************************************************************************** |
| ** |
| ** Copyright (C) 2017 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 <QtTest/QtTest> |
| #include <QMetaType> |
| #include <QProcess> |
| #include <QStandardPaths> |
| |
| namespace { |
| |
| QString findExecutable(const QString &executableName, const QStringList &paths) |
| { |
| const auto path = QStandardPaths::findExecutable(executableName, paths); |
| if (!path.isEmpty()) { |
| return path; |
| } |
| |
| qWarning() << "Could not find executable:" << executableName << "in any of" << paths; |
| return QString(); |
| } |
| |
| } |
| |
| class tst_Integration_MultiProcess: public QObject |
| { |
| Q_OBJECT |
| |
| private slots: |
| void initTestCase() |
| { |
| QLoggingCategory::setFilterRules("qt.remoteobjects.warning=false"); |
| } |
| |
| void cleanup() |
| { |
| // wait for delivery of RemoveObject events to the source |
| QTest::qWait(200); |
| } |
| |
| void testRun_data() |
| { |
| QTest::addColumn<bool>("templated"); |
| QTest::newRow("non-templated enableRemoting") << false; |
| QTest::newRow("templated enableRemoting") << true; |
| } |
| |
| void testRun() |
| { |
| QFETCH(bool, templated); |
| |
| qDebug() << "Starting server process"; |
| QProcess serverProc; |
| serverProc.setProcessChannelMode(QProcess::ForwardedChannels); |
| if (templated) { |
| QProcessEnvironment env = QProcessEnvironment::systemEnvironment(); |
| env.insert("TEMPLATED_REMOTING", "true"); |
| serverProc.setProcessEnvironment(env); |
| } |
| serverProc.start(findExecutable("integration_multiprocess_server", { |
| QCoreApplication::applicationDirPath() + "/../server/" |
| }), QStringList()); |
| QVERIFY(serverProc.waitForStarted()); |
| |
| // wait for server start |
| QTest::qWait(200); |
| |
| qDebug() << "Starting client process"; |
| QProcess clientProc; |
| clientProc.setProcessChannelMode(QProcess::ForwardedChannels); |
| clientProc.start(findExecutable("integration_multiprocess_client", { |
| QCoreApplication::applicationDirPath() + "/../client/" |
| }), QStringList()); |
| QVERIFY(clientProc.waitForStarted()); |
| |
| QVERIFY(clientProc.waitForFinished()); |
| QVERIFY(serverProc.waitForFinished()); |
| |
| QCOMPARE(serverProc.exitCode(), 0); |
| QCOMPARE(clientProc.exitCode(), 0); |
| } |
| }; |
| |
| QTEST_MAIN(tst_Integration_MultiProcess) |
| |
| #include "tst_integration_multiprocess.moc" |