tests/auto/qgraphicsgridlayout/tst_qgraphicsgridlayout.cpp
changeset 0 1918ee327afb
child 3 41300fa6a67c
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/tests/auto/qgraphicsgridlayout/tst_qgraphicsgridlayout.cpp	Mon Jan 11 14:00:40 2010 +0000
@@ -0,0 +1,2109 @@
+/****************************************************************************
+**
+** 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 <qgraphicsgridlayout.h>
+#include <qgraphicswidget.h>
+#include <qgraphicsscene.h>
+#include <qgraphicsview.h>
+
+class tst_QGraphicsGridLayout : public QObject
+{
+    Q_OBJECT
+
+public slots:
+    void initTestCase();
+    void cleanupTestCase();
+    void init();
+    void cleanup();
+
+private slots:
+    void qgraphicsgridlayout_data();
+    void qgraphicsgridlayout();
+    void addItem_data();
+    void addItem();
+    void alignment();
+    void alignment2();
+    void alignment2_data();
+    void columnAlignment();
+    void columnCount();
+    void columnMaximumWidth();
+    void columnMinimumWidth();
+    void columnPreferredWidth();
+    void setColumnFixedWidth();
+    void columnSpacing();
+    void columnStretchFactor();
+    void count();
+    void contentsMargins();
+    void horizontalSpacing_data();
+    void horizontalSpacing();
+    void itemAt();
+    void removeAt();
+    void rowAlignment();
+    void rowCount();
+    void rowMaximumHeight();
+    void rowMinimumHeight();
+    void rowPreferredHeight();
+    void rowSpacing();
+    void rowStretchFactor();
+    void setColumnSpacing_data();
+    void setColumnSpacing();
+    void setGeometry_data();
+    void setGeometry();
+    void setRowFixedHeight();
+    void setRowSpacing_data();
+    void setRowSpacing();
+    void setSpacing_data();
+    void setSpacing();
+    void sizeHint_data();
+    void sizeHint();
+    void verticalSpacing_data();
+    void verticalSpacing();
+    void layoutDirection();
+    void removeLayout();
+    void defaultStretchFactors_data();
+    void defaultStretchFactors();
+    void geometries_data();
+    void geometries();
+    void avoidRecursionInInsertItem();
+    void task236367_maxSizeHint();
+};
+
+// This will be called before the first test function is executed.
+// It is only called once.
+void tst_QGraphicsGridLayout::initTestCase()
+{
+}
+
+// This will be called after the last test function is executed.
+// It is only called once.
+void tst_QGraphicsGridLayout::cleanupTestCase()
+{
+}
+
+// This will be called before each test function is executed.
+void tst_QGraphicsGridLayout::init()
+{
+#ifdef Q_OS_WINCE //disable magic for WindowsCE
+    qApp->setAutoMaximizeThreshold(-1);
+#endif
+}
+
+// This will be called after every test function.
+void tst_QGraphicsGridLayout::cleanup()
+{
+}
+
+void tst_QGraphicsGridLayout::qgraphicsgridlayout_data()
+{
+}
+
+void tst_QGraphicsGridLayout::qgraphicsgridlayout()
+{
+    QGraphicsGridLayout layout;
+    QTest::ignoreMessage(QtWarningMsg, "QGraphicsGridLayout::addItem: invalid row span/column span: 0");
+    layout.addItem(0, 0, 0, 0, 0);
+    QTest::ignoreMessage(QtWarningMsg, "QGraphicsGridLayout::addItem: cannot add null item");
+    layout.addItem(0, 0, 0);
+    layout.alignment(0);
+    layout.columnAlignment(0);
+    layout.columnCount();
+    layout.columnMaximumWidth(0);
+    layout.columnMinimumWidth(0);
+    layout.columnPreferredWidth(0);
+    layout.columnSpacing(0);
+    layout.columnStretchFactor(0);
+    layout.count();
+    layout.horizontalSpacing();
+    QTest::ignoreMessage(QtWarningMsg, "QGraphicsGridLayout::itemAt: invalid row, column 0, 0");
+    layout.itemAt(0, 0);
+    QTest::ignoreMessage(QtWarningMsg, "QGraphicsGridLayout::itemAt: invalid index 0");
+    layout.itemAt(0);
+    QTest::ignoreMessage(QtWarningMsg, "QGraphicsGridLayout::removeAt: invalid index 0");
+    layout.removeAt(0);
+    layout.rowAlignment(0);
+    layout.rowCount();
+    layout.rowMaximumHeight(0);
+    layout.rowMinimumHeight(0);
+    layout.rowPreferredHeight(0);
+    layout.rowSpacing(0);
+    layout.rowStretchFactor(0);
+    layout.setAlignment(0, Qt::AlignRight);
+    layout.setColumnAlignment(0, Qt::AlignRight);
+    layout.setColumnFixedWidth(0, 0);
+    layout.setColumnMaximumWidth(0, 0);
+    layout.setColumnMinimumWidth(0, 0);
+    layout.setColumnPreferredWidth(0, 0);
+    layout.setColumnSpacing(0, 0);
+    layout.setColumnStretchFactor(0, 0);
+    layout.setGeometry(QRectF());
+    layout.setHorizontalSpacing(0);
+    layout.setRowAlignment(0, 0);
+    layout.setRowFixedHeight(0, 0);
+    layout.setRowMaximumHeight(0, 0);
+    layout.setRowMinimumHeight(0, 0);
+    layout.setRowPreferredHeight(0, 0);
+    layout.setRowSpacing(0, 0);
+    layout.setRowStretchFactor(0, 0);
+    layout.setSpacing(0);
+    layout.setVerticalSpacing(0);
+    layout.sizeHint(Qt::MinimumSize);
+    layout.verticalSpacing();
+}
+
+class RectWidget : public QGraphicsWidget
+{
+public:
+    RectWidget(QGraphicsItem *parent = 0) : QGraphicsWidget(parent){}
+
+    void paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget *widget)
+    {
+        Q_UNUSED(option);
+        Q_UNUSED(widget);
+        painter->drawRoundRect(rect());
+        painter->drawLine(rect().topLeft(), rect().bottomRight());
+        painter->drawLine(rect().bottomLeft(), rect().topRight());
+    }
+
+    QSizeF sizeHint(Qt::SizeHint which, const QSizeF &constraint = QSizeF()) const
+    {
+        if (m_sizeHints[which].isValid()) {
+            return m_sizeHints[which];
+        }
+        return QGraphicsWidget::sizeHint(which, constraint);
+    }
+
+    void setSizeHint(Qt::SizeHint which, const QSizeF &size) {
+        m_sizeHints[which] = size;
+        updateGeometry();
+    }
+
+    QSizeF m_sizeHints[Qt::NSizeHints];
+};
+
+static void populateLayout(QGraphicsGridLayout *gridLayout, int width, int height)
+{
+    for (int y = 0; y < height; ++y) {
+        for (int x = 0; x < width; ++x) {
+            QGraphicsWidget *item = new RectWidget();
+            item->setMinimumSize(10, 10);
+            item->setPreferredSize(25, 25);
+            item->setMaximumSize(50, 50);
+            gridLayout->addItem(item, y, x);
+        }
+    }
+}
+
+
+/** populates \a gridLayout with a 3x2 layout:
+ * +----+----+----+
+ * |+---|---+|xxxx|
+ * ||span=2 ||hole|
+ * |+---|---+|xxxx|
+ * +----+----+----+
+ * |xxxx|+---|---+|
+ * |hole||span=2 ||
+ * |xxxx|+---|---+|
+ * +----+----+----+
+ */
+static void populateLayoutWithSpansAndHoles(QGraphicsGridLayout *gridLayout)
+{
+    QGraphicsWidget *item = new RectWidget();
+    item->setMinimumSize(10, 10);
+    item->setPreferredSize(25, 25);
+    item->setMaximumSize(50, 50);
+    gridLayout->addItem(item, 0, 0, 1, 2);
+
+    item = new RectWidget();
+    item->setMinimumSize(10, 10);
+    item->setPreferredSize(25, 25);
+    item->setMaximumSize(50, 50);
+    gridLayout->addItem(item, 1, 1, 1, 2);
+}
+
+Q_DECLARE_METATYPE(Qt::Alignment)
+void tst_QGraphicsGridLayout::addItem_data()
+{
+    QTest::addColumn<int>("row");
+    QTest::addColumn<int>("column");
+    QTest::addColumn<int>("rowSpan");
+    QTest::addColumn<int>("columnSpan");
+    QTest::addColumn<Qt::Alignment>("alignment");
+
+    for (int a = -1; a < 3; ++a) {
+    for (int b = -1; b < 2; ++b) {
+    for (int c = -1; c < 2; ++c) {
+    for (int d = -1; d < 2; ++d) {
+    for (int e = 0; e < 9; ++e) {
+        int row = a;
+        int column = b;
+        int rowSpan = c;
+        int columnSpan = d;
+        QString name = QString::fromAscii("(%1,%2,%3,%4").arg(a).arg(b).arg(c).arg(d);
+        Qt::Alignment alignment = Qt::AlignLeft;
+        QTest::newRow(name.toLatin1()) << row << column << rowSpan << columnSpan << alignment;
+    }}}}}
+}
+
+// public void addItem(QGraphicsLayoutItem* item, int row, int column, int rowSpan, int columnSpan, Qt::Alignment alignment = 0)
+void tst_QGraphicsGridLayout::addItem()
+{
+    QFETCH(int, row);
+    QFETCH(int, column);
+    QFETCH(int, rowSpan);
+    QFETCH(int, columnSpan);
+    QFETCH(Qt::Alignment, alignment);
+
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout;
+
+    QGraphicsWidget *wid = new QGraphicsWidget;
+    if (row < 0 || column < 0) {
+        QTest::ignoreMessage(QtWarningMsg, "QGraphicsGridLayout::addItem: invalid row/column: -1");
+    } else if (rowSpan < 1 || columnSpan < 1) {
+        char buf[1024];
+        ::qsnprintf(buf, sizeof(buf), "QGraphicsGridLayout::addItem: invalid row span/column span: %d",
+            rowSpan < 1 ? rowSpan : columnSpan);
+        QTest::ignoreMessage(QtWarningMsg, buf);
+    }
+    layout->addItem(wid, row, column, rowSpan, columnSpan, alignment);
+
+    delete layout;
+}
+
+// public Qt::Alignment alignment(QGraphicsLayoutItem* item) const
+void tst_QGraphicsGridLayout::alignment()
+{
+#ifdef Q_WS_MAC
+    QSKIP("Resizing a QGraphicsWidget to effectiveSizeHint(Qt::MaximumSize) is currently not supported on mac", SkipAll);
+#endif
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout();
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    populateLayout(layout, 3, 2);
+    layout->setContentsMargins(0, 0, 0, 0);
+    layout->setSpacing(0);
+
+    view.show();
+    widget->show();
+    widget->resize(widget->effectiveSizeHint(Qt::PreferredSize));
+    QApplication::processEvents();
+    // no alignment (the default)
+    QCOMPARE(layout->itemAt(0, 0)->geometry().left(), 0.0);
+    QCOMPARE(layout->itemAt(0, 0)->geometry().right(), layout->itemAt(0, 1)->geometry().left());
+    QCOMPARE(layout->itemAt(0, 1)->geometry().left(), 25.0);
+    QCOMPARE(layout->itemAt(0, 1)->geometry().right(), layout->itemAt(0, 2)->geometry().left());
+    QCOMPARE(layout->itemAt(0, 2)->geometry().left(), 50.0);
+    QCOMPARE(layout->itemAt(0, 2)->geometry().right(), 75.0);
+
+    QCOMPARE(layout->itemAt(1, 0)->geometry().left(), 0.0);
+    QCOMPARE(layout->itemAt(1, 0)->geometry().right(), layout->itemAt(1, 1)->geometry().left());
+    QCOMPARE(layout->itemAt(1, 1)->geometry().left(), 25.0);
+    QCOMPARE(layout->itemAt(1, 1)->geometry().right(), layout->itemAt(1, 2)->geometry().left());
+    QCOMPARE(layout->itemAt(1, 2)->geometry().left(), 50.0);
+    QCOMPARE(layout->itemAt(1, 2)->geometry().right(), 75.0);
+
+    QCOMPARE(layout->itemAt(0, 0)->geometry().top(), 0.0);
+    QCOMPARE(layout->itemAt(0, 0)->geometry().bottom(), layout->itemAt(1, 0)->geometry().top());
+    QCOMPARE(layout->itemAt(1, 0)->geometry().top(), 25.0);
+    QCOMPARE(layout->itemAt(1, 0)->geometry().bottom(), 50.0);
+
+    // align first column left, second hcenter, third right
+    layout->setColumnMinimumWidth(0, 100);
+    layout->setAlignment(layout->itemAt(0,0), Qt::AlignLeft);
+    layout->setAlignment(layout->itemAt(1,0), Qt::AlignLeft);
+    layout->setColumnMinimumWidth(1, 100);
+    layout->setAlignment(layout->itemAt(0,1), Qt::AlignHCenter);
+    layout->setAlignment(layout->itemAt(1,1), Qt::AlignHCenter);
+    layout->setColumnMinimumWidth(2, 100);
+    layout->setAlignment(layout->itemAt(0,2), Qt::AlignRight);
+    layout->setAlignment(layout->itemAt(1,2), Qt::AlignRight);
+
+    widget->resize(widget->effectiveSizeHint(Qt::MaximumSize));
+    QApplication::processEvents();
+
+    QCOMPARE(layout->itemAt(0,0)->geometry(), QRectF(0,    0,  50,  25));
+    QCOMPARE(layout->itemAt(1,0)->geometry(), QRectF(0,   25,  50,  25));
+    QCOMPARE(layout->itemAt(0,1)->geometry(), QRectF(125,  0,  50,  25));
+    QCOMPARE(layout->itemAt(1,1)->geometry(), QRectF(125, 25,  50,  25));
+    QCOMPARE(layout->itemAt(0,2)->geometry(), QRectF(250,  0,  50,  25));
+    QCOMPARE(layout->itemAt(1,2)->geometry(), QRectF(250, 25,  50,  25));
+
+    delete widget;
+}
+
+// public void setColumnAlignment(int column, Qt::Alignment alignment)
+// public Qt::Alignment columnAlignment(int column) const
+void tst_QGraphicsGridLayout::columnAlignment()
+{
+#ifdef Q_WS_MAC
+    QSKIP("Resizing a QGraphicsWidget to effectiveSizeHint(Qt::MaximumSize) is currently not supported on mac", SkipAll);
+#endif
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout();
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    populateLayout(layout, 3, 2);
+    layout->setContentsMargins(0, 0, 0, 0);
+    layout->setSpacing(1);
+    widget->setContentsMargins(0, 0, 0, 0);
+
+    layout->setColumnMinimumWidth(0, 100);
+    layout->setColumnMinimumWidth(1, 100);
+    layout->setColumnMinimumWidth(2, 100);
+
+    view.resize(450,150);
+    widget->resize(widget->effectiveSizeHint(Qt::MaximumSize));
+    view.show();
+    widget->show();
+    QApplication::processEvents();
+    // Check default
+    QCOMPARE(layout->columnAlignment(0), 0);
+    QCOMPARE(layout->columnAlignment(1), 0);
+    QCOMPARE(layout->columnAlignment(2), 0);
+
+    layout->setColumnAlignment(0, Qt::AlignLeft);
+    layout->setColumnAlignment(1, Qt::AlignHCenter);
+    layout->setColumnAlignment(2, Qt::AlignRight);
+
+    // see if item alignment takes preference over columnAlignment
+    layout->setAlignment(layout->itemAt(1,0), Qt::AlignHCenter);
+    layout->setAlignment(layout->itemAt(1,1), Qt::AlignRight);
+    layout->setAlignment(layout->itemAt(1,2), Qt::AlignLeft);
+
+    QApplication::processEvents();  // process LayoutRequest
+    /*
+      +----------+------------+---------+
+      | Left     |  HCenter   |  Right  |
+      +----------+------------+---------+
+      | HCenter  |   Right    |   Left  |
+      +---------------------------------+
+    */
+    QCOMPARE(layout->itemAt(0,0)->geometry(), QRectF(0,   0,   50,  25));
+    QCOMPARE(layout->itemAt(1,0)->geometry(), QRectF(25,  26,  50,  25));   // item is king
+    QCOMPARE(layout->itemAt(0,1)->geometry(), QRectF(126,  0,  50,  25));
+    QCOMPARE(layout->itemAt(1,1)->geometry(), QRectF(151, 26,  50,  25));   // item is king
+    QCOMPARE(layout->itemAt(0,2)->geometry(), QRectF(252,  0,  50,  25));
+    QCOMPARE(layout->itemAt(1,2)->geometry(), QRectF(202, 26,  50,  25));   // item is king
+
+    delete widget;
+}
+
+// public int columnCount() const
+void tst_QGraphicsGridLayout::columnCount()
+{
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout();
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    layout->setContentsMargins(0, 0, 0, 0);
+    layout->setSpacing(0);
+    widget->setContentsMargins(0, 0, 0, 0);
+
+    view.show();
+    widget->show();
+    QApplication::processEvents();
+
+    QCOMPARE(layout->columnCount(), 0);
+    layout->addItem(new RectWidget(widget), 0, 0);
+    QCOMPARE(layout->columnCount(), 1);
+    layout->addItem(new RectWidget(widget), 1, 1);
+    QCOMPARE(layout->columnCount(), 2);
+    layout->addItem(new RectWidget(widget), 0, 2);
+    QCOMPARE(layout->columnCount(), 3);
+    layout->addItem(new RectWidget(widget), 1, 0);
+    QCOMPARE(layout->columnCount(), 3);
+    layout->addItem(new RectWidget(widget), 0, 1);
+    QCOMPARE(layout->columnCount(), 3);
+    layout->addItem(new RectWidget(widget), 1, 2);
+    QCOMPARE(layout->columnCount(), 3);
+
+    // ### Talk with Jasmin. Not sure if removeAt() should adjust columnCount().
+    widget->setLayout(0);
+    layout = new QGraphicsGridLayout();
+    populateLayout(layout, 3, 2);
+    QCOMPARE(layout->columnCount(), 3);
+    layout->removeAt(5);
+    layout->removeAt(3);
+    QCOMPARE(layout->columnCount(), 3);
+    layout->removeAt(1);
+    QCOMPARE(layout->columnCount(), 3);
+    layout->removeAt(0);
+    QCOMPARE(layout->columnCount(), 3);
+    layout->removeAt(0);
+    QCOMPARE(layout->columnCount(), 2);
+
+    delete widget;
+}
+
+// public qreal columnMaximumWidth(int column) const
+void tst_QGraphicsGridLayout::columnMaximumWidth()
+{
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout();
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    populateLayout(layout, 3, 2);
+    layout->setContentsMargins(0, 0, 0, 0);
+    layout->setSpacing(0);
+
+    // should at least be a very large number
+    QVERIFY(layout->columnMaximumWidth(0) >= 10000);
+    QCOMPARE(layout->columnMaximumWidth(0), layout->columnMaximumWidth(1));
+    QCOMPARE(layout->columnMaximumWidth(1), layout->columnMaximumWidth(2));
+    layout->setColumnMaximumWidth(0, 20);
+    layout->setColumnMaximumWidth(2, 60);
+
+    view.show();
+    widget->show();
+    widget->resize(widget->effectiveSizeHint(Qt::PreferredSize));
+    QApplication::processEvents();
+
+    QCOMPARE(layout->itemAt(0,0)->geometry().width(), 20.0);
+    QCOMPARE(layout->itemAt(1,0)->geometry().width(), 20.0);
+    QCOMPARE(layout->itemAt(0,1)->geometry().width(), 25.0);
+    QCOMPARE(layout->itemAt(1,1)->geometry().width(), 25.0);
+    QCOMPARE(layout->itemAt(0,2)->geometry().width(), 25.0);
+    QCOMPARE(layout->itemAt(1,2)->geometry().width(), 25.0);
+
+    delete widget;
+}
+
+// public qreal columnMinimumWidth(int column) const
+void tst_QGraphicsGridLayout::columnMinimumWidth()
+{
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout();
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    populateLayout(layout, 3, 2);
+    layout->setContentsMargins(0, 0, 0, 0);
+    layout->setSpacing(0);
+
+    // should at least be a very large number
+    QCOMPARE(layout->columnMinimumWidth(0), 0.0);
+    QCOMPARE(layout->columnMinimumWidth(0), layout->columnMinimumWidth(1));
+    QCOMPARE(layout->columnMinimumWidth(1), layout->columnMinimumWidth(2));
+    layout->setColumnMinimumWidth(0, 20);
+    layout->setColumnMinimumWidth(2, 40);
+
+    view.show();
+    widget->show();
+    widget->resize(widget->effectiveSizeHint(Qt::PreferredSize));
+    QApplication::processEvents();
+
+    QCOMPARE(layout->itemAt(0,0)->geometry().width(), 25.0);
+    QCOMPARE(layout->itemAt(1,0)->geometry().width(), 25.0);
+    QCOMPARE(layout->itemAt(0,1)->geometry().width(), 25.0);
+    QCOMPARE(layout->itemAt(1,1)->geometry().width(), 25.0);
+    QCOMPARE(layout->itemAt(0,2)->geometry().width(), 40.0);
+    QCOMPARE(layout->itemAt(1,2)->geometry().width(), 40.0);
+
+    delete widget;
+}
+
+// public qreal columnPreferredWidth(int column) const
+void tst_QGraphicsGridLayout::columnPreferredWidth()
+{
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout();
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    populateLayout(layout, 3, 2);
+    layout->setContentsMargins(0, 0, 0, 0);
+    layout->setSpacing(0);
+
+    // default preferred width ??
+    QCOMPARE(layout->columnPreferredWidth(0), 0.0);
+    QCOMPARE(layout->columnPreferredWidth(0), layout->columnPreferredWidth(1));
+    QCOMPARE(layout->columnPreferredWidth(1), layout->columnPreferredWidth(2));
+    layout->setColumnPreferredWidth(0, 20);
+    layout->setColumnPreferredWidth(2, 40);
+
+    view.show();
+    widget->show();
+    widget->resize(widget->effectiveSizeHint(Qt::PreferredSize));
+    QApplication::processEvents();
+
+    QCOMPARE(layout->itemAt(0,0)->geometry().width(), 25.0);
+    QCOMPARE(layout->itemAt(1,0)->geometry().width(), 25.0);
+    QCOMPARE(layout->itemAt(0,1)->geometry().width(), 25.0);
+    QCOMPARE(layout->itemAt(1,1)->geometry().width(), 25.0);
+    QCOMPARE(layout->itemAt(0,2)->geometry().width(), 40.0);
+    QCOMPARE(layout->itemAt(1,2)->geometry().width(), 40.0);
+
+    delete widget;
+}
+
+// public void setColumnFixedWidth(int row, qreal height)
+void tst_QGraphicsGridLayout::setColumnFixedWidth()
+{
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout();
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    populateLayout(layout, 3, 2);
+    layout->setContentsMargins(0, 0, 0, 0);
+    layout->setSpacing(0);
+
+    layout->setColumnFixedWidth(0, 20);
+    layout->setColumnFixedWidth(2, 40);
+
+    view.show();
+    widget->show();
+    widget->resize(widget->effectiveSizeHint(Qt::PreferredSize));
+    QApplication::processEvents();
+
+    QCOMPARE(layout->itemAt(0,0)->geometry().width(), 20.0);
+    QCOMPARE(layout->itemAt(1,0)->geometry().width(), 20.0);
+    QCOMPARE(layout->itemAt(0,1)->geometry().width(), 25.0);
+    QCOMPARE(layout->itemAt(1,1)->geometry().width(), 25.0);
+    QCOMPARE(layout->itemAt(0,2)->geometry().width(), 40.0);
+    QCOMPARE(layout->itemAt(1,2)->geometry().width(), 40.0);
+
+    delete widget;
+}
+
+// public qreal columnSpacing(int column) const
+void tst_QGraphicsGridLayout::columnSpacing()
+{
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout();
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    populateLayout(layout, 3, 2);
+    layout->setContentsMargins(0, 0, 0, 0);
+    layout->setSpacing(0);
+    QCOMPARE(layout->columnSpacing(0), 0.0);
+
+    layout->setColumnSpacing(0, 20);
+    view.show();
+    widget->show();
+    widget->resize(widget->effectiveSizeHint(Qt::PreferredSize));
+    QApplication::processEvents();
+
+    QCOMPARE(layout->itemAt(0,0)->geometry().left(),   0.0);
+    QCOMPARE(layout->itemAt(0,0)->geometry().right(), 25.0);
+    QCOMPARE(layout->itemAt(0,1)->geometry().left(),  45.0);
+    QCOMPARE(layout->itemAt(0,1)->geometry().right(), 70.0);
+    QCOMPARE(layout->itemAt(0,2)->geometry().left(),  70.0);
+    QCOMPARE(layout->itemAt(0,2)->geometry().right(), 95.0);
+
+    delete widget;
+}
+
+// public int columnStretchFactor(int column) const
+void tst_QGraphicsGridLayout::columnStretchFactor()
+{
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout();
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    populateLayout(layout, 3, 2);
+    layout->setContentsMargins(0, 0, 0, 0);
+    layout->setSpacing(0);
+
+    layout->setColumnStretchFactor(0, 1);
+    layout->setColumnStretchFactor(1, 2);
+    layout->setColumnStretchFactor(2, 3);
+    view.show();
+    widget->show();
+    widget->resize(130, 50);
+    QApplication::processEvents();
+
+    QVERIFY(layout->itemAt(0,0)->geometry().width() <  layout->itemAt(0,1)->geometry().width());
+    QVERIFY(layout->itemAt(0,1)->geometry().width() <  layout->itemAt(0,2)->geometry().width());
+    QVERIFY(layout->itemAt(1,0)->geometry().width() <  layout->itemAt(1,1)->geometry().width());
+    QVERIFY(layout->itemAt(1,1)->geometry().width() <  layout->itemAt(1,2)->geometry().width());
+
+    delete widget;
+}
+
+
+// public int count() const
+void tst_QGraphicsGridLayout::count()
+{
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout();
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    populateLayout(layout, 3, 2);
+    QCOMPARE(layout->count(), 6);
+    layout->removeAt(5);
+    layout->removeAt(3);
+    QCOMPARE(layout->count(), 4);
+    layout->removeAt(1);
+    QCOMPARE(layout->count(), 3);
+    layout->removeAt(0);
+    QCOMPARE(layout->count(), 2);
+    layout->removeAt(0);
+    QCOMPARE(layout->count(), 1);
+    layout->removeAt(0);
+    QCOMPARE(layout->count(), 0);
+
+    delete widget;
+}
+
+void tst_QGraphicsGridLayout::horizontalSpacing_data()
+{
+    QTest::addColumn<qreal>("horizontalSpacing");
+    QTest::newRow("zero") << qreal(0.0);
+    QTest::newRow("10") << qreal(10.0);
+}
+
+// public qreal horizontalSpacing() const
+void tst_QGraphicsGridLayout::horizontalSpacing()
+{
+    QFETCH(qreal, horizontalSpacing);
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout();
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    populateLayout(layout, 3, 2);
+    layout->setContentsMargins(0, 0, 0, 0);
+    qreal w = layout->sizeHint(Qt::PreferredSize, QSizeF()).width();
+    qreal oldSpacing = layout->horizontalSpacing();
+    if (oldSpacing != -1) {
+        layout->setHorizontalSpacing(horizontalSpacing);
+        QApplication::processEvents();
+        qreal new_w = layout->sizeHint(Qt::PreferredSize, QSizeF()).width();
+        QCOMPARE(new_w, w - (3-1)*(oldSpacing - horizontalSpacing));
+    } else {
+        QSKIP("The current style uses non-uniform layout spacing", SkipAll);
+    }
+    delete widget;
+}
+
+void tst_QGraphicsGridLayout::contentsMargins()
+{
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout();
+    QGraphicsGridLayout *sublayout = new QGraphicsGridLayout();
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    layout->addItem(sublayout,0, 1);
+
+    qreal left, top, right, bottom;
+    // sublayouts have 0 margin
+    sublayout->getContentsMargins(&left, &top, &right, &bottom);
+    QCOMPARE(left, 0.0);
+    QCOMPARE(top, 0.0);
+    QCOMPARE(right, 0.0);
+    QCOMPARE(bottom, 0.0);
+
+    // top level layouts have style dependent margins.
+    // we'll just check if its different from 0. (applies to all our styles)
+    layout->getContentsMargins(&left, &top, &right, &bottom);
+    QVERIFY(left >= 0.0);
+    QVERIFY(top >= 0.0);
+    QVERIFY(right >= 0.0);
+    QVERIFY(bottom >= 0.0);
+
+    delete widget;
+}
+
+// public QGraphicsLayoutItem* itemAt(int index) const
+void tst_QGraphicsGridLayout::itemAt()
+{
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout();
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    populateLayoutWithSpansAndHoles(layout);
+
+    //itemAt(int row, int column)
+    QVERIFY( layout->itemAt(0,0));
+    QVERIFY( layout->itemAt(0,1));
+    QCOMPARE(layout->itemAt(0,2), static_cast<QGraphicsLayoutItem*>(0));
+    QCOMPARE(layout->itemAt(1,0), static_cast<QGraphicsLayoutItem*>(0));
+    QVERIFY( layout->itemAt(1,1));
+    QVERIFY( layout->itemAt(1,2));
+
+
+    //itemAt(int index)
+    for (int i = -2; i < layout->count() + 2; ++i) {
+        if (i >= 0 && i < layout->count()) {
+            QVERIFY(layout->itemAt(i));
+        } else {
+            QTest::ignoreMessage(QtWarningMsg, QString::fromAscii("QGraphicsGridLayout::itemAt: invalid index %1").arg(i).toLatin1().constData());
+            QCOMPARE(layout->itemAt(i), static_cast<QGraphicsLayoutItem*>(0));
+        }
+    }
+    delete widget;
+}
+
+// public void removeAt(int index)
+void tst_QGraphicsGridLayout::removeAt()
+{
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout();
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    populateLayout(layout, 3, 2);
+    QCOMPARE(layout->count(), 6);
+    layout->removeAt(5);
+    layout->removeAt(3);
+    QCOMPARE(layout->count(), 4);
+    layout->removeAt(1);
+    QCOMPARE(layout->count(), 3);
+    layout->removeAt(0);
+    QCOMPARE(layout->count(), 2);
+    layout->removeAt(0);
+    QCOMPARE(layout->count(), 1);
+    QGraphicsLayoutItem *item0 = layout->itemAt(0);
+    QCOMPARE(item0->parentLayoutItem(), static_cast<QGraphicsLayoutItem *>(layout));
+    layout->removeAt(0);
+    QCOMPARE(item0->parentLayoutItem(), static_cast<QGraphicsLayoutItem *>(0));
+    QCOMPARE(layout->count(), 0);
+    QTest::ignoreMessage(QtWarningMsg, QString::fromAscii("QGraphicsGridLayout::removeAt: invalid index 0").toLatin1().constData());
+    layout->removeAt(0);
+    QCOMPARE(layout->count(), 0);
+    delete widget;
+}
+
+// public Qt::Alignment rowAlignment(int row) const
+void tst_QGraphicsGridLayout::rowAlignment()
+{
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout();
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    populateLayout(layout, 2, 3);
+    layout->setContentsMargins(0, 0, 0, 0);
+    layout->setSpacing(1);
+    widget->setContentsMargins(0, 0, 0, 0);
+
+    view.resize(330,450);
+    widget->resize(300, 400);
+    view.show();
+    widget->show();
+    QApplication::processEvents();
+    // Check default
+    QCOMPARE(layout->rowAlignment(0), 0);
+    QCOMPARE(layout->rowAlignment(1), 0);
+    QCOMPARE(layout->rowAlignment(2), 0);
+
+    // make the grids larger than the items, so that alignment kicks in
+    layout->setRowMinimumHeight(0, 100.0);
+    layout->setRowMinimumHeight(1, 100.0);
+    layout->setRowMinimumHeight(2, 100.0);
+    // expand columns also, so we can test combination of horiz and vertical alignment
+    layout->setColumnMinimumWidth(0, 100.0);
+    layout->setColumnMinimumWidth(1, 100.0);
+
+    layout->setRowAlignment(0, Qt::AlignBottom);
+    layout->setRowAlignment(1, Qt::AlignVCenter);
+    layout->setRowAlignment(2, Qt::AlignTop);
+
+    // see if item alignment takes preference over rowAlignment
+    layout->setAlignment(layout->itemAt(0,0), Qt::AlignRight);
+    layout->setAlignment(layout->itemAt(1,0), Qt::AlignTop);
+    layout->setAlignment(layout->itemAt(2,0), Qt::AlignHCenter);
+
+    QApplication::processEvents();  // process LayoutRequest
+
+    QCOMPARE(layout->alignment(layout->itemAt(0,0)), Qt::AlignRight);  //Qt::AlignRight | Qt::AlignBottom
+    QCOMPARE(layout->itemAt(0,0)->geometry(), QRectF(50,  50,  50,  50));
+    QCOMPARE(layout->rowAlignment(0), Qt::AlignBottom);
+    QCOMPARE(layout->itemAt(0,1)->geometry(), QRectF(101, 50,  50,  50));
+    QCOMPARE(layout->alignment(layout->itemAt(1,0)), Qt::AlignTop);
+    QCOMPARE(layout->itemAt(1,0)->geometry(), QRectF(0,  101,  50,  50));
+    QCOMPARE(layout->rowAlignment(1), Qt::AlignVCenter);
+    QCOMPARE(layout->itemAt(1,1)->geometry(), QRectF(101, 126, 50,  50));
+    QCOMPARE(layout->alignment(layout->itemAt(2,0)), Qt::AlignHCenter);
+    QCOMPARE(layout->itemAt(2,0)->geometry(), QRectF(25, 202,  50,  50));
+    QCOMPARE(layout->rowAlignment(2), Qt::AlignTop);
+    QCOMPARE(layout->itemAt(2,1)->geometry(), QRectF(101,202,  50,  50));
+
+    delete widget;
+}
+
+// public int rowCount() const
+// public int columnCount() const
+void tst_QGraphicsGridLayout::rowCount()
+{
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout();
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    populateLayout(layout, 2, 3);
+    layout->setContentsMargins(0, 0, 0, 0);
+    layout->setSpacing(0);
+    widget->setContentsMargins(0, 0, 0, 0);
+    QCOMPARE(layout->rowCount(), 3);
+    QCOMPARE(layout->columnCount(), 2);
+
+    // with spans and holes...
+    widget->setLayout(0);
+    layout = new QGraphicsGridLayout();
+    populateLayoutWithSpansAndHoles(layout);
+    QCOMPARE(layout->rowCount(), 2);
+    QCOMPARE(layout->columnCount(), 3);
+
+    delete widget;
+}
+
+// public qreal rowMaximumHeight(int row) const
+void tst_QGraphicsGridLayout::rowMaximumHeight()
+{
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout;
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    populateLayout(layout, 2, 3);
+    layout->setContentsMargins(0, 0, 0, 0);
+    layout->setSpacing(0);
+
+    // should at least be a very large number
+    QVERIFY(layout->rowMaximumHeight(0) >= 10000);
+    QCOMPARE(layout->rowMaximumHeight(0), layout->rowMaximumHeight(1));
+    QCOMPARE(layout->rowMaximumHeight(1), layout->rowMaximumHeight(2));
+    layout->setRowMaximumHeight(0, 20);
+    layout->setRowMaximumHeight(2, 60);
+
+    view.show();
+    widget->show();
+    widget->resize(widget->effectiveSizeHint(Qt::PreferredSize));
+    QApplication::processEvents();
+
+    QCOMPARE(layout->itemAt(0,0)->geometry().height(), 20.0);
+    QCOMPARE(layout->itemAt(0,1)->geometry().height(), 20.0);
+    QCOMPARE(layout->itemAt(1,0)->geometry().height(), 25.0);
+    QCOMPARE(layout->itemAt(1,1)->geometry().height(), 25.0);
+    QCOMPARE(layout->itemAt(2,0)->geometry().height(), 25.0);
+    QCOMPARE(layout->itemAt(2,1)->geometry().height(), 25.0);
+
+    delete widget;
+}
+
+// public qreal rowMinimumHeight(int row) const
+void tst_QGraphicsGridLayout::rowMinimumHeight()
+{
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout();
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    populateLayout(layout, 2, 3);
+    layout->setContentsMargins(0, 0, 0, 0);
+    layout->setSpacing(0);
+
+    // should at least be a very large number
+    QCOMPARE(layout->rowMinimumHeight(0), 0.0);
+    QCOMPARE(layout->rowMinimumHeight(0), layout->rowMinimumHeight(1));
+    QCOMPARE(layout->rowMinimumHeight(1), layout->rowMinimumHeight(2));
+    layout->setRowMinimumHeight(0, 20);
+    layout->setRowMinimumHeight(2, 40);
+
+    view.show();
+    widget->show();
+    widget->resize(widget->effectiveSizeHint(Qt::PreferredSize));
+    QApplication::processEvents();
+
+    QCOMPARE(layout->itemAt(0,0)->geometry().height(), 25.0);
+    QCOMPARE(layout->itemAt(0,1)->geometry().height(), 25.0);
+    QCOMPARE(layout->itemAt(1,0)->geometry().height(), 25.0);
+    QCOMPARE(layout->itemAt(1,1)->geometry().height(), 25.0);
+    QCOMPARE(layout->itemAt(2,0)->geometry().height(), 40.0);
+    QCOMPARE(layout->itemAt(2,1)->geometry().height(), 40.0);
+
+    delete widget;
+}
+
+// public qreal rowPreferredHeight(int row) const
+void tst_QGraphicsGridLayout::rowPreferredHeight()
+{
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout();
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    populateLayout(layout, 2, 3);
+    layout->setContentsMargins(0, 0, 0, 0);
+    layout->setSpacing(0);
+
+    // default preferred height ??
+    QCOMPARE(layout->rowPreferredHeight(0), 0.0);
+    QCOMPARE(layout->rowPreferredHeight(0), layout->rowPreferredHeight(1));
+    QCOMPARE(layout->rowPreferredHeight(1), layout->rowPreferredHeight(2));
+    layout->setRowPreferredHeight(0, 20);
+    layout->setRowPreferredHeight(2, 40);
+
+    view.show();
+    widget->show();
+    widget->resize(widget->effectiveSizeHint(Qt::PreferredSize));
+    QApplication::processEvents();
+
+    // ### Jasmin: Should rowPreferredHeight have precedence over sizeHint(Qt::PreferredSize) ?
+    QCOMPARE(layout->itemAt(0,0)->geometry().height(), 25.0);
+    QCOMPARE(layout->itemAt(0,1)->geometry().height(), 25.0);
+    QCOMPARE(layout->itemAt(1,0)->geometry().height(), 25.0);
+    QCOMPARE(layout->itemAt(1,1)->geometry().height(), 25.0);
+    QCOMPARE(layout->itemAt(2,0)->geometry().height(), 40.0);
+    QCOMPARE(layout->itemAt(2,1)->geometry().height(), 40.0);
+
+    delete widget;
+}
+
+// public void setRowFixedHeight(int row, qreal height)
+void tst_QGraphicsGridLayout::setRowFixedHeight()
+{
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout();
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    populateLayout(layout, 2, 3);
+    layout->setContentsMargins(0, 0, 0, 0);
+    layout->setSpacing(0);
+
+    layout->setRowFixedHeight(0, 20.);
+    layout->setRowFixedHeight(2, 40.);
+
+    view.show();
+    widget->show();
+    widget->resize(widget->effectiveSizeHint(Qt::PreferredSize));
+    QApplication::processEvents();
+
+    QCOMPARE(layout->itemAt(0,0)->geometry().height(), 20.0);
+    QCOMPARE(layout->itemAt(0,1)->geometry().height(), 20.0);
+    QCOMPARE(layout->itemAt(1,0)->geometry().height(), 25.0);
+    QCOMPARE(layout->itemAt(1,1)->geometry().height(), 25.0);
+    QCOMPARE(layout->itemAt(2,0)->geometry().height(), 40.0);
+    QCOMPARE(layout->itemAt(2,1)->geometry().height(), 40.0);
+
+    delete widget;
+}
+
+// public qreal rowSpacing(int row) const
+void tst_QGraphicsGridLayout::rowSpacing()
+{
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout();
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    populateLayout(layout, 3, 2);
+    layout->setContentsMargins(0, 0, 0, 0);
+    layout->setSpacing(0);
+    QCOMPARE(layout->columnSpacing(0), 0.0);
+
+    layout->setColumnSpacing(0, 20);
+    view.show();
+    widget->show();
+    widget->resize(widget->effectiveSizeHint(Qt::PreferredSize));
+    QApplication::processEvents();
+
+    QCOMPARE(layout->itemAt(0,0)->geometry().left(),   0.0);
+    QCOMPARE(layout->itemAt(0,0)->geometry().right(), 25.0);
+    QCOMPARE(layout->itemAt(0,1)->geometry().left(),  45.0);
+    QCOMPARE(layout->itemAt(0,1)->geometry().right(), 70.0);
+    QCOMPARE(layout->itemAt(0,2)->geometry().left(),  70.0);
+    QCOMPARE(layout->itemAt(0,2)->geometry().right(), 95.0);
+
+    delete widget;
+
+}
+
+// public int rowStretchFactor(int row) const
+void tst_QGraphicsGridLayout::rowStretchFactor()
+{
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout();
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    populateLayout(layout, 2, 3);
+    layout->setContentsMargins(0, 0, 0, 0);
+    layout->setSpacing(0);
+
+    layout->setRowStretchFactor(0, 1);
+    layout->setRowStretchFactor(1, 2);
+    layout->setRowStretchFactor(2, 3);
+    view.show();
+    widget->show();
+    widget->resize(50, 130);
+    QApplication::processEvents();
+
+    QVERIFY(layout->itemAt(0,0)->geometry().height() <  layout->itemAt(1,0)->geometry().height());
+    QVERIFY(layout->itemAt(1,0)->geometry().height() <  layout->itemAt(2,0)->geometry().height());
+    QVERIFY(layout->itemAt(0,1)->geometry().height() <  layout->itemAt(1,1)->geometry().height());
+    QVERIFY(layout->itemAt(1,1)->geometry().height() <  layout->itemAt(2,1)->geometry().height());
+
+    delete widget;
+}
+
+void tst_QGraphicsGridLayout::setColumnSpacing_data()
+{
+    QTest::addColumn<int>("column");
+    QTest::addColumn<qreal>("spacing");
+    QTest::newRow("null") << 0 << qreal(0.0);
+    QTest::newRow("10") << 0 << qreal(10.0);
+
+}
+
+// public void setColumnSpacing(int column, qreal spacing)
+void tst_QGraphicsGridLayout::setColumnSpacing()
+{
+    QFETCH(int, column);
+    QFETCH(qreal, spacing);
+
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout();
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    populateLayout(layout, 3, 2);
+    layout->setSpacing(0);
+    layout->setContentsMargins(0, 0, 0, 0);
+    qreal oldSpacing = layout->columnSpacing(column);
+    QCOMPARE(oldSpacing, 0.0);
+    qreal w = layout->sizeHint(Qt::PreferredSize, QSizeF()).width();
+    layout->setColumnSpacing(column, spacing);
+    QApplication::processEvents();
+    QCOMPARE(layout->sizeHint(Qt::PreferredSize, QSizeF()).width(), w + spacing);
+}
+
+void tst_QGraphicsGridLayout::setGeometry_data()
+{
+    QTest::addColumn<QRectF>("rect");
+    QTest::newRow("null") << QRectF();
+    QTest::newRow("normal") << QRectF(0,0, 50, 50);
+}
+
+// public void setGeometry(QRectF const& rect)
+void tst_QGraphicsGridLayout::setGeometry()
+{
+    QFETCH(QRectF, rect);
+
+    QGraphicsWidget *window = new QGraphicsWidget;
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout();
+    window->setLayout(layout);
+    QGraphicsGridLayout *layout2 = new QGraphicsGridLayout();
+    layout2->setMaximumSize(100, 100);
+    layout->addItem(layout2, 0, 0);
+    layout2->setGeometry(rect);
+    QCOMPARE(layout2->geometry(), rect);
+}
+
+void tst_QGraphicsGridLayout::setRowSpacing_data()
+{
+    QTest::addColumn<int>("row");
+    QTest::addColumn<qreal>("spacing");
+    QTest::newRow("null") << 0 << qreal(0.0);
+    QTest::newRow("10") << 0 << qreal(10.0);
+
+}
+
+// public void setRowSpacing(int row, qreal spacing)
+void tst_QGraphicsGridLayout::setRowSpacing()
+{
+    QFETCH(int, row);
+    QFETCH(qreal, spacing);
+
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout();
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    populateLayout(layout, 3, 2);
+    layout->setSpacing(0);
+    layout->setContentsMargins(0, 0, 0, 0);
+    qreal oldSpacing = layout->rowSpacing(row);
+    QCOMPARE(oldSpacing, 0.0);
+    qreal h = layout->sizeHint(Qt::PreferredSize, QSizeF()).height();
+    layout->setRowSpacing(row, spacing);
+    QApplication::processEvents();
+    QCOMPARE(layout->sizeHint(Qt::PreferredSize, QSizeF()).height(), h + spacing);
+}
+
+void tst_QGraphicsGridLayout::setSpacing_data()
+{
+    QTest::addColumn<qreal>("spacing");
+    QTest::newRow("zero") << qreal(0.0);
+    QTest::newRow("17") << qreal(17.0);
+}
+
+// public void setSpacing(qreal spacing)
+void tst_QGraphicsGridLayout::setSpacing()
+{
+    QFETCH(qreal, spacing);
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout();
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    populateLayout(layout, 3, 2);
+    layout->setContentsMargins(0, 0, 0, 0);
+    QSizeF sh = layout->sizeHint(Qt::PreferredSize, QSizeF());
+    qreal oldVSpacing = layout->verticalSpacing();
+    qreal oldHSpacing = layout->horizontalSpacing();
+    if (oldVSpacing != -1) {
+        layout->setSpacing(spacing);
+        QApplication::processEvents();
+        QSizeF newSH = layout->sizeHint(Qt::PreferredSize, QSizeF());
+        QCOMPARE(newSH.height(), sh.height() - (2-1)*(oldVSpacing - spacing));
+        QCOMPARE(newSH.width(), sh.width() - (3-1)*(oldHSpacing - spacing));
+    } else {
+        QSKIP("The current style uses non-uniform layout spacing", SkipAll);
+    }
+    delete widget;
+}
+
+void tst_QGraphicsGridLayout::sizeHint_data()
+{
+
+    /*
+    QTest::addColumn<Qt::SizeHint>("which");
+    QTest::addColumn<QSizeF>("constraint");
+    QTest::addColumn<QSizeF>("sizeHint");
+    QTest::newRow("null") << 0;
+    */
+}
+
+// public QSizeF sizeHint(Qt::SizeHint which, QSizeF const& constraint = QSizeF()) const
+void tst_QGraphicsGridLayout::sizeHint()
+{
+    /*
+    QFETCH(Qt::SizeHint, which);
+    QFETCH(QSizeF, constraint);
+    QFETCH(QSizeF, sizeHint);
+
+    QGraphicsGridLayout layout;
+
+    layout.sizeHint();
+    */
+    QSKIP("Test unimplemented", SkipSingle);
+}
+
+void tst_QGraphicsGridLayout::verticalSpacing_data()
+{
+    QTest::addColumn<qreal>("verticalSpacing");
+    QTest::newRow("zero") << qreal(0.0);
+    QTest::newRow("17") << qreal(10.0);
+}
+
+// public qreal verticalSpacing() const
+void tst_QGraphicsGridLayout::verticalSpacing()
+{
+    QFETCH(qreal, verticalSpacing);
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout();
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    populateLayout(layout, 3, 2);
+    layout->setContentsMargins(0, 0, 0, 0);
+    qreal h = layout->sizeHint(Qt::PreferredSize, QSizeF()).height();
+    qreal oldSpacing = layout->verticalSpacing();
+    if (oldSpacing != -1) {
+        layout->setVerticalSpacing(verticalSpacing);
+        QApplication::processEvents();
+        qreal new_h = layout->sizeHint(Qt::PreferredSize, QSizeF()).height();
+        QCOMPARE(new_h, h - (2-1)*(oldSpacing - verticalSpacing));
+    } else {
+        QSKIP("The current style uses non-uniform layout spacing", SkipAll);
+    }
+    delete widget;
+}
+
+void tst_QGraphicsGridLayout::layoutDirection()
+{
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+
+    QGraphicsWidget *window = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout;
+    layout->setContentsMargins(1, 2, 3, 4);
+    layout->setSpacing(6);
+    RectWidget *w1 = new RectWidget;
+    w1->setMinimumSize(30, 20);
+    layout->addItem(w1, 0, 0);
+    RectWidget *w2 = new RectWidget;
+    w2->setMinimumSize(20, 20);
+    w2->setMaximumSize(20, 20);
+    layout->addItem(w2, 0, 1);
+    RectWidget *w3 = new RectWidget;
+    w3->setMinimumSize(20, 20);
+    w3->setMaximumSize(20, 20);
+    layout->addItem(w3, 1, 0);
+    RectWidget *w4 = new RectWidget;
+    w4->setMinimumSize(30, 20);
+    layout->addItem(w4, 1, 1);
+
+    layout->setAlignment(w2, Qt::AlignRight);
+    layout->setAlignment(w3, Qt::AlignLeft);
+
+    scene.addItem(window);
+    window->setLayout(layout);
+    view.show();
+    window->resize(70, 52);
+    QApplication::processEvents();
+    QCOMPARE(w1->geometry().left(), 1.0);
+    QCOMPARE(w1->geometry().right(), 31.0);
+    QCOMPARE(w2->geometry().left(), 47.0);
+    QCOMPARE(w2->geometry().right(), 67.0);
+    QCOMPARE(w3->geometry().left(), 1.0);
+    QCOMPARE(w3->geometry().right(), 21.0);
+    QCOMPARE(w4->geometry().left(), 37.0);
+    QCOMPARE(w4->geometry().right(), 67.0);
+
+    window->setLayoutDirection(Qt::RightToLeft);
+    QApplication::processEvents();
+    QCOMPARE(w1->geometry().left(),  39.0);
+    QCOMPARE(w1->geometry().right(), 69.0);
+    QCOMPARE(w2->geometry().left(),   3.0);
+    QCOMPARE(w2->geometry().right(), 23.0);
+    QCOMPARE(w3->geometry().left(),  49.0);
+    QCOMPARE(w3->geometry().right(), 69.0);
+    QCOMPARE(w4->geometry().left(),   3.0);
+    QCOMPARE(w4->geometry().right(), 33.0);
+
+    delete window;
+}
+
+void tst_QGraphicsGridLayout::removeLayout()
+{
+    QGraphicsScene scene;
+    RectWidget *textEdit = new RectWidget;
+    RectWidget *pushButton = new RectWidget;
+    scene.addItem(textEdit);
+    scene.addItem(pushButton);
+
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout;
+    layout->addItem(textEdit, 0, 0);
+    layout->addItem(pushButton, 1, 0);
+
+    QGraphicsWidget *form = new QGraphicsWidget;
+    form->setLayout(layout);
+    scene.addItem(form);
+
+    QGraphicsView view(&scene);
+    view.show();
+    QTest::qWait(20);
+
+    QRectF r1 = textEdit->geometry();
+    QRectF r2 = pushButton->geometry();
+    form->setLayout(0);
+    //documentation of QGraphicsWidget::setLayout:
+    //If layout is 0, the widget is left without a layout. Existing subwidgets' geometries will remain unaffected.
+    QCOMPARE(textEdit->geometry(), r1);
+    QCOMPARE(pushButton->geometry(), r2);
+}
+
+struct ItemDesc
+{
+    ItemDesc(int row, int col)
+    : m_pos(qMakePair(row, col)),
+      m_rowSpan(1),
+      m_colSpan(1),
+      m_sizePolicy(QSizePolicy(QSizePolicy::Preferred, QSizePolicy::Preferred)),
+      m_align(0)
+    {
+    }
+
+    ItemDesc &rowSpan(int span) {
+        m_rowSpan = span;
+        return (*this);
+    }
+
+    ItemDesc &colSpan(int span) {
+        m_colSpan = span;
+        return (*this);
+    }
+
+    ItemDesc &sizePolicy(const QSizePolicy &sp) {
+        m_sizePolicy = sp;
+        return (*this);
+    }
+
+    ItemDesc &sizePolicy(QSizePolicy::Policy horAndVer) {
+        m_sizePolicy = QSizePolicy(horAndVer, horAndVer);
+        return (*this);
+    }
+
+    ItemDesc &sizePolicyH(QSizePolicy::Policy hor) {
+        m_sizePolicy.setHorizontalPolicy(hor);
+        return (*this);
+    }
+
+    ItemDesc &sizePolicyV(QSizePolicy::Policy ver) {
+        m_sizePolicy.setVerticalPolicy(ver);
+        return (*this);
+    }
+
+    ItemDesc &sizePolicy(QSizePolicy::Policy hor, QSizePolicy::Policy ver) {
+        m_sizePolicy = QSizePolicy(hor, ver);
+        return (*this);
+    }
+
+    ItemDesc &sizeHint(Qt::SizeHint which, const QSizeF &sh) {
+        m_sizeHints[which] = sh;
+        return (*this);
+    }
+
+    ItemDesc &preferredSizeHint(const QSizeF &sh) {
+        m_sizeHints[Qt::PreferredSize] = sh;
+        return (*this);
+    }
+
+    ItemDesc &minSize(const QSizeF &sz) {
+        m_sizes[Qt::MinimumSize] = sz;
+        return (*this);
+    }
+    ItemDesc &preferredSize(const QSizeF &sz) {
+        m_sizes[Qt::PreferredSize] = sz;
+        return (*this);
+    }
+    ItemDesc &maxSize(const QSizeF &sz) {
+        m_sizes[Qt::MaximumSize] = sz;
+        return (*this);
+    }
+
+    ItemDesc &alignment(Qt::Alignment alignment) {
+        m_align = alignment;
+        return (*this);
+    }
+
+    void apply(QGraphicsGridLayout *layout, RectWidget *item) {
+        item->setSizePolicy(m_sizePolicy);
+        for (int i = 0; i < Qt::NSizeHints; ++i) {
+            item->setSizeHint((Qt::SizeHint)i, m_sizeHints[i]);
+            if (!m_sizes[i].isValid())
+                continue;
+            switch ((Qt::SizeHint)i) {
+            case Qt::MinimumSize:
+                item->setMinimumSize(m_sizes[i]);
+                break;
+            case Qt::PreferredSize:
+                item->setPreferredSize(m_sizes[i]);
+                break;
+            case Qt::MaximumSize:
+                item->setMaximumSize(m_sizes[i]);
+                break;
+            default:
+                qWarning("not implemented");
+                break;
+            }
+        }
+        layout->addItem(item, m_pos.first, m_pos.second, m_rowSpan, m_colSpan);
+        layout->setAlignment(item, m_align);
+    }
+
+//private:
+    QPair<int,int> m_pos; // row,col
+    int m_rowSpan;
+    int m_colSpan;
+    QSizePolicy m_sizePolicy;
+    QSizeF m_sizeHints[Qt::NSizeHints];
+    QSizeF m_sizes[Qt::NSizeHints];
+    Qt::Alignment m_align;
+};
+
+typedef QList<ItemDesc> ItemList;
+Q_DECLARE_METATYPE(ItemList);
+
+typedef QList<QSizeF> SizeList;
+Q_DECLARE_METATYPE(SizeList);
+
+void tst_QGraphicsGridLayout::defaultStretchFactors_data()
+{
+    QTest::addColumn<ItemList>("itemDescriptions");
+    QTest::addColumn<QSizeF>("newSize");
+    QTest::addColumn<SizeList>("expectedSizes");
+
+    QTest::newRow("usepreferredsize") << (ItemList()
+                                    << ItemDesc(0,0)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(0,1)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(0,2)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(1,0)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(1,1)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(1,2)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                )
+                            << QSizeF()
+                            << (SizeList()
+                                << QSizeF(10,10) << QSizeF(10,10) << QSizeF(10,10)
+                                << QSizeF(10,10) << QSizeF(10,10) << QSizeF(10,10)
+                            );
+
+    QTest::newRow("ignoreitem01") << (ItemList()
+                                    << ItemDesc(0,0)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(0,1)
+                                        .sizePolicy(QSizePolicy::Ignored)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(0,2)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(1,0)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(1,1)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(1,2)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                )
+                            << QSizeF()
+                            << (SizeList()
+                                << QSizeF(10,10) << QSizeF(10,10) << QSizeF(10,10)
+                                << QSizeF(10,10) << QSizeF(10,10) << QSizeF(10,10)
+                            );
+
+    QTest::newRow("ignoreitem01_resize120x40") << (ItemList()
+                                    << ItemDesc(0,0)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(0,1)
+                                        .sizePolicy(QSizePolicy::Ignored)
+                                        .preferredSizeHint(QSizeF(20,10))
+                                    << ItemDesc(0,2)
+                                        .preferredSizeHint(QSizeF(30,10))
+                                    << ItemDesc(1,0)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(1,1)
+                                        .preferredSizeHint(QSizeF(20,10))
+                                    << ItemDesc(1,2)
+                                        .preferredSizeHint(QSizeF(30,10))
+                                )
+                            << QSizeF(120, 40)
+                            << (SizeList()
+                                << QSizeF(20,20) << QSizeF(40,20) << QSizeF(60,20)
+                                << QSizeF(20,20) << QSizeF(40,20) << QSizeF(60,20)
+                            );
+
+    QTest::newRow("ignoreitem11_resize120x40") << (ItemList()
+                                    << ItemDesc(0,0)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(0,1)
+                                        .preferredSizeHint(QSizeF(20,10))
+                                    << ItemDesc(0,2)
+                                        .preferredSizeHint(QSizeF(30,10))
+                                    << ItemDesc(1,0)
+                                        .preferredSizeHint(QSizeF(10,20))
+                                    << ItemDesc(1,1)
+                                        .sizePolicy(QSizePolicy::Ignored)
+                                        .preferredSizeHint(QSizeF(20,20))
+                                    << ItemDesc(1,2)
+                                        .preferredSizeHint(QSizeF(30,20))
+                                )
+                            << QSizeF(120, 60)
+                            << (SizeList()
+                                << QSizeF(20,20) << QSizeF(40,20) << QSizeF(60,20)
+                                << QSizeF(20,40) << QSizeF(40,40) << QSizeF(60,40)
+                            );
+
+    QTest::newRow("ignoreitem01_span01_resize70x60") << (ItemList()
+                                    << ItemDesc(0,0)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(0,1)
+                                        .preferredSizeHint(QSizeF(20,10))
+                                        .sizePolicy(QSizePolicy::Ignored)
+                                        .rowSpan(2)
+                                    << ItemDesc(0,2)
+                                        .preferredSizeHint(QSizeF(30,10))
+                                    << ItemDesc(1,0)
+                                        .preferredSizeHint(QSizeF(10,20))
+                                    << ItemDesc(1,2)
+                                        .preferredSizeHint(QSizeF(30,20))
+                                )
+                            << QSizeF(70, 60)
+                            << (SizeList()
+                                << QSizeF(20,20) << QSizeF(10,60) << QSizeF(40,20)
+                                << QSizeF(20,40) << QSizeF(40,40)
+                            );
+
+    QTest::newRow("ignoreitem10_resize40x120") << (ItemList()
+                                    << ItemDesc(0,0)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(0,1)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(1,0)
+                                        .sizePolicy(QSizePolicy::Ignored)
+                                        .preferredSizeHint(QSizeF(10,20))
+                                    << ItemDesc(1,1)
+                                        .preferredSizeHint(QSizeF(10,20))
+                                    << ItemDesc(2,0)
+                                        .preferredSizeHint(QSizeF(10,30))
+                                    << ItemDesc(2,1)
+                                        .preferredSizeHint(QSizeF(10,30))
+                                )
+                            << QSizeF(40, 120)
+                            << (SizeList()
+                                << QSizeF(20,20) << QSizeF(20,20)
+                                << QSizeF(20,40) << QSizeF(20,40)
+                                << QSizeF(20,60) << QSizeF(20,60)
+                            );
+
+    QTest::newRow("ignoreitem01_span02") << (ItemList()
+                                    << ItemDesc(0,0)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(0,1)
+                                        .sizePolicy(QSizePolicy::Ignored)
+                                        .preferredSizeHint(QSizeF(10,20))
+                                        .rowSpan(2)
+                                    << ItemDesc(0,2)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(1,0)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(1,2)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                )
+                            << QSizeF()
+                            << (SizeList()
+                                << QSizeF(10,10) << QSizeF(0,20) << QSizeF(10,10)
+                                << QSizeF(10,10) << QSizeF(10,10)
+                            );
+
+    QTest::newRow("ignoreitem02_span02") << (ItemList()
+                                    << ItemDesc(0,0)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(0,1)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(0,2)
+                                        .sizePolicy(QSizePolicy::Ignored)
+                                        .preferredSizeHint(QSizeF(10,20))
+                                        .rowSpan(2)
+                                    << ItemDesc(1,0)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(1,1)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                )
+                            << QSizeF()
+                            << (SizeList()
+                                << QSizeF(10,10) << QSizeF(10,10) << QSizeF(0,20)
+                                << QSizeF(10,10) << QSizeF(10,10)
+                            );
+
+    QTest::newRow("ignoreitem02_span00_span02") << (ItemList()
+                                    << ItemDesc(0,0)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                        .rowSpan(2)
+                                    << ItemDesc(0,1)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(0,2)
+                                        .sizePolicy(QSizePolicy::Ignored)
+                                        .preferredSizeHint(QSizeF(10,20))
+                                        .rowSpan(2)
+                                    << ItemDesc(1,1)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                )
+                            << QSizeF()
+                            << (SizeList()
+                                << QSizeF(10,20) << QSizeF(10,10) << QSizeF(0,20)
+                                << QSizeF(10,10)
+                            );
+
+    QTest::newRow("ignoreitem00_colspan00") << (ItemList()
+                                    << ItemDesc(0,0)
+                                        .sizePolicy(QSizePolicy::Ignored)
+                                        .preferredSizeHint(QSizeF(10,20))
+                                        .colSpan(2)
+                                    << ItemDesc(0,2)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(1,0)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(1,1)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(1,2)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                )
+                            << QSizeF()
+                            << (SizeList()
+                                << QSizeF(20,10) << QSizeF(10,10) << QSizeF(10,10)
+                                << QSizeF(10,10) << QSizeF(10,10)
+                            );
+
+    QTest::newRow("ignoreitem01_colspan01") << (ItemList()
+                                    << ItemDesc(0,0)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(0,1)
+                                        .sizePolicy(QSizePolicy::Ignored)
+                                        .preferredSizeHint(QSizeF(10,20))
+                                        .colSpan(2)
+                                    << ItemDesc(1,0)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(1,1)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(1,2)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                )
+                            << QSizeF()
+                            << (SizeList()
+                                << QSizeF(10,10) << QSizeF(20,10) << QSizeF(10,10)
+                                << QSizeF(10,10) << QSizeF(10,10)
+                            );
+
+    QTest::newRow("ignorecolumn1_resize70x60") << (ItemList()
+                                    << ItemDesc(0,0)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(0,1)
+                                        .sizePolicy(QSizePolicy::Ignored)
+                                        .preferredSizeHint(QSizeF(20,10))
+                                    << ItemDesc(0,2)
+                                        .preferredSizeHint(QSizeF(30,10))
+                                    << ItemDesc(1,0)
+                                        .preferredSizeHint(QSizeF(10,20))
+                                    << ItemDesc(1,1)
+                                        .sizePolicy(QSizePolicy::Ignored)
+                                        .preferredSizeHint(QSizeF(20,20))
+                                    << ItemDesc(1,2)
+                                        .preferredSizeHint(QSizeF(30,20))
+                                )
+                            << QSizeF(70, 60)
+                            << (SizeList()
+                                << QSizeF(20,20) << QSizeF(10,20) << QSizeF(40,20)
+                                << QSizeF(20,40) << QSizeF(10,40) << QSizeF(40,40)
+                            );
+
+    QTest::newRow("ignorerow0") << (ItemList()
+                                    << ItemDesc(0,0)
+                                        .sizePolicy(QSizePolicy::Ignored)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(0,1)
+                                        .sizePolicy(QSizePolicy::Ignored)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(0,2)
+                                        .sizePolicy(QSizePolicy::Ignored)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(1,0)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(1,1)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(1,2)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                )
+                            << QSizeF()
+                            << (SizeList()
+                                << QSizeF(10,0) << QSizeF(10,0) << QSizeF(10,0)
+                                << QSizeF(10,10) << QSizeF(10,10) << QSizeF(10,10)
+                            );
+
+    QTest::newRow("ignorerow1") << (ItemList()
+                                    << ItemDesc(0,0)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(0,1)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(0,2)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(1,0)
+                                        .sizePolicy(QSizePolicy::Ignored)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(1,1)
+                                        .sizePolicy(QSizePolicy::Ignored)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(1,2)
+                                        .sizePolicy(QSizePolicy::Ignored)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                )
+                            << QSizeF()
+                            << (SizeList()
+                                << QSizeF(10,10) << QSizeF(10,10) << QSizeF(10,10)
+                                << QSizeF(10,0) << QSizeF(10,0) << QSizeF(10,0)
+                            );
+
+    QTest::newRow("ignorerow0_resize60x50") << (ItemList()
+                                    << ItemDesc(0,0)
+                                        .sizePolicy(QSizePolicy::Ignored)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                    << ItemDesc(0,1)
+                                        .sizePolicy(QSizePolicy::Ignored)
+                                        .preferredSizeHint(QSizeF(20,10))
+                                    << ItemDesc(0,2)
+                                        .sizePolicy(QSizePolicy::Ignored)
+                                        .preferredSizeHint(QSizeF(30,10))
+                                    << ItemDesc(1,0)
+                                        .preferredSizeHint(QSizeF(10,30))
+                                    << ItemDesc(1,1)
+                                        .preferredSizeHint(QSizeF(20,30))
+                                    << ItemDesc(1,2)
+                                        .preferredSizeHint(QSizeF(30,30))
+                                )
+                            << QSizeF(60, 50)
+                            << (SizeList()
+                                << QSizeF(10,10) << QSizeF(20,10) << QSizeF(30,10)
+                                << QSizeF(10,40) << QSizeF(20,40) << QSizeF(30,40)
+                            );
+
+}
+
+void tst_QGraphicsGridLayout::defaultStretchFactors()
+{
+    QFETCH(ItemList, itemDescriptions);
+    QFETCH(QSizeF, newSize);
+    QFETCH(SizeList, expectedSizes);
+
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout;
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    layout->setContentsMargins(0, 0, 0, 0);
+    layout->setSpacing(0.0);
+    widget->setContentsMargins(0, 0, 0, 0);
+
+    int i;
+    for (i = 0; i < itemDescriptions.count(); ++i) {
+        ItemDesc desc = itemDescriptions.at(i);
+        RectWidget *item = new RectWidget(widget);
+        desc.apply(layout, item);
+    }
+
+    QApplication::processEvents();
+
+    widget->show();
+    view.show();
+    view.resize(400,300);
+    if (newSize.isValid())
+        widget->resize(newSize);
+
+    QApplication::processEvents();
+    for (i = 0; i < expectedSizes.count(); ++i) {
+        QSizeF itemSize = layout->itemAt(i)->geometry().size();
+        QCOMPARE(itemSize, expectedSizes.at(i));
+    }
+
+    delete widget;
+}
+
+typedef QList<QRectF> RectList;
+Q_DECLARE_METATYPE(RectList);
+
+void tst_QGraphicsGridLayout::alignment2_data()
+{
+    QTest::addColumn<ItemList>("itemDescriptions");
+    QTest::addColumn<QSizeF>("newSize");
+    QTest::addColumn<RectList>("expectedGeometries");
+
+    QTest::newRow("hor_sizepolicy_fixed") << (ItemList()
+                                    << ItemDesc(0,0)
+                                        .preferredSizeHint(QSizeF(10,20))
+                                        .sizePolicyV(QSizePolicy::Fixed)
+                                    << ItemDesc(0,1)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                        .sizePolicyV(QSizePolicy::Fixed)
+                                )
+                            << QSizeF()
+                            << (RectList()
+                                << QRectF(0, 0, 10,20) << QRectF(10, 0, 10,10)
+                            );
+
+    QTest::newRow("hor_sizepolicy_fixed_alignvcenter") << (ItemList()
+                                    << ItemDesc(0,0)
+                                        .preferredSizeHint(QSizeF(10,20))
+                                        .sizePolicyV(QSizePolicy::Fixed)
+                                    << ItemDesc(0,1)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                        .sizePolicyV(QSizePolicy::Fixed)
+                                        .alignment(Qt::AlignVCenter)
+                                )
+                            << QSizeF()
+                            << (RectList()
+                                << QRectF(0, 0, 10,20) << QRectF(10, 5, 10,10)
+                            );
+
+    QTest::newRow("hor_sizepolicy_fixed_aligntop") << (ItemList()
+                                    << ItemDesc(0,0)
+                                        .preferredSizeHint(QSizeF(10,20))
+                                        .sizePolicyV(QSizePolicy::Fixed)
+                                    << ItemDesc(0,1)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                        .sizePolicyV(QSizePolicy::Fixed)
+                                        .alignment(Qt::AlignTop)
+                                )
+                            << QSizeF()
+                            << (RectList()
+                                << QRectF(0, 0, 10,20) << QRectF(10, 0, 10,10)
+                            );
+
+    QTest::newRow("hor_sizepolicy_fixed_alignbottom") << (ItemList()
+                                    << ItemDesc(0,0)
+                                        .preferredSizeHint(QSizeF(10,20))
+                                        .sizePolicyV(QSizePolicy::Fixed)
+                                    << ItemDesc(0,1)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                        .sizePolicyV(QSizePolicy::Fixed)
+                                        .alignment(Qt::AlignBottom)
+                                )
+                            << QSizeF()
+                            << (RectList()
+                                << QRectF(0, 0, 10,20) << QRectF(10, 10, 10,10)
+                            );
+
+    QTest::newRow("ver_sizepolicy_fixed") << (ItemList()
+                                    << ItemDesc(0,0)
+                                        .preferredSizeHint(QSizeF(20,10))
+                                        .sizePolicyH(QSizePolicy::Fixed)
+                                    << ItemDesc(1,0)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                        .sizePolicyH(QSizePolicy::Fixed)
+                                )
+                            << QSizeF()
+                            << (RectList()
+                                << QRectF(0, 0, 20,10) << QRectF(0, 10, 10,10)
+                            );
+
+    QTest::newRow("ver_sizepolicy_fixed_alignhcenter") << (ItemList()
+                                    << ItemDesc(0,0)
+                                        .preferredSizeHint(QSizeF(20,10))
+                                        .sizePolicyH(QSizePolicy::Fixed)
+                                    << ItemDesc(1,0)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                        .sizePolicyH(QSizePolicy::Fixed)
+                                        .alignment(Qt::AlignHCenter)
+                                )
+                            << QSizeF()
+                            << (RectList()
+                                << QRectF(0, 0, 20,10) << QRectF(5, 10, 10,10)
+                            );
+
+    QTest::newRow("ver_sizepolicy_fixed_alignleft") << (ItemList()
+                                    << ItemDesc(0,0)
+                                        .preferredSizeHint(QSizeF(20,10))
+                                        .sizePolicyH(QSizePolicy::Fixed)
+                                    << ItemDesc(1,0)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                        .sizePolicyH(QSizePolicy::Fixed)
+                                        .alignment(Qt::AlignLeft)
+                                )
+                            << QSizeF()
+                            << (RectList()
+                                << QRectF(0, 0, 20,10) << QRectF(0, 10, 10,10)
+                            );
+
+    QTest::newRow("ver_sizepolicy_fixed_alignright") << (ItemList()
+                                    << ItemDesc(0,0)
+                                        .preferredSizeHint(QSizeF(20,10))
+                                        .sizePolicyH(QSizePolicy::Fixed)
+                                    << ItemDesc(1,0)
+                                        .preferredSizeHint(QSizeF(10,10))
+                                        .sizePolicyH(QSizePolicy::Fixed)
+                                        .alignment(Qt::AlignRight)
+                                )
+                            << QSizeF()
+                            << (RectList()
+                                << QRectF(0, 0, 20,10) << QRectF(10, 10, 10,10)
+                            );
+}
+
+void tst_QGraphicsGridLayout::alignment2()
+{
+    QFETCH(ItemList, itemDescriptions);
+    QFETCH(QSizeF, newSize);
+    QFETCH(RectList, expectedGeometries);
+
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout;
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    layout->setContentsMargins(0, 0, 0, 0);
+    layout->setSpacing(0.0);
+    widget->setContentsMargins(0, 0, 0, 0);
+
+    int i;
+    for (i = 0; i < itemDescriptions.count(); ++i) {
+        ItemDesc desc = itemDescriptions.at(i);
+        RectWidget *item = new RectWidget(widget);
+        desc.apply(layout, item);
+    }
+
+    QApplication::processEvents();
+
+    widget->show();
+    view.resize(400,300);
+    view.show();
+    if (newSize.isValid())
+        widget->resize(newSize);
+
+    QApplication::processEvents();
+    for (i = 0; i < expectedGeometries.count(); ++i) {
+        QRectF itemRect = layout->itemAt(i)->geometry();
+        QCOMPARE(itemRect, expectedGeometries.at(i));
+    }
+
+    delete widget;
+}
+
+void tst_QGraphicsGridLayout::geometries_data()
+{
+
+    QTest::addColumn<ItemList>("itemDescriptions");
+    QTest::addColumn<QSizeF>("newSize");
+    QTest::addColumn<RectList>("expectedGeometries");
+
+    QTest::newRow("combine_max_sizes") << (ItemList()
+                                    << ItemDesc(0,0)
+                                        .maxSize(QSizeF(50,10))
+                                    << ItemDesc(1,0)
+                                        .maxSize(QSizeF(10,10))
+                                )
+                            << QSizeF(50, 20)
+                            << (RectList()
+                                << QRectF(0, 0, 50,10) << QRectF(0, 10, 10,10)
+                            );
+
+    QTest::newRow("combine_min_sizes") << (ItemList()
+                                    << ItemDesc(0,0)
+                                        .minSize(QSizeF(50,10))
+                                    << ItemDesc(1,0)
+                                        .minSize(QSizeF(10,10))
+                                )
+                            << QSizeF(60, 20)
+                            << (RectList()
+                                << QRectF(0, 0, 60,10) << QRectF(0, 10, 60,10)
+                            );
+
+}
+
+void tst_QGraphicsGridLayout::geometries()
+{
+    QFETCH(ItemList, itemDescriptions);
+    QFETCH(QSizeF, newSize);
+    QFETCH(RectList, expectedGeometries);
+
+    QGraphicsScene scene;
+    QGraphicsView view(&scene);
+    QGraphicsWidget *widget = new QGraphicsWidget(0, Qt::Window);
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout;
+    scene.addItem(widget);
+    widget->setLayout(layout);
+    layout->setContentsMargins(0, 0, 0, 0);
+    layout->setSpacing(0.0);
+    widget->setContentsMargins(0, 0, 0, 0);
+
+    int i;
+    for (i = 0; i < itemDescriptions.count(); ++i) {
+        ItemDesc desc = itemDescriptions.at(i);
+        RectWidget *item = new RectWidget(widget);
+        desc.apply(layout, item);
+    }
+
+    QApplication::processEvents();
+
+    widget->show();
+    view.resize(400,300);
+    view.show();
+    if (newSize.isValid())
+        widget->resize(newSize);
+
+    QApplication::processEvents();
+    for (i = 0; i < expectedGeometries.count(); ++i) {
+        QRectF itemRect = layout->itemAt(i)->geometry();
+        QCOMPARE(itemRect, expectedGeometries.at(i));
+    }
+
+    delete widget;
+}
+
+void tst_QGraphicsGridLayout::avoidRecursionInInsertItem()
+{
+    QGraphicsWidget window(0, Qt::Window);
+	QGraphicsGridLayout *layout = new QGraphicsGridLayout(&window);
+    QCOMPARE(layout->count(), 0);
+    QTest::ignoreMessage(QtWarningMsg, "QGraphicsGridLayout::addItem: cannot insert itself");
+    layout->addItem(layout, 0, 0);
+    QCOMPARE(layout->count(), 0);
+}
+
+void tst_QGraphicsGridLayout::task236367_maxSizeHint()
+{
+    QGraphicsWidget *widget = new QGraphicsWidget;
+    QGraphicsGridLayout *layout = new QGraphicsGridLayout;
+    widget->setLayout(layout);
+    layout->setContentsMargins(0, 0, 0, 0);
+    int w = 203;
+    int h = 204;
+    widget->resize(w, h);
+    QCOMPARE(widget->size(), QSizeF(w, h));
+}
+
+QTEST_MAIN(tst_QGraphicsGridLayout)
+#include "tst_qgraphicsgridlayout.moc"
+