about summary refs log tree commit diff stats
path: root/tests
diff options
context:
space:
mode:
authorJames Booth <boothj5@gmail.com>2014-01-19 16:17:34 +0000
committerJames Booth <boothj5@gmail.com>2014-01-19 16:17:34 +0000
commit79e9ab83b02ca8bd1c4ad77b59eb536fa7f081a8 (patch)
treeade0c519927789d8a77730ae22a760ea8c399035 /tests
parenta9a860cb1321415276c790cac0b58720d77c53e7 (diff)
downloadprofani-tty-79e9ab83b02ca8bd1c4ad77b59eb536fa7f081a8.tar.gz
Changed /statuses preferences
Diffstat (limited to 'tests')
-rw-r--r--tests/test_cmd_statuses.c217
-rw-r--r--tests/test_cmd_statuses.h11
-rw-r--r--tests/testsuite.c24
3 files changed, 252 insertions, 0 deletions
diff --git a/tests/test_cmd_statuses.c b/tests/test_cmd_statuses.c
index 1cc7a277..d3797d9c 100644
--- a/tests/test_cmd_statuses.c
+++ b/tests/test_cmd_statuses.c
@@ -1,3 +1,7 @@
+#define _XOPEN_SOURCE 600
+#include <stdio.h>
+#include <ftw.h>
+#include <unistd.h>
 #include <stdarg.h>
 #include <stddef.h>
 #include <setjmp.h>
@@ -6,11 +10,49 @@
 #include <string.h>
 #include <glib.h>
 
+#include "config/preferences.h"
+
 #include "ui/ui.h"
 #include "ui/mock_ui.h"
 
 #include "command/commands.h"
 
+static int unlink_cb(const char *fpath, const struct stat *sb, int typeflag, struct FTW *ftwbuf)
+{
+    int rv = remove(fpath);
+
+    if (rv)
+        perror(fpath);
+
+    return rv;
+}
+
+static int rmrf(char *path)
+{
+    return nftw(path, unlink_cb, 64, FTW_DEPTH | FTW_PHYS);
+}
+
+void create_config_dir(void **state)
+{
+    setenv("XDG_CONFIG_HOME", "./tests/files/xdg_config_home", 1);
+    gchar *xdg_config = xdg_get_config_home();
+
+    GString *profanity_dir = g_string_new(xdg_config);
+    g_string_append(profanity_dir, "/profanity");
+
+    if (!mkdir_recursive(profanity_dir->str)) {
+        assert_true(FALSE);
+    }
+    g_string_free(profanity_dir, TRUE);
+
+    g_free(xdg_config);
+}
+
+void delete_config_dir(void **state)
+{
+   rmrf("./tests/files");
+}
+
 void cmd_statuses_shows_usage_when_bad_subcmd(void **state)
 {
     mock_cons_show();
@@ -70,3 +112,178 @@ void cmd_statuses_shows_usage_when_bad_muc_setting(void **state)
 
     free(help);
 }
