aboutsummaryrefslogtreecommitdiff
path: root/plugins/tests/test-fixture.c
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/tests/test-fixture.c')
-rw-r--r--plugins/tests/test-fixture.c163
1 files changed, 0 insertions, 163 deletions
diff --git a/plugins/tests/test-fixture.c b/plugins/tests/test-fixture.c
deleted file mode 100644
index 29eb8d55..00000000
--- a/plugins/tests/test-fixture.c
+++ /dev/null
@@ -1,163 +0,0 @@
-/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
-/*
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation; either version 2 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details:
- *
- * Copyright (C) 2013 Aleksander Morgado <aleksander@gnu.org>
- */
-
-#include "test-fixture.h"
-
-void
-test_fixture_setup (TestFixture *fixture)
-{
- GError *error = NULL;
- GVariant *result;
-
- /* Create the global dbus-daemon for this test suite */
- fixture->dbus = g_test_dbus_new (G_TEST_DBUS_NONE);
-
- /* Add the private directory with our in-tree service files,
- * TEST_SERVICES is defined by the build system to point
- * to the right directory. */
- g_test_dbus_add_service_dir (fixture->dbus, TEST_SERVICES);
-
- /* Start the private DBus daemon */
- g_test_dbus_up (fixture->dbus);
-
- /* Create DBus connection */
- fixture->connection = g_bus_get_sync (G_BUS_TYPE_SESSION, NULL, &error);
- if (fixture->connection == NULL)
- g_error ("Error getting connection to test bus: %s", error->message);
-
- /* Ping to autostart MM; wait up to 30s */
- result = g_dbus_connection_call_sync (fixture->connection,
- "org.freedesktop.ModemManager1",
- "/org/freedesktop/ModemManager1",
- "org.freedesktop.DBus.Peer",
- "Ping",
- NULL, /* inputs */
- NULL, /* outputs */
- G_DBUS_CALL_FLAGS_NONE,
- 30000, /* timeout, ms */
- NULL, /* cancellable */
- &error);
- if (!result)
- g_error ("Error starting ModemManager in test bus: %s", error->message);
- g_variant_unref (result);
-
- /* Create the proxy that we're going to test */
- fixture->test = mm_gdbus_test_proxy_new_sync (fixture->connection,
- G_DBUS_PROXY_FLAGS_NONE,
- "org.freedesktop.ModemManager1",
- "/org/freedesktop/ModemManager1",
- NULL, /* cancellable */
- &error);
- if (fixture->test == NULL)
- g_error ("Error getting ModemManager test proxy: %s", error->message);
-}
-
-void
-test_fixture_teardown (TestFixture *fixture)
-{
- g_object_unref (fixture->connection);
-
- /* Tear down the proxy */
- if (fixture->test)
- g_object_unref (fixture->test);
-
- /* Stop the private D-Bus daemon; stopping the bus will stop MM as well */
- g_test_dbus_down (fixture->dbus);
- g_object_unref (fixture->dbus);
-}
-
-void
-test_fixture_set_profile (TestFixture *fixture,
- const gchar *profile_name,
- const gchar *plugin,
- const gchar *const *ports)
-{
- GError *error = NULL;
-
- /* Set the test profile */
- g_assert (fixture->test != NULL);
- if (!mm_gdbus_test_call_set_profile_sync (fixture->test,
- profile_name,
- plugin,
- ports,
- NULL, /* cancellable */
- &error))
- g_error ("Error setting test profile: %s", error->message);
-}
-
-static MMObject *
-common_get_modem (TestFixture *fixture,
- gboolean modem_expected)
-{
- MMObject *found = NULL;
- guint wait_time = 0;
-
- /* Find new modem object */
- while (TRUE) {
- GError *error = NULL;
- MMManager *manager;
- GList *modems;
- guint n_modems;
- gboolean ready = FALSE;
-
- /* Create manager on each loop, so that we don't require on an external
- * global main context processing to receive the DBus property updates.
- */
- g_assert (fixture->connection != NULL);
- manager = mm_manager_new_sync (fixture->connection,
- G_DBUS_OBJECT_MANAGER_CLIENT_FLAGS_NONE,
- NULL, /* cancellable */
- &error);
- if (!manager)
- g_error ("Couldn't create manager: %s", error->message);
-
- modems = g_dbus_object_manager_get_objects (G_DBUS_OBJECT_MANAGER (manager));
- n_modems = g_list_length (modems);
- g_assert_cmpuint (n_modems, <=, 1);
-
- if ((guint)modem_expected == n_modems) {
- if (modems) {
- found = MM_OBJECT (g_object_ref (modems->data));
- g_message ("Found modem at '%s'", mm_object_get_path (found));
- }
- ready = TRUE;
- }
-
- g_list_free_full (modems, g_object_unref);
- g_object_unref (manager);
-
- if (ready)
- break;
-
- /* Blocking wait */
- g_assert_cmpuint (wait_time, <=, 20);
- wait_time++;
- sleep (1);
- }
-
- return found;
-}
-
-MMObject *
-test_fixture_get_modem (TestFixture *fixture)
-{
- return common_get_modem (fixture, TRUE);
-}
-
-void
-test_fixture_no_modem (TestFixture *fixture)
-{
- common_get_modem (fixture, FALSE);
-}