mirror of
https://github.com/profanity-im/profanity.git
synced 2025-01-03 14:57:42 -05:00
Added custom resource checker
This commit is contained in:
parent
af73cb82e6
commit
06b18be851
@ -130,6 +130,7 @@ stabbertest_sources = \
|
|||||||
src/config/theme.c src/config/theme.h \
|
src/config/theme.c src/config/theme.h \
|
||||||
stabbertests/ui/stub_ui.c \
|
stabbertests/ui/stub_ui.c \
|
||||||
stabbertests/proftest.c stabbertests/proftest.h \
|
stabbertests/proftest.c stabbertests/proftest.h \
|
||||||
|
stabbertests/checkers/checkers.c stabbertests/checkers/checkers.h \
|
||||||
stabbertests/test_connect.c stabbertests/test_connect.h \
|
stabbertests/test_connect.c stabbertests/test_connect.h \
|
||||||
stabbertests/stabbertestsuite.c
|
stabbertests/stabbertestsuite.c
|
||||||
|
|
||||||
|
26
stabbertests/checkers/checkers.c
Normal file
26
stabbertests/checkers/checkers.c
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
#include "resource.h"
|
||||||
|
|
||||||
|
int
|
||||||
|
resource_equal_check(void *param, void *value)
|
||||||
|
{
|
||||||
|
Resource *param_res = (Resource *)param;
|
||||||
|
Resource *value_res = (Resource *)value;
|
||||||
|
|
||||||
|
if (g_strcmp0(param_res->name, value_res->name) != 0) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (param_res->presence != value_res->presence) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (param_res->priority != value_res->priority) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (g_strcmp0(param_res->status, value_res->status) != 0) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
6
stabbertests/checkers/checkers.h
Normal file
6
stabbertests/checkers/checkers.h
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
#ifndef __H_CHECKERS
|
||||||
|
#define __H_CHECKERS
|
||||||
|
|
||||||
|
int resource_equal_check(void *param, void *value);
|
||||||
|
|
||||||
|
#endif
|
@ -1,3 +1,8 @@
|
|||||||
|
#ifndef __H_PROFTEST
|
||||||
|
#define __H_PROFTEST
|
||||||
|
|
||||||
void init_prof_test(void **state);
|
void init_prof_test(void **state);
|
||||||
void close_prof_test(void **state);
|
void close_prof_test(void **state);
|
||||||
void prof_process_xmpp(int loops);
|
void prof_process_xmpp(int loops);
|
||||||
|
|
||||||
|
#endif
|
@ -31,6 +31,9 @@ int main(int argc, char* argv[]) {
|
|||||||
unit_test_setup_teardown(connect_bad_password,
|
unit_test_setup_teardown(connect_bad_password,
|
||||||
init_prof_test,
|
init_prof_test,
|
||||||
close_prof_test),
|
close_prof_test),
|
||||||
|
unit_test_setup_teardown(show_presence_updates,
|
||||||
|
init_prof_test,
|
||||||
|
close_prof_test),
|
||||||
unit_test_setup_teardown(sends_rooms_iq,
|
unit_test_setup_teardown(sends_rooms_iq,
|
||||||
init_prof_test,
|
init_prof_test,
|
||||||
close_prof_test),
|
close_prof_test),
|
||||||
|
@ -9,6 +9,7 @@
|
|||||||
#include <stabber.h>
|
#include <stabber.h>
|
||||||
|
|
||||||
#include "proftest.h"
|
#include "proftest.h"
|
||||||
|
#include "checkers/checkers.h"
|
||||||
#include "xmpp/xmpp.h"
|
#include "xmpp/xmpp.h"
|
||||||
#include "ui/stub_ui.h"
|
#include "ui/stub_ui.h"
|
||||||
#include "ui/window.h"
|
#include "ui/window.h"
|
||||||
@ -99,6 +100,57 @@ connect_bad_password(void **state)
|
|||||||
assert_true(status == JABBER_DISCONNECTED);
|
assert_true(status == JABBER_DISCONNECTED);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
show_presence_updates(void **state)
|
||||||
|
{
|
||||||
|
will_return(ui_ask_password, strdup("password"));
|
||||||
|
expect_any_cons_show();
|
||||||
|
|
||||||
|
stbbr_for("roster",
|
||||||
|
"<iq id=\"roster\" 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>"
|
||||||
|
);
|
||||||
|
|
||||||
|
cmd_process_input(strdup("/connect stabber@localhost port 5230"));
|
||||||
|
prof_process_xmpp(20);
|
||||||
|
|
||||||
|
stbbr_send(
|
||||||
|
"<presence to=\"stabber@localhost\" from=\"buddy1@localhost/mobile\">"
|
||||||
|
"<show>dnd</show>"
|
||||||
|
"<status>busy!</status>"
|
||||||
|
"</presence>"
|
||||||
|
"<presence to=\"stabber@localhost\" from=\"buddy1@localhost/laptop\">"
|
||||||
|
"<show>chat</show>"
|
||||||
|
"<status>Talk to me!</status>"
|
||||||
|
"</presence>"
|
||||||
|
"<presence to=\"stabber@localhost\" from=\"buddy2@localhost/work\">"
|
||||||
|
"<show>away</show>"
|
||||||
|
"<status>Out of office</status>"
|
||||||
|
"</presence>"
|
||||||
|
);
|
||||||
|
|
||||||
|
Resource *resource1 = resource_new("mobile", RESOURCE_DND, "busy!", 0);
|
||||||
|
expect_string(ui_contact_online, barejid, "buddy1@localhost");
|
||||||
|
expect_check(ui_contact_online, resource, (CheckParameterValue)resource_equal_check, resource1);
|
||||||
|
expect_value(ui_contact_online, last_activity, NULL);
|
||||||
|
|
||||||
|
Resource *resource2 = resource_new("laptop", RESOURCE_CHAT, "Talk to me!", 0);
|
||||||
|
expect_string(ui_contact_online, barejid, "buddy1@localhost");
|
||||||
|
expect_check(ui_contact_online, resource, (CheckParameterValue)resource_equal_check, resource2);
|
||||||
|
expect_value(ui_contact_online, last_activity, NULL);
|
||||||
|
|
||||||
|
Resource *resource3 = resource_new("work", RESOURCE_AWAY, "Out of office", 0);
|
||||||
|
expect_string(ui_contact_online, barejid, "buddy2@localhost");
|
||||||
|
expect_check(ui_contact_online, resource, (CheckParameterValue)resource_equal_check, resource3);
|
||||||
|
expect_value(ui_contact_online, last_activity, NULL);
|
||||||
|
|
||||||
|
prof_process_xmpp(20);
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
sends_rooms_iq(void **state)
|
sends_rooms_iq(void **state)
|
||||||
{
|
{
|
||||||
@ -182,7 +234,6 @@ responds_to_ping(void **state)
|
|||||||
"<ping xmlns=\"urn:xmpp:ping\"/>"
|
"<ping xmlns=\"urn:xmpp:ping\"/>"
|
||||||
"</iq>"
|
"</iq>"
|
||||||
);
|
);
|
||||||
|
|
||||||
prof_process_xmpp(20);
|
prof_process_xmpp(20);
|
||||||
|
|
||||||
assert_true(stbbr_verify(
|
assert_true(stbbr_verify(
|
||||||
|
@ -3,6 +3,7 @@ void connect_jid_requests_roster(void **state);
|
|||||||
void connect_jid_sends_presence_after_receiving_roster(void **state);
|
void connect_jid_sends_presence_after_receiving_roster(void **state);
|
||||||
void connect_jid_requests_bookmarks(void **state);
|
void connect_jid_requests_bookmarks(void **state);
|
||||||
void connect_bad_password(void **state);
|
void connect_bad_password(void **state);
|
||||||
|
void show_presence_updates(void **state);
|
||||||
void sends_rooms_iq(void **state);
|
void sends_rooms_iq(void **state);
|
||||||
void multiple_pings(void **state);
|
void multiple_pings(void **state);
|
||||||
void responds_to_ping(void **state);
|
void responds_to_ping(void **state);
|
||||||
|
Loading…
Reference in New Issue
Block a user