aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAqua-sama <aqua@iserlohn-fortress.net>2018-10-21 14:25:52 +0200
committerAqua-sama <aqua@iserlohn-fortress.net>2018-10-21 14:25:52 +0200
commit197175c8b9e11fce379e77bdba6441c74097bd58 (patch)
treed0dfa5bcc6514ad0ac52c8d8b61f638a646a08b0
parenturlfilter: base AdBlockRule off FilterLeaf (diff)
downloadsmolbote-197175c8b9e11fce379e77bdba6441c74097bd58.tar.xz
Add MatcherBenchmark
-rw-r--r--CMakeLists.txt4
-rw-r--r--test/CMakeLists.txt13
-rw-r--r--test/matcherbenchmark/matcherbenchmark.cpp51
-rw-r--r--test/matcherbenchmark/matcherbenchmark.h17
4 files changed, 81 insertions, 4 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt
index 622fb21..f75bba4 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -42,11 +42,11 @@ add_subdirectory(src)
add_subdirectory(doc)
-if(CONFIG_TESTS)
+#if(CONFIG_TESTS)
enable_testing()
find_package(Qt5 COMPONENTS Test REQUIRED)
add_subdirectory(test)
-endif(CONFIG_TESTS)
+#endif(CONFIG_TESTS)
# Summarize
message(STATUS "=== Configuration summary ===")
diff --git a/test/CMakeLists.txt b/test/CMakeLists.txt
index 6b740d7..4a802d1 100644
--- a/test/CMakeLists.txt
+++ b/test/CMakeLists.txt
@@ -2,6 +2,7 @@ set(CMAKE_INCLUDE_CURRENT_DIR ON)
set(CMAKE_AUTOMOC ON)
set(CMAKE_AUTORCC ON)
+# AdblockTest
add_executable(AdBlockTest
adblock/adblocktest.cpp
adblock/adblocktest.h
@@ -9,13 +10,21 @@ add_executable(AdBlockTest
target_include_directories(AdBlockTest PRIVATE ../lib/urlfilter)
target_link_libraries(AdBlockTest Qt5::Test urlfilter)
+add_test(NAME urlfilter-adblock COMMAND AdBlockTest WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR})
+# HostlistTest
add_executable(HostlistTest
hostlist/hostlisttest.cpp
hostlist/hostlisttest.h
)
target_include_directories(HostlistTest PRIVATE ../lib/urlfilter/)
target_link_libraries(HostlistTest Qt5::Test urlfilter)
-
-add_test(NAME urlfilter-adblock COMMAND AdBlockTest WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR})
add_test(NAME urlfilter-hostlist COMMAND HostlistTest WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR})
+
+# matching algorithm benchmark
+add_executable(MatcherBenchmark
+ matcherbenchmark/matcherbenchmark.cpp
+ matcherbenchmark/matcherbenchmark.h
+)
+target_link_libraries(MatcherBenchmark Qt5::Test)
+add_test(NAME matcher-benchmark COMMAND MatcherBenchmark WORKING_DIRECTORY ${CMAKE_CURRENT_LIST_DIR})
diff --git a/test/matcherbenchmark/matcherbenchmark.cpp b/test/matcherbenchmark/matcherbenchmark.cpp
new file mode 100644
index 0000000..cb4feb1
--- /dev/null
+++ b/test/matcherbenchmark/matcherbenchmark.cpp
@@ -0,0 +1,51 @@
+#include "matcherbenchmark.h"
+#include <QtTest/QTest>
+#include <QRegExp>
+#include <QRegularExpression>
+#include <QStringMatcher>
+
+void MatcherBenchmark::qstringcontains()
+{
+ const QString pattern("spamdomain");
+ const QString request("subdomain.spamdomain.com");
+
+ QCOMPARE(request.contains(pattern), true);
+ QBENCHMARK {
+ request.contains(pattern);
+ }
+}
+
+void MatcherBenchmark::qstringmatcher()
+{
+ const QStringMatcher pattern("spamdomain");
+ const QString request("subdomain.spamdomain.com");
+
+ QCOMPARE(pattern.indexIn(request) != -1, true);
+ QBENCHMARK {
+ pattern.indexIn(request);
+ }
+}
+
+void MatcherBenchmark::qregexp()
+{
+ const QRegExp pattern("spamdomain");
+ const QString request("subdomain.spamdomain.com");
+
+ QCOMPARE(pattern.indexIn(request) != -1, true);
+ QBENCHMARK {
+ pattern.indexIn(request);
+ }
+}
+
+void MatcherBenchmark::qregularexpressionmatch()
+{
+ const QRegularExpression pattern("spamdomain");
+ const QString request("subdomain.spamdomain.com");
+
+ QCOMPARE(pattern.match(request).hasMatch(), true);
+ QBENCHMARK {
+ QCOMPARE(pattern.match(request).hasMatch(), true);
+ }
+}
+
+QTEST_GUILESS_MAIN(MatcherBenchmark)
diff --git a/test/matcherbenchmark/matcherbenchmark.h b/test/matcherbenchmark/matcherbenchmark.h
new file mode 100644
index 0000000..cdc77f6
--- /dev/null
+++ b/test/matcherbenchmark/matcherbenchmark.h
@@ -0,0 +1,17 @@
+#ifndef MATCHER_BENCHMARK
+#define MATCHER_BENCHMARK
+
+#include <QObject>
+
+class MatcherBenchmark : public QObject
+{
+ Q_OBJECT
+
+private slots:
+ void qstringcontains();
+ void qstringmatcher();
+ void qregexp();
+ void qregularexpressionmatch();
+};
+
+#endif