1
0
mirror of https://github.com/profanity-im/profanity.git synced 2024-06-16 21:35:24 +00:00

Added id attributes to roster queries

fixes #596
This commit is contained in:
James Booth 2015-07-22 22:48:37 +01:00
parent fceec61a2c
commit f9a7e35001
8 changed files with 160 additions and 13 deletions

View File

@ -103,6 +103,7 @@ functionaltest_sources = \
tests/functionaltests/test_chat_session.c tests/functionaltests/test_chat_session.h \
tests/functionaltests/test_carbons.c tests/functionaltests/test_carbons.h \
tests/functionaltests/test_receipts.c tests/functionaltests/test_receipts.h \
tests/functionaltests/test_roster.c tests/functionaltests/test_roster.h \
tests/functionaltests/functionaltests.c
main_source = src/main.c

View File

@ -102,7 +102,9 @@ roster_send_add_new(const char * const barejid, const char * const name)
{
xmpp_conn_t * const conn = connection_get_conn();
xmpp_ctx_t * const ctx = connection_get_ctx();
xmpp_stanza_t *iq = stanza_create_roster_set(ctx, NULL, barejid, name, NULL);
char *id = create_unique_id("roster");
xmpp_stanza_t *iq = stanza_create_roster_set(ctx, id, barejid, name, NULL);
free(id);
xmpp_send(conn, iq);
xmpp_stanza_release(iq);
}
@ -122,8 +124,9 @@ roster_send_name_change(const char * const barejid, const char * const new_name,
{
xmpp_conn_t * const conn = connection_get_conn();
xmpp_ctx_t * const ctx = connection_get_ctx();
xmpp_stanza_t *iq = stanza_create_roster_set(ctx, NULL, barejid, new_name,
groups);
char *id = create_unique_id("roster");
xmpp_stanza_t *iq = stanza_create_roster_set(ctx, id, barejid, new_name, groups);
free(id);
xmpp_send(conn, iq);
xmpp_stanza_release(iq);
}
@ -354,4 +357,4 @@ _get_groups_from_item(xmpp_stanza_t *item)
}
return groups;
}
}

View File

@ -373,6 +373,10 @@ stanza_create_roster_remove_set(xmpp_ctx_t *ctx, const char * const barejid)
xmpp_stanza_set_name(iq, STANZA_NAME_IQ);
xmpp_stanza_set_type(iq, STANZA_TYPE_SET);
char *id = create_unique_id("roster");
xmpp_stanza_set_id(iq, id);
free(id);
xmpp_stanza_t *query = xmpp_stanza_new(ctx);
xmpp_stanza_set_name(query, STANZA_NAME_QUERY);
xmpp_stanza_set_ns(query, XMPP_NS_ROSTER);

View File

@ -18,6 +18,7 @@
#include "test_carbons.h"
#include "test_chat_session.h"
#include "test_receipts.h"
#include "test_roster.h"
#define PROF_FUNC_TEST(test) unit_test_setup_teardown(test, init_prof_test, close_prof_test)
@ -68,6 +69,11 @@ int main(int argc, char* argv[]) {
PROF_FUNC_TEST(send_receipt_request),
PROF_FUNC_TEST(send_receipt_on_request),
PROF_FUNC_TEST(sends_new_item),
PROF_FUNC_TEST(sends_new_item_nick),
PROF_FUNC_TEST(sends_remove_item),
PROF_FUNC_TEST(sends_nick_change),
};
return run_tests(all_tests);

View File

