summaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorAlan Alpert <alan.alpert@nokia.com>2009-11-05 07:09:18 (GMT)
committerAlan Alpert <alan.alpert@nokia.com>2009-11-05 07:09:18 (GMT)
commit31e07c3838b72a208ec2853e6194ebe1692128f3 (patch)
tree0c09bd00e72db73299003d9cd2c7cbd3194c00f6 /tests
parent085dd75830357b359abf53b7d37c049cdd17977c (diff)
parent26cae0653332caf0b4e315fd35fd59469c66bac9 (diff)
downloadQt-31e07c3838b72a208ec2853e6194ebe1692128f3.zip
Qt-31e07c3838b72a208ec2853e6194ebe1692128f3.tar.gz
Qt-31e07c3838b72a208ec2853e6194ebe1692128f3.tar.bz2
Merge branch 'kinetic-declarativeui' of git@scm.dev.nokia.troll.no:qt/kinetic into kinetic-declarativeui
Diffstat (limited to 'tests')
-rw-r--r--tests/auto/declarative/declarative.pro2
-rw-r--r--tests/auto/declarative/listview/data/listview-sections.qml59
-rw-r--r--tests/auto/declarative/listview/tst_listview.cpp94
-rw-r--r--tests/auto/declarative/qfxloader/tst_qfxloader.cpp13
-rw-r--r--tests/auto/declarative/qmlfontloader/data/Fontin-Bold.ttfbin30916 -> 0 bytes
-rw-r--r--tests/auto/declarative/qmlfontloader/data/FreeMono.ttfbin0 -> 267400 bytes
-rw-r--r--tests/auto/declarative/qmlfontloader/tst_qmlfontloader.cpp4
-rw-r--r--tests/auto/declarative/qmlgraphicsgridview/data/gridview.qml49
-rw-r--r--tests/auto/declarative/qmlgraphicsgridview/qmlgraphicsgridview.pro8
-rw-r--r--tests/auto/declarative/qmlgraphicsgridview/tst_qmlgraphicsgridview.cpp585
-rw-r--r--tests/auto/declarative/qmlsystempalette/qmlsystempalette.pro5
-rw-r--r--tests/auto/declarative/qmlsystempalette/tst_qmlsystempalette.cpp154
-rw-r--r--tests/auto/declarative/valuetypes/testtypes.cpp2
-rw-r--r--tests/auto/declarative/visual/fillmode/data-MAC/fillmode.0.pngbin0 -> 26099 bytes
-rw-r--r--tests/auto/declarative/visual/fillmode/data-MAC/fillmode.qml279
-rw-r--r--tests/auto/declarative/visual/fillmode/data/fillmode.0.pngbin0 -> 26099 bytes
-rw-r--r--tests/auto/declarative/visual/fillmode/data/fillmode.qml279
-rw-r--r--tests/auto/declarative/visual/fillmode/face.pngbin0 -> 905 bytes
-rw-r--r--tests/auto/declarative/visual/fillmode/fillmode.qml16
-rw-r--r--tests/auto/declarative/visual/qfxtext/font/data-MAC/plaintext.0.pngbin94120 -> 103016 bytes
-rw-r--r--tests/auto/declarative/visual/qfxtext/font/data-MAC/plaintext.qml166
-rw-r--r--tests/auto/declarative/visual/qfxtext/font/data-MAC/richtext.0.pngbin121122 -> 136499 bytes
-rw-r--r--tests/auto/declarative/visual/qfxtext/font/data-MAC/richtext.qml170
-rw-r--r--tests/auto/declarative/visual/qfxtext/font/plaintext.qml15
-rw-r--r--tests/auto/declarative/visual/qfxtext/font/richtext.qml15
25 files changed, 1735 insertions, 180 deletions
diff --git a/tests/auto/declarative/declarative.pro b/tests/auto/declarative/declarative.pro
index b9f59d6..02d5a55 100644
--- a/tests/auto/declarative/declarative.pro
+++ b/tests/auto/declarative/declarative.pro
@@ -8,6 +8,7 @@ SUBDIRS += \
examples \
layouts \ # Cover
listview \ # Cover
+ qmlgraphicsgridview \ # Cover
numberformatter \ # Cover
pathview \ # Cover
qfxloader \ # Cover
@@ -30,6 +31,7 @@ SUBDIRS += \
qmlpixmapcache \ # Cover
qmlpropertymap \ # Cover
qmlqt \ # Cover
+ qmlsystempalette \ # Cover
qmltimer \ # Cover
qmlxmllistmodel \ # Cover
repeater \ # Cover
diff --git a/tests/auto/declarative/listview/data/listview-sections.qml b/tests/auto/declarative/listview/data/listview-sections.qml
new file mode 100644
index 0000000..56700be
--- /dev/null
+++ b/tests/auto/declarative/listview/data/listview-sections.qml
@@ -0,0 +1,59 @@
+import Qt 4.6
+
+Rectangle {
+ width: 240
+ height: 320
+ color: "#ffffff"
+ resources: [
+ Component {
+ id: myDelegate
+ Item {
+ id: wrapper
+ objectName: "wrapper"
+ height: ListView.prevSection != ListView.section ? 40 : 20;
+ width: 240
+ Rectangle {
+ y: wrapper.ListView.prevSection != wrapper.ListView.section ? 20 : 0
+ height: 20
+ width: parent.width
+ color: wrapper.ListView.isCurrentItem ? "lightsteelblue" : "white"
+ Text {
+ text: index
+ }
+ Text {
+ x: 30
+ id: textName
+ objectName: "textName"
+ text: name
+ }
+ Text {
+ x: 120
+ id: textNumber
+ objectName: "textNumber"
+ text: number
+ }
+ Text {
+ x: 200
+ text: wrapper.y
+ }
+ }
+ Rectangle {
+ color: "#99bb99"
+ height: wrapper.ListView.prevSection != wrapper.ListView.section ? 20 : 0
+ width: parent.width
+ visible: wrapper.ListView.prevSection != wrapper.ListView.section ? true : false
+ Text { text: wrapper.ListView.section }
+ }
+ }
+ }
+ ]
+ ListView {
+ id: list
+ objectName: "list"
+ width: 240
+ height: 320
+ model: testModel
+ delegate: myDelegate
+ sectionExpression: "Math.floor(index/5)"
+ }
+}
diff --git a/tests/auto/declarative/listview/tst_listview.cpp b/tests/auto/declarative/listview/tst_listview.cpp
index 6bf1080..b8f87b7 100644
--- a/tests/auto/declarative/listview/tst_listview.cpp
+++ b/tests/auto/declarative/listview/tst_listview.cpp
@@ -70,6 +70,8 @@ private slots:
void qAbstractItemModel_moved();
void enforceRange();
+ void spacing();
+ void sections();
private:
template <class T> void items();
@@ -264,6 +266,13 @@ void tst_QmlGraphicsListView::items()
listview->decrementCurrentIndex();
QCOMPARE(listview->currentIndex(), 0);
+ // set an empty model and confirm that items are destroyed
+ T model2;
+ ctxt->setContextProperty("testModel", &model2);
+
+ int itemCount = findItems<QmlGraphicsItem>(viewport, "wrapper").count();
+ QVERIFY(itemCount == 0);
+
delete canvas;
}
@@ -632,6 +641,91 @@ void tst_QmlGraphicsListView::enforceRange()
delete canvas;
}
+void tst_QmlGraphicsListView::spacing()
+{
+ QmlView *canvas = createView(SRCDIR "/data/listview.qml");
+
+ TestModel model;
+ for (int i = 0; i < 30; i++)
+ model.addItem("Item" + QString::number(i), "");
+
+ QmlContext *ctxt = canvas->rootContext();
+ ctxt->setContextProperty("testModel", &model);
+
+ canvas->execute();
+ qApp->processEvents();
+
+ QmlGraphicsListView *listview = findItem<QmlGraphicsListView>(canvas->root(), "list");
+ QVERIFY(listview != 0);
+
+ QmlGraphicsItem *viewport = listview->viewport();
+ QVERIFY(viewport != 0);
+
+ // Confirm items positioned correctly
+ int itemCount = findItems<QmlGraphicsItem>(viewport, "wrapper").count();
+ for (int i = 0; i < model.count() && i < itemCount; ++i) {
+ QmlGraphicsItem *item = findItem<QmlGraphicsItem>(viewport, "wrapper", i);
+ if (!item) qWarning() << "Item" << i << "not found";
+ QVERIFY(item);
+ QVERIFY(item->y() == i*20);
+ }
+
+ listview->setSpacing(10);
+
+ // Confirm items positioned correctly
+ itemCount = findItems<QmlGraphicsItem>(viewport, "wrapper").count();
+ for (int i = 0; i < model.count() && i < itemCount; ++i) {
+ QmlGraphicsItem *item = findItem<QmlGraphicsItem>(viewport, "wrapper", i);
+ if (!item) qWarning() << "Item" << i << "not found";
+ QVERIFY(item);
+ QVERIFY(item->y() == i*30);
+ }
+
+ listview->setSpacing(0);
+
+ // Confirm items positioned correctly
+ itemCount = findItems<QmlGraphicsItem>(viewport, "wrapper").count();
+ for (int i = 0; i < model.count() && i < itemCount; ++i) {
+ QmlGraphicsItem *item = findItem<QmlGraphicsItem>(viewport, "wrapper", i);
+ if (!item) qWarning() << "Item" << i << "not found";
+ QVERIFY(item);
+ QVERIFY(item->y() == i*20);
+ }
+
+ delete canvas;
+}
+
+void tst_QmlGraphicsListView::sections()
+{
+ QmlView *canvas = createView(SRCDIR "/data/listview-sections.qml");
+
+ TestModel model;
+ for (int i = 0; i < 30; i++)
+ model.addItem("Item" + QString::number(i), "");
+
+ QmlContext *ctxt = canvas->rootContext();
+ ctxt->setContextProperty("testModel", &model);
+
+ canvas->execute();
+ qApp->processEvents();
+
+ QmlGraphicsListView *listview = findItem<QmlGraphicsListView>(canvas->root(), "list");
+ QVERIFY(listview != 0);
+
+ QmlGraphicsItem *viewport = listview->viewport();
+ QVERIFY(viewport != 0);
+
+ // Confirm items positioned correctly
+ int itemCount = findItems<QmlGraphicsItem>(viewport, "wrapper").count();
+ for (int i = 0; i < model.count() && i < itemCount; ++i) {
+ QmlGraphicsItem *item = findItem<QmlGraphicsItem>(viewport, "wrapper", i);
+ QVERIFY(item);
+ QCOMPARE(item->y(), qreal(i*20 + ((i+4)/5) * 20));
+ }
+
+ delete canvas;
+}
+
void tst_QmlGraphicsListView::qListModelInterface_items()
{
items<TestModel>();
diff --git a/tests/auto/declarative/qfxloader/tst_qfxloader.cpp b/tests/auto/declarative/qfxloader/tst_qfxloader.cpp
index 9a8f8f1..9a3da90 100644
--- a/tests/auto/declarative/qfxloader/tst_qfxloader.cpp
+++ b/tests/auto/declarative/qfxloader/tst_qfxloader.cpp
@@ -110,14 +110,21 @@ void tst_qfxloader::component()
void tst_qfxloader::clear()
{
- QmlComponent component(&engine, QByteArray("import Qt 4.6\nLoader { source: \"Rect120x60.qml\" }"), QUrl("file://" SRCDIR "/"));
+ QmlComponent component(&engine, QByteArray(
+ "import Qt 4.6\n"
+ " Loader { id: loader\n"
+ " source: 'Rect120x60.qml'\n"
+ " Timer { interval: 200; running: true; onTriggered: loader.source = '' }\n"
+ " }")
+ , QUrl("file://" SRCDIR "/"));
QmlGraphicsLoader *loader = qobject_cast<QmlGraphicsLoader*>(component.create());
QVERIFY(loader != 0);
QVERIFY(loader->item());
QCOMPARE(loader->progress(), 1.0);
QCOMPARE(static_cast<QGraphicsItem*>(loader)->children().count(), 1);
- loader->setSource(QUrl(""));
+ QTest::qWait(500);
+
QVERIFY(loader->item() == 0);
QCOMPARE(loader->progress(), 0.0);
QCOMPARE(static_cast<QGraphicsItem*>(loader)->children().count(), 0);
@@ -136,7 +143,7 @@ void tst_qfxloader::urlToComponent()
"}" )
, QUrl("file://" SRCDIR "/"));
QmlGraphicsLoader *loader = qobject_cast<QmlGraphicsLoader*>(component.create());
- QTest::qWait(1000);
+ QTest::qWait(500);
QVERIFY(loader != 0);
QVERIFY(loader->item());
QCOMPARE(loader->progress(), 1.0);
diff --git a/tests/auto/declarative/qmlfontloader/data/Fontin-Bold.ttf b/tests/auto/declarative/qmlfontloader/data/Fontin-Bold.ttf
deleted file mode 100644
index f6a33b0..0000000
--- a/tests/auto/declarative/qmlfontloader/data/Fontin-Bold.ttf
+++ /dev/null
Binary files differ
diff --git a/tests/auto/declarative/qmlfontloader/data/FreeMono.ttf b/tests/auto/declarative/qmlfontloader/data/FreeMono.ttf
new file mode 100644
index 0000000..d7ce52d
--- /dev/null
+++ b/tests/auto/declarative/qmlfontloader/data/FreeMono.ttf
Binary files differ
diff --git a/tests/auto/declarative/qmlfontloader/tst_qmlfontloader.cpp b/tests/auto/declarative/qmlfontloader/tst_qmlfontloader.cpp
index 23f7025..a5ab13d 100644
--- a/tests/auto/declarative/qmlfontloader/tst_qmlfontloader.cpp
+++ b/tests/auto/declarative/qmlfontloader/tst_qmlfontloader.cpp
@@ -97,13 +97,13 @@ void tst_qmlfontloader::namedFont()
void tst_qmlfontloader::localFont()
{
- QString componentStr = "import Qt 4.6\nFontLoader { source: \"" SRCDIR "/data/Fontin-Bold.ttf\" }";
+ QString componentStr = "import Qt 4.6\nFontLoader { source: \"" SRCDIR "/data/FreeMono.ttf\" }";
QmlComponent component(&engine, componentStr.toLatin1(), QUrl("file://"));
QmlFontLoader *fontObject = qobject_cast<QmlFontLoader*>(component.create());
QVERIFY(fontObject != 0);
QVERIFY(fontObject->source() != QUrl(""));
- QTRY_COMPARE(fontObject->name(), QString("Fontin"));
+ QTRY_COMPARE(fontObject->name(), QString("FreeMono"));
QTRY_VERIFY(fontObject->status() == QmlFontLoader::Ready);
}
diff --git a/tests/auto/declarative/qmlgraphicsgridview/data/gridview.qml b/tests/auto/declarative/qmlgraphicsgridview/data/gridview.qml
new file mode 100644
index 0000000..37eb622
--- /dev/null
+++ b/tests/auto/declarative/qmlgraphicsgridview/data/gridview.qml
@@ -0,0 +1,49 @@
+import Qt 4.6
+
+Rectangle {
+ width: 240
+ height: 320
+ color: "#ffffff"
+ resources: [
+ Component {
+ id: myDelegate
+ Rectangle {
+ id: wrapper
+ objectName: "wrapper"
+ width: 80
+ height: 60
+ border.color: "blue"
+ Text {
+ text: index
+ }
+ Text {
+ x: 40
+ text: wrapper.x + ", " + wrapper.y
+ }
+ Text {
+ y: 20
+ id: textName
+ objectName: "textName"
+ text: name
+ }
+ Text {
+ y: 40
+ id: textNumber
+ objectName: "textNumber"
+ text: number
+ }
+ color: GridView.isCurrentItem ? "lightsteelblue" : "white"
+ }
+ }
+ ]
+ GridView {
+ id: grid
+ objectName: "grid"
+ width: 240
+ height: 320
+ cellWidth: 80
+ cellHeight: 60
+ model: testModel
+ delegate: myDelegate
+ }
+}
diff --git a/tests/auto/declarative/qmlgraphicsgridview/qmlgraphicsgridview.pro b/tests/auto/declarative/qmlgraphicsgridview/qmlgraphicsgridview.pro
new file mode 100644
index 0000000..8eae8ae
--- /dev/null
+++ b/tests/auto/declarative/qmlgraphicsgridview/qmlgraphicsgridview.pro
@@ -0,0 +1,8 @@
+load(qttest_p4)
+contains(QT_CONFIG,declarative): QT += declarative
+macx:CONFIG -= app_bundle
+
+SOURCES += tst_qmlgraphicsgridview.cpp
+
+# Define SRCDIR equal to test's source directory
+DEFINES += SRCDIR=\\\"$$PWD\\\"
diff --git a/tests/auto/declarative/qmlgraphicsgridview/tst_qmlgraphicsgridview.cpp b/tests/auto/declarative/qmlgraphicsgridview/tst_qmlgraphicsgridview.cpp
new file mode 100644
index 0000000..c6ea25a
--- /dev/null
+++ b/tests/auto/declarative/qmlgraphicsgridview/tst_qmlgraphicsgridview.cpp
@@ -0,0 +1,585 @@
+/****************************************************************************
+**
+** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
+** All rights reserved.
+** Contact: Nokia Corporation (qt-info@nokia.com)
+**
+** This file is part of the test suite of the Qt Toolkit.
+**
+** $QT_BEGIN_LICENSE:LGPL$
+** No Commercial Usage
+** This file contains pre-release code and may not be distributed.
+** You may use this file in accordance with the terms and conditions
+** contained in the Technology Preview License Agreement accompanying
+** this package.
+**
+** GNU Lesser General Public License Usage
+** Alternatively, this file may be used under the terms of the GNU Lesser
+** General Public License version 2.1 as published by the Free Software
+** Foundation and appearing in the file LICENSE.LGPL included in the
+** packaging of this file. Please review the following information to
+** ensure the GNU Lesser General Public License version 2.1 requirements
+** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
+**
+** In addition, as a special exception, Nokia gives you certain additional
+** rights. These rights are described in the Nokia Qt LGPL Exception
+** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
+**
+** If you have questions regarding the use of this file, please contact
+** Nokia at qt-info@nokia.com.
+**
+**
+**
+**
+**
+**
+**
+**
+** $QT_END_LICENSE$
+**
+****************************************************************************/
+#include <QtTest/QtTest>
+#include <private/qlistmodelinterface_p.h>
+#include <qmlview.h>
+#include <private/qmlgraphicsgridview_p.h>
+#include <private/qmlgraphicstext_p.h>
+#include <qmlcontext.h>
+#include <qmlexpression.h>
+
+class tst_QmlGraphicsGridView : public QObject
+{
+ Q_OBJECT
+public:
+ tst_QmlGraphicsGridView();
+
+private slots:
+ void items();
+ void changed();
+ void inserted();
+ void removed();
+ void moved();
+
+private:
+ QmlView *createView(const QString &filename);
+ template<typename T>
+ T *findItem(QmlGraphicsItem *parent, const QString &id, int index=-1);
+ template<typename T>
+ QList<T*> findItems(QmlGraphicsItem *parent, const QString &objectName);
+};
+
+class TestModel : public QAbstractListModel
+{
+public:
+ enum Roles { Name = Qt::UserRole+1, Number = Qt::UserRole+2 };
+
+ TestModel(QObject *parent=0) : QAbstractListModel(parent) {
+ QHash<int, QByteArray> roles;
+ roles[Name] = "name";
+ roles[Number] = "number";
+ setRoleNames(roles);
+ }
+
+ int rowCount(const QModelIndex &parent=QModelIndex()) const { return list.count(); }
+ QVariant data(const QModelIndex &index, int role=Qt::DisplayRole) const {
+ QVariant rv;
+ if (role == Name)
+ rv = list.at(index.row()).first;
+ else if (role == Number)
+ rv = list.at(index.row()).second;
+
+ return rv;
+ }
+
+ int count() const { return rowCount(); }
+ QString name(int index) const { return list.at(index).first; }
+ QString number(int index) const { return list.at(index).second; }
+
+ void addItem(const QString &name, const QString &number) {
+ emit beginInsertRows(QModelIndex(), list.count(), list.count());
+ list.append(QPair<QString,QString>(name, number));
+ emit endInsertRows();
+ }
+
+ void insertItem(int index, const QString &name, const QString &number) {
+ emit beginInsertRows(QModelIndex(), index, index);
+ list.insert(index, QPair<QString,QString>(name, number));
+ emit endInsertRows();
+ }
+
+ void removeItem(int index) {
+ emit beginRemoveRows(QModelIndex(), index, index);
+ list.removeAt(index);
+ emit endRemoveRows();
+ }
+
+ void moveItem(int from, int to) {
+ emit beginMoveRows(QModelIndex(), from, from, QModelIndex(), to);
+ list.move(from, to);
+ emit endMoveRows();
+ }
+
+ void modifyItem(int idx, const QString &name, const QString &number) {
+ list[idx] = QPair<QString,QString>(name, number);
+ emit dataChanged(index(idx,0), index(idx,0));
+ }
+
+private:
+ QList<QPair<QString,QString> > list;
+};
+
+tst_QmlGraphicsGridView::tst_QmlGraphicsGridView()
+{
+}
+
+void tst_QmlGraphicsGridView::items()
+{
+ QmlView *canvas = createView(SRCDIR "/data/gridview.qml");
+
+ TestModel model;
+ model.addItem("Fred", "12345");
+ model.addItem("John", "2345");
+ model.addItem("Bob", "54321");
+ model.addItem("Billy", "22345");
+ model.addItem("Sam", "2945");
+ model.addItem("Ben", "04321");
+ model.addItem("Jim", "0780");
+
+ QmlContext *ctxt = canvas->rootContext();
+ ctxt->setContextProperty("testModel", &model);
+
+ canvas->execute();
+ qApp->processEvents();
+
+ QmlGraphicsGridView *gridview = findItem<QmlGraphicsGridView>(canvas->root(), "grid");
+ QVERIFY(gridview != 0);
+
+ QmlGraphicsItem *viewport = gridview->viewport();
+ QVERIFY(viewport != 0);
+
+ QCOMPARE(gridview->count(), model.count());
+ QCOMPARE(viewport->childItems().count(), model.count()+1); // assumes all are visible, +1 for the (default) highlight item
+
+ for (int i = 0; i < model.count(); ++i) {
+ QmlGraphicsText *name = findItem<QmlGraphicsText>(viewport, "textName", i);
+ QVERIFY(name != 0);
+ QCOMPARE(name->text(), model.name(i));
+ QmlGraphicsText *number = findItem<QmlGraphicsText>(viewport, "textNumber", i);
+ QVERIFY(number != 0);
+ QCOMPARE(number->text(), model.number(i));
+ }
+
+ gridview->moveCurrentIndexRight();
+ QCOMPARE(gridview->currentIndex(), 1);
+ gridview->moveCurrentIndexDown();
+ QCOMPARE(gridview->currentIndex(), 4);
+ gridview->moveCurrentIndexUp();
+ QCOMPARE(gridview->currentIndex(), 1);
+ gridview->moveCurrentIndexLeft();
+ QCOMPARE(gridview->currentIndex(), 0);
+
+ // set an empty model and confirm that items are destroyed
+ TestModel model2;
+ ctxt->setContextProperty("testModel", &model2);
+
+ int itemCount = findItems<QmlGraphicsItem>(viewport, "wrapper").count();
+ QVERIFY(itemCount == 0);
+
+ delete canvas;
+}
+
+void tst_QmlGraphicsGridView::changed()
+{
+ QmlView *canvas = createView(SRCDIR "/data/gridview.qml");
+
+ TestModel model;
+ model.addItem("Fred", "12345");
+ model.addItem("John", "2345");
+ model.addItem("Bob", "54321");
+ model.addItem("Billy", "22345");
+ model.addItem("Sam", "2945");
+ model.addItem("Ben", "04321");
+ model.addItem("Jim", "0780");
+
+ QmlContext *ctxt = canvas->rootContext();
+ ctxt->setContextProperty("testModel", &model);
+
+ canvas->execute();
+ qApp->processEvents();
+
+ QmlGraphicsFlickable *gridview = findItem<QmlGraphicsFlickable>(canvas->root(), "grid");
+ QVERIFY(gridview != 0);
+
+ QmlGraphicsItem *viewport = gridview->viewport();
+ QVERIFY(viewport != 0);
+
+ model.modifyItem(1, "Will", "9876");
+ QmlGraphicsText *name = findItem<QmlGraphicsText>(viewport, "textName", 1);
+ QVERIFY(name != 0);
+ QCOMPARE(name->text(), model.name(1));
+ QmlGraphicsText *number = findItem<QmlGraphicsText>(viewport, "textNumber", 1);
+ QVERIFY(number != 0);
+ QCOMPARE(number->text(), model.number(1));
+
+ delete canvas;
+}
+
+void tst_QmlGraphicsGridView::inserted()
+{
+ QmlView *canvas = createView(SRCDIR "/data/gridview.qml");
+
+ TestModel model;
+ model.addItem("Fred", "12345");
+ model.addItem("John", "2345");
+ model.addItem("Bob", "54321");
+
+ QmlContext *ctxt = canvas->rootContext();
+ ctxt->setContextProperty("testModel", &model);
+
+ canvas->execute();
+ qApp->processEvents();
+
+ QmlGraphicsGridView *gridview = findItem<QmlGraphicsGridView>(canvas->root(), "grid");
+ QVERIFY(gridview != 0);
+
+ QmlGraphicsItem *viewport = gridview->viewport();
+ QVERIFY(viewport != 0);
+
+ model.insertItem(1, "Will", "9876");
+
+ // let transitions settle.
+ QTest::qWait(300);
+
+ QCOMPARE(viewport->childItems().count(), model.count()+1); // assumes all are visible, +1 for the (default) highlight item
+
+ QmlGraphicsText *name = findItem<QmlGraphicsText>(viewport, "textName", 1);
+ QVERIFY(name != 0);
+ QCOMPARE(name->text(), model.name(1));
+ QmlGraphicsText *number = findItem<QmlGraphicsText>(viewport, "textNumber", 1);
+ QVERIFY(number != 0);
+ QCOMPARE(number->text(), model.number(1));
+
+ // Confirm items positioned correctly
+ for (int i = 0; i < model.count(); ++i) {
+ QmlGraphicsItem *item = findItem<QmlGraphicsItem>(viewport, "wrapper", i);
+ QVERIFY(item->x() == (i%3)*80);
+ QVERIFY(item->y() == (i/3)*60);
+ }
+
+ model.insertItem(0, "Foo", "1111"); // zero index, and current item
+
+ // let transitions settle.
+ QTest::qWait(300);
+
+ QCOMPARE(viewport->childItems().count(), model.count()+1); // assumes all are visible, +1 for the (default) highlight item
+
+ name = findItem<QmlGraphicsText>(viewport, "textName", 0);
+ QVERIFY(name != 0);
+ QCOMPARE(name->text(), model.name(0));
+ number = findItem<QmlGraphicsText>(viewport, "textNumber", 0);
+ QVERIFY(number != 0);
+ QCOMPARE(number->text(), model.number(0));
+
+ QCOMPARE(gridview->currentIndex(), 1);
+
+ // Confirm items positioned correctly
+ for (int i = 0; i < model.count(); ++i) {
+ QmlGraphicsItem *item = findItem<QmlGraphicsItem>(viewport, "wrapper", i);
+ QVERIFY(item->x() == (i%3)*80);
+ QVERIFY(item->y() == (i/3)*60);
+ }
+
+ for (int i = model.count(); i < 30; ++i)
+ model.insertItem(i, "Hello", QString::number(i));
+ QTest::qWait(300);
+
+ gridview->setViewportY(120);
+ QTest::qWait(300);
+
+ // Insert item outside visible area
+ model.insertItem(1, "Hello", "1324");
+ QTest::qWait(300);
+
+ QVERIFY(gridview->viewportY() == 120);
+
+ delete canvas;
+}
+
+void tst_QmlGraphicsGridView::removed()
+{
+ QmlView *canvas = createView(SRCDIR "/data/gridview.qml");
+
+ TestModel model;
+ for (int i = 0; i < 30; i++)
+ model.addItem("Item" + QString::number(i), "");
+
+ QmlContext *ctxt = canvas->rootContext();
+ ctxt->setContextProperty("testModel", &model);
+
+ canvas->execute();
+ qApp->processEvents();
+
+ QmlGraphicsGridView *gridview = findItem<QmlGraphicsGridView>(canvas->root(), "grid");
+ QVERIFY(gridview != 0);
+
+ QmlGraphicsItem *viewport = gridview->viewport();
+ QVERIFY(viewport != 0);
+
+ model.removeItem(1);
+
+ // let transitions settle.
+ QTest::qWait(300);
+
+ QmlGraphicsText *name = findItem<QmlGraphicsText>(viewport, "textName", 1);
+ QVERIFY(name != 0);
+ QCOMPARE(name->text(), model.name(1));
+ QmlGraphicsText *number = findItem<QmlGraphicsText>(viewport, "textNumber", 1);
+ QVERIFY(number != 0);
+ QCOMPARE(number->text(), model.number(1));
+
+ // Confirm items positioned correctly
+ int itemCount = findItems<QmlGraphicsItem>(viewport, "wrapper").count();
+ for (int i = 0; i < model.count() && i < itemCount; ++i) {
+ QmlGraphicsItem *item = findItem<QmlGraphicsItem>(viewport, "wrapper", i);
+ if (!item) qWarning() << "Item" << i << "not found";
+ QVERIFY(item);
+ QVERIFY(item->x() == (i%3)*80);
+ QVERIFY(item->y() == (i/3)*60);
+ }
+
+ // Remove first item (which is the current item);
+ model.removeItem(0);
+
+ // let transitions settle.
+ QTest::qWait(300);
+
+ name = findItem<QmlGraphicsText>(viewport, "textName", 0);
+ QVERIFY(name != 0);
+ QCOMPARE(name->text(), model.name(0));
+ number = findItem<QmlGraphicsText>(viewport, "textNumber", 0);
+ QVERIFY(number != 0);
+ QCOMPARE(number->text(), model.number(0));
+
+ // Confirm items positioned correctly
+ itemCount = findItems<QmlGraphicsItem>(viewport, "wrapper").count();
+ for (int i = 0; i < model.count() && i < itemCount; ++i) {
+ QmlGraphicsItem *item = findItem<QmlGraphicsItem>(viewport, "wrapper", i);
+ if (!item) qWarning() << "Item" << i << "not found";
+ QVERIFY(item);
+ QVERIFY(item->x() == (i%3)*80);
+ QVERIFY(item->y() == (i/3)*60);
+ }
+
+ // Remove items not visible
+ model.removeItem(25);
+ // let transitions settle.
+ QTest::qWait(300);
+
+ // Confirm items positioned correctly
+ itemCount = findItems<QmlGraphicsItem>(viewport, "wrapper").count();
+ for (int i = 0; i < model.count() && i < itemCount; ++i) {
+ QmlGraphicsItem *item = findItem<QmlGraphicsItem>(viewport, "wrapper", i);
+ if (!item) qWarning() << "Item" << i << "not found";
+ QVERIFY(item);
+ QVERIFY(item->x() == (i%3)*80);
+ QVERIFY(item->y() == (i/3)*60);
+ }
+
+ // Remove items before visible
+ gridview->setViewportY(120);
+ gridview->setCurrentIndex(10);
+
+ model.removeItem(1);
+ // let transitions settle.
+ QTest::qWait(300);
+
+ // Confirm items positioned correctly
+ for (int i = 6; i < 18; ++i) {
+ QmlGraphicsItem *item = findItem<QmlGraphicsItem>(viewport, "wrapper", i);
+ if (!item) qWarning() << "Item" << i << "not found";
+ QVERIFY(item);
+ QVERIFY(item->x() == (i%3)*80);
+ QVERIFY(item->y() == (i/3)*60);
+ }
+
+ gridview->setViewportY(0);
+ // let transitions settle.
+ QTest::qWait(300);
+
+ // Confirm items positioned correctly
+ itemCount = findItems<QmlGraphicsItem>(viewport, "wrapper").count();
+ for (int i = 0; i < model.count() && i < itemCount; ++i) {
+ QmlGraphicsItem *item = findItem<QmlGraphicsItem>(viewport, "wrapper", i);
+ if (!item) qWarning() << "Item" << i << "not found";
+ QVERIFY(item);
+ QVERIFY(item->x() == (i%3)*80);
+ QVERIFY(item->y() == (i/3)*60);
+ }
+
+ delete canvas;
+}
+
+void tst_QmlGraphicsGridView::moved()
+{
+ QmlView *canvas = createView(SRCDIR "/data/gridview.qml");
+
+ TestModel model;
+ for (int i = 0; i < 30; i++)
+ model.addItem("Item" + QString::number(i), "");
+
+ QmlContext *ctxt = canvas->rootContext();
+ ctxt->setContextProperty("testModel", &model);
+
+ canvas->execute();
+ qApp->processEvents();
+
+ QmlGraphicsGridView *gridview = findItem<QmlGraphicsGridView>(canvas->root(), "grid");
+ QVERIFY(gridview != 0);
+
+ QmlGraphicsItem *viewport = gridview->viewport();
+ QVERIFY(viewport != 0);
+
+ model.moveItem(1, 8);
+
+ // let transitions settle.
+ QTest::qWait(300);
+
+ QmlGraphicsText *name = findItem<QmlGraphicsText>(viewport, "textName", 1);
+ QVERIFY(name != 0);
+ QCOMPARE(name->text(), model.name(1));
+ QmlGraphicsText *number = findItem<QmlGraphicsText>(viewport, "textNumber", 1);
+ QVERIFY(number != 0);
+ QCOMPARE(number->text(), model.number(1));
+
+ name = findItem<QmlGraphicsText>(viewport, "textName", 8);
+ QVERIFY(name != 0);
+ QCOMPARE(name->text(), model.name(8));
+ number = findItem<QmlGraphicsText>(viewport, "textNumber", 8);
+ QVERIFY(number != 0);
+ QCOMPARE(number->text(), model.number(8));
+
+ // Confirm items positioned correctly
+ int itemCount = findItems<QmlGraphicsItem>(viewport, "wrapper").count();
+ for (int i = 0; i < model.count() && i < itemCount; ++i) {
+ QmlGraphicsItem *item = findItem<QmlGraphicsItem>(viewport, "wrapper", i);
+ if (!item) qWarning() << "Item" << i << "not found";
+ QVERIFY(item);
+ QVERIFY(item->x() == (i%3)*80);
+ QVERIFY(item->y() == (i/3)*60);
+ }
+
+ gridview->setViewportY(120);
+
+ // move outside visible area
+ model.moveItem(1, 25);
+
+ // let transitions settle.
+ QTest::qWait(300);
+
+ // Confirm items positioned correctly and indexes correct
+ itemCount = findItems<QmlGraphicsItem>(viewport, "wrapper").count();
+ for (int i = 3; i < model.count() && i < itemCount; ++i) {
+ QmlGraphicsItem *item = findItem<QmlGraphicsItem>(viewport, "wrapper", i);
+ if (!item) qWarning() << "Item" << i << "not found";
+ QVERIFY(item);
+ QCOMPARE(item->x(), qreal((i%3)*80));
+ QCOMPARE(item->y(), qreal((i/3)*60 + 60));
+ name = findItem<QmlGraphicsText>(viewport, "textName", i);
+ QVERIFY(name != 0);
+ QCOMPARE(name->text(), model.name(i));
+ number = findItem<QmlGraphicsText>(viewport, "textNumber", i);
+ QVERIFY(number != 0);
+ QCOMPARE(number->text(), model.number(i));
+ }
+
+ // move from outside visible into visible
+ model.moveItem(28, 8);
+
+ // let transitions settle.
+ QTest::qWait(300);
+
+ // Confirm items positioned correctly and indexes correct
+ for (int i = 3; i < model.count() && i < itemCount; ++i) {
+ QmlGraphicsItem *item = findItem<QmlGraphicsItem>(viewport, "wrapper", i);
+ if (!item) qWarning() << "Item" << i << "not found";
+ QVERIFY(item);
+ QVERIFY(item->x() == (i%3)*80);
+ QVERIFY(item->y() == (i/3)*60 + 60);
+ name = findItem<QmlGraphicsText>(viewport, "textName", i);
+ QVERIFY(name != 0);
+ QCOMPARE(name->text(), model.name(i));
+ number = findItem<QmlGraphicsText>(viewport, "textNumber", i);
+ QVERIFY(number != 0);
+ QCOMPARE(number->text(), model.number(i));
+ }
+
+ delete canvas;
+}
+
+QmlView *tst_QmlGraphicsGridView::createView(const QString &filename)
+{
+ QmlView *canvas = new QmlView(0);
+ canvas->setFixedSize(240,320);
+
+ QFile file(filename);
+ file.open(QFile::ReadOnly);
+ QString qml = file.readAll();
+ canvas->setQml(qml, filename);
+
+ return canvas;
+}
+
+/*
+ Find an item with the specified objectName. If index is supplied then the
+ item must also evaluate the {index} expression equal to index
+*/
+template<typename T>
+T *tst_QmlGraphicsGridView::findItem(QmlGraphicsItem *parent, const QString &objectName, int index)
+{
+ const QMetaObject &mo = T::staticMetaObject;
+ //qDebug() << parent->QGraphicsObject::children().count() << "children";
+ for (int i = 0; i < parent->QGraphicsObject::children().count(); ++i) {
+ QmlGraphicsItem *item = qobject_cast<QmlGraphicsItem*>(parent->QGraphicsObject::children().at(i));
+ if(!item)
+ continue;
+ //qDebug() << "try" << item;
+ if (mo.cast(item) && (objectName.isEmpty() || item->objectName() == objectName)) {
+ if (index != -1) {
+ QmlExpression e(qmlContext(item), "index", item);
+ e.setTrackChange(false);
+ if (e.value().toInt() == index)
+ return static_cast<T*>(item);
+ } else {
+ return static_cast<T*>(item);
+ }
+ }
+ item = findItem<T>(item, objectName, index);
+ if (item)
+ return static_cast<T*>(item);
+ }
+
+ return 0;
+}
+
+template<typename T>
+QList<T*> tst_QmlGraphicsGridView::findItems(QmlGraphicsItem *parent, const QString &objectName)
+{
+ QList<T*> items;
+ const QMetaObject &mo = T::staticMetaObject;
+ //qDebug() << parent->QGraphicsObject::children().count() << "children";
+ for (int i = 0; i < parent->QGraphicsObject::children().count(); ++i) {
+ QmlGraphicsItem *item = qobject_cast<QmlGraphicsItem*>(parent->QGraphicsObject::children().at(i));
+ if(!item)
+ continue;
+ //qDebug() << "try" << item;
+ if (mo.cast(item) && (objectName.isEmpty() || item->objectName() == objectName))
+ items.append(static_cast<T*>(item));
+ items += findItems<T>(item, objectName);
+ }
+
+ return items;
+}
+
+
+QTEST_MAIN(tst_QmlGraphicsGridView)
+
+#include "tst_qmlgraphicsgridview.moc"
diff --git a/tests/auto/declarative/qmlsystempalette/qmlsystempalette.pro b/tests/auto/declarative/qmlsystempalette/qmlsystempalette.pro
new file mode 100644
index 0000000..4d55b46
--- /dev/null
+++ b/tests/auto/declarative/qmlsystempalette/qmlsystempalette.pro
@@ -0,0 +1,5 @@
+load(qttest_p4)
+contains(QT_CONFIG,declarative): QT += declarative gui
+macx:CONFIG -= app_bundle
+
+SOURCES += tst_qmlsystempalette.cpp
diff --git a/tests/auto/declarative/qmlsystempalette/tst_qmlsystempalette.cpp b/tests/auto/declarative/qmlsystempalette/tst_qmlsystempalette.cpp
new file mode 100644
index 0000000..039eaa8
--- /dev/null
+++ b/tests/auto/declarative/qmlsystempalette/tst_qmlsystempalette.cpp
@@ -0,0 +1,154 @@
+/****************************************************************************
+**
+** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
+** All rights reserved.
+** Contact: Nokia Corporation (qt-info@nokia.com)
+**
+** This file is part of the test suite of the Qt Toolkit.
+**
+** $QT_BEGIN_LICENSE:LGPL$
+** No Commercial Usage
+** This file contains pre-release code and may not be distributed.
+** You may use this file in accordance with the terms and conditions
+** contained in the Technology Preview License Agreement accompanying
+** this package.
+**
+** GNU Lesser General Public License Usage
+** Alternatively, this file may be used under the terms of the GNU Lesser
+** General Public License version 2.1 as published by the Free Software
+** Foundation and appearing in the file LICENSE.LGPL included in the
+** packaging of this file. Please review the following information to
+** ensure the GNU Lesser General Public License version 2.1 requirements
+** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
+**
+** In addition, as a special exception, Nokia gives you certain additional
+** rights. These rights are described in the Nokia Qt LGPL Exception
+** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
+**
+** If you have questions regarding the use of this file, please contact
+** Nokia at qt-info@nokia.com.
+**
+**
+**
+**
+**
+**
+**
+**
+** $QT_END_LICENSE$
+**
+****************************************************************************/
+#include <qtest.h>
+#include <QtDeclarative/qmlengine.h>
+#include <QtDeclarative/qmlcomponent.h>
+#include <private/qmlsystempalette_p.h>
+#include <qpalette.h>
+#include "../../../shared/util.h"
+
+class tst_qmlsystempalette : public QObject
+
+{
+ Q_OBJECT
+public:
+ tst_qmlsystempalette();
+
+private slots:
+ void activePalette();
+ void inactivePalette();
+ void disabledPalette();
+
+private:
+ QmlEngine engine;
+};
+
+tst_qmlsystempalette::tst_qmlsystempalette()
+{
+}
+
+void tst_qmlsystempalette::activePalette()
+{
+ QString componentStr = "import Qt 4.6\nSystemPalette { }";
+ QmlComponent component(&engine, componentStr.toLatin1(), QUrl("file://"));
+ QmlSystemPalette *object = qobject_cast<QmlSystemPalette*>(component.create());
+
+ QVERIFY(object != 0);
+
+ QPalette palette;
+ palette.setCurrentColorGroup(QPalette::Active);
+ QCOMPARE(palette.window().color(), object->window());
+ QCOMPARE(palette.windowText().color(), object->windowText());
+ QCOMPARE(palette.base().color(), object->base());
+ QCOMPARE(palette.text().color(), object->text());
+ QCOMPARE(palette.alternateBase().color(), object->alternateBase());
+ QCOMPARE(palette.button().color(), object->button());
+ QCOMPARE(palette.buttonText().color(), object->buttonText());
+ QCOMPARE(palette.light().color(), object->light());
+ QCOMPARE(palette.midlight().color(), object->midlight());
+ QCOMPARE(palette.dark().color(), object->dark());
+ QCOMPARE(palette.mid().color(), object->mid());
+ QCOMPARE(palette.shadow().color(), object->shadow());
+ QCOMPARE(palette.highlight().color(), object->highlight());
+ QCOMPARE(palette.highlightedText().color(), object->highlightedText());
+
+ delete object;
+}
+
+void tst_qmlsystempalette::inactivePalette()
+{
+ QString componentStr = "import Qt 4.6\nSystemPalette { colorGroup: SystemPalette.Inactive }";
+ QmlComponent component(&engine, componentStr.toLatin1(), QUrl("file://"));
+ QmlSystemPalette *object = qobject_cast<QmlSystemPalette*>(component.create());
+
+ QVERIFY(object != 0);
+
+ QPalette palette;
+ palette.setCurrentColorGroup(QPalette::Inactive);
+ QCOMPARE(palette.window().color(), object->window());
+ QCOMPARE(palette.windowText().color(), object->windowText());
+ QCOMPARE(palette.base().color(), object->base());
+ QCOMPARE(palette.text().color(), object->text());
+ QCOMPARE(palette.alternateBase().color(), object->alternateBase());
+ QCOMPARE(palette.button().color(), object->button());
+ QCOMPARE(palette.buttonText().color(), object->buttonText());
+ QCOMPARE(palette.light().color(), object->light());
+ QCOMPARE(palette.midlight().color(), object->midlight());
+ QCOMPARE(palette.dark().color(), object->dark());
+ QCOMPARE(palette.mid().color(), object->mid());
+ QCOMPARE(palette.shadow().color(), object->shadow());
+ QCOMPARE(palette.highlight().color(), object->highlight());
+ QCOMPARE(palette.highlightedText().color(), object->highlightedText());
+
+ delete object;
+}
+
+void tst_qmlsystempalette::disabledPalette()
+{
+ QString componentStr = "import Qt 4.6\nSystemPalette { colorGroup: SystemPalette.Disabled }";
+ QmlComponent component(&engine, componentStr.toLatin1(), QUrl("file://"));
+ QmlSystemPalette *object = qobject_cast<QmlSystemPalette*>(component.create());
+
+ QVERIFY(object != 0);
+
+ QPalette palette;
+ palette.setCurrentColorGroup(QPalette::Disabled);
+ QCOMPARE(palette.window().color(), object->window());
+ QCOMPARE(palette.windowText().color(), object->windowText());
+ QCOMPARE(palette.base().color(), object->base());
+ QCOMPARE(palette.text().color(), object->text());
+ QCOMPARE(palette.alternateBase().color(), object->alternateBase());
+ QCOMPARE(palette.button().color(), object->button());
+ QCOMPARE(palette.buttonText().color(), object->buttonText());
+ QCOMPARE(palette.light().color(), object->light());
+ QCOMPARE(palette.midlight().color(), object->midlight());
+ QCOMPARE(palette.dark().color(), object->dark());
+ QCOMPARE(palette.mid().color(), object->mid());
+ QCOMPARE(palette.shadow().color(), object->shadow());
+ QCOMPARE(palette.highlight().color(), object->highlight());
+ QCOMPARE(palette.highlightedText().color(), object->highlightedText());
+
+ delete object;
+}
+
+QTEST_MAIN(tst_qmlsystempalette)
+
+#include "tst_qmlsystempalette.moc"
diff --git a/tests/auto/declarative/valuetypes/testtypes.cpp b/tests/auto/declarative/valuetypes/testtypes.cpp
index d57afaf..f0fdaf8 100644
--- a/tests/auto/declarative/valuetypes/testtypes.cpp
+++ b/tests/auto/declarative/valuetypes/testtypes.cpp
@@ -40,4 +40,4 @@
****************************************************************************/
#include "testtypes.h"
-QML_DEFINE_TYPE(Test, 1, 0, 0, MyTypeObject, MyTypeObject);
+QML_DEFINE_TYPE(Test, 1, 0, MyTypeObject, MyTypeObject);
diff --git a/tests/auto/declarative/visual/fillmode/data-MAC/fillmode.0.png b/tests/auto/declarative/visual/fillmode/data-MAC/fillmode.0.png
new file mode 100644
index 0000000..9c9ceae
--- /dev/null
+++ b/tests/auto/declarative/visual/fillmode/data-MAC/fillmode.0.png
Binary files differ
diff --git a/tests/auto/declarative/visual/fillmode/data-MAC/fillmode.qml b/tests/auto/declarative/visual/fillmode/data-MAC/fillmode.qml
new file mode 100644
index 0000000..7ac6f51
--- /dev/null
+++ b/tests/auto/declarative/visual/fillmode/data-MAC/fillmode.qml
@@ -0,0 +1,279 @@
+import Qt.VisualTest 4.6
+
+VisualTest {
+ Frame {
+ msec: 0
+ }
+ Frame {
+ msec: 16
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 32
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 48
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 64
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 80
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 96
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 112
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 128
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 144
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 160
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 176
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 192
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 208
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 224
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 240
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 256
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 272
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 288
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 304
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 320
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 336
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 352
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 368
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 384
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 400
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 416
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 432
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 448
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 464
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 480
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 496
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 512
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 528
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 544
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 560
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 576
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 592
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 608
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 624
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 640
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 656
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 672
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 688
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 704
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Key {
+ type: 6
+ key: 16777249
+ modifiers: 0
+ text: ""
+ autorep: false
+ count: 1
+ }
+ Frame {
+ msec: 720
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 736
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 752
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 768
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 784
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 800
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 816
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 832
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 848
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 864
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 880
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 896
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 912
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 928
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 944
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 960
+ image: "fillmode.0.png"
+ }
+ Frame {
+ msec: 976
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 992
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 1008
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 1024
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 1040
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 1056
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+}
diff --git a/tests/auto/declarative/visual/fillmode/data/fillmode.0.png b/tests/auto/declarative/visual/fillmode/data/fillmode.0.png
new file mode 100644
index 0000000..9c9ceae
--- /dev/null
+++ b/tests/auto/declarative/visual/fillmode/data/fillmode.0.png
Binary files differ
diff --git a/tests/auto/declarative/visual/fillmode/data/fillmode.qml b/tests/auto/declarative/visual/fillmode/data/fillmode.qml
new file mode 100644
index 0000000..58af8e8
--- /dev/null
+++ b/tests/auto/declarative/visual/fillmode/data/fillmode.qml
@@ -0,0 +1,279 @@
+import Qt.VisualTest 4.6
+
+VisualTest {
+ Frame {
+ msec: 0
+ }
+ Frame {
+ msec: 16
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 32
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 48
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 64
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 80
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 96
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 112
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 128
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 144
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 160
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 176
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 192
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 208
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 224
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 240
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 256
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 272
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 288
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 304
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 320
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 336
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 352
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 368
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 384
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 400
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 416
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 432
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 448
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 464
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 480
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 496
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 512
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 528
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 544
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 560
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 576
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 592
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 608
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 624
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 640
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 656
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 672
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 688
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 704
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Key {
+ type: 6
+ key: 16777249
+ modifiers: 67108864
+ text: ""
+ autorep: false
+ count: 1
+ }
+ Frame {
+ msec: 720
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 736
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 752
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 768
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 784
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 800
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 816
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 832
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 848
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 864
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 880
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 896
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 912
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 928
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 944
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 960
+ image: "fillmode.0.png"
+ }
+ Frame {
+ msec: 976
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 992
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 1008
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 1024
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 1040
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+ Frame {
+ msec: 1056
+ hash: "c8cb8d51ca04231dc272133faaf2fb6d"
+ }
+}
diff --git a/tests/auto/declarative/visual/fillmode/face.png b/tests/auto/declarative/visual/fillmode/face.png
new file mode 100644
index 0000000..9623b1a
--- /dev/null
+++ b/tests/auto/declarative/visual/fillmode/face.png
Binary files differ
diff --git a/tests/auto/declarative/visual/fillmode/fillmode.qml b/tests/auto/declarative/visual/fillmode/fillmode.qml
new file mode 100644
index 0000000..8450bf2
--- /dev/null
+++ b/tests/auto/declarative/visual/fillmode/fillmode.qml
@@ -0,0 +1,16 @@
+import Qt 4.6
+
+Rectangle {
+ id: screen; width: 750; height: 600; color: "gray"
+ property string source: "face.png"
+
+ Grid {
+ columns: 3
+ Image { width: 250; height: 300; source: screen.source; fillMode: Image.Stretch }
+ Image { width: 250; height: 300; source: screen.source; fillMode: Image.PreserveAspectFit; smooth: true }
+ Image { width: 250; height: 300; source: screen.source; fillMode: Image.PreserveAspectCrop }
+ Image { width: 250; height: 300; source: screen.source; fillMode: Image.Tile; smooth: true }
+ Image { width: 250; height: 300; source: screen.source; fillMode: Image.TileHorizontally }
+ Image { width: 250; height: 300; source: screen.source; fillMode: Image.TileVertically }
+ }
+}
diff --git a/tests/auto/declarative/visual/qfxtext/font/data-MAC/plaintext.0.png b/tests/auto/declarative/visual/qfxtext/font/data-MAC/plaintext.0.png
index 50d56dc..a54a327 100644
--- a/tests/auto/declarative/visual/qfxtext/font/data-MAC/plaintext.0.png
+++ b/tests/auto/declarative/visual/qfxtext/font/data-MAC/plaintext.0.png
Binary files differ
diff --git a/tests/auto/declarative/visual/qfxtext/font/data-MAC/plaintext.qml b/tests/auto/declarative/visual/qfxtext/font/data-MAC/plaintext.qml
index 63e20d4..266c9a3 100644
--- a/tests/auto/declarative/visual/qfxtext/font/data-MAC/plaintext.qml
+++ b/tests/auto/declarative/visual/qfxtext/font/data-MAC/plaintext.qml
@@ -6,239 +6,239 @@ VisualTest {
}
Frame {
msec: 16
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 32
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 48
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 64
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 80
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 96
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 112
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 128
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 144
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 160
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 176
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 192
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 208
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 224
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 240
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 256
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 272
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 288
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 304
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 320
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 336
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 352
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 368
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 384
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 400
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 416
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 432
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 448
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 464
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 480
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 496
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 512
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 528
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 544
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 560
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 576
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 592
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 608
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 624
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 640
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 656
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 672
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 688
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 704
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 720
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 736
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 752
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 768
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 784
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 800
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 816
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 832
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 848
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 864
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 880
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 896
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 912
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 928
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 944
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 960
@@ -246,59 +246,59 @@ VisualTest {
}
Frame {
msec: 976
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 992
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 1008
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 1024
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 1040
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 1056
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 1072
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 1088
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 1104
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 1120
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 1136
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 1152
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 1168
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 1184
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Key {
type: 6
@@ -310,42 +310,42 @@ VisualTest {
}
Frame {
msec: 1200
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 1216
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 1232
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 1248
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 1264
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 1280
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 1296
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 1312
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 1328
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
Frame {
msec: 1344
- hash: "d553014bc56a46787e30459b0f44f57a"
+ hash: "9f3d0a505dec1982d9b405be72c265f8"
}
}
diff --git a/tests/auto/declarative/visual/qfxtext/font/data-MAC/richtext.0.png b/tests/auto/declarative/visual/qfxtext/font/data-MAC/richtext.0.png
index 2910670..c2ddee1 100644
--- a/tests/auto/declarative/visual/qfxtext/font/data-MAC/richtext.0.png
+++ b/tests/auto/declarative/visual/qfxtext/font/data-MAC/richtext.0.png
Binary files differ
diff --git a/tests/auto/declarative/visual/qfxtext/font/data-MAC/richtext.qml b/tests/auto/declarative/visual/qfxtext/font/data-MAC/richtext.qml
index d55ad90..e971809 100644
--- a/tests/auto/declarative/visual/qfxtext/font/data-MAC/richtext.qml
+++ b/tests/auto/declarative/visual/qfxtext/font/data-MAC/richtext.qml
@@ -6,239 +6,239 @@ VisualTest {
}
Frame {
msec: 16
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 32
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 48
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 64
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 80
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 96
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 112
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 128
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 144
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 160
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 176
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 192
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 208
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 224
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 240
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 256
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 272
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 288
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 304
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 320
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 336
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 352
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 368
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 384
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 400
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 416
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 432
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 448
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 464
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 480
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 496
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 512
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 528
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 544
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 560
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 576
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 592
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 608
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 624
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 640
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 656
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 672
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 688
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 704
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 720
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 736
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 752
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 768
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 784
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 800
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 816
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 832
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 848
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 864
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 880
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 896
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 912
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 928
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 944
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 960
@@ -246,51 +246,51 @@ VisualTest {
}
Frame {
msec: 976
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 992
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 1008
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 1024
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 1040
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 1056
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 1072
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 1088
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 1104
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 1120
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 1136
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 1152
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Key {
type: 6
@@ -302,58 +302,58 @@ VisualTest {
}
Frame {
msec: 1168
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 1184
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 1200
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 1216
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 1232
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 1248
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 1264
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 1280
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 1296
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 1312
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 1328
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 1344
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 1360
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
Frame {
msec: 1376
- hash: "dfea78484b840b8cab690e277b960723"
+ hash: "259cc9829171ea866dac4ffe8ef6b489"
}
}
diff --git a/tests/auto/declarative/visual/qfxtext/font/plaintext.qml b/tests/auto/declarative/visual/qfxtext/font/plaintext.qml
index c58b95c..f219e09 100644
--- a/tests/auto/declarative/visual/qfxtext/font/plaintext.qml
+++ b/tests/auto/declarative/visual/qfxtext/font/plaintext.qml
@@ -1,7 +1,7 @@
import Qt 4.6
Rectangle {
- id: s; width: 800; height: 800; color: "lightsteelblue"
+ id: s; width: 800; height: 1000; color: "lightsteelblue"
property string text: "The quick brown fox jumps over the lazy dog."
Column {
@@ -16,7 +16,7 @@ Rectangle {
text: s.text; font.pointSize: 25
}
Text {
- text: s.text; color: "red"
+ text: s.text; color: "red"; smooth: true
}
Text {
text: s.text; font.capitalization: "AllUppercase"
@@ -25,7 +25,7 @@ Rectangle {
text: s.text; font.underline: true
}
Text {
- text: s.text; font.overline: true
+ text: s.text; font.overline: true; smooth: true
}
Text {
text: s.text; font.strikeout: true
@@ -72,5 +72,14 @@ Rectangle {
Text {
text: s.text; elide: Text.ElideRight; width: 200
}
+ Text {
+ text: s.text; elide: Text.ElideLeft; width: 200; wrap: true
+ }
+ Text {
+ text: s.text; elide: Text.ElideMiddle; width: 200; wrap: true
+ }
+ Text {
+ text: s.text; elide: Text.ElideRight; width: 200; wrap: true
+ }
}
}
diff --git a/tests/auto/declarative/visual/qfxtext/font/richtext.qml b/tests/auto/declarative/visual/qfxtext/font/richtext.qml
index 390527a..00a9749 100644
--- a/tests/auto/declarative/visual/qfxtext/font/richtext.qml
+++ b/tests/auto/declarative/visual/qfxtext/font/richtext.qml
@@ -1,7 +1,7 @@
import Qt 4.6
Rectangle {
- id: s; width: 800; height: 800; color: "lightsteelblue"
+ id: s; width: 800; height: 1000; color: "lightsteelblue"
property string text: "<b>The</b> <i>quick</i> <u>brown</u> <o>fox</o> <big>jumps</big> <small>over</small> <tt>the</tt> <s>lazy</s> <em>dog</em>."
Column {
@@ -16,7 +16,7 @@ Rectangle {
text: s.text; font.pointSize: 25
}
Text {
- text: s.text; color: "red"
+ text: s.text; color: "red"; smooth: true
}
Text {
text: s.text; font.capitalization: "AllUppercase"
@@ -25,7 +25,7 @@ Rectangle {
text: s.text; font.underline: true
}
Text {
- text: s.text; font.overline: true
+ text: s.text; font.overline: true; smooth: true
}
Text {
text: s.text; font.strikeout: true
@@ -72,5 +72,14 @@ Rectangle {
Text {
text: s.text; elide: Text.ElideRight; width: 200
}
+ Text {
+ text: s.text; elide: Text.ElideLeft; width: 200; wrap: true
+ }
+ Text {
+ text: s.text; elide: Text.ElideMiddle; width: 200; wrap: true
+ }
+ Text {
+ text: s.text; elide: Text.ElideRight; width: 200; wrap: true
+ }
}
}