From f7f5477ec57232ae9a627cfbcc44c392efe17ec8 Mon Sep 17 00:00:00 2001 From: Isak Fyksen Date: Fri, 17 Nov 2023 17:52:03 +0100 Subject: [PATCH] Make adding new rows to QTestTable more efficient Added QDuplicateTracker to keep track of used tags, rather than looping through QTestTablePrivate::dataList for every added tag. Removed method `hasRow`, instead calling `QDuplicateTracker::hasSeen` directly in `newData`. Task-number: QTBUG-118619 Change-Id: Idaab70d8c94227f75620924e0f1ead477f93b27a Reviewed-by: Marc Mutz (cherry picked from commit 8a23e3aa323443d2ea958b1213b00031e5b13aed) Reviewed-by: Qt Cherry-pick Bot --- src/testlib/qtesttable.cpp | 14 ++++++-------- 1 file changed, 6 insertions(+), 8 deletions(-) diff --git a/src/testlib/qtesttable.cpp b/src/testlib/qtesttable.cpp index 5dc3a12661c..2276365505e 100644 --- a/src/testlib/qtesttable.cpp +++ b/src/testlib/qtesttable.cpp @@ -5,6 +5,7 @@ #include #include +#include #include #include @@ -35,9 +36,11 @@ public: using DataList = std::vector; DataList dataList; + using TagSet = QDuplicateTracker; + TagSet tagSet; + void addColumn(int elemType, const char *elemName) { elementList.push_back(Element(elemName, elemType)); } void addRow(QTestData *data) { dataList.push_back(data); } - bool hasRow(const char *name) const; static QTestTable *currentTestTable; static QTestTable *gTable; @@ -73,7 +76,8 @@ bool QTestTable::isEmpty() const QTestData *QTestTable::newData(const char *tag) { - if (d->hasRow(tag)) + QTEST_ASSERT(tag); + if (d->tagSet.hasSeen(tag)) qWarning("Duplicate data tag \"%s\" - please rename.", tag); QTestData *dt = new QTestData(tag, this); @@ -123,12 +127,6 @@ private: const char *m_needle; }; -bool QTestTablePrivate::hasRow(const char *rowName) const -{ - QTEST_ASSERT(rowName); - return std::find_if(dataList.begin(), dataList.end(), NamePredicate(rowName)) != dataList.end(); -} - int QTestTable::indexOf(const char *elementName) const { QTEST_ASSERT(elementName);