summaryrefslogtreecommitdiffstats
path: root/tests
diff options
context:
space:
mode:
authorGravatar jan Iversen <jani@apache.org>2018-07-27 22:22:51 +0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2018-07-30 07:43:22 -0700
commite198230c83b4c3690ee47d47df676b2a6cb157f4 (patch)
tree33ea32674b274c94794520ce3d3c619d70768d63 /tests
parent181d2cf364f22c5e673916d884ca5f0742e137ce (diff)
downloadsubsurface-e198230c83b4c3690ee47d47df676b2a6cb157f4.tar.gz
tests: add qPrefProxy testcases
add test cases to secure struct preferences and qPrefProxy work together Signed-off-by: Jan Iversen <jani@apache.org>
Diffstat (limited to 'tests')
-rw-r--r--tests/CMakeLists.txt2
-rw-r--r--tests/testqPrefProxy.cpp135
-rw-r--r--tests/testqPrefProxy.h19
3 files changed, 156 insertions, 0 deletions
diff --git a/tests/CMakeLists.txt b/tests/CMakeLists.txt
index 388f7783d..b66dbb009 100644
--- a/tests/CMakeLists.txt
+++ b/tests/CMakeLists.txt
@@ -106,6 +106,7 @@ TEST(TestQPrefCloudStorage testqPrefCloudStorage.cpp)
TEST(TestQPrefDisplay testqPrefDisplay.cpp)
TEST(TestQPrefDiveComputer testqPrefDiveComputer.cpp)
TEST(TestQPrefFacebook testqPrefFacebook.cpp)
+TEST(TestQPrefProxy testqPrefProxy.cpp)
add_test(NAME TestQML COMMAND $<TARGET_FILE:TestQML> ${SUBSURFACE_SOURCE}/tests)
@@ -129,6 +130,7 @@ add_custom_target(check COMMAND ${CMAKE_CTEST_COMMAND}
TestQPrefDisplay
TestQPrefDiveComputer
TestQPrefFacebook
+ TestQPrefProxy
TestQML
)
diff --git a/tests/testqPrefProxy.cpp b/tests/testqPrefProxy.cpp
new file mode 100644
index 000000000..4db48baf0
--- /dev/null
+++ b/tests/testqPrefProxy.cpp
@@ -0,0 +1,135 @@
+// SPDX-License-Identifier: GPL-2.0
+#include "testqPrefProxy.h"
+
+#include "core/pref.h"
+#include "core/qthelper.h"
+#include "core/settings/qPref.h"
+
+#include <QTest>
+
+void TestQPrefProxy::initTestCase()
+{
+ QCoreApplication::setOrganizationName("Subsurface");
+ QCoreApplication::setOrganizationDomain("subsurface.hohndel.org");
+ QCoreApplication::setApplicationName("SubsurfaceTestQPrefProxy");
+}
+
+void TestQPrefProxy::test_struct_get()
+{
+ // Test struct pref -> get func.
+
+ auto tst = qPrefProxy::instance();
+
+ prefs.proxy_auth = true;
+ prefs.proxy_host = copy_qstring("t1 host");
+ prefs.proxy_pass = copy_qstring("t1 pass");
+ prefs.proxy_port = 512;
+ prefs.proxy_type = 3;
+ prefs.proxy_user = copy_qstring("t1 user");
+
+ QCOMPARE(tst->proxy_auth(), true);
+ QCOMPARE(tst->proxy_host(), QString(prefs.proxy_host));
+ QCOMPARE(tst->proxy_pass(), QString(prefs.proxy_pass));
+ QCOMPARE(tst->proxy_port(), 512);
+ QCOMPARE(tst->proxy_type(), 3);
+ QCOMPARE(tst->proxy_user(), QString(prefs.proxy_user));
+}
+
+void TestQPrefProxy::test_set_struct()
+{
+ // Test set func -> struct pref
+
+ auto tst = qPrefProxy::instance();
+
+ tst->set_proxy_auth(false);
+ tst->set_proxy_host("t2 host");
+ tst->set_proxy_pass("t2 pass");
+ tst->set_proxy_port(524);
+ tst->set_proxy_type(2);
+ tst->set_proxy_user("t2 user");
+
+ QCOMPARE(prefs.proxy_auth, false);
+ QCOMPARE(QString(prefs.proxy_host), QString("t2 host"));
+ QCOMPARE(QString(prefs.proxy_pass), QString("t2 pass"));
+ QCOMPARE(prefs.proxy_port, 524);
+ QCOMPARE(prefs.proxy_type, 2);
+ QCOMPARE(QString(prefs.proxy_user), QString("t2 user"));
+}
+
+void TestQPrefProxy::test_set_load_struct()
+{
+ // test set func -> load -> struct pref
+
+ auto tst = qPrefProxy::instance();
+
+ tst->set_proxy_auth(true);
+ tst->set_proxy_host("t3 host");
+ tst->set_proxy_pass("t3 pass");
+ tst->set_proxy_port(532);
+ tst->set_proxy_type(1);
+ tst->set_proxy_user("t3 user");
+
+ tst->sync();
+ prefs.proxy_auth = false;
+ prefs.proxy_host = copy_qstring("error1");
+ prefs.proxy_pass = copy_qstring("error1");
+ prefs.proxy_port = 128;
+ prefs.proxy_type = 0;
+ prefs.proxy_user = copy_qstring("error1");
+
+ tst->load();
+ QCOMPARE(prefs.proxy_auth, true);
+ QCOMPARE(QString(prefs.proxy_host), QString("t3 host"));
+ QCOMPARE(QString(prefs.proxy_pass), QString("t3 pass"));
+ QCOMPARE(prefs.proxy_port, 532);
+ QCOMPARE(prefs.proxy_type, 1);
+ QCOMPARE(QString(prefs.proxy_user), QString("t3 user"));
+}
+
+void TestQPrefProxy::test_struct_disk()
+{
+ // test struct prefs -> disk
+
+ auto tst = qPrefProxy::instance();
+
+ prefs.proxy_auth = false;
+ prefs.proxy_host = copy_qstring("t4 host");
+ prefs.proxy_pass = copy_qstring("t4 pass");
+ prefs.proxy_port = 544;
+ prefs.proxy_type = 4;
+ prefs.proxy_user = copy_qstring("t4 user");
+
+ tst->sync();
+ prefs.proxy_auth = true;
+ prefs.proxy_host = copy_qstring("error1");
+ prefs.proxy_pass = copy_qstring("error1");
+ prefs.proxy_port = 128;
+ prefs.proxy_type = 5;
+ prefs.proxy_user = copy_qstring("error1");
+
+ tst->load();
+ QCOMPARE(prefs.proxy_auth, false);
+ QCOMPARE(QString(prefs.proxy_host), QString("t4 host"));
+ QCOMPARE(QString(prefs.proxy_pass), QString("t4 pass"));
+ QCOMPARE(prefs.proxy_port, 544);
+ QCOMPARE(prefs.proxy_type, 4);
+ QCOMPARE(QString(prefs.proxy_user), QString("t4 user"));
+}
+
+void TestQPrefProxy::test_multiple()
+{
+ // test multiple instances have the same information
+
+ prefs.proxy_port= 37;
+ auto tst_direct = new qPrefProxy;
+
+ prefs.proxy_type = 25;
+ auto tst = qPrefProxy::instance();
+
+ QCOMPARE(tst->proxy_port(), tst_direct->proxy_port());
+ QCOMPARE(tst->proxy_port(), 37);
+ QCOMPARE(tst->proxy_type(), tst_direct->proxy_type());
+ QCOMPARE(tst->proxy_type(), 25);
+}
+
+QTEST_MAIN(TestQPrefProxy)
diff --git a/tests/testqPrefProxy.h b/tests/testqPrefProxy.h
new file mode 100644
index 000000000..27c0312f9
--- /dev/null
+++ b/tests/testqPrefProxy.h
@@ -0,0 +1,19 @@
+// SPDX-License-Identifier: GPL-2.0
+#ifndef TESTQPREFPROXY_H
+#define TESTQPREFPROXY_H
+
+#include <QObject>
+
+class TestQPrefProxy : 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 // TESTQPREFPROXY_H