summaryrefslogtreecommitdiffstats
path: root/tests/auto/cmake/tst_qaddpreroutine/tst_qaddpreroutine.cpp
diff options
context:
space:
mode:
authorJiDe Zhang <zhangjide@uniontech.com>2021-01-16 04:27:39 +0800
committerAlexey Edelev <alexey.edelev@qt.io>2021-04-23 18:51:30 +0200
commit22e967c3049608f82abd32a0beb0b4b36ee134bf (patch)
treebb92fc22698ba34b596728214580e193e7068ecf /tests/auto/cmake/tst_qaddpreroutine/tst_qaddpreroutine.cpp
parentf1c37ead59cff4ce5788c75a9183f327c0681480 (diff)
fix: The QtStartUpFunction function may be called repeatedly
Don't call pre routine function in qAddPreRoutine if the qt_call_pre_routines is not called Pick-to: 6.1 6.0 Task-number: QTBUG-90341 Change-Id: I0ee70561dc57b857f8b3b1cf42c9dfe0cf45bd49 Reviewed-by: Alexandru Croitor <alexandru.croitor@qt.io>
Diffstat (limited to 'tests/auto/cmake/tst_qaddpreroutine/tst_qaddpreroutine.cpp')
-rw-r--r--tests/auto/cmake/tst_qaddpreroutine/tst_qaddpreroutine.cpp69
1 files changed, 69 insertions, 0 deletions
diff --git a/tests/auto/cmake/tst_qaddpreroutine/tst_qaddpreroutine.cpp b/tests/auto/cmake/tst_qaddpreroutine/tst_qaddpreroutine.cpp
new file mode 100644
index 0000000000..fd6fde30ce
--- /dev/null
+++ b/tests/auto/cmake/tst_qaddpreroutine/tst_qaddpreroutine.cpp
@@ -0,0 +1,69 @@
+/****************************************************************************
+**
+** Copyright (C) 2021 zccrs <zccrs@live.com>, JiDe Zhang <zhangjide@uniontech.com>.
+** Contact: https://www.qt.io/licensing/
+**
+** This file is part of the test suite 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 <QTest>
+#include <QGuiApplication>
+
+class tst_qAddPreRoutine : public QObject
+{
+ Q_OBJECT
+
+public:
+ static void initMain()
+ {
+ // The purpose of this use case is indeed to test "qAddPreRoutine", but
+ // as you can see, there is nowhere to call "qAddPreRoutine". Please see
+ // the following two lines of code, which set the "QT_QPA_PLATFORM_PLUGIN_PATH"
+ // and "QT_QPA_PLATFORMTHEME" environment variables that a new platform
+ // theme plugin will be loaded, and the Q_COREAPP_STARTUP_FUNCTION macro
+ // is used in this plugin, which will cause "qAddPreRoutine" to be called
+ // indirectly in the Q*Application class when load the platform theme plugin.
+ // See the "plugin.cpp" file.
+#ifndef Q_OS_ANDROID // The plug-in is in the apk package, no need to specify its directory
+ qputenv("QT_QPA_PLATFORM_PLUGIN_PATH", QT_QPA_PLATFORM_PLUGIN_PATH);
+#endif
+ qputenv("QT_QPA_PLATFORMTHEME", "QTBUG_90341");
+ }
+
+private slots:
+ void tst_QTBUG_90341()
+ {
+#ifdef Q_OS_ANDROID
+ QSKIP("Android can't load the platform theme plugin this test needs, see QTBUG-92893");
+#endif
+ QVERIFY2(qEnvironmentVariableIsSet("QTBUG_90341_ThemePlugin"),
+ "The \"QTBUG_90341\" theme plugin not loaded.");
+ // This "test_function_call_count" property is assigned in the "QTBUG_90341" plugin.
+ // See the "plugin.cpp" file.
+ QCOMPARE(qApp->property("test_function_call_count").toInt(), 1);
+ }
+};
+
+QTEST_MAIN(tst_qAddPreRoutine)
+
+#include "tst_qaddpreroutine.moc"