]> cloud.milkyroute.net Git - dolphin.git/blobdiff - src/tests/dolphinquerytest.cpp
Merge remote-tracking branch 'origin/master' into kf6
[dolphin.git] / src / tests / dolphinquerytest.cpp
index 9e1c7673774cf7c39c84db427906a25d3577397b..b6feab686ff404e58cf924ced72e4a1b1b8f7891 100644 (file)
@@ -1,21 +1,8 @@
-/***************************************************************************
- *   Copyright (C) 2019 by Ismael Asensio <isma.af@gmail.com>              *
- *                                                                         *
- *   This program is free software; you can redistribute it and/or modify  *
- *   it under the terms of the GNU General Public License as published by  *
- *   the Free Software Foundation; either version 2 of the License, or     *
- *   (at your option) any later version.                                   *
- *                                                                         *
- *   This program is distributed in the hope that it will be useful,       *
- *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
- *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
- *   GNU General Public License for more details.                          *
- *                                                                         *
- *   You should have received a copy of the GNU General Public License     *
- *   along with this program; if not, write to the                         *
- *   Free Software Foundation, Inc.,                                       *
- *   51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA            *
- ***************************************************************************/
+/*
+ * SPDX-FileCopyrightText: 2019 Ismael Asensio <isma.af@gmail.com>
+ *
+ * SPDX-License-Identifier: GPL-2.0-or-later
+ */
 
 #include "search/dolphinquery.h"
 
 
 #include <QJsonDocument>
 #include <QJsonObject>
+#include <QStandardPaths>
 #include <QStringList>
 #include <QUrl>
 #include <QUrlQuery>
 
-class DolphinSearchBoxTest : public QObject
+class DolphinQueryTest : public QObject
 {
     Q_OBJECT
 
-private slots:
+private Q_SLOTS:
+    void initTestCase();
     void testBalooSearchParsing_data();
     void testBalooSearchParsing();
 };
@@ -39,11 +28,9 @@ private slots:
 /**
  * Helper function to compose the baloo query URL used for searching
  */
-QUrl balooQueryUrl(const QStringsearchString)
+QUrl balooQueryUrl(const QString &searchString)
 {
-    const QJsonObject jsonObject {
-        {"searchString", searchString}
-    };
+    const QJsonObject jsonObject{{"searchString", searchString}};
 
     const QJsonDocument doc(jsonObject);
     const QString queryString = QString::fromUtf8(doc.toJson(QJsonDocument::Compact));
@@ -58,12 +45,16 @@ QUrl balooQueryUrl(const QString& searchString)
     return searchUrl;
 }
 
+void DolphinQueryTest::initTestCase()
+{
+    QStandardPaths::setTestModeEnabled(true);
+}
+
 /**
  * Defines the parameters for the test cases in testBalooSearchParsing()
  */
