qtdeclarative/tests/benchmarks/qml/compilation/tst_compilation.cpp

167 lines
4.0 KiB
C++
Raw Permalink Normal View History

// Copyright (C) 2016 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only
#include <qtest.h>
#include <QtQml/qqmlengine.h>
#include <QtQml/qqmlcomponent.h>
#include <QtQml/private/qqmljsengine_p.h>
#include <QtQml/private/qqmljsmemorypool_p.h>
#include <QtQml/private/qqmljsparser_p.h>
#include <QtQml/private/qqmljslexer_p.h>
#include <QFile>
#include <QDebug>
#include <QTextStream>
class tst_compilation : public QObject
{
Q_OBJECT
public:
tst_compilation();
private slots:
void boomblock();
void jsparser_data();
void jsparser();
tst_compilation: Add a test for compilation of a large number of types As I'll be touching QQmlImport, it would be good to ensure it doesn't regress. This may also be useful for future such changes (e.g. I want to try play around with how the implicit import is handled). Results for me on a recent dev snapshot, 2013 rmbp: ********* Start testing of tst_compilation ********* Config: Using QtTest library 5.9.0, Qt 5.9.0 (x86_64-little_endian-lp64 shared (dynamic) release build; by Clang 8.0.0 (clang-800.0.42.1) (Apple)) PASS : tst_compilation::initTestCase() PASS : tst_compilation::bigimport(10, qmldir) RESULT : tst_compilation::bigimport():"10, qmldir": 3.6 msecs per iteration (total: 59, iterations: 16) PASS : tst_compilation::bigimport(100, qmldir) RESULT : tst_compilation::bigimport():"100, qmldir": 54 msecs per iteration (total: 54, iterations: 1) PASS : tst_compilation::bigimport(1000, qmldir) RESULT : tst_compilation::bigimport():"1000, qmldir": 558 msecs per iteration (total: 558, iterations: 1) PASS : tst_compilation::bigimport(10, noqmldir) RESULT : tst_compilation::bigimport():"10, noqmldir": 5.0 msecs per iteration (total: 80, iterations: 16) PASS : tst_compilation::bigimport(100, noqmldir) RESULT : tst_compilation::bigimport():"100, noqmldir": 58 msecs per iteration (total: 58, iterations: 1) PASS : tst_compilation::bigimport(1000, noqmldir) RESULT : tst_compilation::bigimport():"1000, noqmldir": 558 msecs per iteration (total: 558, iterations: 1) PASS : tst_compilation::cleanupTestCase() Totals: 8 passed, 0 failed, 0 skipped, 0 blacklisted, 22400ms ********* Finished testing of tst_compilation ********* Change-Id: I7159e561fb13a3c48e966d5b963dc0ef1ca783e3 Reviewed-by: Simon Hausmann <simon.hausmann@qt.io>
2017-01-21 20:13:23 +00:00
void bigimport_data();
void bigimport();
private:
QQmlEngine engine;
};
tst_compilation::tst_compilation()
{
}
inline QUrl TEST_FILE(const QString &filename)
{
return QUrl::fromLocalFile(QLatin1String(SRCDIR) + QLatin1String("/data/") + filename);
}
void tst_compilation::boomblock()
{
QFile f(SRCDIR + QLatin1String("/data/BoomBlock.qml"));
QVERIFY(f.open(QIODevice::ReadOnly));
QByteArray data = f.readAll();
//get rid of initialization effects
{
QQmlComponent c(&engine);
c.setData(data, QUrl());
}
#if !QT_CONFIG(opengl)
QSKIP("boomblock imports Particles which requires OpenGL Support");
#endif
QBENCHMARK {
QQmlComponent c(&engine);
c.setData(data, QUrl());
QVERIFY2(c.isReady(), qPrintable(c.errorString()));
}
}
void tst_compilation::jsparser_data()
{
QTest::addColumn<QString>("file");
QTest::newRow("boomblock") << QString(SRCDIR + QLatin1String("/data/BoomBlock.qml"));
}
void tst_compilation::jsparser()
{
QFETCH(QString, file);
QFile f(file);
QVERIFY(f.open(QIODevice::ReadOnly));
QByteArray data = f.readAll();
QTextStream stream(data, QIODevice::ReadOnly);
const QString code = stream.readAll();
QBENCHMARK {
QQmlJS::Engine engine;
QQmlJS::Lexer lexer(&engine);
lexer.setCode(code, -1);
QQmlJS::Parser parser(&engine);
parser.parse();
parser.ast();
}
}
tst_compilation: Add a test for compilation of a large number of types As I'll be touching QQmlImport, it would be good to ensure it doesn't regress. This may also be useful for future such changes (e.g. I want to try play around with how the implicit import is handled). Results for me on a recent dev snapshot, 2013 rmbp: ********* Start testing of tst_compilation ********* Config: Using QtTest library 5.9.0, Qt 5.9.0 (x86_64-little_endian-lp64 shared (dynamic) release build; by Clang 8.0.0 (clang-800.0.42.1) (Apple)) PASS : tst_compilation::initTestCase() PASS : tst_compilation::bigimport(10, qmldir) RESULT : tst_compilation::bigimport():"10, qmldir": 3.6 msecs per iteration (total: 59, iterations: 16) PASS : tst_compilation::bigimport(100, qmldir) RESULT : tst_compilation::bigimport():"100, qmldir": 54 msecs per iteration (total: 54, iterations: 1) PASS : tst_compilation::bigimport(1000, qmldir) RESULT : tst_compilation::bigimport():"1000, qmldir": 558 msecs per iteration (total: 558, iterations: 1) PASS : tst_compilation::bigimport(10, noqmldir) RESULT : tst_compilation::bigimport():"10, noqmldir": 5.0 msecs per iteration (total: 80, iterations: 16) PASS : tst_compilation::bigimport(100, noqmldir) RESULT : tst_compilation::bigimport():"100, noqmldir": 58 msecs per iteration (total: 58, iterations: 1) PASS : tst_compilation::bigimport(1000, noqmldir) RESULT : tst_compilation::bigimport():"1000, noqmldir": 558 msecs per iteration (total: 558, iterations: 1) PASS : tst_compilation::cleanupTestCase() Totals: 8 passed, 0 failed, 0 skipped, 0 blacklisted, 22400ms ********* Finished testing of tst_compilation ********* Change-Id: I7159e561fb13a3c48e966d5b963dc0ef1ca783e3 Reviewed-by: Simon Hausmann <simon.hausmann@qt.io>
2017-01-21 20:13:23 +00:00
void tst_compilation::bigimport_data()
{
QTest::addColumn<int>("filesToCreate");
QTest::addColumn<bool>("writeQmldir");
QTest::newRow("10, qmldir")
<< 10 << true;
QTest::newRow("100, qmldir")
<< 100 << true;
QTest::newRow("1000, qmldir")
<< 1000 << true;
QTest::newRow("10, noqmldir")
<< 10 << false;
QTest::newRow("100, noqmldir")
<< 100 << false;
QTest::newRow("1000, noqmldir")
<< 1000 << false;
}
void tst_compilation::bigimport()
{
QFETCH(int, filesToCreate);
QFETCH(bool, writeQmldir);
QTemporaryDir d;
//d.setAutoRemove(false); // for debugging
QString p;
{
for (int i = 0; i < filesToCreate; ++i) {
QFile f(d.path() + QDir::separator() + QString::fromLatin1("Type%1.qml").arg(i));
QVERIFY(f.open(QIODevice::WriteOnly));
f.write("import QtQuick 2.0\n");
f.write("import \".\"\n");
f.write("Item {}\n");
}
QFile qmldir(d.path() + QDir::separator() + "qmldir");
if (writeQmldir)
QVERIFY(qmldir.open(QIODevice::WriteOnly));
QFile main(d.path() + QDir::separator() + "main.qml");
QVERIFY(main.open(QIODevice::WriteOnly));
p = QFileInfo(main).absoluteFilePath();
//qDebug() << p; // for debugging
main.write("import QtQuick 2.0\n");
main.write("import \".\"\n");
main.write("\n");
main.write("Item {\n");
for (int i = 0; i < filesToCreate; ++i) {
main.write(qPrintable(QString::fromLatin1("Type%1 {}\n").arg(i)));
if (writeQmldir)
qmldir.write(qPrintable(QString::fromLatin1("Type%1 1.0 Type%1.qml\n").arg(i)));
}
main.write("}");
}
QBENCHMARK {
QQmlEngine e;
QQmlComponent c(&e, p);
QCOMPARE(c.status(), QQmlComponent::Ready);
QScopedPointer<QObject> o(c.create());
QVERIFY(o->children().size() == filesToCreate);
tst_compilation: Add a test for compilation of a large number of types As I'll be touching QQmlImport, it would be good to ensure it doesn't regress. This may also be useful for future such changes (e.g. I want to try play around with how the implicit import is handled). Results for me on a recent dev snapshot, 2013 rmbp: ********* Start testing of tst_compilation ********* Config: Using QtTest library 5.9.0, Qt 5.9.0 (x86_64-little_endian-lp64 shared (dynamic) release build; by Clang 8.0.0 (clang-800.0.42.1) (Apple)) PASS : tst_compilation::initTestCase() PASS : tst_compilation::bigimport(10, qmldir) RESULT : tst_compilation::bigimport():"10, qmldir": 3.6 msecs per iteration (total: 59, iterations: 16) PASS : tst_compilation::bigimport(100, qmldir) RESULT : tst_compilation::bigimport():"100, qmldir": 54 msecs per iteration (total: 54, iterations: 1) PASS : tst_compilation::bigimport(1000, qmldir) RESULT : tst_compilation::bigimport():"1000, qmldir": 558 msecs per iteration (total: 558, iterations: 1) PASS : tst_compilation::bigimport(10, noqmldir) RESULT : tst_compilation::bigimport():"10, noqmldir": 5.0 msecs per iteration (total: 80, iterations: 16) PASS : tst_compilation::bigimport(100, noqmldir) RESULT : tst_compilation::bigimport():"100, noqmldir": 58 msecs per iteration (total: 58, iterations: 1) PASS : tst_compilation::bigimport(1000, noqmldir) RESULT : tst_compilation::bigimport():"1000, noqmldir": 558 msecs per iteration (total: 558, iterations: 1) PASS : tst_compilation::cleanupTestCase() Totals: 8 passed, 0 failed, 0 skipped, 0 blacklisted, 22400ms ********* Finished testing of tst_compilation ********* Change-Id: I7159e561fb13a3c48e966d5b963dc0ef1ca783e3 Reviewed-by: Simon Hausmann <simon.hausmann@qt.io>
2017-01-21 20:13:23 +00:00
}
}
QTEST_MAIN(tst_compilation)
#include "tst_compilation.moc"