diff options
| author | Salanto <62221668+Salanto@users.noreply.github.com> | 2024-05-18 03:33:43 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2024-05-18 03:33:43 +0200 |
| commit | 51338e30e046f1a62c84049b34577f0f3b5db6e3 (patch) | |
| tree | 283c95f8f776ed852d03a816388695afd65c0f73 /test | |
| parent | 469e293a1885e49f1d5994d41ac7cfc9f4666952 (diff) | |
| parent | f9c7205210fb9f768f583065971ece09e6b5eb03 (diff) | |
Merge pull request #957 from AttorneyOnline/kaleidoscope
The Kaleidoscope - Hell, it's about time.
Diffstat (limited to 'test')
| -rw-r--r-- | test/CMakeLists.txt | 29 | ||||
| -rw-r--r-- | test/test_aopacket.cpp | 93 | ||||
| -rw-r--r-- | test/test_apng.cpp | 61 | ||||
| -rw-r--r-- | test/test_bass.cpp | 41 | ||||
| -rw-r--r-- | test/test_caseloading.cpp | 18 |
5 files changed, 80 insertions, 162 deletions
diff --git a/test/CMakeLists.txt b/test/CMakeLists.txt index 393a7537..c78740c1 100644 --- a/test/CMakeLists.txt +++ b/test/CMakeLists.txt @@ -1,8 +1,21 @@ -find_package(Qt5 COMPONENTS Core Gui Widgets REQUIRED) -find_package(Catch2 REQUIRED) - -add_executable(test test_aopacket.cpp test_caseloading.cpp test_apng.cpp test_bass.cpp ../include/aopacket.h ../src/aopacket.cpp) -target_include_directories(test PRIVATE ../include) -target_link_directories(test PRIVATE ../lib) -target_link_libraries(test PRIVATE Qt5::Core Qt5::Gui Qt5::Widgets Catch2::Catch2 bass bassmidi bassopus discord-rpc) -target_compile_definitions(Attorney_Online PRIVATE DISCORD) +project(tests LANGUAGES CXX C) + +find_package(Qt${QT_VERSION_MAJOR} COMPONENTS Test REQUIRED) + +set(CMAKE_INCLUDE_CURRENT_DIR ON) + +enable_testing(true) + +set(SKIP_AUTOMOC ON) + +function(ao_declare_test test_id) + message(STATUS "Adding test: ${test_id}") + message(STATUS "Source files: ${ARGN}") + add_executable(${test_id} ${ARGN}) + target_include_directories(${test_id} PRIVATE ../src src) + target_link_directories(${test_id} PRIVATE ../lib) + target_link_libraries(${test_id} PRIVATE Qt${QT_VERSION_MAJOR}::Core Qt${QT_VERSION_MAJOR}::Gui Qt${QT_VERSION_MAJOR}::Widgets Qt${QT_VERSION_MAJOR}::Test) + add_test(NAME ${test_id} COMMAND ${test_id}) +endfunction() + +ao_declare_test(test_aopacket test_aopacket.cpp ../src/aopacket.cpp) diff --git a/test/test_aopacket.cpp b/test/test_aopacket.cpp index 0b318213..4a24dcd3 100644 --- a/test/test_aopacket.cpp +++ b/test/test_aopacket.cpp @@ -1,45 +1,70 @@ -#define CATCH_CONFIG_MAIN -#include <catch2/catch.hpp> - #include "aopacket.h" -TEST_CASE("AOPacket construct", "[aopacket]") { - // Parameters - QString packet_string = "CT#MY_OOC_NAME#/doc https://docs.google.com/document/d/123/edit##%"; +#include <QString> +#include <QtTest/QTest> - SECTION("Packet string") { - AOPacket p(packet_string); - REQUIRE(p.to_string() == packet_string); - } - SECTION("Header and contents") { - QStringList contents = {"MY_OOC_NAME", "/doc https://docs.google.com/document/d/123/edit#"}; - AOPacket p("CT", contents); - REQUIRE(p.to_string() == packet_string); - } -} +class test_AOPacket : public QObject +{ + Q_OBJECT + +private: + const QMap<QString, QString> SYMBOL_MAP{ + {"#", "<num>"}, + {"%", "<percent>"}, + {"$", "<dollar>"}, + {"&", "<and>"}, + }; + +private Q_SLOTS: + void constructPacket_data() + { + QTest::addColumn<QString>("header"); + QTest::addColumn<QStringList>("content"); + QTest::addColumn<QString>("result"); -TEST_CASE("AOPacket encode/decode", "[aopacket]") { - // Parameters - QString packet_string = "CT#MY_OOC_NAME#/doc https://docs.google.com/document/d/%$&/edit##%"; - QString good_encode = "CT#MY_OOC_NAME#/doc https://docs.google.com/document/d/<percent><dollar><and>/edit<num>#%"; + QTest::newRow("Basic Packet") << "CT" << QStringList{"MY_OOC_NAME", "/doc https://docs.google.com/document/d/123/edit"} << "CT#MY_OOC_NAME#/doc https://docs.google.com/document/d/123/edit#%"; + } - SECTION("Bad encode/decode because packet string constructor splits the '#' after 'edit'") { - AOPacket p(packet_string); - p.net_encode(); - REQUIRE(p.to_string() != good_encode); + void constructPacket() + { + QFETCH(QString, header); + QFETCH(QStringList, content); + QFETCH(QString, result); - p.net_decode(); - REQUIRE(p.to_string() == packet_string); + AOPacket packet(header, content); + QVERIFY(packet.toString(true) == result); } - SECTION("Good encode/decode with header and contents constructor") { - QStringList contents = {"MY_OOC_NAME", "/doc https://docs.google.com/document/d/%$&/edit#"}; - AOPacket p("CT", contents); + void encodeDecodeData_data() + { + QTest::addColumn<QString>("what"); + QTest::addColumn<QString>("result"); + QTest::addColumn<bool>("encode"); + + for (auto it = SYMBOL_MAP.begin(); it != SYMBOL_MAP.end(); ++it) + { + QTest::newRow(QString("Encode %1").arg(it.key()).toUtf8()) << it.key() << it.value() << true; + QTest::newRow(QString("Decode %1").arg(it.value()).toUtf8()) << it.value() << it.key() << false; + } + } - p.net_encode(); - REQUIRE(p.to_string() == good_encode); + void encodeDecodeData() + { + QFETCH(QString, what); + QFETCH(QString, result); + QFETCH(bool, encode); - p.net_decode(); - REQUIRE(p.to_string() == packet_string); + if (encode) + { + QVERIFY(AOPacket::encode(what) == result); + } + else + { + QVERIFY(AOPacket::decode(what) == result); + } } -} +}; + +#include "test/test_aopacket.moc" + +QTEST_MAIN(test_AOPacket) diff --git a/test/test_apng.cpp b/test/test_apng.cpp deleted file mode 100644 index 20c7e927..00000000 --- a/test/test_apng.cpp +++ /dev/null @@ -1,61 +0,0 @@ -#include <catch2/catch.hpp> - -#include <QPluginLoader> -#include <QImageReader> -#include <QCoreApplication> -#include <QGuiApplication> -#include <QPixmap> - -TEST_CASE("Support APNG Plugin", "[apng]") { - // Check paths for libs - QCoreApplication::addLibraryPath("."); - QCoreApplication::addLibraryPath("lib"); - - // Either it's loaded from system or we load local - QPluginLoader apngPlugin("qapng"); - apngPlugin.load(); - - INFO(QImageReader::supportedImageFormats().join(' ').toStdString()); - REQUIRE(QImageReader::supportedImageFormats().contains("apng")); -} - -TEST_CASE("Detect png animation", "[apng]") { - // Required for QPixmap methods - int argc = 1; - char bin[] = "test"; - char *argv[] = { bin }; - QGuiApplication app(argc, argv); - - // Instantiate reader - QImageReader reader; - - SECTION("Decide format from content fails on apng") { - reader.setFileName("snackoo.png"); - reader.setDecideFormatFromContent(true); - REQUIRE(!reader.supportsAnimation()); - REQUIRE(!QPixmap::fromImage(reader.read()).isNull()); - } - - SECTION("Auto detect fails on apng") { - reader.setFileName("snackoo.png"); - reader.setAutoDetectImageFormat(true); - REQUIRE(!reader.supportsAnimation()); - REQUIRE(!QPixmap::fromImage(reader.read()).isNull()); - } - - SECTION("Detect apng supports animation") { - reader.setFileName("snackoo.png"); - reader.setFormat("apng"); - REQUIRE(reader.supportsAnimation()); - REQUIRE(!QPixmap::fromImage(reader.read()).isNull()); - } - - SECTION("Detect png frame has no animation") { - reader.setFileName("missle.png"); - reader.setFormat("apng"); - REQUIRE(!reader.supportsAnimation()); - reader.setFormat("png"); - REQUIRE(!reader.supportsAnimation()); - REQUIRE(!QPixmap::fromImage(reader.read()).isNull()); - } -} diff --git a/test/test_bass.cpp b/test/test_bass.cpp deleted file mode 100644 index e48decd8..00000000 --- a/test/test_bass.cpp +++ /dev/null @@ -1,41 +0,0 @@ -#include <iostream> -#include <cstring> - -#include <catch2/catch.hpp> -#include <QString> - -#include "bass.h" -#include "bassmidi.h" -#include "bassopus.h" - -TEST_CASE("BASS URL streaming", "[bass][noci]") { - // Sample - QString url = "https://raw.githubusercontent.com/skyedeving/aocharedit/master/Attorney%20Online%20Character%20Editor/Resources/about.mp3"; - - // initialize - BASS_Init(-1, 44100, 0, 0, nullptr); - - // create stream from url - HSTREAM stream; - unsigned int flags = BASS_STREAM_AUTOFREE | BASS_STREAM_STATUS; - if (url.endsWith(".opus")) { - stream = BASS_OPUS_StreamCreateURL(url.toStdString().c_str(), 0, flags, nullptr, 0); - } - else { - stream = BASS_StreamCreateURL(url.toStdString().c_str(), 0, flags, nullptr, 0); - } - - // Log http status - const char *tags = BASS_ChannelGetTags(stream, BASS_TAG_HTTP); - if (tags) { - while(*tags) { - UNSCOPED_INFO(tags); - tags += strlen(tags) + 1; - } - } - - // Test - REQUIRE(stream != 0); - REQUIRE(BASS_ChannelPlay(stream, TRUE) == TRUE); - // while (BASS_ChannelIsActive(stream) != BASS_ACTIVE_STOPPED); // block test to listen -} diff --git a/test/test_caseloading.cpp b/test/test_caseloading.cpp deleted file mode 100644 index 5df27823..00000000 --- a/test/test_caseloading.cpp +++ /dev/null @@ -1,18 +0,0 @@ -#include <catch2/catch.hpp> - -#include <QStringList> - -TEST_CASE("Sort case evidence numerically", "[case]") { - // Parameters - QStringList case_evidence = {"1", "10", "11", "2", "3", "4", "5", "6", "7", "8", "9"}; - QStringList case_evidence_sorted = {"1", "2", "3", "4", "5", "6", "7", "8", "9", "10", "11"}; - - // Sort - std::sort(case_evidence.begin(), case_evidence.end(), - [] (const QString &a, const QString &b) { - return a.toInt() < b.toInt(); - }); - - // Test - REQUIRE(case_evidence == case_evidence_sorted); -} |
