From f87890aacb2f346d399b176ec05444902e474a45 Mon Sep 17 00:00:00 2001 From: Daniel Wagner Date: Tue, 7 Jun 2011 15:42:22 +0200 Subject: unit: Add session connect test --- unit/test-session.c | 38 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) (limited to 'unit') diff --git a/unit/test-session.c b/unit/test-session.c index ef380162..388073fc 100644 --- a/unit/test-session.c +++ b/unit/test-session.c @@ -222,6 +222,41 @@ static void set_session_mode(struct test_fix *fix, util_idle_call(fix, util_quit_loop, NULL); } +static void test_session_connect_notify(struct test_session *session) +{ + LOG("session %p online %d", session, session->info->online); + + if (session->info->online != TRUE) + return; + + util_session_cleanup(session); + + g_assert(is_connman_running(session->connection) == TRUE); + util_idle_call(session->fix, util_quit_loop, util_session_destroy); +} + +static gboolean test_session_connect(gpointer data) +{ + struct test_fix *fix = data; + struct test_session *session; + DBusMessage *msg; + + util_session_create(fix, 1); + session = fix->session; + + session->notify_path = g_strdup("/foo"); + session->notify = test_session_connect_notify; + util_session_init(session); + + msg = session_connect(session->connection, session); + g_assert(msg != NULL); + g_assert(dbus_message_get_type(msg) != DBUS_MESSAGE_TYPE_ERROR); + + dbus_message_unref(msg); + + return FALSE; +} + static gboolean enable_session_mode(gpointer data) { struct test_fix *fix = data; @@ -273,5 +308,8 @@ int main(int argc, char *argv[]) util_test_add("/manager/session create many", test_session_create_many, setup_cb, teardown_cb); + util_test_add("/session/connect", + test_session_connect, setup_cb, teardown_cb); + return g_test_run(); } -- cgit v1.2.3