IMPORTANT: due to a drive failure, as of 13-Mar-2021, the Mercurial repository had to be re-mirrored, which changed every commit SHA. The old SHAs and trees are backed up in the vault branches. Please migrate to the new branches as soon as you can.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
prosody/spec/util_sasl_spec.lua

75 lines
2.0 KiB

local sasl = require "util.sasl";
-- profile * mechanism
-- callbacks could use spies instead
describe("util.sasl", function ()
describe("plain_test profile", function ()
local profile = {
plain_test = function (_, username, password, realm)
assert.equals("user", username)
assert.equals("pencil", password)
assert.equals("sasl.test", realm)
return true, true;
end;
};
it("works with PLAIN", function ()
local plain = sasl.new("sasl.test", profile);
assert.truthy(plain:select("PLAIN"));
assert.truthy(plain:process("\000user\000pencil"));
assert.equals("user", plain.username);
end);
end);
describe("plain profile", function ()
local profile = {
plain = function (_, username, realm)
assert.equals("user", username)
assert.equals("sasl.test", realm)
return "pencil", true;
end;
};
it("works with PLAIN", function ()
local plain = sasl.new("sasl.test", profile);
assert.truthy(plain:select("PLAIN"));
assert.truthy(plain:process("\000user\000pencil"));
assert.equals("user", plain.username);
end);
-- TODO SCRAM
end);
describe("oauthbearer profile", function()
local profile = {
oauthbearer = function(_, token, _realm, _authzid)
if token == "example-bearer-token" then
return "user", true, {};
else
return nil, nil, {}
end
end;
}
it("works with OAUTHBEARER", function()
local bearer = sasl.new("sasl.test", profile);
assert.truthy(bearer:select("OAUTHBEARER"));
assert.equals("success", bearer:process("n,,\1auth=Bearer example-bearer-token\1\1"));
assert.equals("user", bearer.username);
end)
it("returns extras with OAUTHBEARER", function()
local bearer = sasl.new("sasl.test", profile);
assert.truthy(bearer:select("OAUTHBEARER"));
local status, extra = bearer:process("n,,\1auth=Bearer unknown\1\1");
assert.equals("challenge", status);
assert.equals("{\"status\":\"invalid_token\"}", extra);
assert.equals("failure", bearer:process("\1"));
end)
end)
end);