summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar jan Iversen <jani@apache.org>2018-07-23 18:14:43 +0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2018-07-27 12:36:20 -0700
commit4102cc755ff53b4ec811a9cf89156842a20258ac (patch)
tree9f07785562679622df300b24d90d4fff97ac92f9
parentf175890632d5845d57066b0669c347b4c0992ff9 (diff)
downloadsubsurface-4102cc755ff53b4ec811a9cf89156842a20258ac.tar.gz
tests: add qPrefFacebook testcases
add test cases to secure struct preferences and qPrefFacebook work together Signed-off-by: Jan Iversen <jani@apache.org>
-rw-r--r--tests/CMakeLists.txt2
-rw-r--r--tests/testqPrefFacebook.cpp60
-rw-r--r--tests/testqPrefFacebook.h18
3 files changed, 80 insertions, 0 deletions
diff --git a/tests/CMakeLists.txt b/tests/CMakeLists.txt
index 10fd7dfe9..388f7783d 100644
--- a/tests/CMakeLists.txt
+++ b/tests/CMakeLists.txt
@@ -105,6 +105,7 @@ TEST(TestQPrefAnimations testqPrefAnimations.cpp)
TEST(TestQPrefCloudStorage testqPrefCloudStorage.cpp)
TEST(TestQPrefDisplay testqPrefDisplay.cpp)
TEST(TestQPrefDiveComputer testqPrefDiveComputer.cpp)
+TEST(TestQPrefFacebook testqPrefFacebook.cpp)
add_test(NAME TestQML COMMAND $<TARGET_FILE:TestQML> ${SUBSURFACE_SOURCE}/tests)
@@ -127,6 +128,7 @@ add_custom_target(check COMMAND ${CMAKE_CTEST_COMMAND}
TestQPrefCloudStorage
TestQPrefDisplay
TestQPrefDiveComputer
+ TestQPrefFacebook
TestQML
)
diff --git a/tests/testqPrefFacebook.cpp b/tests/testqPrefFacebook.cpp
new file mode 100644
index 000000000..230197b10
--- /dev/null
+++ b/tests/testqPrefFacebook.cpp
@@ -0,0 +1,60 @@
+// SPDX-License-Identifier: GPL-2.0
+#include "testqPrefFacebook.h"
+
+#include "core/settings/qPref.h"
+#include "core/pref.h"
+#include "core/qthelper.h"
+
+#include <QTest>
+
+void TestQPrefFacebook::initTestCase()
+{
+ QCoreApplication::setOrganizationName("Subsurface");
+ QCoreApplication::setOrganizationDomain("subsurface.hohndel.org");
+ QCoreApplication::setApplicationName("SubsurfaceTestQPrefFacebook");
+}
+
+void TestQPrefFacebook::test_struct_get()
+{
+ // Test struct pref -> get func.
+
+ auto tst = qPrefFacebook::instance();
+
+ prefs.facebook.access_token = copy_qstring("t1 token");
+ prefs.facebook.album_id = copy_qstring("t1 album");
+ prefs.facebook.user_id = copy_qstring("t1 user");
+
+ QCOMPARE(tst->access_token(), QString(prefs.facebook.access_token));
+ QCOMPARE(tst->album_id(), QString(prefs.facebook.album_id));
+ QCOMPARE(tst->user_id(), QString(prefs.facebook.user_id));
+}
+
+void TestQPrefFacebook::test_set_struct()
+{
+ // Test set func -> struct pref
+
+ auto tst = qPrefFacebook::instance();
+
+ tst->set_access_token("t2 token");
+ tst->set_album_id("t2 album");
+ tst->set_user_id("t2 user");
+
+ QCOMPARE(QString(prefs.facebook.access_token), QString("t2 token"));
+ QCOMPARE(QString(prefs.facebook.album_id), QString("t2 album"));
+ QCOMPARE(QString(prefs.facebook.user_id), QString("t2 user"));
+}
+
+void TestQPrefFacebook::test_multiple()
+{
+ // test multiple instances have the same information
+
+ prefs.facebook.access_token = copy_qstring("test 1");
+ auto tst_direct = new qPrefFacebook;
+
+ prefs.facebook.access_token = copy_qstring("test 2");
+ auto tst = qPrefFacebook::instance();
+
+ QCOMPARE(tst->access_token(), tst_direct->access_token());
+}
+
+QTEST_MAIN(TestQPrefFacebook)
diff --git a/tests/testqPrefFacebook.h b/tests/testqPrefFacebook.h
new file mode 100644
index 000000000..ecdbbe143
--- /dev/null
+++ b/tests/testqPrefFacebook.h
@@ -0,0 +1,18 @@
+// SPDX-License-Identifier: GPL-2.0
+#ifndef TESTQPREFFACEBOOK_H
+#define TESTQPREFFACEBOOK_H
+
+#include <QObject>
+
+class TestQPrefFacebook : public QObject
+{
+ Q_OBJECT
+
+private slots:
+ void initTestCase();
+ void test_struct_get();
+ void test_set_struct();
+ void test_multiple();
+};
+
+#endif // TESTQPREFFACEBOOK_H