@ -210,16 +210,10 @@ prof_output_regex(char *text)
}
void
prof_connect(void)
prof_connect_with_roster(char *roster)
{
stbbr_for_query("jabber:iq:roster",
"<iq type=\"result\" to=\"stabber@localhost/profanity\">"
"<query xmlns=\"jabber:iq:roster\" ver=\"362\">"
"<item jid=\"buddy1@localhost\" subscription=\"both\" name=\"Buddy1\"/>"
"<item jid=\"buddy2@localhost\" subscription=\"both\" name=\"Buddy2\"/>"
"</query>"
"</iq>"
);
stbbr_for_query("jabber:iq:roster", roster);
stbbr_for_id("prof_presence_1",
"<presence id=\"prof_presence_1\" lang=\"en\" to=\"stabber@localhost/profanity\" from=\"stabber@localhost/profanity\">"
"<priority>0</priority>"
@ -236,3 +230,16 @@ prof_connect(void)
exp_timeout = 10;
stbbr_wait_for("prof_presence_*");
}
void
prof_connect(void)
{
prof_connect_with_roster(
"<iq type=\"result\" to=\"stabber@localhost/profanity\">"
"<query xmlns=\"jabber:iq:roster\" ver=\"362\">"
"<item jid=\"buddy1@localhost\" subscription=\"both\" name=\"Buddy1\"/>"
"<item jid=\"buddy2@localhost\" subscription=\"both\" name=\"Buddy2\"/>"
"</query>"
"</iq>"
);
}

View File

@ -9,6 +9,7 @@ void close_prof_test(void **state);
void prof_start(void);
void prof_connect(void);
void prof_connect_with_roster(char *roster);
void prof_input(char *input);
int prof_output_exact(char *text);

View File

@ -0,0 +1,121 @@
#include <glib.h>
#include <stdarg.h>
#include <stddef.h>
#include <setjmp.h>
#include <cmocka.h>
#include <stdlib.h>
#include <string.h>
#include <stabber.h>
#include <expect.h>
#include "proftest.h"
void
sends_new_item(void **state)
{
prof_connect();
stbbr_for_query("jabber:iq:roster",
"<iq type=\"set\" from=\"stabber@localhost\">"
"<query xmlns=\"jabber:iq:roster\">"
"<item jid=\"bob@localhost\" subscription=\"none\" name=\"\"/>"
"</query>"
"</iq>"
);
prof_input("/roster add bob@localhost");
assert_true(stbbr_received(
"<iq type=\"set\" id=\"*\">"
"<query xmlns=\"jabber:iq:roster\">"
"<item jid=\"bob@localhost\" name=\"\"/>"
"</query>"
"</iq>"
));
assert_true(prof_output_exact("Roster item added: bob@localhost"));
}
void
sends_new_item_nick(void **state)
{
prof_connect();
stbbr_for_query("jabber:iq:roster",
"<iq type=\"set\" from=\"stabber@localhost\">"
"<query xmlns=\"jabber:iq:roster\">"
"<item jid=\"bob@localhost\" subscription=\"none\" name=\"Bobby\"/>"
"</query>"
"</iq>"
);
prof_input("/roster add bob@localhost Bobby");
assert_true(stbbr_received(
"<iq type=\"set\" id=\"*\">"
"<query xmlns=\"jabber:iq:roster\">"
"<item jid=\"bob@localhost\" name=\"Bobby\"/>"
"</query>"
"</iq>"
));
assert_true(prof_output_exact("Roster item added: bob@localhost (Bobby)"));
}
void
sends_remove_item(void **state)
{
prof_connect_with_roster(
"<iq type=\"result\" to=\"stabber@localhost/profanity\">"
"<query xmlns=\"jabber:iq:roster\" ver=\"362\">"
"<item jid=\"buddy1@localhost\" subscription=\"both\"/>"
"<item jid=\"buddy2@localhost\" subscription=\"both\"/>"
"</query>"
"</iq>"
);
stbbr_for_query("jabber:iq:roster",
"<iq id=\"*\" type=\"set\">"
"<query xmlns=\"jabber:iq:roster\">"
"<item jid=\"buddy1@localhost\" subscription=\"remove\"/>"
"</query>"
"</iq>"
);
prof_input("/roster remove buddy1@localhost");
assert_true(stbbr_received(
"<iq type=\"set\" id=\"*\">"
"<query xmlns=\"jabber:iq:roster\">"
"<item jid=\"buddy1@localhost\" subscription=\"remove\"/>"
"</query>"
"</iq>"
));
assert_true(prof_output_exact("Roster item removed: buddy1@localhost"));
}
void
sends_nick_change(void **state)
{
prof_connect_with_roster(
"<iq type=\"result\" to=\"stabber@localhost/profanity\">"
"<query xmlns=\"jabber:iq:roster\" ver=\"362\">"
"<item jid=\"buddy1@localhost\" subscription=\"both\"/>"
"</query>"
"</iq>"
);
prof_input("/roster nick buddy1@localhost Buddy1");
assert_true(prof_output_exact("Nickname for buddy1@localhost set to: Buddy1."));
assert_true(stbbr_received(
"<iq type=\"set\" id=\"*\">"
"<query xmlns=\"jabber:iq:roster\">"
"<item jid=\"buddy1@localhost\" name=\"Buddy1\"/>"
"</query>"
"</iq>"
));
}

View File

@ -0,0 +1,4 @@
void sends_new_item(void **state);
void sends_new_item_nick(void **state);
void sends_remove_item(void **state);
void sends_nick_change(void **state);