aboutsummaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorAqua-sama <aqua@iserlohn-fortress.net>2018-07-05 19:37:05 +0200
committerAqua-sama <aqua@iserlohn-fortress.net>2018-07-05 19:37:05 +0200
commitaaed4ebc642d95dfb3cddab4fad196e870077bcf (patch)
tree1534dccf6ffd1b6ae3f4d85b13201c0d474c3f78 /test
parentAdd filter.header (diff)
downloadsmolbote-aaed4ebc642d95dfb3cddab4fad196e870077bcf.tar.xz
Add web/urlfilter
Diffstat (limited to 'test')
-rw-r--r--test/CMakeLists.txt19
-rw-r--r--test/HostlistTest.cpp25
-rw-r--r--test/HostlistTest.h16
-rw-r--r--test/autotests.qrc5
-rw-r--r--test/data/hostlist.txt2
-rw-r--r--test/urlfilter/urlfiltertest.cpp88
-rw-r--r--test/urlfilter/urlfiltertest.h41
7 files changed, 137 insertions, 59 deletions
diff --git a/test/CMakeLists.txt b/test/CMakeLists.txt
index ad2ca1f..a44da07 100644
--- a/test/CMakeLists.txt
+++ b/test/CMakeLists.txt
@@ -2,16 +2,13 @@ set(CMAKE_INCLUDE_CURRENT_DIR ON)
set(CMAKE_AUTOMOC ON)
set(CMAKE_AUTORCC ON)
-macro(create_test testname)
- add_executable(${testname}
- ${testname}.cpp ${testname}.h
- autotests.qrc
- ${ARGN})
+add_executable(UrlFilterTest
+ urlfilter/urlfiltertest.cpp
+ urlfilter/urlfiltertest.h
+)
- target_include_directories(${testname} PRIVATE ../lib PRIVATE ../src)
- target_link_libraries(${testname} Qt5::Test Qt5::Concurrent Qt5::WebEngineWidgets)
+target_include_directories(UrlFilterTest
+ PRIVATE ../lib/web
+)
- add_test(NAME smolbote-${testname} COMMAND ${testname})
-endmacro()
-
-create_test(HostlistTest ../src/webengine/urlinterceptor.cpp ../src/webengine/urlinterceptor.h)
+target_link_libraries(UrlFilterTest Qt5::Test web)
diff --git a/test/HostlistTest.cpp b/test/HostlistTest.cpp
deleted file mode 100644
index 31ae11c..0000000
--- a/test/HostlistTest.cpp
+++ /dev/null
@@ -1,25 +0,0 @@
-#include "HostlistTest.h"
-
-void HostlistTest::initTestCase()
-{
- rules = parse(":/autotests/data/hostlist.txt");
-}
-
-void HostlistTest::parse_ruleCount()
-{
- QVERIFY(rules.count() == 3);
-}
-
-void HostlistTest::parse_blockSomehost()
-{
- QVERIFY(rules.contains("somehost.org"));
- QVERIFY(rules.value("somehost.org").isBlocking);
-}
-
-void HostlistTest::parse_blockHost2()
-{
- QVERIFY(rules.contains("host2.org"));
- QVERIFY(rules.value("host2.org").isBlocking);
-}
-
-QTEST_MAIN(HostlistTest)
diff --git a/test/HostlistTest.h b/test/HostlistTest.h
deleted file mode 100644
index dcfd5a3..0000000
--- a/test/HostlistTest.h
+++ /dev/null
@@ -1,16 +0,0 @@
-#include <QtTest/QtTest>
-#include "webengine/urlinterceptor.h"
-
-class HostlistTest : public QObject
-{
- Q_OBJECT
-
-private slots:
- void initTestCase();
- void parse_ruleCount();
- void parse_blockSomehost();
- void parse_blockHost2();
-
-private:
- QHash<QString, UrlRequestInterceptor::HostRule> rules;
-};
diff --git a/test/autotests.qrc b/test/autotests.qrc
deleted file mode 100644
index 5817c00..0000000
--- a/test/autotests.qrc
+++ /dev/null
@@ -1,5 +0,0 @@
-<RCC>
- <qresource prefix="/autotests">
- <file>data/hostlist.txt</file>
- </qresource>
-</RCC> \ No newline at end of file
diff --git a/test/data/hostlist.txt b/test/data/hostlist.txt
deleted file mode 100644
index d228e1d..0000000
--- a/test/data/hostlist.txt
+++ /dev/null
@@ -1,2 +0,0 @@
-0.0.0.0 somehost.org
-0.0.0.0 host1.org host2.org
diff --git a/test/urlfilter/urlfiltertest.cpp b/test/urlfilter/urlfiltertest.cpp
new file mode 100644
index 0000000..f7ae0fb
--- /dev/null
+++ b/test/urlfilter/urlfiltertest.cpp
@@ -0,0 +1,88 @@
+/* ============================================================
+* Falkon - Qt web browser
+* Copyright (C) 2013-2018 David Rosca <nowrep@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 3 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, see <http://www.gnu.org/licenses/>.
+* ============================================================ */
+
+#include "urlfiltertest.h"
+#include <QtTest/QtTest>
+#include <QUrl>
+
+#include <QJsonObject>
+
+void UrlFilterTest::matchingDomain_data()
+{
+ filterDomain.addDomain("example.com");
+ filterDomain.addDomain("second-domain.org");
+
+ // Test adapted from Falkon
+ QTest::addColumn<QString>("domain");
+ QTest::addColumn<bool>("result");
+
+ // description site domain result
+ QTest::newRow("missing tld") << "example" << false;
+ QTest::newRow("different tld") << "example.org" << false;
+ QTest::newRow("exact match") << "example.com" << true;
+ QTest::newRow("exact match 2") << "second-domain.org" << true;
+ QTest::newRow("subdomain match") << "www.example.com" << true;
+ QTest::newRow("subdomain match") << "www.test.example.com" << true;
+ QTest::newRow("similar domain") << "anotherexample.com" << false;
+ QTest::newRow("empty domain") << "" << false;
+}
+
+void UrlFilterTest::matchingDomain()
+{
+ QFETCH(QString, domain);
+ QFETCH(bool, result);
+
+ filterDomain.setType(FilterDomain::Whitelist);
+ QCOMPARE(filterDomain.hasMatch(domain), result);
+ filterDomain.setType(FilterDomain::Blacklist);
+ QCOMPARE(filterDomain.hasMatch(domain), !result);
+ filterDomain.setType(FilterDomain::WhitelistAll);
+ QCOMPARE(filterDomain.hasMatch(domain), true);
+ filterDomain.setType(FilterDomain::BlacklistAll);
+ QCOMPARE(filterDomain.hasMatch(domain), false);
+}
+
+void UrlFilterTest::matchingType_data()
+{
+ QJsonObject j;
+ j.insert("action", "Blacklist");
+ j.insert("contains", "annoying-ad.banner");
+
+ filterRule = new FilterRule(j);
+ Q_ASSERT(filterRule->isValid());
+
+ QTest::addColumn<QString>("requestUrl");
+ QTest::addColumn<int>("resourceType");
+ QTest::addColumn<bool>("result");
+
+ QTest::newRow("contains 1") << "http://example.com/ads/annoying-ad.banner/something" << static_cast<int>(QWebEngineUrlRequestInfo::ResourceTypeImage) << true;
+ QTest::newRow("contains 2") << "http://example.com/ads/annoying-ad.banner/something" << static_cast<int>(QWebEngineUrlRequestInfo::ResourceTypeMedia) << false;
+ QTest::newRow("contains 3") << "http://example.com/ads/banner" << static_cast<int>(QWebEngineUrlRequestInfo::ResourceTypeImage) << false;
+ QTest::newRow("blank") << "" << static_cast<int>(QWebEngineUrlRequestInfo::ResourceTypeUnknown) << false;
+}
+
+void UrlFilterTest::matchingType()
+{
+ QFETCH(QString, requestUrl);
+ QFETCH(int, resourceType);
+ QFETCH(bool, result);
+
+ QCOMPARE(filterRule->matchRequestUrl(requestUrl, static_cast<QWebEngineUrlRequestInfo::ResourceType>(resourceType)), result);
+}
+
+QTEST_GUILESS_MAIN(UrlFilterTest)
diff --git a/test/urlfilter/urlfiltertest.h b/test/urlfilter/urlfiltertest.h
new file mode 100644
index 0000000..1b158e8
--- /dev/null
+++ b/test/urlfilter/urlfiltertest.h
@@ -0,0 +1,41 @@
+/* ============================================================
+* Falkon - Qt web browser
+* Copyright (C) 2013-2018 David Rosca <nowrep@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 3 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, see <http://www.gnu.org/licenses/>.
+* ============================================================ */
+#ifndef URLFILTER_TEST_H
+#define URLFILTER_TEST_H
+
+#include "urlfilter/filterrule.h"
+#include "urlfilter/filterdomain.h"
+#include <QObject>
+
+class UrlFilterTest : public QObject
+{
+ Q_OBJECT
+
+private slots:
+ void matchingDomain_data();
+ void matchingDomain();
+
+ void matchingType_data();
+ void matchingType();
+
+private:
+ FilterDomain filterDomain;
+ FilterRule *filterRule;
+};
+
+#endif // URLFILTER_TEST_H