about summary refs log tree commit diff stats
path: root/tests
diff options
context:
space:
mode:
authorJames Booth <boothj5@gmail.com>2014-12-24 20:41:28 +0000
committerJames Booth <boothj5@gmail.com>2014-12-24 20:41:28 +0000
commit3487100c0f7ede4885d5c178faf3c3df5902efb8 (patch)
treef125c82082eb4755cfb4ed0d08bfbb75890625e6 /tests
parent8b4c7e93b868366ca76cc630d39b71c28f1c0c9a (diff)
downloadprofani-tty-3487100c0f7ede4885d5c178faf3c3df5902efb8.tar.gz
Added cmd_bookmark tests
Diffstat (limited to 'tests')
-rw-r--r--tests/test_cmd_bookmark.c125
-rw-r--r--tests/testsuite.c3
-rw-r--r--tests/ui/stub_ui.c10
-rw-r--r--tests/xmpp/stub_xmpp.c11
4 files changed, 94 insertions, 55 deletions
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 <string.h>
 #include <glib.h>
 
-#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)