diff options
Diffstat (limited to 'tests/auto/qml/qqmlapplicationengine/tst_qqmlapplicationengine.cpp')
-rw-r--r-- | tests/auto/qml/qqmlapplicationengine/tst_qqmlapplicationengine.cpp | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/tests/auto/qml/qqmlapplicationengine/tst_qqmlapplicationengine.cpp b/tests/auto/qml/qqmlapplicationengine/tst_qqmlapplicationengine.cpp index 0f5eea8b95..5e855efe1a 100644 --- a/tests/auto/qml/qqmlapplicationengine/tst_qqmlapplicationengine.cpp +++ b/tests/auto/qml/qqmlapplicationengine/tst_qqmlapplicationengine.cpp @@ -30,6 +30,7 @@ #include <QQmlApplicationEngine> #include <QScopedPointer> #include <QSignalSpy> +#include <QRegularExpression> #if QT_CONFIG(process) #include <QProcess> #endif @@ -53,6 +54,7 @@ private slots: void loadTranslation_data(); void loadTranslation(); void setInitialProperties(); + void failureToLoadTriggersWarningSignal(); private: QString buildDir; @@ -293,6 +295,20 @@ void tst_qqmlapplicationengine::setInitialProperties() } } +Q_DECLARE_METATYPE(QList<QQmlError>) // for signalspy below + +void tst_qqmlapplicationengine::failureToLoadTriggersWarningSignal() +{ + auto url = testFileUrl("invalid.qml"); + qRegisterMetaType<QList<QQmlError>>(); + QTest::ignoreMessage(QtMsgType::QtWarningMsg, "QQmlApplicationEngine failed to load component"); + QTest::ignoreMessage(QtMsgType::QtWarningMsg, QRegularExpression(url.toString() + QLatin1Char('*'))); + QQmlApplicationEngine test; + QSignalSpy warningObserver(&test, &QQmlApplicationEngine::warnings); + test.load(url); + QTRY_COMPARE(warningObserver.count(), 1); +} + QTEST_MAIN(tst_qqmlapplicationengine) #include "tst_qqmlapplicationengine.moc" |