empathy r1540 - trunk/tests



Author: xclaesse
Date: Mon Oct 13 07:53:36 2008
New Revision: 1540
URL: http://svn.gnome.org/viewvc/empathy?rev=1540&view=rev

Log:
add EmpathyChatroom tests

Added:
   trunk/tests/check-empathy-chatroom.c
Modified:
   trunk/tests/Makefile.am
   trunk/tests/check-libempathy.h
   trunk/tests/check-main.c

Modified: trunk/tests/Makefile.am
==============================================================================
--- trunk/tests/Makefile.am	(original)
+++ trunk/tests/Makefile.am	Mon Oct 13 07:53:36 2008
@@ -37,7 +37,8 @@
     check-irc-helper.c                           \
     check-empathy-irc-server.c                   \
     check-empathy-irc-network.c                  \
-    check-empathy-irc-network-manager.c
+    check-empathy-irc-network-manager.c          \
+    check-empathy-chatroom.c
 
 check_main_LDADD = \
     @CHECK_LIBS@ \

Added: trunk/tests/check-empathy-chatroom.c
==============================================================================
--- (empty file)
+++ trunk/tests/check-empathy-chatroom.c	Mon Oct 13 07:53:36 2008
@@ -0,0 +1,128 @@
+#include <stdlib.h>
+#include <stdio.h>
+#include <string.h>
+
+#include <check.h>
+#include "check-helpers.h"
+#include "check-libempathy.h"
+
+#include <libempathy/empathy-chatroom.h>
+
+static EmpathyChatroom *
+create_chatroom (void)
+{
+  McProfile *profile;
+  McAccount *account;
+  EmpathyChatroom *chatroom;
+
+  /* FIXME: we should fake the profile */
+  profile = mc_profile_lookup ("jabber");
+  account = mc_account_create (profile);
+  chatroom = empathy_chatroom_new (account);
+  fail_if (chatroom == NULL);
+
+  g_object_unref (profile);
+
+  return chatroom;
+}
+
+START_TEST (test_empathy_chatroom_new)
+{
+  EmpathyChatroom *chatroom;
+  gboolean auto_connect, favorite;
+
+  chatroom = create_chatroom ();
+  fail_if (empathy_chatroom_get_auto_connect (chatroom));
+  g_object_get (chatroom,
+      "auto_connect", &auto_connect,
+      "favorite", &favorite,
+      NULL);
+  fail_if (auto_connect);
+  fail_if (favorite);
+
+  g_object_unref (chatroom);
+  /* FIXME: unref the account ? */
+}
+END_TEST
+
+START_TEST (test_favorite_and_auto_connect)
+{
+  /* auto connect implies favorite */
+  EmpathyChatroom *chatroom;
+  gboolean auto_connect, favorite;
+
+  chatroom = create_chatroom ();
+
+  /* set auto_connect so favorite as a side effect */
+  empathy_chatroom_set_auto_connect (chatroom, TRUE);
+  fail_if (!empathy_chatroom_get_auto_connect (chatroom));
+  g_object_get (chatroom,
+      "auto_connect", &auto_connect,
+      "favorite", &favorite,
+      NULL);
+  fail_if (!auto_connect);
+  fail_if (!favorite);
+
+  /* Remove auto_connect. Chatroom is still favorite */
+  empathy_chatroom_set_auto_connect (chatroom, FALSE);
+  fail_if (empathy_chatroom_get_auto_connect (chatroom));
+  g_object_get (chatroom,
+      "auto_connect", &auto_connect,
+      "favorite", &favorite,
+      NULL);
+  fail_if (auto_connect);
+  fail_if (!favorite);
+
+  /* Remove favorite too now */
+  g_object_set (chatroom, "favorite", FALSE, NULL);
+  fail_if (empathy_chatroom_get_auto_connect (chatroom));
+  g_object_get (chatroom,
+      "auto_connect", &auto_connect,
+      "favorite", &favorite,
+      NULL);
+  fail_if (auto_connect);
+  fail_if (favorite);
+
+  /* Just add favorite but not auto-connect */
+  g_object_set (chatroom, "favorite", TRUE, NULL);
+  fail_if (empathy_chatroom_get_auto_connect (chatroom));
+  g_object_get (chatroom,
+      "auto_connect", &auto_connect,
+      "favorite", &favorite,
+      NULL);
+  fail_if (auto_connect);
+  fail_if (!favorite);
+
+  /* ... and re-add auto_connect */
+  g_object_set (chatroom, "auto_connect", TRUE, NULL);
+  fail_if (!empathy_chatroom_get_auto_connect (chatroom));
+  g_object_get (chatroom,
+      "auto_connect", &auto_connect,
+      "favorite", &favorite,
+      NULL);
+  fail_if (!auto_connect);
+  fail_if (!favorite);
+
+  /* Remove favorite remove auto_connect too */
+  g_object_set (chatroom, "favorite", FALSE, NULL);
+  fail_if (empathy_chatroom_get_auto_connect (chatroom));
+  g_object_get (chatroom,
+      "auto_connect", &auto_connect,
+      "favorite", &favorite,
+      NULL);
+  fail_if (auto_connect);
+  fail_if (favorite);
+
+  g_object_unref (chatroom);
+  /* FIXME: unref the account ? */
+}
+END_TEST
+
+TCase *
+make_empathy_chatroom_tcase (void)
+{
+    TCase *tc = tcase_create ("empathy-chatroom");
+    tcase_add_test (tc, test_empathy_chatroom_new);
+    tcase_add_test (tc, test_favorite_and_auto_connect);
+    return tc;
+}

Modified: trunk/tests/check-libempathy.h
==============================================================================
--- trunk/tests/check-libempathy.h	(original)
+++ trunk/tests/check-libempathy.h	Mon Oct 13 07:53:36 2008
@@ -5,5 +5,6 @@
 TCase * make_empathy_irc_server_tcase (void);
 TCase * make_empathy_irc_network_tcase (void);
 TCase * make_empathy_irc_network_manager_tcase (void);
+TCase * make_empathy_chatroom_tcase (void);
 
 #endif /* #ifndef __CHECK_LIBEMPATHY__ */

Modified: trunk/tests/check-main.c
==============================================================================
--- trunk/tests/check-main.c	(original)
+++ trunk/tests/check-main.c	Mon Oct 13 07:53:36 2008
@@ -19,6 +19,7 @@
     suite_add_tcase (s, make_empathy_irc_server_tcase ());
     suite_add_tcase (s, make_empathy_irc_network_tcase ());
     suite_add_tcase (s, make_empathy_irc_network_manager_tcase ());
+    suite_add_tcase (s, make_empathy_chatroom_tcase ());
 
     return s;
 }



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]