From a16ae6c64b75706f9663fb27510a73d1a6a29de8 Mon Sep 17 00:00:00 2001 From: Christian Mollekopf Date: Sun, 19 Mar 2017 12:28:17 +0100 Subject: Handle filtered thread-leader --- common/datastorequery.cpp | 10 ++++++-- tests/querytest.cpp | 65 +++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 73 insertions(+), 2 deletions(-) diff --git a/common/datastorequery.cpp b/common/datastorequery.cpp index 34d2bae..0db59e1 100644 --- a/common/datastorequery.cpp +++ b/common/datastorequery.cpp @@ -152,7 +152,7 @@ public: } }; -class Reduce : public FilterBase { +class Reduce : public Filter { public: typedef QSharedPointer Ptr; @@ -198,7 +198,7 @@ public: QList mAggregators; Reduce(const QByteArray &reductionProperty, const QByteArray &selectionProperty, QueryBase::Reduce::Selector::Comparator comparator, FilterBase::Ptr source, DataStoreQuery *store) - : FilterBase(source, store), + : Filter(source, store), mReductionProperty(reductionProperty), mSelectionProperty(selectionProperty), mSelectionComparator(comparator) @@ -236,6 +236,11 @@ public: for (const auto &r : results) { readEntity(r, [&, this](const Sink::ApplicationDomain::ApplicationDomainType &entity, Sink::Operation operation) { + //We need to apply all property filters that we have until the reduction, because the index lookup was unfiltered. + if (!matchesFilter(entity)) { + return; + } + Q_ASSERT(operation != Sink::Operation_Removal); for (auto &aggregator : mAggregators) { if (!aggregator.property.isEmpty()) { @@ -553,6 +558,7 @@ void DataStoreQuery::setupQuery(const Sink::QueryBase &query_) for (const auto &aggregator : filter->aggregators) { reduction->mAggregators << Reduce::Aggregator(aggregator.operation, aggregator.propertyToCollect, aggregator.resultProperty); } + reduction->propertyFilter = query.getBaseFilters(); baseSet = reduction; } else if (auto filter = stage.dynamicCast()) { baseSet = Bloom::Ptr::create(filter->property, baseSet, this); diff --git a/tests/querytest.cpp b/tests/querytest.cpp index bd3b927..f639d94 100644 --- a/tests/querytest.cpp +++ b/tests/querytest.cpp @@ -1042,6 +1042,71 @@ private slots: QCOMPARE(layoutChangedSpy.size(), 0); QCOMPARE(resetSpy.size(), 0); } + + /* + * Ensure that we handle the situation properly if the thread-leader doesn't match a property filter. + */ + void testFilteredThreadLeader() + { + // Setup + auto folder1 = Folder::createEntity("sink.dummy.instance1"); + VERIFYEXEC(Sink::Store::create(folder1)); + + auto folder2 = Folder::createEntity("sink.dummy.instance1"); + VERIFYEXEC(Sink::Store::create(folder2)); + + QDateTime earlier{QDate{2017, 2, 3}, QTime{9, 0, 0}}; + QDateTime now{QDate{2017, 2, 3}, QTime{10, 0, 0}}; + QDateTime later{QDate{2017, 2, 3}, QTime{11, 0, 0}}; + + { + auto mail1 = Mail::createEntity("sink.dummy.instance1"); + mail1.setExtractedMessageId("mail1"); + mail1.setFolder(folder1); + mail1.setExtractedDate(now); + mail1.setImportant(false); + VERIFYEXEC(Sink::Store::create(mail1)); + } + { + auto mail2 = Mail::createEntity("sink.dummy.instance1"); + mail2.setExtractedMessageId("mail2"); + mail2.setFolder(folder1); + mail2.setExtractedDate(earlier); + mail2.setImportant(false); + VERIFYEXEC(Sink::Store::create(mail2)); + } + { + auto mail3 = Mail::createEntity("sink.dummy.instance1"); + mail3.setExtractedMessageId("mail3"); + mail3.setFolder(folder1); + mail3.setExtractedDate(later); + mail3.setImportant(true); + VERIFYEXEC(Sink::Store::create(mail3)); + } + + // Ensure all local data is processed + VERIFYEXEC(Sink::ResourceControl::flushMessageQueue("sink.dummy.instance1")); + + Query query; + query.setId("testLivequeryThreadleaderChange"); + query.setFlags(Query::LiveQuery); + query.reduce(Query::Reduce::Selector::max()).count("count").collect("folders"); + query.sort(); + query.request(); + query.filter(false); + + auto model = Sink::Store::loadModel(query); + QTRY_VERIFY(model->data(QModelIndex(), Sink::Store::ChildrenFetchedRole).toBool()); + + QCOMPARE(model->rowCount(), 1); + + { + auto mail = model->data(model->index(0, 0, QModelIndex{}), Sink::Store::DomainObjectRole).value(); + QCOMPARE(mail->getMessageId(), QByteArray{"mail1"}); + QCOMPARE(mail->getProperty("count").toInt(), 2); + QCOMPARE(mail->getProperty("folders").toList().size(), 2); + } + } }; QTEST_MAIN(QueryTest) -- cgit v1.2.3