summaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
Diffstat (limited to 'tests')
-rw-r--r--tests/CMakeLists.txt2
-rw-r--r--tests/testqPrefUnits.cpp189
-rw-r--r--tests/testqPrefUnits.h20
3 files changed, 211 insertions, 0 deletions
diff --git a/tests/CMakeLists.txt b/tests/CMakeLists.txt
index b66dbb009..8ff1ffd91 100644
--- a/tests/CMakeLists.txt
+++ b/tests/CMakeLists.txt
@@ -107,6 +107,7 @@ TEST(TestQPrefDisplay testqPrefDisplay.cpp)
TEST(TestQPrefDiveComputer testqPrefDiveComputer.cpp)
TEST(TestQPrefFacebook testqPrefFacebook.cpp)
TEST(TestQPrefProxy testqPrefProxy.cpp)
+TEST(TestQPrefUnits testqPrefUnits.cpp)
add_test(NAME TestQML COMMAND $<TARGET_FILE:TestQML> ${SUBSURFACE_SOURCE}/tests)
@@ -131,6 +132,7 @@ add_custom_target(check COMMAND ${CMAKE_CTEST_COMMAND}
TestQPrefDiveComputer
TestQPrefFacebook
TestQPrefProxy
+ TestQPrefUnits
TestQML
)
diff --git a/tests/testqPrefUnits.cpp b/tests/testqPrefUnits.cpp
new file mode 100644
index 000000000..8f803cf93
--- /dev/null
+++ b/tests/testqPrefUnits.cpp
@@ -0,0 +1,189 @@
+// SPDX-License-Identifier: GPL-2.0
+#include "testqPrefUnits.h"
+
+#include "core/pref.h"
+#include "core/qthelper.h"
+#include "core/settings/qPref.h"
+
+#include <QTest>
+
+void TestQPrefUnits::initTestCase()
+{
+ QCoreApplication::setOrganizationName("Subsurface");
+ QCoreApplication::setOrganizationDomain("subsurface.hohndel.org");
+ QCoreApplication::setApplicationName("SubsurfaceTestQPrefUnits");
+}
+
+void TestQPrefUnits::test_struct_get()
+{
+ // Test struct pref -> get func.
+
+ auto tst = qPrefUnits::instance();
+
+ prefs.coordinates_traditional = true;
+ prefs.units.duration_units = units::MIXED;
+ prefs.units.length = units::METERS;
+ prefs.units.pressure = units::BAR;
+ prefs.units.show_units_table = true;
+ prefs.units.temperature = units::CELSIUS;
+ prefs.units.vertical_speed_time = units::SECONDS;
+ prefs.units.volume = units::LITER;
+ prefs.units.weight = units::KG;
+
+ QCOMPARE(tst->coordinates_traditional(), true);
+ QCOMPARE(tst->duration_units(), units::MIXED);
+ QCOMPARE(tst->length(), units::METERS);
+ QCOMPARE(tst->pressure(), units::BAR);
+ QCOMPARE(tst->show_units_table(), true);
+ QCOMPARE(tst->temperature(), units::CELSIUS);
+ QCOMPARE(tst->vertical_speed_time(), units::SECONDS);
+ QCOMPARE(tst->volume(), units::LITER);
+ QCOMPARE(tst->weight(), units::KG);
+}
+
+void TestQPrefUnits::test_set_struct()
+{
+ // Test set func -> struct pref
+
+ auto tst = qPrefUnits::instance();
+
+ tst->set_coordinates_traditional(false);
+ tst->set_duration_units(units::MINUTES_ONLY);
+ tst->set_length(units::FEET);
+ tst->set_pressure(units::PSI);
+ tst->set_show_units_table(false);
+ tst->set_temperature(units::FAHRENHEIT);
+ tst->set_vertical_speed_time(units::MINUTES);
+ tst->set_volume(units::CUFT);
+ tst->set_weight(units::LBS);
+
+ QCOMPARE(prefs.coordinates_traditional, false);
+ QCOMPARE(prefs.units.duration_units, units::MINUTES_ONLY);
+ QCOMPARE(prefs.units.length, units::FEET);
+ QCOMPARE(prefs.units.pressure, units::PSI);
+ QCOMPARE(prefs.units.show_units_table, false);
+ QCOMPARE(prefs.units.temperature, units::FAHRENHEIT);
+ QCOMPARE(prefs.units.vertical_speed_time, units::MINUTES);
+ QCOMPARE(prefs.units.volume, units::CUFT);
+ QCOMPARE(prefs.units.weight, units::LBS);
+}
+
+void TestQPrefUnits::test_set_load_struct()
+{
+ // test set func -> load -> struct pref
+
+ auto tst = qPrefUnits::instance();
+
+ tst->set_coordinates_traditional(false);
+ tst->set_duration_units(units::MINUTES_ONLY);
+ tst->set_length(units::FEET);
+ tst->set_pressure(units::PSI);
+ tst->set_show_units_table(false);
+ tst->set_temperature(units::FAHRENHEIT);
+ tst->set_vertical_speed_time(units::MINUTES);
+ tst->set_volume(units::CUFT);
+ tst->set_weight(units::LBS);
+
+ tst->sync();
+ prefs.coordinates_traditional = true;
+ prefs.units.duration_units = units::MIXED;
+ prefs.units.length = units::METERS;
+ prefs.units.pressure = units::BAR;
+ prefs.units.show_units_table = true;
+ prefs.units.temperature = units::CELSIUS;
+ prefs.units.vertical_speed_time = units::SECONDS;
+ prefs.units.volume = units::LITER;
+ prefs.units.weight = units::KG;
+
+ tst->load();
+ QCOMPARE(prefs.coordinates_traditional, false);
+ QCOMPARE(prefs.units.duration_units, units::MINUTES_ONLY);
+ QCOMPARE(prefs.units.length, units::FEET);
+ QCOMPARE(prefs.units.pressure, units::PSI);
+ QCOMPARE(prefs.units.show_units_table, false);
+ QCOMPARE(prefs.units.temperature, units::FAHRENHEIT);
+ QCOMPARE(prefs.units.vertical_speed_time, units::MINUTES);
+ QCOMPARE(prefs.units.volume, units::CUFT);
+ QCOMPARE(prefs.units.weight, units::LBS);
+}
+
+void TestQPrefUnits::test_struct_disk()
+{
+ // test struct prefs -> disk
+
+ auto tst = qPrefUnits::instance();
+
+ prefs.coordinates_traditional = true;
+ prefs.units.duration_units = units::MIXED;
+ prefs.units.length = units::METERS;
+ prefs.units.pressure = units::BAR;
+ prefs.units.show_units_table = true;
+ prefs.units.temperature = units::CELSIUS;
+ prefs.units.vertical_speed_time = units::SECONDS;
+ prefs.units.volume = units::LITER;
+ prefs.units.weight = units::KG;
+
+ tst->sync();
+ prefs.coordinates_traditional = false;
+ prefs.units.duration_units = units::MINUTES_ONLY;
+ prefs.units.length = units::FEET;
+ prefs.units.pressure = units::PSI;
+ prefs.units.show_units_table = false;
+ prefs.units.temperature = units::FAHRENHEIT;
+ prefs.units.vertical_speed_time = units::MINUTES;
+ prefs.units.volume = units::CUFT;
+ prefs.units.weight = units::LBS;
+
+ tst->load();
+ QCOMPARE(prefs.coordinates_traditional, true);
+ QCOMPARE(prefs.units.duration_units, units::MIXED);
+ QCOMPARE(prefs.units.length, units::METERS);
+ QCOMPARE(prefs.units.pressure, units::BAR);
+ QCOMPARE(prefs.units.show_units_table, true);
+ QCOMPARE(prefs.units.temperature, units::CELSIUS);
+ QCOMPARE(prefs.units.vertical_speed_time, units::SECONDS);
+ QCOMPARE(prefs.units.volume, units::LITER);
+ QCOMPARE(prefs.units.weight, units::KG);
+}
+
+void TestQPrefUnits::test_multiple()
+{
+ // test multiple instances have the same information
+
+ prefs.units.length = units::METERS;
+ auto tst_direct = new qPrefUnits;
+
+ prefs.units.pressure = units::BAR;
+ auto tst = qPrefUnits::instance();
+
+ QCOMPARE(tst->length(), tst_direct->length());
+ QCOMPARE(tst->length(), units::METERS);
+ QCOMPARE(tst->pressure(), tst_direct->pressure());
+ QCOMPARE(tst->pressure(), units::BAR);
+}
+
+void TestQPrefUnits::test_unit_system()
+{
+ // test struct prefs <-> set/get unit_system
+
+ auto tst = qPrefUnits::instance();
+
+ tst->set_unit_system("metric");
+ QCOMPARE(prefs.unit_system, METRIC);
+ QCOMPARE(tst->unit_system(), QString("metric"));
+ tst->set_unit_system("imperial");
+ QCOMPARE(prefs.unit_system, IMPERIAL);
+ QCOMPARE(tst->unit_system(), QString("imperial"));
+ tst->set_unit_system("personalized");
+ QCOMPARE(prefs.unit_system, PERSONALIZE);
+ QCOMPARE(tst->unit_system(), QString("personalized"));
+
+ prefs.unit_system = METRIC;
+ QCOMPARE(tst->unit_system(), QString("metric"));
+ prefs.unit_system = IMPERIAL;
+ QCOMPARE(tst->unit_system(), QString("imperial"));
+ prefs.unit_system = PERSONALIZE;
+ QCOMPARE(tst->unit_system(), QString("personalized"));
+}
+
+QTEST_MAIN(TestQPrefUnits)
diff --git a/tests/testqPrefUnits.h b/tests/testqPrefUnits.h
new file mode 100644
index 000000000..13a684728
--- /dev/null
+++ b/tests/testqPrefUnits.h
@@ -0,0 +1,20 @@
+// SPDX-License-Identifier: GPL-2.0
+#ifndef TESTQPREFUNITS_H
+#define TESTQPREFUNITS_H
+
+#include <QObject>
+
+class TestQPrefUnits : 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_multiple();
+ void test_unit_system();
+};
+
+#endif // TESTQPREFUNITS_H