mirror of
https://github.com/profanity-im/profanity.git
synced 2024-12-04 14:46:46 -05:00
Merge branch 'master' into plugins
This commit is contained in:
commit
38e1ff22fc
@ -143,22 +143,22 @@ static struct cmd_t command_defs[] =
|
||||
|
||||
{ "/roster",
|
||||
cmd_roster, parse_args_with_freetext, 0, 3, NULL,
|
||||
{ "/roster [add|remove|nick] [jid] [handle]", "Manage your roster.",
|
||||
{ "/roster [add|remove|nick] [jid] [handle]",
|
||||
"----------------------------------------",
|
||||
{ "/roster [add|remove|nick|clearnick] [jid] [nickname]", "Manage your roster.",
|
||||
{ "/roster [add|remove|nick|clearnick] [jid] [nickname]",
|
||||
"----------------------------------------------------",
|
||||
"View, add to, and remove from your roster.",
|
||||
"Passing no arguments lists all contacts in your roster.",
|
||||
"The 'add' command will add a new item, the jid is required, the handle is an optional nickname",
|
||||
"The 'remove' command removes a contact, the jid is required.",
|
||||
"The 'nick' command changes a contacts nickname, the jid is required,",
|
||||
"if no handle is supplied, the current one is removed.",
|
||||
"The 'add' command will add a new item, jid is required, nickname is optional.",
|
||||
"The 'remove' command removes a contact, jid is required.",
|
||||
"The 'nick' command changes a contacts nickname, both jid and nickname are required,",
|
||||
"The 'clearnick' command removes the current nickname, jid is required.",
|
||||
"",
|
||||
"Example : /roster (show your roster)",
|
||||
"Example : /roster add someone@contacts.org (add the contact)",
|
||||
"Example : /roster add someone@contacts.org Buddy (add the contact with nickname 'Buddy')",
|
||||
"Example : /roster remove someone@contacts.org (remove the contact)",
|
||||
"Example : /roster nick myfriend@chat.org My Friend",
|
||||
"Example : /roster nick kai@server.com (clears handle)",
|
||||
"Example : /roster clearnick kai@server.com (clears nickname)",
|
||||
NULL } } },
|
||||
|
||||
{ "/group",
|
||||
@ -1022,6 +1022,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();
|
||||
@ -1552,6 +1553,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;
|
||||
|
@ -1203,49 +1203,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);
|
||||
@ -1259,17 +1251,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
|
||||
|
@ -69,7 +69,7 @@ void cmd_roster_shows_roster_when_no_args(void **state)
|
||||
roster_free();
|
||||
}
|
||||
|
||||
void cmd_roster_add_shows_message_when_no_jid(void)
|
||||
void cmd_roster_add_shows_message_when_no_jid(void **state)
|
||||
{
|
||||
mock_cons_show();
|
||||
CommandHelp *help = malloc(sizeof(CommandHelp));
|
||||
@ -85,7 +85,7 @@ void cmd_roster_add_shows_message_when_no_jid(void)
|
||||
free(help);
|
||||
}
|
||||
|
||||
void cmd_roster_add_sends_roster_add_request(void)
|
||||
void cmd_roster_add_sends_roster_add_request(void **state)
|
||||
{
|
||||
char *jid = "bob@server.org";
|
||||
char *nick = "bob";
|
||||
@ -101,3 +101,174 @@ void cmd_roster_add_sends_roster_add_request(void)
|
||||
|
||||
free(help);
|
||||
}
|
||||
|
||||
void cmd_roster_remove_shows_message_when_no_jid(void **state)
|
||||
{
|
||||
mock_cons_show();
|
||||
CommandHelp *help = malloc(sizeof(CommandHelp));
|
||||
help->usage = "some usage";
|
||||
gchar *args[] = { "remove", 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_remove_sends_roster_remove_request(void **state)
|
||||
{
|
||||
char *jid = "bob@server.org";
|
||||
CommandHelp *help = malloc(sizeof(CommandHelp));
|
||||
gchar *args[] = { "remove", jid, NULL };
|
||||
|
||||
mock_roster_send_remove();
|
||||
mock_connection_status(JABBER_CONNECTED);
|
||||
roster_send_remove_expect(jid);
|
||||
|
||||
gboolean result = cmd_roster(args, *help);
|
||||
assert_true(result);
|
||||
|
||||
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();
|
||||
}
|
||||
|
@ -5,3 +5,12 @@ void cmd_roster_shows_message_when_undefined(void **state);
|
||||
void cmd_roster_shows_roster_when_no_args(void **state);
|
||||
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);
|
||||
|
@ -509,6 +509,15 @@ int main(int argc, char* argv[]) {
|
||||
unit_test(cmd_roster_shows_roster_when_no_args),
|
||||
unit_test(cmd_roster_add_shows_message_when_no_jid),
|
||||
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);
|
||||
|
@ -350,7 +350,7 @@ expect_cons_show_contact_online(PContact contact, Resource *resource, GDateTime
|
||||
expect_memory(_mock_cons_show_contact_online, contact, contact, sizeof(contact));
|
||||
expect_memory(_mock_cons_show_contact_online, resource, resource, sizeof(Resource));
|
||||
if (last_activity == NULL) {
|
||||
expect_any(_mock_cons_show_contact_online, last_activity);
|
||||
expect_value(_mock_cons_show_contact_online, last_activity, NULL);
|
||||
} else {
|
||||
expect_memory(_mock_cons_show_contact_online, last_activity, last_activity, sizeof(last_activity));
|
||||
}
|
||||
|
@ -103,6 +103,21 @@ _mock_roster_send_add_new(const char *const barejid, const char * const name)
|
||||
check_expected(name);
|
||||
}
|
||||
|
||||
static void
|
||||
_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)
|
||||
{
|
||||
@ -152,6 +167,18 @@ mock_roster_send_add_new(void)
|
||||
roster_send_add_new = _mock_roster_send_add_new;
|
||||
}
|
||||
|
||||
void
|
||||
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)
|
||||
{
|
||||
@ -187,7 +214,7 @@ jabber_connect_with_details_expect_and_return(char *jid,
|
||||
expect_string(_mock_jabber_connect_with_details, jid, jid);
|
||||
expect_string(_mock_jabber_connect_with_details, passwd, password);
|
||||
if (altdomain == NULL) {
|
||||
expect_any(_mock_jabber_connect_with_details, altdomain);
|
||||
expect_value(_mock_jabber_connect_with_details, altdomain, NULL);
|
||||
} else {
|
||||
expect_string(_mock_jabber_connect_with_details, altdomain, altdomain);
|
||||
}
|
||||
@ -237,7 +264,7 @@ expect_and_return_bookmark_add(char *expected_jid, char *expected_nick,
|
||||
if (expected_nick != NULL) {
|
||||
expect_string(_mock_bookmark_add, nick, expected_nick);
|
||||
} else {
|
||||
expect_any(_mock_bookmark_add, nick);
|
||||
expect_value(_mock_bookmark_add, nick, NULL);
|
||||
}
|
||||
expect_value(_mock_bookmark_add, autojoin, expected_autojoin);
|
||||
|
||||
@ -268,7 +295,7 @@ presence_join_room_expect(char *room, char *nick, char *passwd)
|
||||
expect_string(_mock_presence_join_room, room, room);
|
||||
expect_string(_mock_presence_join_room, nick, nick);
|
||||
if (passwd == NULL) {
|
||||
expect_any(_mock_presence_join_room, passwd);
|
||||
expect_value(_mock_presence_join_room, passwd, NULL);
|
||||
} else {
|
||||
expect_string(_mock_presence_join_room, passwd, passwd);
|
||||
}
|
||||
@ -280,3 +307,21 @@ roster_send_add_new_expect(char *jid, char *nick)
|
||||
expect_string(_mock_roster_send_add_new, barejid, jid);
|
||||
expect_string(_mock_roster_send_add_new, name, nick);
|
||||
}
|
||||
|
||||
void
|
||||
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));
|
||||
}
|
||||
|
@ -39,4 +39,10 @@ void presence_join_room_expect(char *room, char *nick, char *passwd);
|
||||
void mock_roster_send_add_new(void);
|
||||
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…
Reference in New Issue
Block a user