From f09b12cea1143f1b2763064bb0d3e6592081de2b Mon Sep 17 00:00:00 2001 From: Nils Jeisecke Date: Fri, 28 Feb 2014 12:53:43 +0100 Subject: Make sure that the itemview's count property is reliable This fixes a missing countChanged signal when model changes happen while the itemview component is not completely initialized. Task-number: QTBUG-37115 Change-Id: I20c749b9e521b0292186adbecd09e1d362520881 Reviewed-by: Alan Alpert --- .../tst_qdeclarativelistview.cpp | 48 ++++++++++++++++++++++ 1 file changed, 48 insertions(+) (limited to 'tests/auto/declarative/qdeclarativelistview/tst_qdeclarativelistview.cpp') diff --git a/tests/auto/declarative/qdeclarativelistview/tst_qdeclarativelistview.cpp b/tests/auto/declarative/qdeclarativelistview/tst_qdeclarativelistview.cpp index eb0e0948..f2f39102 100644 --- a/tests/auto/declarative/qdeclarativelistview/tst_qdeclarativelistview.cpp +++ b/tests/auto/declarative/qdeclarativelistview/tst_qdeclarativelistview.cpp @@ -60,6 +60,8 @@ public: tst_QDeclarativeListView(); private slots: + void initTestCase(); + // Test both QListModelInterface and QAbstractItemModel model types void qListModelInterface_items(); void qAbstractItemModel_items(); @@ -116,6 +118,7 @@ private slots: void test_mirroring(); void orientationChange(); void contentPosJump(); + void QTBUG_37115(); private: template void items(); @@ -350,10 +353,41 @@ private: QList > list; }; +class TestFilterModel : public QSortFilterProxyModel +{ + Q_OBJECT + Q_PROPERTY(QString filter READ filter WRITE setFilter NOTIFY filterChanged) + QString m_filter; + +public: + explicit TestFilterModel(QObject *parent = 0) : QSortFilterProxyModel(parent) + { + setSourceModel(new QStringListModel(QStringList() << "AA" << "BB" << "CC", this)); + } + + QString filter() const { return m_filter; } + void setFilter(const QString &filter) + { + if (m_filter != filter) { + m_filter = filter; + setFilterWildcard(m_filter); + emit filterChanged(); + } + } + +signals: + void filterChanged(); +}; + tst_QDeclarativeListView::tst_QDeclarativeListView() { } +void tst_QDeclarativeListView::initTestCase() +{ + qmlRegisterType("org.test.models", 1, 0, "TestFilterModel"); +} + template void tst_QDeclarativeListView::items() { @@ -2721,6 +2755,20 @@ void tst_QDeclarativeListView::contentPosJump() delete canvas; } +void tst_QDeclarativeListView::QTBUG_37115() +{ + QDeclarativeView *canvas = createView(); + + canvas->setSource(QUrl::fromLocalFile(SRCDIR "/data/qtbug37115.qml")); + qApp->processEvents(); + + QDeclarativeListView *listview = findItem(canvas->rootObject(), "listview"); + QTRY_VERIFY(listview != 0); + QTRY_COMPARE(listview->property("countCopy").toInt(), 0); + + delete canvas; +} + void tst_QDeclarativeListView::qListModelInterface_items() { items(); -- cgit v1.2.3