┌   ┐
54
└   ┘

summaryrefslogtreecommitdiff
path: root/src/tests/kfileitemlistviewtest.cpp
diff options
context:
space:
mode:
authorPeter Penz <[email protected]>2012-05-17 11:46:16 +0200
committerPeter Penz <[email protected]>2012-05-17 11:47:21 +0200
commitbca055a38edf722c2433c41cd45f86c27fccc541 (patch)
tree089bc1194f4507fb6b902ea8d8282c1bdcc64acf /src/tests/kfileitemlistviewtest.cpp
parentff6e4341c5ce58b44af32db27ee3cec7057c8ce7 (diff)
Add unit-test to test a possible crash when updating group-headers
Diffstat (limited to 'src/tests/kfileitemlistviewtest.cpp')
-rw-r--r--src/tests/kfileitemlistviewtest.cpp45
1 files changed, 38 insertions, 7 deletions
diff --git a/src/tests/kfileitemlistviewtest.cpp b/src/tests/kfileitemlistviewtest.cpp
index a7493d17f..9f1745840 100644
--- a/src/tests/kfileitemlistviewtest.cpp
+++ b/src/tests/kfileitemlistviewtest.cpp
@@ -19,9 +19,9 @@
#include <qtest_kde.h>
-#include <KDirLister>
#include "kitemviews/kfileitemlistview.h"
#include "kitemviews/kfileitemmodel.h"
+#include "kitemviews/private/kfileitemmodeldirlister.h"
#include "testdir.h"
#include <QGraphicsView>
@@ -37,11 +37,11 @@ class KFileItemListViewTest : public QObject
private slots:
void init();
void cleanup();
+ void testGroupedItemChanges();
private:
KFileItemListView* m_listView;
KFileItemModel* m_model;
- KDirLister* m_dirLister;
TestDir* m_testDir;
QGraphicsView* m_graphicsView;
};
@@ -52,8 +52,8 @@ void KFileItemListViewTest::init()
qRegisterMetaType<KFileItemList>("KFileItemList");
m_testDir = new TestDir();
- m_dirLister = new KDirLister();
- m_model = new KFileItemModel(m_dirLister);
+ m_model = new KFileItemModel();
+ m_model->m_dirLister->setAutoUpdate(false);
m_listView = new KFileItemListView();
m_listView->onModelChanged(m_model, 0);
@@ -74,13 +74,44 @@ void KFileItemListViewTest::cleanup()
delete m_model;
m_model = 0;
- delete m_dirLister;
- m_dirLister = 0;
-
delete m_testDir;
m_testDir = 0;
}
+/**
+ * If grouping is enabled, the group headers must be updated
+ * when items have been inserted or removed. This updating
+ * may only be done after all multiple ranges have been inserted
+ * or removed and not after each individual range (see description
+ * in #ifndef QT_NO_DEBUG-block of KItemListView::slotItemsInserted()
+ * and KItemListView::slotItemsRemoved()). This test inserts and
+ * removes multiple ranges and will trigger the Q_ASSERT in the
+ * ifndef QT_NO_DEBUG-block in case if a group-header will be updated
+ * too early.
+ */
+void KFileItemListViewTest::testGroupedItemChanges()
+{
+ m_model->setGroupedSorting(true);
+
+ m_testDir->createFiles(QStringList() << "1" << "3" << "5");
+
+ m_model->loadDirectory(m_testDir->url());
+ QVERIFY(QTest::kWaitForSignal(m_model, SIGNAL(itemsInserted(KItemRangeList)), DefaultTimeout));
+ QCOMPARE(m_model->count(), 3);
+
+ m_testDir->createFiles(QStringList() << "2" << "4");
+ m_model->m_dirLister->updateDirectory(m_testDir->url());
+ QVERIFY(QTest::kWaitForSignal(m_model, SIGNAL(itemsInserted(KItemRangeList)), DefaultTimeout));
+ QCOMPARE(m_model->count(), 5);
+
+ m_testDir->removeFile("1");
+ m_testDir->removeFile("3");
+ m_testDir->removeFile("5");
+ m_model->m_dirLister->updateDirectory(m_testDir->url());
+ QVERIFY(QTest::kWaitForSignal(m_model, SIGNAL(itemsRemoved(KItemRangeList)), DefaultTimeout));
+ QCOMPARE(m_model->count(), 2);
+}
+
QTEST_KDEMAIN(KFileItemListViewTest, GUI)
#include "kfileitemlistviewtest.moc"