diff options
| author | Ulf Hermann <ulf.hermann@qt.io> | 2021-11-23 19:00:29 +0100 |
|---|---|---|
| committer | Ulf Hermann <ulf.hermann@qt.io> | 2021-12-03 12:09:26 +0100 |
| commit | 58ff7aa4fed5b3a27b6a859fc02f9ee27dd1a6cc (patch) | |
| tree | cd8d455066d5e9e6d14988e945f4ba421765b743 /tests/auto/qml/qmlcachegen/tst_qmlcachegen.cpp | |
| parent | c2f50cf90d143d96313ab3cfdbb9e4552a095cbb (diff) | |
Compile QML files ahead of time with qmlcachegen
qmlcachegen compiles bindings and functions to C++ as far as
QQmlJSAotCompiler can. It does respect "pragma Strict" and rejects the
file if it's violated. Furthermore, it sets up the logger to follow the
qt.qml.compiler.aot logging category. By default it's completely silent.
Compiling the examples with qmlcachegen exposes a bug in the type
resolver where it returns an invalid generic type. It should never do
that. Fix it by returning JSValue.
[ChangeLog][QtQml][Important Behavior Changes] QML bindings and
functions are now compiled to C++ by qmlcachegen, if possible. Use the
qt.qml.compiler.aot logging category to receive diagnostics about the
compilation.
Task-number: QTBUG-98305
Change-Id: I6953812c3fd20b68339617a5714fcbe16a384360
Reviewed-by: Qt CI Bot <qt_ci_bot@qt-project.org>
Reviewed-by: Fabian Kosmale <fabian.kosmale@qt.io>
Diffstat (limited to 'tests/auto/qml/qmlcachegen/tst_qmlcachegen.cpp')
| -rw-r--r-- | tests/auto/qml/qmlcachegen/tst_qmlcachegen.cpp | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/tests/auto/qml/qmlcachegen/tst_qmlcachegen.cpp b/tests/auto/qml/qmlcachegen/tst_qmlcachegen.cpp index 0ae3195234..70b1c259e1 100644 --- a/tests/auto/qml/qmlcachegen/tst_qmlcachegen.cpp +++ b/tests/auto/qml/qmlcachegen/tst_qmlcachegen.cpp @@ -736,6 +736,7 @@ void tst_qmlcachegen::inlineComponent() QVERIFY2(ok, errors); QQmlEngine engine; CleanlyLoadingComponent component(&engine, testFileUrl("inlineComponentWithId.qml")); + QVERIFY2(component.isReady(), qPrintable(component.errorString())); QTest::ignoreMessage(QtMsgType::QtInfoMsg, "42"); QScopedPointer<QObject> obj(component.create()); QVERIFY(!obj.isNull()); @@ -749,7 +750,9 @@ void tst_qmlcachegen::posthocRequired() CleanlyLoadingComponent component(&engine, testFileUrl("posthocrequired.qml")); QScopedPointer<QObject> obj(component.create()); QVERIFY(obj.isNull() && component.isError()); - QVERIFY(component.errorString().contains(QStringLiteral("Required property x was not initialized"))); + QVERIFY2(component.errorString().contains( + QStringLiteral("Required property x was not initialized")), + qPrintable(component.errorString())); } void tst_qmlcachegen::scriptStringCachegenInteraction() |
