summaryrefslogtreecommitdiffstats
path: root/tests/testqPrefGeocoding.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'tests/testqPrefGeocoding.cpp')
-rw-r--r--tests/testqPrefGeocoding.cpp104
1 files changed, 104 insertions, 0 deletions
diff --git a/tests/testqPrefGeocoding.cpp b/tests/testqPrefGeocoding.cpp
new file mode 100644
index 000000000..b0dbcbc6c
--- /dev/null
+++ b/tests/testqPrefGeocoding.cpp
@@ -0,0 +1,104 @@
+// SPDX-License-Identifier: GPL-2.0
+#include "testqPrefGeocoding.h"
+
+#include "core/pref.h"
+#include "core/qthelper.h"
+#include "core/settings/qPref.h"
+
+#include <QTest>
+
+void TestQPrefGeocoding::initTestCase()
+{
+ QCoreApplication::setOrganizationName("Subsurface");
+ QCoreApplication::setOrganizationDomain("subsurface.hohndel.org");
+ QCoreApplication::setApplicationName("SubsurfaceTestQPrefGeocoding");
+}
+
+void TestQPrefGeocoding::test_struct_get()
+{
+ // Test struct pref -> get func.
+
+ auto tst = qPrefGeocoding::instance();
+
+ prefs.geocoding.category[0] = TC_NONE;
+ prefs.geocoding.category[1] = TC_OCEAN;
+ prefs.geocoding.category[2] = TC_ADMIN_L1;
+
+ QCOMPARE(tst->first_taxonomy_category(), prefs.geocoding.category[0]);
+ QCOMPARE(tst->second_taxonomy_category(), prefs.geocoding.category[1]);
+ QCOMPARE(tst->third_taxonomy_category(), prefs.geocoding.category[2]);
+}
+
+void TestQPrefGeocoding::test_set_struct()
+{
+ // Test set func -> struct pref
+
+ auto tst = qPrefGeocoding::instance();
+
+ tst->set_first_taxonomy_category(TC_COUNTRY);
+ tst->set_second_taxonomy_category(TC_ADMIN_L1);
+ tst->set_third_taxonomy_category(TC_ADMIN_L2);
+
+ QCOMPARE(prefs.geocoding.category[0], TC_COUNTRY);
+ QCOMPARE(prefs.geocoding.category[1], TC_ADMIN_L1);
+ QCOMPARE(prefs.geocoding.category[2], TC_ADMIN_L2);
+}
+
+void TestQPrefGeocoding::test_set_load_struct()
+{
+ // test set func -> load -> struct pref
+
+ auto tst = qPrefGeocoding::instance();
+
+ tst->set_first_taxonomy_category(TC_LOCALNAME);
+ tst->set_second_taxonomy_category(TC_ADMIN_L3);
+ tst->set_third_taxonomy_category(TC_NR_CATEGORIES);
+
+ prefs.geocoding.category[0] = TC_NONE;
+ prefs.geocoding.category[1] = TC_OCEAN;
+ prefs.geocoding.category[2] = TC_ADMIN_L1;
+
+ tst->load();
+ QCOMPARE(prefs.geocoding.category[0], TC_LOCALNAME);
+ QCOMPARE(prefs.geocoding.category[1], TC_ADMIN_L3);
+ QCOMPARE(prefs.geocoding.category[2], TC_NR_CATEGORIES);
+}
+
+void TestQPrefGeocoding::test_struct_disk()
+{
+ // test struct prefs -> disk
+
+ auto tst = qPrefGeocoding::instance();
+
+ prefs.geocoding.category[0] = TC_NONE;
+ prefs.geocoding.category[1] = TC_OCEAN;
+ prefs.geocoding.category[2] = TC_ADMIN_L1;
+
+ tst->sync();
+ prefs.geocoding.category[0] = TC_ADMIN_L2;
+ prefs.geocoding.category[1] = TC_ADMIN_L2;
+ prefs.geocoding.category[2] = TC_ADMIN_L2;
+
+ tst->load();
+ QCOMPARE(prefs.geocoding.category[0], TC_NONE);
+ QCOMPARE(prefs.geocoding.category[1], TC_OCEAN);
+ QCOMPARE(prefs.geocoding.category[2], TC_ADMIN_L1);
+}
+
+void TestQPrefGeocoding::test_multiple()
+{
+ // test multiple instances have the same information
+
+ prefs.geocoding.category[0] = TC_NONE;
+ auto tst_direct = new qPrefGeocoding;
+
+ prefs.geocoding.category[1] = TC_OCEAN;
+ auto tst = qPrefGeocoding::instance();
+
+ QCOMPARE(tst->first_taxonomy_category(), tst_direct->first_taxonomy_category());
+ QCOMPARE(tst->second_taxonomy_category(), tst_direct->second_taxonomy_category());
+ QCOMPARE(tst->first_taxonomy_category(), TC_NONE);
+ QCOMPARE(tst->second_taxonomy_category(), TC_OCEAN);
+}
+
+QTEST_MAIN(TestQPrefGeocoding)