aboutsummaryrefslogtreecommitdiffstats
path: root/tests/auto/quick/qquicklistview/tst_qquicklistview.cpp
diff options
context:
space:
mode:
authorJ-P Nurmi <jpnurmi@digia.com>2014-04-04 10:42:37 +0200
committerThe Qt Project <gerrit-noreply@qt-project.org>2014-04-09 00:29:23 +0200
commitfc5314f96990148a7c32b988caf53c5db92b2b4b (patch)
tree2e376334b071b30072ab5aa111432cdd733f0597 /tests/auto/quick/qquicklistview/tst_qquicklistview.cpp
parent1674bf32c8d2b52d95dab62429bb605ca9d279cc (diff)
ListView: fix rounding errors
Task-number: QTBUG-37339 Change-Id: I223e4d6bcabb1daa705c0ed2212e7e2b2fc3f37c Reviewed-by: Andy Shaw <andy.shaw@digia.com> Reviewed-by: Alan Alpert <aalpert@blackberry.com>
Diffstat (limited to 'tests/auto/quick/qquicklistview/tst_qquicklistview.cpp')
-rw-r--r--tests/auto/quick/qquicklistview/tst_qquicklistview.cpp60
1 files changed, 60 insertions, 0 deletions
diff --git a/tests/auto/quick/qquicklistview/tst_qquicklistview.cpp b/tests/auto/quick/qquicklistview/tst_qquicklistview.cpp
index 288c0d0a58..29755e3890 100644
--- a/tests/auto/quick/qquicklistview/tst_qquicklistview.cpp
+++ b/tests/auto/quick/qquicklistview/tst_qquicklistview.cpp
@@ -224,6 +224,9 @@ private slots:
void QTBUG_36481();
void QTBUG_35920();
+ void roundingErrors();
+ void roundingErrors_data();
+
private:
template <class T> void items(const QUrl &source);
template <class T> void changed(const QUrl &source);
@@ -7201,6 +7204,63 @@ void tst_QQuickListView::QTBUG_35920()
QTest::mouseRelease(window.data(), Qt::LeftButton, 0, QPoint(10,100));
}
+void tst_QQuickListView::roundingErrors()
+{
+ QFETCH(bool, pixelAligned);
+
+ QScopedPointer<QQuickView> window(createView());
+ window->setSource(testFileUrl("roundingErrors.qml"));
+ window->show();
+ QVERIFY(QTest::qWaitForWindowExposed(window.data()));
+
+ QQuickListView *listview = qobject_cast<QQuickListView *>(window->rootObject());
+ QVERIFY(listview);
+ listview->setPixelAligned(pixelAligned);
+ listview->positionViewAtIndex(20, QQuickListView::Beginning);
+
+ QQuickItem *content = listview->contentItem();
+ QVERIFY(content);
+
+ const QPoint viewPos(150, 36);
+ const QPointF contentPos = content->mapFromItem(listview, viewPos);
+
+ QPointer<QQuickItem> item = listview->itemAt(contentPos.x(), contentPos.y());
+ QVERIFY(item);
+
+ // QTBUG-37339: drag an item and verify that it doesn't
+ // get prematurely released due to rounding errors
+ QTest::mousePress(window.data(), Qt::LeftButton, 0, viewPos);
+ for (int i = 0; i < 150; i += 5) {
+ QTest::mouseMove(window.data(), viewPos - QPoint(i, 0));
+ QVERIFY(item);
+ }
+ QTest::mouseRelease(window.data(), Qt::LeftButton, 0, QPoint(0, 36));
+
+ // maintain position relative to the right edge
+ listview->setLayoutDirection(Qt::RightToLeft);
+ const qreal contentX = listview->contentX();
+ listview->setContentX(contentX + 0.2);
+ QCOMPARE(listview->contentX(), pixelAligned ? qRound(contentX + 0.2) : contentX + 0.2);
+ listview->setWidth(listview->width() - 0.2);
+ QCOMPARE(listview->contentX(), pixelAligned ? qRound(contentX + 0.2) : contentX + 0.2);
+
+ // maintain position relative to the bottom edge
+ listview->setOrientation(QQuickListView::Vertical);
+ listview->setVerticalLayoutDirection(QQuickListView::BottomToTop);
+ const qreal contentY = listview->contentY();
+ listview->setContentY(contentY + 0.2);
+ QCOMPARE(listview->contentY(), pixelAligned ? qRound(contentY + 0.2) : contentY + 0.2);
+ listview->setHeight(listview->height() - 0.2);
+ QCOMPARE(listview->contentY(), pixelAligned ? qRound(contentY + 0.2) : contentY + 0.2);
+}
+
+void tst_QQuickListView::roundingErrors_data()
+{
+ QTest::addColumn<bool>("pixelAligned");
+ QTest::newRow("pixelAligned=true") << true;
+ QTest::newRow("pixelAligned=false") << false;
+}
+
QTEST_MAIN(tst_QQuickListView)
#include "tst_qquicklistview.moc"