X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/3957884bf2e44619a4ed35ba0ffead519988885b..d0f0f1f2e2644e3738c03374d062dab9acc61eaf:/src/tests/kfileitemlistviewtest.cpp diff --git a/src/tests/kfileitemlistviewtest.cpp b/src/tests/kfileitemlistviewtest.cpp index a7493d17f..696580c0a 100644 --- a/src/tests/kfileitemlistviewtest.cpp +++ b/src/tests/kfileitemlistviewtest.cpp @@ -17,11 +17,11 @@ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * ***************************************************************************/ -#include - -#include +#include +#include #include "kitemviews/kfileitemlistview.h" #include "kitemviews/kfileitemmodel.h" +#include "kitemviews/private/kfileitemmodeldirlister.h" #include "testdir.h" #include @@ -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"); 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,47 @@ void KFileItemListViewTest::cleanup() delete m_model; m_model = 0; - delete m_dirLister; - m_dirLister = 0; - delete m_testDir; m_testDir = 0; } -QTEST_KDEMAIN(KFileItemListViewTest, GUI) +/** + * 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({"1", "3", "5"}); + + m_model->loadDirectory(m_testDir->url()); + QSignalSpy psy(m_model, SIGNAL(itemsInserted(KItemRangeList))); + QVERIFY(psy.wait(DefaultTimeout)); + QCOMPARE(m_model->count(), 3); + + m_testDir->createFiles({"2", "4"}); + m_model->m_dirLister->updateDirectory(m_testDir->url()); + QSignalSpy psyItemsInserted(m_model, SIGNAL(itemsInserted(KItemRangeList))); + QVERIFY(psyItemsInserted.wait(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()); + QSignalSpy psyItemsRemoved(m_model, SIGNAL(itemsRemoved(KItemRangeList))); + QVERIFY(psyItemsRemoved.wait(DefaultTimeout)); + QCOMPARE(m_model->count(), 2); +} + +QTEST_MAIN(KFileItemListViewTest) #include "kfileitemlistviewtest.moc"