mirror of
https://github.com/bjc/prosody.git
synced 2025-04-03 21:27:38 +03:00
util.stanza: Extract Application-Specific Condition from errors
API change
This commit is contained in:
parent
a7c3fc20a0
commit
815ce25d10
2 changed files with 21 additions and 6 deletions
|
@ -276,6 +276,19 @@ describe("util.stanza", function()
|
|||
end);
|
||||
end);
|
||||
|
||||
describe("#get_error()", function ()
|
||||
describe("basics", function ()
|
||||
local s = st.message();
|
||||
local e = st.error_reply(s, "cancel", "not-acceptable", "UNACCEPTABLE!!!! ONE MILLION YEARS DUNGEON!")
|
||||
:tag("dungeon", { xmlns = "urn:uuid:c9026187-5b05-4e70-b265-c3b6338a7d0f", period="1000000years"});
|
||||
local typ, cond, text, extra = e:get_error();
|
||||
assert.equal("cancel", typ);
|
||||
assert.equal("not-acceptable", cond);
|
||||
assert.equal("UNACCEPTABLE!!!! ONE MILLION YEARS DUNGEON!", text);
|
||||
assert.not_nil(extra)
|
||||
end)
|
||||
end)
|
||||
|
||||
describe("should reject #invalid", function ()
|
||||
local invalid_names = {
|
||||
["empty string"] = "", ["characters"] = "<>";
|
||||
|
|
|
@ -349,11 +349,11 @@ function stanza_mt.get_text(t)
|
|||
end
|
||||
|
||||
function stanza_mt.get_error(stanza)
|
||||
local error_type, condition, text;
|
||||
local error_type, condition, text, extra_tag;
|
||||
|
||||
local error_tag = stanza:get_child("error");
|
||||
if not error_tag then
|
||||
return nil, nil, nil;
|
||||
return nil, nil, nil, nil;
|
||||
end
|
||||
error_type = error_tag.attr.type;
|
||||
|
||||
|
@ -364,12 +364,14 @@ function stanza_mt.get_error(stanza)
|
|||
elseif not condition then
|
||||
condition = child.name;
|
||||
end
|
||||
if condition and text then
|
||||
break;
|
||||
end
|
||||
else
|
||||
extra_tag = child;
|
||||
end
|
||||
if condition and text and extra_tag then
|
||||
break;
|
||||
end
|
||||
end
|
||||
return error_type, condition or "undefined-condition", text;
|
||||
return error_type, condition or "undefined-condition", text, extra_tag;
|
||||
end
|
||||
|
||||
local function preserialize(stanza)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue