2011-04-27 10:05:43 +00:00
|
|
|
/****************************************************************************
|
|
|
|
**
|
2016-01-19 11:23:05 +00:00
|
|
|
** Copyright (C) 2016 The Qt Company Ltd.
|
|
|
|
** Contact: https://www.qt.io/licensing/
|
2011-04-27 10:05:43 +00:00
|
|
|
**
|
|
|
|
** This file is part of the test suite of the Qt Toolkit.
|
|
|
|
**
|
2016-01-19 11:23:05 +00:00
|
|
|
** $QT_BEGIN_LICENSE:GPL-EXCEPT$
|
2012-09-20 05:21:40 +00:00
|
|
|
** 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
|
2015-01-28 11:55:39 +00:00
|
|
|
** a written agreement between you and The Qt Company. For licensing terms
|
2016-01-19 11:23:05 +00:00
|
|
|
** and conditions see https://www.qt.io/terms-conditions. For further
|
|
|
|
** information use the contact form at https://www.qt.io/contact-us.
|
2012-09-20 05:21:40 +00:00
|
|
|
**
|
2016-01-19 11:23:05 +00:00
|
|
|
** 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.
|
2011-04-27 10:05:43 +00:00
|
|
|
**
|
|
|
|
** $QT_END_LICENSE$
|
|
|
|
**
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#include <qtest.h>
|
2011-05-05 05:24:17 +00:00
|
|
|
|
2012-02-16 04:43:03 +00:00
|
|
|
#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>
|
2011-05-05 05:24:17 +00:00
|
|
|
|
2011-04-27 10:05:43 +00:00
|
|
|
#include <QFile>
|
2011-05-05 05:24:17 +00:00
|
|
|
#include <QDebug>
|
|
|
|
#include <QTextStream>
|
2011-04-27 10:05:43 +00:00
|
|
|
|
|
|
|
class tst_compilation : public QObject
|
|
|
|
{
|
|
|
|
Q_OBJECT
|
|
|
|
public:
|
|
|
|
tst_compilation();
|
|
|
|
|
|
|
|
private slots:
|
|
|
|
void boomblock();
|
|
|
|
|
2011-05-05 05:24:17 +00:00
|
|
|
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();
|
|
|
|
|
2011-04-27 10:05:43 +00:00
|
|
|
private:
|
2012-02-16 04:43:03 +00:00
|
|
|
QQmlEngine engine;
|
2011-04-27 10:05:43 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
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
|
|
|
|
{
|
2012-02-16 04:43:03 +00:00
|
|
|
QQmlComponent c(&engine);
|
2011-04-27 10:05:43 +00:00
|
|
|
c.setData(data, QUrl());
|
|
|
|
}
|
2016-11-16 13:22:36 +00:00
|
|
|
#if !QT_CONFIG(opengl)
|
2016-06-06 10:17:34 +00:00
|
|
|
QSKIP("boomblock imports Particles which requires OpenGL Support");
|
|
|
|
#endif
|
2011-04-27 10:05:43 +00:00
|
|
|
QBENCHMARK {
|
2012-02-16 04:43:03 +00:00
|
|
|
QQmlComponent c(&engine);
|
2011-04-27 10:05:43 +00:00
|
|
|
c.setData(data, QUrl());
|
2014-09-15 01:52:44 +00:00
|
|
|
QVERIFY2(c.isReady(), qPrintable(c.errorString()));
|
2011-04-27 10:05:43 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-05-05 05:24:17 +00:00
|
|
|
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 {
|
2012-02-16 04:43:03 +00:00
|
|
|
QQmlJS::Engine engine;
|
2011-05-05 05:24:17 +00:00
|
|
|
|
2012-02-16 04:43:03 +00:00
|
|
|
QQmlJS::Lexer lexer(&engine);
|
2011-05-05 05:24:17 +00:00
|
|
|
lexer.setCode(code, -1);
|
|
|
|
|
2012-02-16 04:43:03 +00:00
|
|
|
QQmlJS::Parser parser(&engine);
|
2011-05-05 05:24:17 +00:00
|
|
|
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().count() == filesToCreate);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-04-27 10:05:43 +00:00
|
|
|
QTEST_MAIN(tst_compilation)
|
|
|
|
|
|
|
|
#include "tst_compilation.moc"
|