From 2dc1503c797891fffd8aa816d3876cf43ff9ae47 Mon Sep 17 00:00:00 2001
From: Xavier Claessens <xclaesse@src.gnome.org>
Date: Tue, 11 Mar 2008 12:22:43 +0000
Subject: Add a test for empathy_contact_run_until_ready

svn path=/trunk/; revision=758
---
 tests/Makefile.am               |  4 +++-
 tests/contact-run-until-ready.c | 45 +++++++++++++++++++++++++++++++++++++++++
 2 files changed, 48 insertions(+), 1 deletion(-)
 create mode 100644 tests/contact-run-until-ready.c

diff --git a/tests/Makefile.am b/tests/Makefile.am
index e7b162797..7d32dab61 100644
--- a/tests/Makefile.am
+++ b/tests/Makefile.am
@@ -17,9 +17,11 @@ LDADD =								\
 	$(EMPATHY_LIBS)
 
 noinst_PROGRAMS =			\
-	contact-manager
+	contact-manager			\
+	contact-run-until-ready
 
 contact_manager_SOURCES = contact-manager.c
+contact_run_until_ready_SOURCES = contact-run-until-ready.c
 
 check_PROGRAMS = check-main
 TESTS = check-main
diff --git a/tests/contact-run-until-ready.c b/tests/contact-run-until-ready.c
new file mode 100644
index 000000000..8f6dfc67b
--- /dev/null
+++ b/tests/contact-run-until-ready.c
@@ -0,0 +1,45 @@
+#include <stdlib.h>
+
+#include <glib.h>
+#include <libempathy/empathy-contact-factory.h>
+#include <libmissincontrol/mc-account.h>
+
+static gboolean
+time_out (gpointer main_loop)
+{
+	g_main_loop_quit (main_loop);
+
+	return FALSE;
+}
+
+int
+main (int argc, char **argv)
+{
+	EmpathyContactFactory *factory;
+	GMainLoop             *main_loop;
+	McAccount             *account;
+	EmpathyContact        *contact;
+
+	g_type_init ();
+
+	main_loop = g_main_loop_new (NULL, FALSE);
+	factory = empathy_contact_factory_new ();
+	account = mc_account_lookup ("jabber4");
+	g_print ("Got account %p\n", account);
+
+	contact = empathy_contact_factory_get_from_id ("testman@jabber.belnet.be");
+	g_print ("Got contact with handle %d\n", emapthy_contact_get_handle (contact));
+
+	empathy_contact_run_until_ready (contact, EMPATHY_CONTACT_READY_HANDLE);
+	g_print ("Contact handle is now %d\n", emapthy_contact_get_handle (contact));
+
+	g_timeout_add_seconds (5, time_out, main_loop);
+
+	g_main_loop_run (main_loop);
+
+	g_object_unref (manager);
+	g_main_loop_unref (main_loop);
+
+	return EXIT_SUCCESS;
+}
+
-- 
cgit v1.2.3