# HG changeset patch # User Matthew Wild # Date 1234381925 0 # Node ID b85b1dee4f4b6db6178a868f7a6549de7bf6602b # Parent c4a4d5604549dd24350646bbc86592abb65449de Add test to check for incorrect handling of iq from c2s to local bare JIDs diff -r c4a4d5604549 -r b85b1dee4f4b tests/test_core_stanza_router.lua --- a/tests/test_core_stanza_router.lua Wed Feb 11 19:50:58 2009 +0000 +++ b/tests/test_core_stanza_router.lua Wed Feb 11 19:52:05 2009 +0000 @@ -155,6 +155,28 @@ assert_equal(target_routed, true, "stanza was not routed successfully"); end + local function test_iq_to_local_bare() + local env = testlib_new_env(); + local msg = stanza.stanza("iq", { to = "user@localhost", from = "user@localhost", type = "get" }):tag("ping", { xmlns = "urn:xmpp:ping:0" }); + + local target_handled; + + function env.core_handle_stanza(p_origin, p_stanza) + assert_equal(p_origin, local_user_session, "origin of handled stanza is not correct"); + assert_equal(p_stanza, msg, "handled stanza is not correct one: "..p_stanza:pretty_print()); + target_handled = true; + end + + function env.core_route_stanza(p_origin, p_stanza) + + end + + env.hosts = hosts; + setfenv(core_process_stanza, env); + assert_equal(core_process_stanza(local_user_session, msg), nil, "core_process_stanza returned incorrect value"); + assert_equal(target_handled, true, "stanza was not handled successfully"); + end + runtest(test_message_full_jid, "Messages with full JID destinations get routed"); runtest(test_message_bare_jid, "Messages with bare JID destinations get routed"); runtest(test_message_no_to, "Messages with no destination are handled by the server"); @@ -162,6 +184,7 @@ runtest(test_message_to_remote_server, "Messages to a remote server's JID are routed"); runtest(test_iq_to_remote_server, "iq to a remote server's JID are routed"); + runtest(test_iq_to_local_bare, "iq from a local user to a local user's bare JID are handled"); runtest(test_iq_error_to_local_user, "iq type=error to a local user's JID are routed"); end