-void DolphinSearchBoxTest::testBalooSearchParsing_data()
+void DolphinQueryTest::testBalooSearchParsing_data()
 {
-
     QTest::addColumn<QUrl>("searchUrl");
     QTest::addColumn<QString>("expectedText");
     QTest::addColumn<QStringList>("expectedTerms");
@@ -84,81 +75,76 @@ void DolphinSearchBoxTest::testBalooSearchParsing_data()
     const QString modified = QStringLiteral("modified>=2019-08-07");
 
     const QString tag = QStringLiteral("tag:tagA");
-    const QString tagS = QStringLiteral("tag:\"tagB with spaces\"");  // in search url
-    const QString tagR = QStringLiteral("tag:tagB with spaces");      // in result term
+    const QString tagS = QStringLiteral("tag:\"tagB with spaces\""); // in search url
+    const QString tagR = QStringLiteral("tag:tagB with spaces"); // in result term
 
     // Test for "Content"
-    QTest::newRow("content")              << balooQueryUrl(text)   << text  << QStringList() << true  << false;
-    QTest::newRow("content/space")        << balooQueryUrl(textS)  << textS << QStringList() << true  << false;
-    QTest::newRow("content/quoted")       << balooQueryUrl(textQ)  << textS << QStringList() << true  << false;
-    QTest::newRow("content/empty")        << balooQueryUrl("")     << ""    << QStringList() << false << false;
-    QTest::newRow("content/single_quote") << balooQueryUrl("\"")   << "\""  << QStringList() << true  << false;
-    QTest::newRow("content/double_quote") << balooQueryUrl("\"\"") << ""    << QStringList() << false << false;
+    QTest::newRow("content") << balooQueryUrl(text) << text << QStringList() << true << false;
+    QTest::newRow("content/space") << balooQueryUrl(textS) << textS << QStringList() << true << false;
+    QTest::newRow("content/quoted") << balooQueryUrl(textQ) << textS << QStringList() << true << false;
+    QTest::newRow("content/empty") << balooQueryUrl("") << "" << QStringList() << false << false;
+    QTest::newRow("content/single_quote") << balooQueryUrl("\"") << "\"" << QStringList() << true << false;
+    QTest::newRow("content/double_quote") << balooQueryUrl("\"\"") << "" << QStringList() << false << false;
 
     // Test for "FileName"
-    QTest::newRow("filename")              << balooQueryUrl(filename)        << text  << QStringList() << false << true;
-    QTest::newRow("filename/space")        << balooQueryUrl(filenameS)       << textS << QStringList() << false << true;
-    QTest::newRow("filename/quoted")       << balooQueryUrl(filenameQ)       << textQ << QStringList() << false << true;
-    QTest::newRow("filename/mixed")        << balooQueryUrl(filenameM)       << textM << QStringList() << false << true;
-    QTest::newRow("filename/empty")        << balooQueryUrl("filename:")     << ""    << QStringList() << false << false;
-    QTest::newRow("filename/single_quote") << balooQueryUrl("filename:\"")   << "\""  << QStringList() << false << true;
-    QTest::newRow("filename/double_quote") << balooQueryUrl("filename:\"\"") << ""    << QStringList() << false << false;
+    QTest::newRow("filename") << balooQueryUrl(filename) << text << QStringList() << false << true;
+    QTest::newRow("filename/space") << balooQueryUrl(filenameS) << textS << QStringList() << false << true;
+    QTest::newRow("filename/quoted") << balooQueryUrl(filenameQ) << textQ << QStringList() << false << true;
+    QTest::newRow("filename/mixed") << balooQueryUrl(filenameM) << textM << QStringList() << false << true;
+    QTest::newRow("filename/empty") << balooQueryUrl("filename:") << "" << QStringList() << false << false;
+    QTest::newRow("filename/single_quote") << balooQueryUrl("filename:\"") << "\"" << QStringList() << false << true;
+    QTest::newRow("filename/double_quote") << balooQueryUrl("filename:\"\"") << "" << QStringList() << false << false;
 
     // Combined content and filename search
-    QTest::newRow("content+filename")
-        << balooQueryUrl(text + " " + filename)
-        << text + " " + filename << QStringList() << true << true;
+    QTest::newRow("content+filename") << balooQueryUrl(text + " " + filename) << text + " " + filename << QStringList() << true << true;
 
-    QTest::newRow("content+filename/quoted")
-        << balooQueryUrl(textQ + " " + filenameQ)
-        << textS + " " + filenameQ << QStringList() << true << true;
+    QTest::newRow("content+filename/quoted") << balooQueryUrl(textQ + " " + filenameQ) << textS + " " + filenameQ << QStringList() << true << true;
 
     // Test for rating
-    QTest::newRow("rating")          << balooQueryUrl(rating)                  << ""   << QStringList({rating}) << false << false;
-    QTest::newRow("rating+content")  << balooQueryUrl(rating + " " + text)     << text << QStringList({rating}) << true  << false;
+    QTest::newRow("rating") << balooQueryUrl(rating) << "" << QStringList({rating}) << false << false;
+    QTest::newRow("rating+content") << balooQueryUrl(rating + " " + text) << text << QStringList({rating}) << true << false;
     QTest::newRow("rating+filename") << balooQueryUrl(rating + " " + filename) << text << QStringList({rating}) << false << true;
 
     // Test for modified date
-    QTest::newRow("modified")          << balooQueryUrl(modified)                  << ""   << QStringList({modified}) << false << false;
-    QTest::newRow("modified+content")  << balooQueryUrl(modified + " " + text)     << text << QStringList({modified}) << true  << false;
+    QTest::newRow("modified") << balooQueryUrl(modified) << "" << QStringList({modified}) << false << false;
+    QTest::newRow("modified+content") << balooQueryUrl(modified + " " + text) << text << QStringList({modified}) << true << false;
     QTest::newRow("modified+filename") << balooQueryUrl(modified + " " + filename) << text << QStringList({modified}) << false << true;
 
     // Test for tags
-    QTest::newRow("tag")          << balooQueryUrl(tag)                  << ""   << QStringList({tag})       << false << false;
-    QTest::newRow("tag/space" )   << balooQueryUrl(tagS)                 << ""   << QStringList({tagR})      << false << false;
-    QTest::newRow("tag/double")   << balooQueryUrl(tag + " " + tagS)     << ""   << QStringList({tag, tagR}) << false << false;
-    QTest::newRow("tag+content")  << balooQueryUrl(tag + " " + text)     << text << QStringList({tag})       << true  << false;
-    QTest::newRow("tag+filename") << balooQueryUrl(tag + " " + filename) << text << QStringList({tag})       << false << true;
+    QTest::newRow("tag") << balooQueryUrl(tag) << "" << QStringList({tag}) << false << false;
+    QTest::newRow("tag/space") << balooQueryUrl(tagS) << "" << QStringList({tagR}) << false << false;
+    QTest::newRow("tag/double") << balooQueryUrl(tag + " " + tagS) << "" << QStringList({tag, tagR}) << false << false;
+    QTest::newRow("tag+content") << balooQueryUrl(tag + " " + text) << text << QStringList({tag}) << true << false;
+    QTest::newRow("tag+filename") << balooQueryUrl(tag + " " + filename) << text << QStringList({tag}) << false << true;
 
     // Combined search terms
-    QTest::newRow("searchTerms")
-        << balooQueryUrl(rating + " AND " + modified + " AND " + tag + " AND " + tagS)
-        << "" << QStringList({modified, rating, tag, tagR}) << false << false;
+    QTest::newRow("searchTerms") << balooQueryUrl(rating + " AND " + modified + " AND " + tag + " AND " + tagS) << ""
+                                 << QStringList({modified, rating, tag, tagR}) << false << false;
 
-    QTest::newRow("searchTerms+content")
-        << balooQueryUrl(rating + " AND " + modified + " " + text + " " + tag + " AND " + tagS)
-        << text << QStringList({modified, rating, tag, tagR}) << true << false;
+    QTest::newRow("searchTerms+content") << balooQueryUrl(rating + " AND " + modified + " " + text + " " + tag + " AND " + tagS) << text
+                                         << QStringList({modified, rating, tag, tagR}) << true << false;
 
-    QTest::newRow("searchTerms+filename")
-        << balooQueryUrl(rating + " AND " + modified + " " + filename + " " + tag + " AND " + tagS)
-        << text << QStringList({modified, rating, tag, tagR}) << false << true;
+    QTest::newRow("searchTerms+filename") << balooQueryUrl(rating + " AND " + modified + " " + filename + " " + tag + " AND " + tagS) << text
+                                          << QStringList({modified, rating, tag, tagR}) << false << true;
 
-    QTest::newRow("allTerms")
-        << balooQueryUrl(text + " " + filename + " " + rating + " AND " + modified + " AND " + tag)
-        << text + " " + filename << QStringList({modified, rating, tag}) << true << true;
+    QTest::newRow("allTerms") << balooQueryUrl(text + " " + filename + " " + rating + " AND " + modified + " AND " + tag) << text + " " + filename
+                              << QStringList({modified, rating, tag}) << true << true;
 
-    QTest::newRow("allTerms/space")
-        << balooQueryUrl(textS + " " + filenameS + " " + rating + " AND " + modified + " AND " + tagS)
-        << textS + " " + filenameS << QStringList({modified, rating, tagR}) << true << true;
+    QTest::newRow("allTerms/space") << balooQueryUrl(textS + " " + filenameS + " " + rating + " AND " + modified + " AND " + tagS) << textS + " " + filenameS
+                                    << QStringList({modified, rating, tagR}) << true << true;
 
     // Test tags:/ URL scheme
-    const auto tagUrl   = [](const QString &tag) { return QUrl(QStringLiteral("tags:/%1/").arg(tag)); };
-    const auto tagTerms = [](const QString &tag) { return QStringList{QStringLiteral("tag:%1").arg(tag)}; };
+    const auto tagUrl = [](const QString &tag) {
+        return QUrl(QStringLiteral("tags:/%1/").arg(tag));
+    };
+    const auto tagTerms = [](const QString &tag) {
+        return QStringList{QStringLiteral("tag:%1").arg(tag)};
+    };
 
-    QTest::newRow("tagsUrl")       << tagUrl("tagA")             << "" << tagTerms("tagA")             << false << false;
+    QTest::newRow("tagsUrl") << tagUrl("tagA") << "" << tagTerms("tagA") << false << false;
     QTest::newRow("tagsUrl/space") << tagUrl("tagB with spaces") << "" << tagTerms("tagB with spaces") << false << false;
-    QTest::newRow("tagsUrl/hash")  << tagUrl("tagC#hash")        << "" << tagTerms("tagC#hash")        << false << false;
-    QTest::newRow("tagsUrl/slash") << tagUrl("tagD/with/slash")  << "" << tagTerms("tagD/with/slash")  << false << false;
+    QTest::newRow("tagsUrl/hash") << tagUrl("tagC#hash") << "" << tagTerms("tagC#hash") << false << false;
+    QTest::newRow("tagsUrl/slash") << tagUrl("tagD/with/slash") << "" << tagTerms("tagD/with/slash") << false << false;
 }
 
 /**
@@ -166,7 +152,7 @@ void DolphinSearchBoxTest::testBalooSearchParsing_data()
  * properly handled by the searchbox, and only "user" or filename terms are added to the
  * text bar of the searchbox.
  */
-void DolphinSearchBoxTest::testBalooSearchParsing()
+void DolphinQueryTest::testBalooSearchParsing()
 {
     QFETCH(QUrl, searchUrl);
     QFETCH(QString, expectedText);
@@ -196,6 +182,6 @@ void DolphinSearchBoxTest::testBalooSearchParsing()
     QCOMPARE(query.hasFileName(), hasFileName);
 }
 
-QTEST_MAIN(DolphinSearchBoxTest)
+QTEST_MAIN(DolphinQueryTest)
 
 #include "dolphinquerytest.moc"