diff options
Diffstat (limited to 'tests/check-empathy-chatroom-manager.c')
-rw-r--r-- | tests/check-empathy-chatroom-manager.c | 385 |
1 files changed, 0 insertions, 385 deletions
diff --git a/tests/check-empathy-chatroom-manager.c b/tests/check-empathy-chatroom-manager.c deleted file mode 100644 index ef5c77618..000000000 --- a/tests/check-empathy-chatroom-manager.c +++ /dev/null @@ -1,385 +0,0 @@ -#include <stdlib.h> -#include <stdio.h> -#include <string.h> -#include <glib/gstdio.h> - -#include <gconf/gconf.h> -#include <gconf/gconf-client.h> -#include <telepathy-glib/util.h> -#include <check.h> - -#include "check-helpers.h" -#include "check-libempathy.h" -#include "check-empathy-helpers.h" - -#include <libempathy/empathy-chatroom-manager.h> - -#define CHATROOM_SAMPLE "chatrooms-sample.xml" -#define CHATROOM_FILE "chatrooms.xml" - -static void -check_chatroom (EmpathyChatroom *chatroom, - const gchar *name, - const gchar *room, - gboolean auto_connect, - gboolean favorite) -{ - gboolean _favorite; - - fail_if (tp_strdiff (empathy_chatroom_get_name (chatroom), name)); - fail_if (tp_strdiff (empathy_chatroom_get_room (chatroom), room)); - fail_if (empathy_chatroom_get_auto_connect (chatroom) != auto_connect); - g_object_get (chatroom, "favorite", &_favorite, NULL); - fail_if (favorite != _favorite); -} - -struct chatroom_t -{ - gchar *name; - gchar *room; - gboolean auto_connect; - gboolean favorite; -}; - -static void -check_chatrooms_list (EmpathyChatroomManager *mgr, - McAccount *account, - struct chatroom_t *_chatrooms, - guint nb_chatrooms) -{ - GList *chatrooms, *l; - guint i; - GHashTable *found; - - fail_if (empathy_chatroom_manager_get_count (mgr, account) != nb_chatrooms); - - found = g_hash_table_new (g_str_hash, g_str_equal); - for (i = 0; i < nb_chatrooms; i++) - { - g_hash_table_insert (found, _chatrooms[i].room, &_chatrooms[i]); - } - - chatrooms = empathy_chatroom_manager_get_chatrooms (mgr, account); - fail_if (g_list_length (chatrooms) != nb_chatrooms); - - for (l = chatrooms; l != NULL; l = g_list_next (l)) - { - EmpathyChatroom *chatroom = l->data; - struct chatroom_t *tmp; - - tmp = g_hash_table_lookup (found, empathy_chatroom_get_room (chatroom)); - fail_if (tmp == NULL); - - check_chatroom (chatroom, tmp->name, tmp->room, tmp->auto_connect, - tmp->favorite); - - g_hash_table_remove (found, empathy_chatroom_get_room (chatroom)); - } - - fail_if (g_hash_table_size (found) != 0); - - g_list_free (chatrooms); - g_hash_table_destroy (found); -} - -static gboolean -change_account_name_in_file (McAccount *account, - const gchar *file) -{ - gchar *cmd; - - cmd = g_strdup_printf ("sed -i 's/CHANGE_ME/%s/' %s", - mc_account_get_unique_name (account), file); - - if (system (cmd) == -1) - { - g_print ("'%s' call failed\n", cmd); - g_free (cmd); - return FALSE; - } - - g_free (cmd); - return TRUE; -} - -START_TEST (test_empathy_chatroom_manager_dup_singleton) -{ - EmpathyChatroomManager *mgr; - gchar *file; - McAccount *account; - struct chatroom_t chatrooms[] = { - { "name1", "room1", TRUE, TRUE }, - { "name2", "room2", FALSE, TRUE }}; - - account = get_test_account (); - - copy_xml_file (CHATROOM_SAMPLE, CHATROOM_FILE); - - file = get_user_xml_file (CHATROOM_FILE); - - /* change the chatrooms XML file to use the account we just created */ - if (!change_account_name_in_file (account, file)) - return; - - mgr = empathy_chatroom_manager_dup_singleton (file); - check_chatrooms_list (mgr, account, chatrooms, 2); - - g_free (file); - g_object_unref (mgr); - g_object_unref (account); -} -END_TEST - -START_TEST (test_empathy_chatroom_manager_add) -{ - EmpathyChatroomManager *mgr; - gchar *file; - McAccount *account; - struct chatroom_t chatrooms[] = { - { "name1", "room1", TRUE, TRUE }, - { "name2", "room2", FALSE, TRUE }, - { "name3", "room3", FALSE, TRUE }, - { "name4", "room4", FALSE, FALSE }}; - EmpathyChatroom *chatroom; - - account = get_test_account (); - - copy_xml_file (CHATROOM_SAMPLE, CHATROOM_FILE); - - file = get_user_xml_file (CHATROOM_FILE); - - /* change the chatrooms XML file to use the account we just created */ - if (!change_account_name_in_file (account, file)) - return; - - mgr = empathy_chatroom_manager_dup_singleton (file); - - /* add a favorite chatroom */ - chatroom = empathy_chatroom_new_full (account, "room3", "name3", FALSE); - g_object_set (chatroom, "favorite", TRUE, NULL); - empathy_chatroom_manager_add (mgr, chatroom); - g_object_unref (chatroom); - - check_chatrooms_list (mgr, account, chatrooms, 3); - - /* reload chatrooms file */ - g_object_unref (mgr); - mgr = empathy_chatroom_manager_dup_singleton (file); - - /* chatroom has been added to the XML file as it's a favorite */ - check_chatrooms_list (mgr, account, chatrooms, 3); - - /* add a non favorite chatroom */ - chatroom = empathy_chatroom_new_full (account, "room4", "name4", FALSE); - g_object_set (chatroom, "favorite", FALSE, NULL); - empathy_chatroom_manager_add (mgr, chatroom); - g_object_unref (chatroom); - - check_chatrooms_list (mgr, account, chatrooms, 4); - - /* reload chatrooms file */ - g_object_unref (mgr); - mgr = empathy_chatroom_manager_dup_singleton (file); - - /* chatrooms has not been added to the XML file */ - check_chatrooms_list (mgr, account, chatrooms, 3); - - g_object_unref (mgr); - g_free (file); - g_object_unref (account); -} -END_TEST - -START_TEST (test_empathy_chatroom_manager_remove) -{ - EmpathyChatroomManager *mgr; - gchar *file; - McAccount *account; - struct chatroom_t chatrooms[] = { - { "name2", "room2", FALSE, TRUE }}; - EmpathyChatroom *chatroom; - - account = get_test_account (); - - copy_xml_file (CHATROOM_SAMPLE, CHATROOM_FILE); - - file = get_user_xml_file (CHATROOM_FILE); - - /* change the chatrooms XML file to use the account we just created */ - if (!change_account_name_in_file (account, file)) - return; - - mgr = empathy_chatroom_manager_dup_singleton (file); - - /* remove room1 */ - chatroom = empathy_chatroom_manager_find (mgr, account, "room1"); - fail_if (chatroom == NULL); - empathy_chatroom_manager_remove (mgr, chatroom); - - check_chatrooms_list (mgr, account, chatrooms, 1); - - /* reload chatrooms file */ - g_object_unref (mgr); - mgr = empathy_chatroom_manager_dup_singleton (file); - - check_chatrooms_list (mgr, account, chatrooms, 1); - - /* remove room1 */ - chatroom = empathy_chatroom_manager_find (mgr, account, "room2"); - fail_if (chatroom == NULL); - - empathy_chatroom_manager_remove (mgr, chatroom); - - check_chatrooms_list (mgr, account, chatrooms, 0); - - /* reload chatrooms file */ - g_object_unref (mgr); - mgr = empathy_chatroom_manager_dup_singleton (file); - - check_chatrooms_list (mgr, account, chatrooms, 0); - - g_object_unref (mgr); - g_free (file); - g_object_unref (account); -} -END_TEST - -START_TEST (test_empathy_chatroom_manager_change_favorite) -{ - EmpathyChatroomManager *mgr; - gchar *file; - McAccount *account; - struct chatroom_t chatrooms[] = { - { "name1", "room1", TRUE, TRUE }, - { "name2", "room2", FALSE, FALSE }}; - EmpathyChatroom *chatroom; - - account = get_test_account (); - - copy_xml_file (CHATROOM_SAMPLE, CHATROOM_FILE); - - file = get_user_xml_file (CHATROOM_FILE); - - /* change the chatrooms XML file to use the account we just created */ - if (!change_account_name_in_file (account, file)) - return; - - mgr = empathy_chatroom_manager_dup_singleton (file); - - /* room2 is not favorite anymore */ - chatroom = empathy_chatroom_manager_find (mgr, account, "room2"); - fail_if (chatroom == NULL); - g_object_set (chatroom, "favorite", FALSE, NULL); - - check_chatrooms_list (mgr, account, chatrooms, 2); - - /* reload chatrooms file */ - g_object_unref (mgr); - mgr = empathy_chatroom_manager_dup_singleton (file); - - /* room2 is not present in the XML file anymore as it's not a favorite */ - check_chatrooms_list (mgr, account, chatrooms, 1); - - /* re-add room2 */ - chatroom = empathy_chatroom_new_full (account, "room2", "name2", FALSE); - empathy_chatroom_manager_add (mgr, chatroom); - - check_chatrooms_list (mgr, account, chatrooms, 2); - - /* set room2 as favorite */ - g_object_set (chatroom, "favorite", TRUE, NULL); - - chatrooms[1].favorite = TRUE; - check_chatrooms_list (mgr, account, chatrooms, 2); - - /* reload chatrooms file */ - g_object_unref (mgr); - mgr = empathy_chatroom_manager_dup_singleton (file); - - /* room2 is back in the XML file now */ - check_chatrooms_list (mgr, account, chatrooms, 2); - - g_object_unref (mgr); - g_object_unref (chatroom); - g_free (file); - g_object_unref (account); -} -END_TEST - -START_TEST (test_empathy_chatroom_manager_change_chatroom) -{ - EmpathyChatroomManager *mgr; - gchar *file; - McAccount *account; - struct chatroom_t chatrooms[] = { - { "name1", "room1", TRUE, TRUE }, - { "name2", "room2", FALSE, TRUE }}; - EmpathyChatroom *chatroom; - - account = get_test_account (); - - copy_xml_file (CHATROOM_SAMPLE, "foo.xml"); - - file = get_user_xml_file ("foo.xml"); - - /* change the chatrooms XML file to use the account we just created */ - if (!change_account_name_in_file (account, file)) - return; - - mgr = empathy_chatroom_manager_dup_singleton (file); - - check_chatrooms_list (mgr, account, chatrooms, 2); - - /* change room2 name */ - chatroom = empathy_chatroom_manager_find (mgr, account, "room2"); - fail_if (chatroom == NULL); - empathy_chatroom_set_name (chatroom, "new_name"); - - /* reload chatrooms file */ - g_object_unref (mgr); - mgr = empathy_chatroom_manager_dup_singleton (file); - - chatrooms[1].name = "new_name"; - check_chatrooms_list (mgr, account, chatrooms, 2); - - /* change room2 auto-connect status */ - chatroom = empathy_chatroom_manager_find (mgr, account, "room2"); - fail_if (chatroom == NULL); - empathy_chatroom_set_auto_connect (chatroom, TRUE); - - /* reload chatrooms file */ - g_object_unref (mgr); - mgr = empathy_chatroom_manager_dup_singleton (file); - - chatrooms[1].auto_connect = TRUE; - check_chatrooms_list (mgr, account, chatrooms, 2); - - /* change room2 room */ - chatroom = empathy_chatroom_manager_find (mgr, account, "room2"); - fail_if (chatroom == NULL); - empathy_chatroom_set_room (chatroom, "new_room"); - - /* reload chatrooms file */ - g_object_unref (mgr); - mgr = empathy_chatroom_manager_dup_singleton (file); - - chatrooms[1].room = "new_room"; - check_chatrooms_list (mgr, account, chatrooms, 2); - - g_object_unref (mgr); - g_free (file); - g_object_unref (account); -} -END_TEST - -TCase * -make_empathy_chatroom_manager_tcase (void) -{ - TCase *tc = tcase_create ("empathy-chatroom-manager"); - tcase_add_test (tc, test_empathy_chatroom_manager_dup_singleton); - tcase_add_test (tc, test_empathy_chatroom_manager_add); - tcase_add_test (tc, test_empathy_chatroom_manager_remove); - tcase_add_test (tc, test_empathy_chatroom_manager_change_favorite); - tcase_add_test (tc, test_empathy_chatroom_manager_change_chatroom); - return tc; -} |