diff options
Diffstat (limited to 'tests')
-rw-r--r-- | tests/CMakeLists.txt | 2 | ||||
-rw-r--r-- | tests/testqPrefUnits.cpp | 189 | ||||
-rw-r--r-- | tests/testqPrefUnits.h | 20 |
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 |