diff options
author | willemferguson <willemferguson@zoology.up.ac.za> | 2019-12-08 12:03:10 +0200 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2019-12-25 02:57:42 +0900 |
commit | f63f3eb4ae0cd3621cf5748dfd76749b40b6d886 (patch) | |
tree | 04255e67905b1e90c084e56edb3fe6d2e8b01323 /tests | |
parent | 2ac279d12953ad840ade1c08d0eff5c2f4adb0b9 (diff) | |
download | subsurface-f63f3eb4ae0cd3621cf5748dfd76749b40b6d886.tar.gz |
Preferences: Create a test program for qPrefMedia
This is a companion for the new Media tab in the Preferences UI
Signed-off-by: willemferguson <willemferguson@zoology.up.ac.za>
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'tests')
-rw-r--r-- | tests/CMakeLists.txt | 2 | ||||
-rw-r--r-- | tests/testqPrefMedia.cpp | 130 | ||||
-rw-r--r-- | tests/testqPrefMedia.h | 19 |
3 files changed, 151 insertions, 0 deletions
diff --git a/tests/CMakeLists.txt b/tests/CMakeLists.txt index 07452f7a1..fd8bc80a6 100644 --- a/tests/CMakeLists.txt +++ b/tests/CMakeLists.txt @@ -111,6 +111,7 @@ TEST(TestQPrefDiveComputer testqPrefDiveComputer.cpp) TEST(TestQPrefDivePlanner testqPrefDivePlanner.cpp) TEST(TestQPrefGeneral testqPrefGeneral.cpp) TEST(TestQPrefEquipment testqPrefEquipment.cpp) +TEST(TestQPrefMedia testqPrefMedia.cpp) TEST(TestQPrefGeocoding testqPrefGeocoding.cpp) TEST(TestQPrefLanguage testqPrefLanguage.cpp) TEST(TestQPrefLocationService testqPrefLocationService.cpp) @@ -143,6 +144,7 @@ add_custom_target(check COMMAND ${CMAKE_CTEST_COMMAND} TestQPrefDivePlanner TestQPrefGeneral TestQPrefEquipment + TestQPrefMedia TestQPrefGeocoding TestQPrefLanguage TestQPrefLocationService diff --git a/tests/testqPrefMedia.cpp b/tests/testqPrefMedia.cpp new file mode 100644 index 000000000..f0c864408 --- /dev/null +++ b/tests/testqPrefMedia.cpp @@ -0,0 +1,130 @@ +// SPDX-License-Identifier: GPL-2.0 +#include "testqPrefMedia.h" + +#include "core/pref.h" +#include "core/qthelper.h" +#include "core/settings/qPrefMedia.h" +#include "core/settings/qPref.h" + +#include <QTest> +#include <QSignalSpy> + +void TestQPrefMedia::initTestCase() +{ + QCoreApplication::setOrganizationName("Subsurface"); + QCoreApplication::setOrganizationDomain("subsurface.hohndel.org"); + QCoreApplication::setApplicationName("SubsurfaceTestQPrefMedia"); + qPref::registerQML(NULL); +} + +void TestQPrefMedia::test_struct_get() +{ + // Test struct pref -> get func. + + auto tst = qPrefMedia::instance(); + + prefs.auto_recalculate_thumbnails = true; + prefs.extract_video_thumbnails = true; + prefs.extract_video_thumbnails_position = 15; + prefs.ffmpeg_executable = copy_qstring("new base16"); + + QCOMPARE(tst->auto_recalculate_thumbnails(), prefs.auto_recalculate_thumbnails); + QCOMPARE(tst->extract_video_thumbnails(), prefs.extract_video_thumbnails); + QCOMPARE(tst->extract_video_thumbnails_position(), prefs.extract_video_thumbnails_position); + QCOMPARE(tst->ffmpeg_executable(), QString(prefs.ffmpeg_executable)); +} + +void TestQPrefMedia::test_set_struct() +{ + // Test set func -> struct pref + + auto tst = qPrefMedia::instance(); + + tst->set_auto_recalculate_thumbnails(false); + tst->set_extract_video_thumbnails(false); + tst->set_extract_video_thumbnails_position(25); + tst->set_ffmpeg_executable("new base26"); + + QCOMPARE(prefs.auto_recalculate_thumbnails, false); + QCOMPARE(prefs.extract_video_thumbnails, false); + QCOMPARE(prefs.extract_video_thumbnails_position, 25); + QCOMPARE(QString(prefs.ffmpeg_executable), QString("new base26")); +} + +void TestQPrefMedia::test_set_load_struct() +{ + // test set func -> load -> struct pref + + auto tst = qPrefMedia::instance(); + + tst->set_auto_recalculate_thumbnails(true); + tst->set_extract_video_thumbnails(true); + tst->set_extract_video_thumbnails_position(35); + tst->set_ffmpeg_executable("new base36"); + + prefs.auto_recalculate_thumbnails = false; + prefs.extract_video_thumbnails = false; + prefs.extract_video_thumbnails_position = 15; + prefs.ffmpeg_executable = copy_qstring("error"); + + tst->load(); + QCOMPARE(prefs.auto_recalculate_thumbnails, true); + QCOMPARE(prefs.extract_video_thumbnails, true); + QCOMPARE(prefs.extract_video_thumbnails_position, 35); + QCOMPARE(QString(prefs.ffmpeg_executable), QString("new base36")); +} + +void TestQPrefMedia::test_struct_disk() +{ + // test struct prefs -> disk + + auto tst = qPrefMedia::instance(); + + prefs.auto_recalculate_thumbnails = true; + prefs.extract_video_thumbnails = true; + prefs.extract_video_thumbnails_position = 45; + prefs.ffmpeg_executable = copy_qstring("base46"); + + tst->sync(); + prefs.auto_recalculate_thumbnails = false; + prefs.extract_video_thumbnails = false; + prefs.extract_video_thumbnails_position = 15; + prefs.ffmpeg_executable = copy_qstring("error"); + + tst->load(); + QCOMPARE(prefs.auto_recalculate_thumbnails, true); + QCOMPARE(prefs.extract_video_thumbnails, true); + QCOMPARE(prefs.extract_video_thumbnails_position, 45); + QCOMPARE(QString(prefs.ffmpeg_executable), QString("base46")); +} + +#define TEST(METHOD, VALUE) \ + QCOMPARE(METHOD, VALUE); \ + media->sync(); \ + media->load(); \ + QCOMPARE(METHOD, VALUE); + +void TestQPrefMedia::test_signals() +{ + QSignalSpy spy1(qPrefMedia::instance(), &qPrefMedia::auto_recalculate_thumbnailsChanged); + QSignalSpy spy6(qPrefMedia::instance(), &qPrefMedia::extract_video_thumbnailsChanged); + QSignalSpy spy7(qPrefMedia::instance(), &qPrefMedia::extract_video_thumbnails_positionChanged); + QSignalSpy spy8(qPrefMedia::instance(), &qPrefMedia::ffmpeg_executableChanged); + + prefs.auto_recalculate_thumbnails = true; + qPrefMedia::set_auto_recalculate_thumbnails(false); + + qPrefMedia::set_extract_video_thumbnails(false); + qPrefMedia::set_extract_video_thumbnails_position(25); + qPrefMedia::set_ffmpeg_executable("new base26"); + + QCOMPARE(spy1.count(), 1); + + QVERIFY(spy1.takeFirst().at(0).toBool() == false); + + qPrefMedia::set_extract_video_thumbnails(false); + qPrefMedia::set_extract_video_thumbnails_position(25); + qPrefMedia::set_ffmpeg_executable("new base26"); +} + +QTEST_MAIN(TestQPrefMedia) diff --git a/tests/testqPrefMedia.h b/tests/testqPrefMedia.h new file mode 100644 index 000000000..a1bb51058 --- /dev/null +++ b/tests/testqPrefMedia.h @@ -0,0 +1,19 @@ +// SPDX-License-Identifier: GPL-2.0 +#ifndef TESTQPREFMEDIA_H +#define TESTQPREFMEDIA_H + +#include <QObject> + +class TestQPrefMedia : public QObject { + Q_OBJECT + +private slots: + void initTestCase(); + void test_struct_get(); + void test_set_struct(); + void test_set_load_struct(); + void test_struct_disk(); + void test_signals(); +}; + +#endif // TESTQPREFMEDIA_H |