+
+void cmd_statuses_console_sets_all(void **state)
+{
+    mock_cons_show();
+    CommandHelp *help = malloc(sizeof(CommandHelp));
+    gchar *args[] = { "console", "all", NULL };
+
+    expect_cons_show("All presence updates will appear in the console.");
+
+    prefs_load();
+    gboolean result = cmd_statuses(args, *help);
+    prefs_close();
+    prefs_load();
+
+    char *setting = prefs_get_string(PREF_STATUSES_CONSOLE);
+    assert_non_null(setting);
+    assert_string_equal("all", setting);
+    assert_true(result);
+
+    prefs_close();
+    free(help);
+}
+
+void cmd_statuses_console_sets_online(void **state)
+{
+    mock_cons_show();
+    CommandHelp *help = malloc(sizeof(CommandHelp));
+    gchar *args[] = { "console", "online", NULL };
+
+    expect_cons_show("Only online/offline presence updates will appear in the console.");
+
+    prefs_load();
+    gboolean result = cmd_statuses(args, *help);
+    prefs_close();
+    prefs_load();
+
+    char *setting = prefs_get_string(PREF_STATUSES_CONSOLE);
+    assert_non_null(setting);
+    assert_string_equal("online", setting);
+    assert_true(result);
+
+    prefs_close();
+    free(help);
+}
+
+void cmd_statuses_console_sets_none(void **state)
+{
+    mock_cons_show();
+    CommandHelp *help = malloc(sizeof(CommandHelp));
+    gchar *args[] = { "console", "none", NULL };
+
+    expect_cons_show("Presence updates will not appear in the console.");
+
+    prefs_load();
+    gboolean result = cmd_statuses(args, *help);
+    prefs_close();
+    prefs_load();
+
+    char *setting = prefs_get_string(PREF_STATUSES_CONSOLE);
+    assert_non_null(setting);
+    assert_string_equal("none", setting);
+    assert_true(result);
+
+    prefs_close();
+    free(help);
+}
+
+void cmd_statuses_chat_sets_all(void **state)
+{
+    mock_cons_show();
+    CommandHelp *help = malloc(sizeof(CommandHelp));
+    gchar *args[] = { "chat", "all", NULL };
+
+    expect_cons_show("All presence updates will appear in chat windows.");
+
+    prefs_load();
+    gboolean result = cmd_statuses(args, *help);
+    prefs_close();
+    prefs_load();
+
+    char *setting = prefs_get_string(PREF_STATUSES_CHAT);
+    assert_non_null(setting);
+    assert_string_equal("all", setting);
+    assert_true(result);
+
+    prefs_close();
+    free(help);
+}
+
+void cmd_statuses_chat_sets_online(void **state)
+{
+    mock_cons_show();
+    CommandHelp *help = malloc(sizeof(CommandHelp));
+    gchar *args[] = { "chat", "online", NULL };
+
+    expect_cons_show("Only online/offline presence updates will appear in chat windows.");
+
+    prefs_load();
+    gboolean result = cmd_statuses(args, *help);
+    prefs_close();
+    prefs_load();
+
+    char *setting = prefs_get_string(PREF_STATUSES_CHAT);
+    assert_non_null(setting);
+    assert_string_equal("online", setting);
+    assert_true(result);
+
+    prefs_close();
+    free(help);
+}
+
+void cmd_statuses_chat_sets_none(void **state)
+{
+    mock_cons_show();
+    CommandHelp *help = malloc(sizeof(CommandHelp));
+    gchar *args[] = { "chat", "none", NULL };
+
+    expect_cons_show("Presence updates will not appear in chat windows.");
+
+    prefs_load();
+    gboolean result = cmd_statuses(args, *help);
+    prefs_close();
+    prefs_load();
+
+    char *setting = prefs_get_string(PREF_STATUSES_CHAT);
+    assert_non_null(setting);
+    assert_string_equal("none", setting);
+    assert_true(result);
+
+    prefs_close();
+    free(help);
+}
+
+void cmd_statuses_muc_sets_on(void **state)
+{
+    mock_cons_show();
+    CommandHelp *help = malloc(sizeof(CommandHelp));
+    gchar *args[] = { "muc", "on", NULL };
+
+    expect_cons_show("Chat room presence updates enabled.");
+
+    prefs_load();
+    gboolean result = cmd_statuses(args, *help);
+    prefs_close();
+    prefs_load();
+
+    gboolean setting = prefs_get_boolean(PREF_STATUSES_MUC);
+    assert_non_null(setting);
+    assert_true(setting);
+    assert_true(result);
+
+    prefs_close();
+    free(help);
+}
+
+void cmd_statuses_muc_sets_off(void **state)
+{
+    mock_cons_show();
+    CommandHelp *help = malloc(sizeof(CommandHelp));
+    gchar *args[] = { "muc", "off", NULL };
+
+    expect_cons_show("Chat room presence updates disabled.");
+
+    prefs_load();
+    gboolean result = cmd_statuses(args, *help);
+    prefs_close();
+    prefs_load();
+
+    gboolean setting = prefs_get_boolean(PREF_STATUSES_MUC);
+    assert_false(setting);
+    assert_true(result);
+
+    prefs_close();
+    free(help);
+}
diff --git a/tests/test_cmd_statuses.h b/tests/test_cmd_statuses.h
index 473bd212..2ad74c44 100644
--- a/tests/test_cmd_statuses.h
+++ b/tests/test_cmd_statuses.h
@@ -1,4 +1,15 @@
+void create_config_dir(void **state);
+void delete_config_dir(void **state);
+
 void cmd_statuses_shows_usage_when_bad_subcmd(void **state);
 void cmd_statuses_shows_usage_when_bad_console_setting(void **state);
 void cmd_statuses_shows_usage_when_bad_chat_setting(void **state);
 void cmd_statuses_shows_usage_when_bad_muc_setting(void **state);
+void cmd_statuses_console_sets_all(void **state);
+void cmd_statuses_console_sets_online(void **state);
+void cmd_statuses_console_sets_none(void **state);
+void cmd_statuses_chat_sets_all(void **state);
+void cmd_statuses_chat_sets_online(void **state);
+void cmd_statuses_chat_sets_none(void **state);
+void cmd_statuses_muc_sets_on(void **state);
+void cmd_statuses_muc_sets_off(void **state);
diff --git a/tests/testsuite.c b/tests/testsuite.c
index 1c91e17a..642f3e80 100644
--- a/tests/testsuite.c
+++ b/tests/testsuite.c
@@ -329,6 +329,30 @@ int main(int argc, char* argv[]) {
         unit_test(cmd_statuses_shows_usage_when_bad_console_setting),
         unit_test(cmd_statuses_shows_usage_when_bad_chat_setting),
         unit_test(cmd_statuses_shows_usage_when_bad_muc_setting),
+        unit_test_setup_teardown(cmd_statuses_console_sets_all,
+            create_config_dir,
+            delete_config_dir),
+        unit_test_setup_teardown(cmd_statuses_console_sets_online,
+            create_config_dir,
+            delete_config_dir),
+        unit_test_setup_teardown(cmd_statuses_console_sets_none,
+            create_config_dir,
+            delete_config_dir),
+        unit_test_setup_teardown(cmd_statuses_chat_sets_all,
+            create_config_dir,
+            delete_config_dir),
+        unit_test_setup_teardown(cmd_statuses_chat_sets_online,
+            create_config_dir,
+            delete_config_dir),
+        unit_test_setup_teardown(cmd_statuses_chat_sets_none,
+            create_config_dir,
+            delete_config_dir),
+        unit_test_setup_teardown(cmd_statuses_muc_sets_on,
+            create_config_dir,
+            delete_config_dir),
+        unit_test_setup_teardown(cmd_statuses_muc_sets_off,
+            create_config_dir,
+            delete_config_dir),
     };
 
     int bak, new;