mirror of
https://github.com/subsurface/subsurface.git
synced 2025-02-19 22:16:15 +00:00
tests: add qPrefLocationService testcases
add test cases to secure struct preferences and qPrefLocationService work together Signed-off-by: Jan Iversen <jani@apache.org>
This commit is contained in:
parent
75ce813a27
commit
3174c71563
3 changed files with 115 additions and 0 deletions
|
@ -107,6 +107,7 @@ TEST(TestQPrefDisplay testqPrefDisplay.cpp)
|
||||||
TEST(TestQPrefDiveComputer testqPrefDiveComputer.cpp)
|
TEST(TestQPrefDiveComputer testqPrefDiveComputer.cpp)
|
||||||
TEST(TestQPrefDivePlanner testqPrefDivePlanner.cpp)
|
TEST(TestQPrefDivePlanner testqPrefDivePlanner.cpp)
|
||||||
TEST(TestQPrefFacebook testqPrefFacebook.cpp)
|
TEST(TestQPrefFacebook testqPrefFacebook.cpp)
|
||||||
|
TEST(TestQPrefLocationService testqPrefLocationService.cpp)
|
||||||
TEST(TestQPrefProxy testqPrefProxy.cpp)
|
TEST(TestQPrefProxy testqPrefProxy.cpp)
|
||||||
TEST(TestQPrefTechnicalDetails testqPrefTechnicalDetails.cpp)
|
TEST(TestQPrefTechnicalDetails testqPrefTechnicalDetails.cpp)
|
||||||
TEST(TestQPrefUnits testqPrefUnits.cpp)
|
TEST(TestQPrefUnits testqPrefUnits.cpp)
|
||||||
|
@ -135,6 +136,7 @@ add_custom_target(check COMMAND ${CMAKE_CTEST_COMMAND}
|
||||||
TestQPrefDiveComputer
|
TestQPrefDiveComputer
|
||||||
TestQPrefDivePlanner
|
TestQPrefDivePlanner
|
||||||
TestQPrefFacebook
|
TestQPrefFacebook
|
||||||
|
TestQPrefLocationService
|
||||||
TestQPrefProxy
|
TestQPrefProxy
|
||||||
TestQPrefTechnicalDetails
|
TestQPrefTechnicalDetails
|
||||||
TestQPrefUnits
|
TestQPrefUnits
|
||||||
|
|
94
tests/testqPrefLocationService.cpp
Normal file
94
tests/testqPrefLocationService.cpp
Normal file
|
@ -0,0 +1,94 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
|
#include "testqPrefLocationService.h"
|
||||||
|
|
||||||
|
#include "core/pref.h"
|
||||||
|
#include "core/qthelper.h"
|
||||||
|
#include "core/settings/qPref.h"
|
||||||
|
|
||||||
|
#include <QTest>
|
||||||
|
|
||||||
|
void TestQPrefLocationService::initTestCase()
|
||||||
|
{
|
||||||
|
QCoreApplication::setOrganizationName("Subsurface");
|
||||||
|
QCoreApplication::setOrganizationDomain("subsurface.hohndel.org");
|
||||||
|
QCoreApplication::setApplicationName("SubsurfaceTestQPrefLocationService");
|
||||||
|
}
|
||||||
|
|
||||||
|
void TestQPrefLocationService::test_struct_get()
|
||||||
|
{
|
||||||
|
// Test struct pref -> get func.
|
||||||
|
|
||||||
|
auto tst = qPrefLocationService::instance();
|
||||||
|
|
||||||
|
prefs.distance_threshold = 1000;
|
||||||
|
prefs.time_threshold = 60;
|
||||||
|
|
||||||
|
QCOMPARE(tst->distance_threshold(), prefs.distance_threshold);
|
||||||
|
QCOMPARE(tst->time_threshold(), prefs.time_threshold);
|
||||||
|
}
|
||||||
|
|
||||||
|
void TestQPrefLocationService::test_set_struct()
|
||||||
|
{
|
||||||
|
// Test set func -> struct pref
|
||||||
|
|
||||||
|
auto tst = qPrefLocationService::instance();
|
||||||
|
|
||||||
|
tst->set_distance_threshold(2000);
|
||||||
|
tst->set_time_threshold(90);
|
||||||
|
|
||||||
|
QCOMPARE(prefs.distance_threshold, 2000);
|
||||||
|
QCOMPARE(prefs.time_threshold, 90);
|
||||||
|
}
|
||||||
|
|
||||||
|
void TestQPrefLocationService::test_set_load_struct()
|
||||||
|
{
|
||||||
|
// test set func -> load -> struct pref
|
||||||
|
|
||||||
|
auto tst = qPrefLocationService::instance();
|
||||||
|
|
||||||
|
tst->set_distance_threshold(2001);
|
||||||
|
tst->set_time_threshold(91);
|
||||||
|
|
||||||
|
prefs.distance_threshold = 1000;
|
||||||
|
prefs.time_threshold = 60;
|
||||||
|
|
||||||
|
tst->load();
|
||||||
|
QCOMPARE(tst->distance_threshold(), 2001);
|
||||||
|
QCOMPARE(tst->time_threshold(), 91);
|
||||||
|
}
|
||||||
|
|
||||||
|
void TestQPrefLocationService::test_struct_disk()
|
||||||
|
{
|
||||||
|
// test struct prefs -> disk
|
||||||
|
|
||||||
|
auto tst = qPrefLocationService::instance();
|
||||||
|
|
||||||
|
prefs.distance_threshold = 1002;
|
||||||
|
prefs.time_threshold = 62;
|
||||||
|
|
||||||
|
tst->sync();
|
||||||
|
prefs.distance_threshold = 12;
|
||||||
|
prefs.time_threshold = 2;
|
||||||
|
|
||||||
|
tst->load();
|
||||||
|
QCOMPARE(tst->distance_threshold(), 1002);
|
||||||
|
QCOMPARE(tst->time_threshold(), 62);
|
||||||
|
}
|
||||||
|
|
||||||
|
void TestQPrefLocationService::test_multiple()
|
||||||
|
{
|
||||||
|
// test multiple instances have the same information
|
||||||
|
|
||||||
|
prefs.distance_threshold = 52;
|
||||||
|
auto tst_direct = new qPrefLocationService;
|
||||||
|
|
||||||
|
prefs.time_threshold = 62;
|
||||||
|
auto tst = qPrefLocationService::instance();
|
||||||
|
|
||||||
|
QCOMPARE(tst->distance_threshold(), tst_direct->distance_threshold());
|
||||||
|
QCOMPARE(tst->time_threshold(), tst_direct->time_threshold());
|
||||||
|
QCOMPARE(tst_direct->distance_threshold(), 52);
|
||||||
|
QCOMPARE(tst_direct->time_threshold(), 62);
|
||||||
|
}
|
||||||
|
|
||||||
|
QTEST_MAIN(TestQPrefLocationService)
|
19
tests/testqPrefLocationService.h
Normal file
19
tests/testqPrefLocationService.h
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
|
#ifndef TESTQPREFLOCATIONSERVICE_H
|
||||||
|
#define TESTQPREFLOCATIONSERVICE_H
|
||||||
|
|
||||||
|
#include <QObject>
|
||||||
|
|
||||||
|
class TestQPrefLocationService : 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();
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // TESTQPREFLOCATIONSERVICE_H
|
Loading…
Add table
Reference in a new issue