From 3487100c0f7ede4885d5c178faf3c3df5902efb8 Mon Sep 17 00:00:00 2001 From: James Booth Date: Wed, 24 Dec 2014 20:41:28 +0000 Subject: [PATCH] Added cmd_bookmark tests --- Makefile.am | 1 + tests/test_cmd_bookmark.c | 125 +++++++++++++++++++++++--------------- tests/testsuite.c | 3 +- tests/ui/stub_ui.c | 10 ++- tests/xmpp/stub_xmpp.c | 11 +++- 5 files changed, 95 insertions(+), 55 deletions(-) diff --git a/Makefile.am b/Makefile.am index 0f20b582..a8b7de1f 100644 --- a/Makefile.am +++ b/Makefile.am @@ -68,6 +68,7 @@ tests_sources = \ tests/helpers.c tests/helpers.h \ tests/test_cmd_account.c tests/test_cmd_account.h \ tests/test_cmd_alias.c tests/test_cmd_alias.h \ + tests/test_cmd_bookmark.c tests/test_cmd_bookmark.h \ tests/test_autocomplete.c tests/test_autocomplete.h \ tests/testsuite.c diff --git a/tests/test_cmd_bookmark.c b/tests/test_cmd_bookmark.c index 7e0e9d0c..695e7362 100644 --- a/tests/test_cmd_bookmark.c +++ b/tests/test_cmd_bookmark.c @@ -6,10 +6,10 @@ #include #include -#include "ui/mock_ui.h" -#include "ui/window.h" #include "xmpp/xmpp.h" -#include "xmpp/mock_xmpp.h" + +#include "ui/ui.h" +#include "ui/stub_ui.h" #include "muc.h" #include "common.h" @@ -18,12 +18,13 @@ #include "xmpp/bookmark.h" +#include "helpers.h" + static void test_with_connection_status(jabber_conn_status_t status) { - mock_cons_show(); CommandHelp *help = malloc(sizeof(CommandHelp)); - mock_connection_status(status); + will_return(jabber_get_connection_status, status); expect_cons_show("You are not currently connected."); gboolean result = cmd_bookmark(NULL, *help); @@ -59,13 +60,13 @@ void cmd_bookmark_shows_message_when_undefined(void **state) void cmd_bookmark_shows_usage_when_no_args(void **state) { - mock_cons_show(); - mock_current_win_type(WIN_CONSOLE); CommandHelp *help = malloc(sizeof(CommandHelp)); help->usage = "some usage"; gchar *args[] = { NULL }; - mock_connection_status(JABBER_CONNECTED); + will_return(jabber_get_connection_status, JABBER_CONNECTED); + will_return(ui_current_win_type, WIN_CONSOLE); + expect_cons_show("Usage: some usage"); gboolean result = cmd_bookmark(args, *help); @@ -81,10 +82,24 @@ static void _free_bookmark(Bookmark *bookmark) free(bookmark); } +static gboolean +_cmp_bookmark(Bookmark *bm1, Bookmark *bm2) +{ + if (strcmp(bm1->jid, bm2->jid) != 0) { + return FALSE; + } + if (strcmp(bm1->nick, bm2->nick) != 0) { + return FALSE; + } + if (bm1->autojoin != bm2->autojoin) { + return FALSE; + } + + return TRUE; +} + void cmd_bookmark_list_shows_bookmarks(void **state) { - mock_cons_show_bookmarks(); - mock_current_win_type(WIN_CONSOLE); CommandHelp *help = malloc(sizeof(CommandHelp)); gchar *args[] = { "list", NULL }; GList *bookmarks = NULL; @@ -116,10 +131,13 @@ void cmd_bookmark_list_shows_bookmarks(void **state) bookmarks = g_list_append(bookmarks, bm4); bookmarks = g_list_append(bookmarks, bm5); - mock_connection_status(JABBER_CONNECTED); + will_return(jabber_get_connection_status, JABBER_CONNECTED); + will_return(ui_current_win_type, WIN_CONSOLE); + will_return(bookmark_get_list, bookmarks); - bookmark_get_list_returns(bookmarks); - expect_cons_show_bookmarks(bookmarks); + // TODO - Custom list compare + glist_set_cmp((GCompareFunc)_cmp_bookmark); + expect_any(cons_show_bookmarks, list); gboolean result = cmd_bookmark(args, *help); assert_true(result); @@ -130,14 +148,12 @@ void cmd_bookmark_list_shows_bookmarks(void **state) void cmd_bookmark_add_shows_message_when_invalid_jid(void **state) { - mock_bookmark_add(); - mock_cons_show(); - mock_current_win_type(WIN_CONSOLE); char *jid = "room"; CommandHelp *help = malloc(sizeof(CommandHelp)); gchar *args[] = { "add", jid, NULL }; - mock_connection_status(JABBER_CONNECTED); + will_return(jabber_get_connection_status, JABBER_CONNECTED); + will_return(ui_current_win_type, WIN_CONSOLE); expect_cons_show("Can't add bookmark with JID 'room'; should be 'room@domain.tld'"); @@ -149,16 +165,19 @@ void cmd_bookmark_add_shows_message_when_invalid_jid(void **state) void cmd_bookmark_add_adds_bookmark_with_jid(void **state) { - mock_bookmark_add(); - mock_cons_show(); - mock_current_win_type(WIN_CONSOLE); char *jid = "room@conf.server"; CommandHelp *help = malloc(sizeof(CommandHelp)); gchar *args[] = { "add", jid, NULL }; - mock_connection_status(JABBER_CONNECTED); + will_return(jabber_get_connection_status, JABBER_CONNECTED); + will_return(ui_current_win_type, WIN_CONSOLE); + + expect_string(bookmark_add, jid, jid); + expect_any(bookmark_add, nick); + expect_any(bookmark_add, password); + expect_any(bookmark_add, autojoin_str); + will_return(bookmark_add, TRUE); - expect_and_return_bookmark_add(jid, NULL, NULL, NULL, TRUE); expect_cons_show("Bookmark added for room@conf.server."); gboolean result = cmd_bookmark(args, *help); @@ -168,18 +187,20 @@ void cmd_bookmark_add_adds_bookmark_with_jid(void **state) } void cmd_bookmark_add_adds_bookmark_with_jid_nick(void **state) -{ - mock_bookmark_add(); - mock_cons_show(); - mock_current_win_type(WIN_CONSOLE); - char *jid = "room@conf.server"; +{ char *jid = "room@conf.server"; char *nick = "bob"; CommandHelp *help = malloc(sizeof(CommandHelp)); gchar *args[] = { "add", jid, "nick", nick, NULL }; - mock_connection_status(JABBER_CONNECTED); + will_return(jabber_get_connection_status, JABBER_CONNECTED); + will_return(ui_current_win_type, WIN_CONSOLE); + + expect_string(bookmark_add, jid, jid); + expect_string(bookmark_add, nick, nick); + expect_any(bookmark_add, password); + expect_any(bookmark_add, autojoin_str); + will_return(bookmark_add, TRUE); - expect_and_return_bookmark_add(jid, nick, NULL, NULL, TRUE); expect_cons_show("Bookmark added for room@conf.server."); gboolean result = cmd_bookmark(args, *help); @@ -190,16 +211,19 @@ void cmd_bookmark_add_adds_bookmark_with_jid_nick(void **state) void cmd_bookmark_add_adds_bookmark_with_jid_autojoin(void **state) { - mock_bookmark_add(); - mock_cons_show(); - mock_current_win_type(WIN_CONSOLE); char *jid = "room@conf.server"; CommandHelp *help = malloc(sizeof(CommandHelp)); gchar *args[] = { "add", jid, "autojoin", "on", NULL }; - mock_connection_status(JABBER_CONNECTED); + will_return(jabber_get_connection_status, JABBER_CONNECTED); + will_return(ui_current_win_type, WIN_CONSOLE); + + expect_string(bookmark_add, jid, jid); + expect_any(bookmark_add, nick); + expect_any(bookmark_add, password); + expect_string(bookmark_add, autojoin_str, "on"); + will_return(bookmark_add, TRUE); - expect_and_return_bookmark_add(jid, NULL, NULL, "on", TRUE); expect_cons_show("Bookmark added for room@conf.server."); gboolean result = cmd_bookmark(args, *help); @@ -210,17 +234,20 @@ void cmd_bookmark_add_adds_bookmark_with_jid_autojoin(void **state) void cmd_bookmark_add_adds_bookmark_with_jid_nick_autojoin(void **state) { - mock_bookmark_add(); - mock_cons_show(); - mock_current_win_type(WIN_CONSOLE); char *jid = "room@conf.server"; char *nick = "bob"; CommandHelp *help = malloc(sizeof(CommandHelp)); gchar *args[] = { "add", jid, "nick", nick, "autojoin", "on", NULL }; - mock_connection_status(JABBER_CONNECTED); + will_return(jabber_get_connection_status, JABBER_CONNECTED); + will_return(ui_current_win_type, WIN_CONSOLE); + + expect_string(bookmark_add, jid, jid); + expect_string(bookmark_add, nick, nick); + expect_any(bookmark_add, password); + expect_string(bookmark_add, autojoin_str, "on"); + will_return(bookmark_add, TRUE); - expect_and_return_bookmark_add(jid, nick, NULL, "on", TRUE); expect_cons_show("Bookmark added for room@conf.server."); gboolean result = cmd_bookmark(args, *help); @@ -231,16 +258,16 @@ void cmd_bookmark_add_adds_bookmark_with_jid_nick_autojoin(void **state) void cmd_bookmark_remove_removes_bookmark(void **state) { - mock_bookmark_remove(); - mock_cons_show(); - mock_current_win_type(WIN_CONSOLE); char *jid = "room@conf.server"; CommandHelp *help = malloc(sizeof(CommandHelp)); gchar *args[] = { "remove", jid, NULL }; - mock_connection_status(JABBER_CONNECTED); + will_return(jabber_get_connection_status, JABBER_CONNECTED); + will_return(ui_current_win_type, WIN_CONSOLE); + + expect_string(bookmark_remove, jid, jid); + will_return(bookmark_remove, TRUE); - expect_and_return_bookmark_remove(jid, TRUE); expect_cons_show("Bookmark removed for room@conf.server."); gboolean result = cmd_bookmark(args, *help); @@ -251,16 +278,16 @@ void cmd_bookmark_remove_removes_bookmark(void **state) void cmd_bookmark_remove_shows_message_when_no_bookmark(void **state) { - mock_bookmark_remove(); - mock_cons_show(); - mock_current_win_type(WIN_CONSOLE); char *jid = "room@conf.server"; CommandHelp *help = malloc(sizeof(CommandHelp)); gchar *args[] = { "remove", jid, NULL }; - mock_connection_status(JABBER_CONNECTED); + will_return(jabber_get_connection_status, JABBER_CONNECTED); + will_return(ui_current_win_type, WIN_CONSOLE); + + expect_any(bookmark_remove, jid); + will_return(bookmark_remove, FALSE); - expect_and_return_bookmark_remove(jid, FALSE); expect_cons_show("No bookmark exists for room@conf.server."); gboolean result = cmd_bookmark(args, *help); diff --git a/tests/testsuite.c b/tests/testsuite.c index 40910be6..aecc3524 100644 --- a/tests/testsuite.c +++ b/tests/testsuite.c @@ -417,7 +417,7 @@ int main(int argc, char* argv[]) { unit_test_setup_teardown(test_muc_invites_count_5, muc_before_test, muc_after_test), unit_test_setup_teardown(test_muc_room_is_not_active, muc_before_test, muc_after_test), unit_test_setup_teardown(test_muc_active, muc_before_test, muc_after_test), - +*/ unit_test(cmd_bookmark_shows_message_when_disconnected), unit_test(cmd_bookmark_shows_message_when_disconnecting), unit_test(cmd_bookmark_shows_message_when_connecting), @@ -432,6 +432,7 @@ int main(int argc, char* argv[]) { unit_test(cmd_bookmark_add_adds_bookmark_with_jid_nick_autojoin), unit_test(cmd_bookmark_remove_removes_bookmark), unit_test(cmd_bookmark_remove_shows_message_when_no_bookmark), +/* #ifdef HAVE_LIBOTR unit_test(cmd_otr_shows_usage_when_no_args), diff --git a/tests/ui/stub_ui.c b/tests/ui/stub_ui.c index dee743e3..7115d2c3 100644 --- a/tests/ui/stub_ui.c +++ b/tests/ui/stub_ui.c @@ -86,9 +86,10 @@ int ui_close_read_wins(void) // current window actions void ui_clear_current(void) {} + win_type_t ui_current_win_type(void) { - return WIN_CONSOLE; + return (win_type_t)mock(); } int ui_current_win_index(void) @@ -330,7 +331,12 @@ void cons_show_account_list(gchar **accounts) } void cons_show_room_list(GSList *room, const char * const conference_node) {} -void cons_show_bookmarks(const GList *list) {} + +void cons_show_bookmarks(const GList *list) +{ + check_expected(list); +} + void cons_show_disco_items(GSList *items, const char * const jid) {} void cons_show_disco_info(const char *from, GSList *identities, GSList *features) {} void cons_show_room_invite(const char * const invitor, const char * const room, diff --git a/tests/xmpp/stub_xmpp.c b/tests/xmpp/stub_xmpp.c index 05d24ff4..cbcc2353 100644 --- a/tests/xmpp/stub_xmpp.c +++ b/tests/xmpp/stub_xmpp.c @@ -140,7 +140,11 @@ void caps_destroy(Capabilities *caps) {} gboolean bookmark_add(const char *jid, const char *nick, const char *password, const char *autojoin_str) { - return FALSE; + check_expected(jid); + check_expected(nick); + check_expected(password); + check_expected(autojoin_str); + return (gboolean)mock(); } gboolean bookmark_update(const char *jid, const char *nick, const char *password, const char *autojoin_str) @@ -150,7 +154,8 @@ gboolean bookmark_update(const char *jid, const char *nick, const char *password gboolean bookmark_remove(const char *jid) { - return FALSE; + check_expected(jid); + return (gboolean)mock(); } gboolean bookmark_join(const char *jid) @@ -160,7 +165,7 @@ gboolean bookmark_join(const char *jid) const GList * bookmark_get_list(void) { - return NULL; + return (GList *)mock(); } char * bookmark_find(char *search_str)