mirror of
https://github.com/profanity-im/profanity.git
synced 2025-02-02 15:08:15 -05:00
Added /roster clearnick command
This commit is contained in:
parent
bcafba2de6
commit
11c04d9fcd
@ -1015,6 +1015,7 @@ cmd_init(void)
|
||||
roster_ac = autocomplete_new();
|
||||
autocomplete_add(roster_ac, "add");
|
||||
autocomplete_add(roster_ac, "nick");
|
||||
autocomplete_add(roster_ac, "clearnick");
|
||||
autocomplete_add(roster_ac, "remove");
|
||||
|
||||
group_ac = autocomplete_new();
|
||||
@ -1564,6 +1565,10 @@ _roster_autocomplete(char *input, int *size)
|
||||
if (result != NULL) {
|
||||
return result;
|
||||
}
|
||||
result = autocomplete_param_with_func(input, size, "/roster clearnick", roster_find_jid);
|
||||
if (result != NULL) {
|
||||
return result;
|
||||
}
|
||||
result = autocomplete_param_with_func(input, size, "/roster remove", roster_find_jid);
|
||||
if (result != NULL) {
|
||||
return result;
|
||||
|
@ -1200,49 +1200,41 @@ cmd_roster(gchar **args, struct cmd_help_t help)
|
||||
GSList *list = roster_get_contacts();
|
||||
cons_show_roster(list);
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
// add contact
|
||||
if (strcmp(args[0], "add") == 0) {
|
||||
|
||||
if (args[1] == NULL) {
|
||||
cons_show("Usage: %s", help.usage);
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
} else if (strcmp(args[0], "add") == 0) {
|
||||
char *jid = args[1];
|
||||
char *name = args[2];
|
||||
|
||||
roster_send_add_new(jid, name);
|
||||
|
||||
if (jid == NULL) {
|
||||
cons_show("Usage: %s", help.usage);
|
||||
} else {
|
||||
char *name = args[2];
|
||||
roster_send_add_new(jid, name);
|
||||
}
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
// remove contact
|
||||
if (strcmp(args[0], "remove") == 0) {
|
||||
|
||||
if (args[1] == NULL) {
|
||||
cons_show("Usage: %s", help.usage);
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
} else if (strcmp(args[0], "remove") == 0) {
|
||||
char *jid = args[1];
|
||||
|
||||
roster_send_remove(jid);
|
||||
|
||||
if (jid == NULL) {
|
||||
cons_show("Usage: %s", help.usage);
|
||||
} else {
|
||||
roster_send_remove(jid);
|
||||
}
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
// change nickname
|
||||
if (strcmp(args[0], "nick") == 0) {
|
||||
|
||||
if (args[1] == NULL) {
|
||||
} else if (strcmp(args[0], "nick") == 0) {
|
||||
char *jid = args[1];
|
||||
if (jid == NULL) {
|
||||
cons_show("Usage: %s", help.usage);
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
char *jid = args[1];
|
||||
char *name = args[2];
|
||||
if (name == NULL) {
|
||||
cons_show("Usage: %s", help.usage);
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
// contact does not exist
|
||||
PContact contact = roster_get_contact(jid);
|
||||
@ -1256,17 +1248,37 @@ cmd_roster(gchar **args, struct cmd_help_t help)
|
||||
GSList *groups = p_contact_groups(contact);
|
||||
roster_send_name_change(barejid, name, groups);
|
||||
|
||||
if (name == NULL) {
|
||||
cons_show("Nickname for %s removed.", jid);
|
||||
} else {
|
||||
cons_show("Nickname for %s set to: %s.", jid, name);
|
||||
}
|
||||
cons_show("Nickname for %s set to: %s.", jid, name);
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
cons_show("Usage: %s", help.usage);
|
||||
return TRUE;
|
||||
// remove nickname
|
||||
} else if (strcmp(args[0], "clearnick") == 0) {
|
||||
char *jid = args[1];
|
||||
if (jid == NULL) {
|
||||
cons_show("Usage: %s", help.usage);
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
// contact does not exist
|
||||
PContact contact = roster_get_contact(jid);
|
||||
if (contact == NULL) {
|
||||
cons_show("Contact not found in roster: %s", jid);
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
const char *barejid = p_contact_barejid(contact);
|
||||
roster_change_name(contact, NULL);
|
||||
GSList *groups = p_contact_groups(contact);
|
||||
roster_send_name_change(barejid, NULL, groups);
|
||||
|
||||
cons_show("Nickname for %s removed.", jid);
|
||||
|
||||
return TRUE;
|
||||
} else {
|
||||
cons_show("Usage: %s", help.usage);
|
||||
return TRUE;
|
||||
}
|
||||
}
|
||||
|
||||
gboolean
|
||||
|
@ -118,7 +118,7 @@ void cmd_roster_remove_shows_message_when_no_jid(void **state)
|
||||
free(help);
|
||||
}
|
||||
|
||||
void cmd_roster_remove_sends_roster_remove_request(void)
|
||||
void cmd_roster_remove_sends_roster_remove_request(void **state)
|
||||
{
|
||||
char *jid = "bob@server.org";
|
||||
CommandHelp *help = malloc(sizeof(CommandHelp));
|
||||
@ -133,3 +133,142 @@ void cmd_roster_remove_sends_roster_remove_request(void)
|
||||
|
||||
free(help);
|
||||
}
|
||||
|
||||
void cmd_roster_nick_shows_message_when_no_jid(void **state)
|
||||
{
|
||||
mock_cons_show();
|
||||
CommandHelp *help = malloc(sizeof(CommandHelp));
|
||||
help->usage = "some usage";
|
||||
gchar *args[] = { "nick", NULL };
|
||||
|
||||
mock_connection_status(JABBER_CONNECTED);
|
||||
expect_cons_show("Usage: some usage");
|
||||
|
||||
gboolean result = cmd_roster(args, *help);
|
||||
assert_true(result);
|
||||
|
||||
free(help);
|
||||
}
|
||||
|
||||
void cmd_roster_nick_shows_message_when_no_nick(void **state)
|
||||
{
|
||||
mock_cons_show();
|
||||
CommandHelp *help = malloc(sizeof(CommandHelp));
|
||||
help->usage = "some usage";
|
||||
gchar *args[] = { "nick", "bob@server.org", NULL };
|
||||
|
||||
mock_connection_status(JABBER_CONNECTED);
|
||||
expect_cons_show("Usage: some usage");
|
||||
|
||||
gboolean result = cmd_roster(args, *help);
|
||||
assert_true(result);
|
||||
|
||||
free(help);
|
||||
}
|
||||
|
||||
void cmd_roster_nick_shows_message_when_no_contact_exists(void **state)
|
||||
{
|
||||
mock_cons_show();
|
||||
CommandHelp *help = malloc(sizeof(CommandHelp));
|
||||
help->usage = "some usage";
|
||||
gchar *args[] = { "nick", "bob@server.org", "bobster", NULL };
|
||||
|
||||
roster_init();
|
||||
mock_connection_status(JABBER_CONNECTED);
|
||||
expect_cons_show("Contact not found in roster: bob@server.org");
|
||||
|
||||
gboolean result = cmd_roster(args, *help);
|
||||
assert_true(result);
|
||||
|
||||
free(help);
|
||||
roster_free();
|
||||
}
|
||||
|
||||
void cmd_roster_nick_sends_name_change_request(void **state)
|
||||
{
|
||||
char *jid = "bob@server.org";
|
||||
char *nick = "bobster";
|
||||
mock_cons_show();
|
||||
mock_roster_send_name_change();
|
||||
CommandHelp *help = malloc(sizeof(CommandHelp));
|
||||
gchar *args[] = { "nick", jid, nick, NULL };
|
||||
|
||||
roster_init();
|
||||
GSList *groups = NULL;
|
||||
groups = g_slist_append(groups, "group1");
|
||||
roster_add(jid, "bob", groups, "both", FALSE);
|
||||
|
||||
mock_connection_status(JABBER_CONNECTED);
|
||||
roster_send_name_change_expect(jid, nick, groups);
|
||||
expect_cons_show("Nickname for bob@server.org set to: bobster.");
|
||||
|
||||
gboolean result = cmd_roster(args, *help);
|
||||
assert_true(result);
|
||||
|
||||
PContact contact = roster_get_contact(jid);
|
||||
assert_string_equal(p_contact_name(contact), nick);
|
||||
|
||||
free(help);
|
||||
roster_free();
|
||||
}
|
||||
|
||||
void cmd_roster_clearnick_shows_message_when_no_jid(void **state)
|
||||
{
|
||||
mock_cons_show();
|
||||
CommandHelp *help = malloc(sizeof(CommandHelp));
|
||||
help->usage = "some usage";
|
||||
gchar *args[] = { "clearnick", NULL };
|
||||
|
||||
mock_connection_status(JABBER_CONNECTED);
|
||||
expect_cons_show("Usage: some usage");
|
||||
|
||||
gboolean result = cmd_roster(args, *help);
|
||||
assert_true(result);
|
||||
|
||||
free(help);
|
||||
}
|
||||
|
||||
void cmd_roster_clearnick_shows_message_when_no_contact_exists(void **state)
|
||||
{
|
||||
mock_cons_show();
|
||||
CommandHelp *help = malloc(sizeof(CommandHelp));
|
||||
help->usage = "some usage";
|
||||
gchar *args[] = { "clearnick", "bob@server.org", NULL };
|
||||
|
||||
roster_init();
|
||||
mock_connection_status(JABBER_CONNECTED);
|
||||
expect_cons_show("Contact not found in roster: bob@server.org");
|
||||
|
||||
gboolean result = cmd_roster(args, *help);
|
||||
assert_true(result);
|
||||
|
||||
free(help);
|
||||
roster_free();
|
||||
}
|
||||
|
||||
void cmd_roster_clearnick_sends_name_change_request_with_empty_nick(void **state)
|
||||
{
|
||||
char *jid = "bob@server.org";
|
||||
mock_cons_show();
|
||||
mock_roster_send_name_change();
|
||||
CommandHelp *help = malloc(sizeof(CommandHelp));
|
||||
gchar *args[] = { "clearnick", jid, NULL };
|
||||
|
||||
roster_init();
|
||||
GSList *groups = NULL;
|
||||
groups = g_slist_append(groups, "group1");
|
||||
roster_add(jid, "bob", groups, "both", FALSE);
|
||||
|
||||
mock_connection_status(JABBER_CONNECTED);
|
||||
roster_send_name_change_expect(jid, NULL, groups);
|
||||
expect_cons_show("Nickname for bob@server.org removed.");
|
||||
|
||||
gboolean result = cmd_roster(args, *help);
|
||||
assert_true(result);
|
||||
|
||||
PContact contact = roster_get_contact(jid);
|
||||
assert_null(p_contact_name(contact));
|
||||
|
||||
free(help);
|
||||
roster_free();
|
||||
}
|
||||
|
@ -7,3 +7,10 @@ void cmd_roster_add_shows_message_when_no_jid(void **state);
|
||||
void cmd_roster_add_sends_roster_add_request(void **state);
|
||||
void cmd_roster_remove_shows_message_when_no_jid(void **state);
|
||||
void cmd_roster_remove_sends_roster_remove_request(void **state);
|
||||
void cmd_roster_nick_shows_message_when_no_jid(void **state);
|
||||
void cmd_roster_nick_shows_message_when_no_nick(void **state);
|
||||
void cmd_roster_nick_shows_message_when_no_contact_exists(void **state);
|
||||
void cmd_roster_nick_sends_name_change_request(void **state);
|
||||
void cmd_roster_clearnick_shows_message_when_no_jid(void **state);
|
||||
void cmd_roster_clearnick_shows_message_when_no_contact_exists(void **state);
|
||||
void cmd_roster_clearnick_sends_name_change_request_with_empty_nick(void **state);
|
||||
|
@ -511,6 +511,13 @@ int main(int argc, char* argv[]) {
|
||||
unit_test(cmd_roster_add_sends_roster_add_request),
|
||||
unit_test(cmd_roster_remove_shows_message_when_no_jid),
|
||||
unit_test(cmd_roster_remove_sends_roster_remove_request),
|
||||
unit_test(cmd_roster_nick_shows_message_when_no_jid),
|
||||
unit_test(cmd_roster_nick_shows_message_when_no_nick),
|
||||
unit_test(cmd_roster_nick_shows_message_when_no_contact_exists),
|
||||
unit_test(cmd_roster_nick_sends_name_change_request),
|
||||
unit_test(cmd_roster_clearnick_shows_message_when_no_jid),
|
||||
unit_test(cmd_roster_clearnick_shows_message_when_no_contact_exists),
|
||||
unit_test(cmd_roster_clearnick_sends_name_change_request_with_empty_nick),
|
||||
};
|
||||
|
||||
return run_tests(all_tests);
|
||||
|
@ -109,6 +109,15 @@ _mock_roster_send_remove(const char * const barejid)
|
||||
check_expected(barejid);
|
||||
}
|
||||
|
||||
static void
|
||||
_mock_roster_send_name_change(const char * const barejid, const char * const new_name,
|
||||
GSList *groups)
|
||||
{
|
||||
check_expected(barejid);
|
||||
check_expected(new_name);
|
||||
check_expected(groups);
|
||||
}
|
||||
|
||||
void
|
||||
mock_jabber_connect_with_details(void)
|
||||
{
|
||||
@ -164,6 +173,12 @@ mock_roster_send_remove(void)
|
||||
roster_send_remove = _mock_roster_send_remove;
|
||||
}
|
||||
|
||||
void
|
||||
mock_roster_send_name_change(void)
|
||||
{
|
||||
roster_send_name_change = _mock_roster_send_name_change;
|
||||
}
|
||||
|
||||
void
|
||||
bookmark_get_list_returns(GList *bookmarks)
|
||||
{
|
||||
@ -298,3 +313,15 @@ roster_send_remove_expect(char *jid)
|
||||
{
|
||||
expect_string(_mock_roster_send_remove, barejid, jid);
|
||||
}
|
||||
|
||||
void
|
||||
roster_send_name_change_expect(char *jid, char *nick, GSList *groups)
|
||||
{
|
||||
expect_string(_mock_roster_send_name_change, barejid, jid);
|
||||
if (nick == NULL) {
|
||||
expect_value(_mock_roster_send_name_change, new_name, NULL);
|
||||
} else {
|
||||
expect_string(_mock_roster_send_name_change, new_name, nick);
|
||||
}
|
||||
expect_memory(_mock_roster_send_name_change, groups, groups, sizeof(GSList));
|
||||
}
|
||||
|
@ -42,4 +42,7 @@ void roster_send_add_new_expect(char *jid, char *nick);
|
||||
void mock_roster_send_remove(void);
|
||||
void roster_send_remove_expect(char *jid);
|
||||
|
||||
void mock_roster_send_name_change(void);
|
||||
void roster_send_name_change_expect(char *jid, char *name, GSList *groups);
|
||||
|
||||
#endif
|
||||
|
Loading…
x
Reference in New Issue
Block a user