diff options
author | JiDe Zhang <zhangjide@uniontech.com> | 2021-01-16 04:27:39 +0800 |
---|---|---|
committer | Alexey Edelev <alexey.edelev@qt.io> | 2021-04-23 18:51:30 +0200 |
commit | 22e967c3049608f82abd32a0beb0b4b36ee134bf (patch) | |
tree | bb92fc22698ba34b596728214580e193e7068ecf /tests/auto/cmake/tst_qaddpreroutine/tst_qaddpreroutine.cpp | |
parent | f1c37ead59cff4ce5788c75a9183f327c0681480 (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.cpp | 69 |
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" |