summaryrefslogtreecommitdiff
path: root/libsecret/test-session.c
diff options
context:
space:
mode:
authorStef Walter <stefw@gnome.org>2014-03-04 08:20:53 +0100
committerStef Walter <stefw@gnome.org>2014-03-04 12:57:19 +0100
commitb72048c920f50df85cb398f4309e68a575d8879e (patch)
tree78e89081991e80e68a05d76583d8e5d96ddb53fd /libsecret/test-session.c
parentec89646b1a1594193d56dc18ffd0da15b211ff82 (diff)
downloadlibsecret-b72048c920f50df85cb398f4309e68a575d8879e.tar.gz
Makefile.am: Use a single Makefile.am and parallel tests
Allow parallel building and testing by using a single Makefile.am Implement parallel testing using TAP, with various drivers and compilers living in the build/ directory. Fix all sorts of issues that this caused, including builddir != srcdir, leaks in tests and so on. It would have been nice to break out all the above into separate commits ... blush.
Diffstat (limited to 'libsecret/test-session.c')
-rw-r--r--libsecret/test-session.c234
1 files changed, 234 insertions, 0 deletions
diff --git a/libsecret/test-session.c b/libsecret/test-session.c
new file mode 100644
index 0000000..b6fd447
--- /dev/null
+++ b/libsecret/test-session.c
@@ -0,0 +1,234 @@
+/* libsecret - GLib wrapper for Secret Service
+ *
+ * Copyright 2011 Collabora Ltd.
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Lesser General Public License as published
+ * by the Free Software Foundation; either version 2 of the licence or (at
+ * your option) any later version.
+ *
+ * See the included COPYING file for more information.
+ */
+
+
+#include "config.h"
+
+#include "secret-item.h"
+#include "secret-service.h"
+#include "secret-paths.h"
+#include "secret-private.h"
+
+#include "mock-service.h"
+
+#include "egg/egg-testing.h"
+
+#include <glib.h>
+
+#include <errno.h>
+#include <stdlib.h>
+
+typedef struct {
+ SecretService *service;
+} Test;
+
+static void
+setup (Test *test,
+ gconstpointer data)
+{
+ GError *error = NULL;
+ const gchar *mock_script = data;
+
+ mock_service_start (mock_script, &error);
+ g_assert_no_error (error);
+
+ test->service = secret_service_get_sync (SECRET_SERVICE_NONE, NULL, &error);
+ g_assert_no_error (error);
+ g_object_add_weak_pointer (G_OBJECT (test->service), (gpointer *)&test->service);
+}
+
+static void
+teardown (Test *test,
+ gconstpointer unused)
+{
+ g_object_unref (test->service);
+ secret_service_disconnect ();
+ g_assert (test->service == NULL);
+
+ mock_service_stop ();
+}
+
+static void
+test_ensure (Test *test,
+ gconstpointer unused)
+{
+ GError *error = NULL;
+ gboolean ret;
+
+ g_assert_cmpstr (secret_service_get_session_dbus_path (test->service), ==, NULL);
+ g_assert_cmpstr (secret_service_get_session_algorithms (test->service), ==, NULL);
+
+ ret = secret_service_ensure_session_sync (test->service, NULL, &error);
+ g_assert_no_error (error);
+ g_assert (ret == TRUE);
+ g_assert_cmpstr (secret_service_get_session_dbus_path (test->service), !=, NULL);
+ g_assert_cmpstr (secret_service_get_session_algorithms (test->service), ==, "dh-ietf1024-sha256-aes128-cbc-pkcs7");
+}
+
+static void
+test_ensure_twice (Test *test,
+ gconstpointer unused)
+{
+ GError *error = NULL;
+ gchar *path;
+ gboolean ret;
+
+ g_assert_cmpstr (secret_service_get_session_dbus_path (test->service), ==, NULL);
+ g_assert_cmpstr (secret_service_get_session_algorithms (test->service), ==, NULL);
+
+ ret = secret_service_ensure_session_sync (test->service, NULL, &error);
+ g_assert_no_error (error);
+ g_assert (ret == TRUE);
+ g_assert_cmpstr (secret_service_get_session_dbus_path (test->service), !=, NULL);
+ g_assert_cmpstr (secret_service_get_session_algorithms (test->service), ==, "dh-ietf1024-sha256-aes128-cbc-pkcs7");
+
+ path = g_strdup (secret_service_get_session_dbus_path (test->service));
+ ret = secret_service_ensure_session_sync (test->service, NULL, &error);
+ g_assert_no_error (error);
+ g_assert (ret == TRUE);
+ g_assert_cmpstr (secret_service_get_session_dbus_path (test->service), ==, path);
+ g_assert_cmpstr (secret_service_get_session_algorithms (test->service), ==, "dh-ietf1024-sha256-aes128-cbc-pkcs7");
+
+ g_free (path);
+}
+
+static void
+test_ensure_plain (Test *test,
+ gconstpointer unused)
+{
+ GError *error = NULL;
+ gboolean ret;
+
+ g_assert_cmpstr (secret_service_get_session_dbus_path (test->service), ==, NULL);
+ g_assert_cmpstr (secret_service_get_session_algorithms (test->service), ==, NULL);
+
+ ret = secret_service_ensure_session_sync (test->service, NULL, &error);
+ g_assert_no_error (error);
+
+ g_assert (ret == TRUE);
+ g_assert_cmpstr (secret_service_get_session_dbus_path (test->service), !=, NULL);
+ g_assert_cmpstr (secret_service_get_session_algorithms (test->service), ==, "plain");
+}
+
+static void
+on_complete_get_result (GObject *source,
+ GAsyncResult *result,
+ gpointer user_data)
+{
+ GAsyncResult **ret = user_data;
+ g_assert (ret != NULL);
+ g_assert (*ret == NULL);
+ *ret = g_object_ref (result);
+ egg_test_wait_stop ();
+}
+
+static void
+test_ensure_async_plain (Test *test,
+ gconstpointer unused)
+{
+ GAsyncResult *result = NULL;
+ GError *error = NULL;
+ gboolean ret;
+
+ secret_service_ensure_session (test->service, NULL, on_complete_get_result, &result);
+ egg_test_wait ();
+
+ g_assert (G_IS_ASYNC_RESULT (result));
+ ret = secret_service_ensure_session_finish (test->service, result, &error);
+ g_assert_no_error (error);
+
+ g_assert (ret == TRUE);
+ g_assert_cmpstr (secret_service_get_session_dbus_path (test->service), !=, NULL);
+ g_assert_cmpstr (secret_service_get_session_algorithms (test->service), ==, "plain");
+
+ g_object_unref (result);
+}
+
+static void
+test_ensure_async_aes (Test *test,
+ gconstpointer unused)
+{
+ GAsyncResult *result = NULL;
+ GError *error = NULL;
+ gboolean ret;
+
+ secret_service_ensure_session (test->service, NULL, on_complete_get_result, &result);
+ egg_test_wait_until (500);
+
+ g_assert (G_IS_ASYNC_RESULT (result));
+ ret = secret_service_ensure_session_finish (test->service, result, &error);
+ g_assert_no_error (error);
+
+ g_assert (ret == TRUE);
+ g_assert_cmpstr (secret_service_get_session_dbus_path (test->service), !=, NULL);
+ g_assert_cmpstr (secret_service_get_session_algorithms (test->service), ==, "dh-ietf1024-sha256-aes128-cbc-pkcs7");
+
+ g_object_unref (result);
+}
+
+static void
+test_ensure_async_twice (Test *test,
+ gconstpointer unused)
+{
+ GAsyncResult *result = NULL;
+ GError *error = NULL;
+ gboolean ret;
+ gchar *path;
+
+ secret_service_ensure_session (test->service, NULL, on_complete_get_result, &result);
+ egg_test_wait_until (500);
+
+ g_assert (G_IS_ASYNC_RESULT (result));
+ ret = secret_service_ensure_session_finish (test->service, result, &error);
+ g_assert_no_error (error);
+
+ g_assert (ret == TRUE);
+ g_assert_cmpstr (secret_service_get_session_dbus_path (test->service), !=, NULL);
+ g_assert_cmpstr (secret_service_get_session_algorithms (test->service), ==, "plain");
+
+ g_object_unref (result);
+ result = NULL;
+
+ path = g_strdup (secret_service_get_session_dbus_path (test->service));
+ secret_service_ensure_session (test->service, NULL, on_complete_get_result, &result);
+ egg_test_wait_until (500);
+
+ g_assert (G_IS_ASYNC_RESULT (result));
+ ret = secret_service_ensure_session_finish (test->service, result, &error);
+ g_assert_no_error (error);
+
+ g_assert (ret == TRUE);
+ g_assert_cmpstr (secret_service_get_session_dbus_path (test->service), ==, path);
+ g_assert_cmpstr (secret_service_get_session_algorithms (test->service), ==, "plain");
+
+ g_object_unref (result);
+ g_free (path);
+}
+
+int
+main (int argc, char **argv)
+{
+ g_test_init (&argc, &argv, NULL);
+ g_set_prgname ("test-session");
+#if !GLIB_CHECK_VERSION(2,35,0)
+ g_type_init ();
+#endif
+
+ g_test_add ("/session/ensure-aes", Test, "mock-service-normal.py", setup, test_ensure, teardown);
+ g_test_add ("/session/ensure-twice", Test, "mock-service-normal.py", setup, test_ensure_twice, teardown);
+ g_test_add ("/session/ensure-plain", Test, "mock-service-only-plain.py", setup, test_ensure_plain, teardown);
+ g_test_add ("/session/ensure-async-aes", Test, "mock-service-normal.py", setup, test_ensure_async_aes, teardown);
+ g_test_add ("/session/ensure-async-plain", Test, "mock-service-only-plain.py", setup, test_ensure_async_plain, teardown);
+ g_test_add ("/session/ensure-async-twice", Test, "mock-service-only-plain.py", setup, test_ensure_async_twice, teardown);
+
+ return egg_tests_run_with_loop ();
+}