blob: 33fb8abc14d3015d3ad77c27627340f3f6db0f8f [file] [log] [blame]
--Copyright 2021 The casbin Authors. All Rights Reserved.
--
--Licensed under the Apache License, Version 2.0 (the "License");
--you may not use this file except in compliance with the License.
--You may obtain a copy of the License at
--
-- http://www.apache.org/licenses/LICENSE-2.0
--
--Unless required by applicable law or agreed to in writing, software
--distributed under the License is distributed on an "AS IS" BASIS,
--WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
--See the License for the specific language governing permissions and
--limitations under the License.
local Model = require("src.model.Model")
local path = os.getenv("PWD") or io.popen("cd"):read()
local basic_path = path .. "/examples/basic_model.conf"
local rbac_path = path .. "/examples/rbac_model.conf"
local rbac_with_domains_path = path .. "/examples/rbac_with_domains_model.conf"
describe("model tests", function()
it("test getPolicy", function ()
local m = Model:new()
m:loadModel(basic_path)
local rule = {'admin', 'domain1', 'data1', 'read'}
m:addPolicy("p", "p", rule)
assert.are.same({rule}, m:getPolicy("p", "p"))
end)
it("test hasPolicy", function ()
local m = Model:new()
m:loadModel(basic_path)
local rule = {'admin', 'domain1', 'data1', 'read'}
m:addPolicy("p", "p", rule)
assert.is.True(m:hasPolicy("p", "p", rule))
end)
it("test hasPolicies", function ()
local m = Model:new()
m:loadModel(basic_path)
local rule = {'admin', 'domain1', 'data1', 'read'}
m:addPolicy("p", "p", rule)
local rule1={'admin', 'domain2', 'data2', 'read'}
m:addPolicy("p", "p", rule1)
local rule2={'admin', 'domain3', 'data3', 'read'}
m:addPolicy("p", "p", rule2)
local rule3={'admin', 'domain4', 'data4', 'read'}
local rulesallmatched={rule,rule1,rule2}
local rulesonematched={rule,rule3}
local rulesnotmatched={rule3}
assert.is.True(m:hasPolicies("p", "p", rulesallmatched))
assert.is.True(m:hasPolicies("p", "p", rulesonematched))
assert.is.False(m:hasPolicies("p", "p", rulesnotmatched))
end)
it("test addPolicy", function ()
local m = Model:new()
m:loadModel(basic_path)
local rule = {'admin', 'domain1', 'data1', 'read'}
assert.is.False(m:hasPolicy("p", "p", rule))
m:addPolicy("p", "p", rule)
assert.is.True(m:hasPolicy("p", "p", rule))
end)
it("test addPoliciesWithAffected", function ()
local m = Model:new()
m:loadModel(basic_path)
local rules = {{'admin', 'domain1', 'data1', 'read'},{'admin', 'domain2', 'data2', 'read'},{'admin', 'domain1', 'data1', 'write'}}
assert.is.False(m:hasPolicies("p", "p", rules))
assert.are.same(rules,m:addPoliciesWithAffected("p", "p", rules))
assert.is.True(m:hasPolicies("p", "p", rules))
local rules1 = {{'Alice', 'domain1', 'data1', 'read'},{'Bob', 'domain2', 'data2', 'read'},{'admin', 'domain1', 'data1', 'write'}}
assert.is.True(m:hasPolicies("p", "p", rules1))
assert.are.same({{'Alice', 'domain1', 'data1', 'read'},{'Bob', 'domain2', 'data2', 'read'}},m:addPoliciesWithAffected("p", "p", rules1))
assert.is.True(m:hasPolicy("p", "p", {'Alice', 'domain1', 'data1', 'read'}))
assert.is.True(m:hasPolicy("p", "p", {'Bob', 'domain2', 'data2', 'read'}))
end)
it("test removePolicy", function ()
local m = Model:new()
m:loadModel(basic_path)
local rule = {'admin', 'domain1', 'data1', 'read'}
assert.is.False(m:hasPolicy("p", "p", rule))
m:addPolicy("p", "p", rule)
assert.is.True(m:hasPolicy("p", "p", rule))
m:removePolicy("p", "p", rule)
assert.is.False(m:hasPolicy("p", "p", rule))
assert.is.False(m:removePolicy("p", "p", rule))
end)
it("test removePoliciesWithEffected", function ()
local m = Model:new()
m:loadModel(basic_path)
local rules = {{'admin', 'domain1', 'data1', 'read'},{'admin', 'domain2', 'data2', 'read'},{'admin', 'domain1', 'data1', 'write'}}
assert.is.False(m:hasPolicies("p", "p", rules))
m:addPolicies("p", "p", rules)
assert.is.True(m:hasPolicies("p", "p", rules))
assert.are.same(rules,m:removePoliciesWithEffected("p", "p", rules))
assert.is.False(m:hasPolicies("p", "p", rules))
assert.is.False(m:removePolicy("p", "p", rules[1]))
m:addPolicies("p", "p", rules)
assert.is.True(m:hasPolicies("p", "p", rules))
local removeList={{'Alice', 'domain1', 'data1', 'read'},{'admin', 'domain2', 'data2', 'read'},{'admin', 'domain1', 'data1', 'write'}}
assert.is.False(m:hasPolicy("p", "p", {'Alice', 'domain1', 'data1', 'read'}))
assert.are.same({{'admin', 'domain2', 'data2', 'read'},{'admin', 'domain1', 'data1', 'write'}},m:removePoliciesWithEffected("p", "p", removeList))
assert.is.False(m:hasPolicy("p", "p", removeList[2]))
assert.is.False(m:removePolicy("p", "p", removeList[3]))
end)
it("test addRolePolicy", function ()
local m = Model:new()
m:loadModel(rbac_path)
local p_rule1 = {'alice', 'data1', 'read'}
m:addPolicy("p", "p", p_rule1)
assert.is.True(m:hasPolicy("p", "p", p_rule1))
local p_rule2 = {'data2_admin', 'data2', 'read'}
m:addPolicy("p", "p", p_rule2)
assert.is.True(m:hasPolicy("p", "p", p_rule2))
local g_rule = {'alice', 'data2_admin'}
m:addPolicy("g", "g", g_rule)
assert.is.True(m:hasPolicy("g", "g", g_rule))
assert.are.same({p_rule1, p_rule2}, m:getPolicy("p", "p"))
assert.are.same({g_rule}, m:getPolicy("g", "g"))
end)
it("test updatePolicy", function ()
local m = Model:new()
m:loadModel(basic_path)
local oldRule = {'admin', 'domain1', 'data1', 'read'}
local newRule = {'admin', 'domain1', 'data2', 'read'}
m:addPolicy("p", "p", oldRule)
assert.is.True(m:hasPolicy("p", "p", oldRule))
m:updatePolicy("p", "p", oldRule, newRule)
assert.is.False(m:hasPolicy("p", "p", oldRule))
assert.is.True(m:hasPolicy("p", "p", newRule))
end)
it("test updatePolicies", function ()
local m = Model:new()
m:loadModel(basic_path)
local oldRules = {
{'admin', 'domain1', 'data1', 'read'},
{'admin', 'domain1', 'data2', 'read'},
{'admin', 'domain1', 'data3', 'read'}
}
local newRules = {
{'admin', 'domain1', 'data4', 'read'},
{'admin', 'domain1', 'data5', 'read'},
{'admin', 'domain1', 'data6', 'read'}
}
m:addPolicies("p", "p", oldRules)
for _, oldRule in pairs(oldRules) do
assert.is.True(m:hasPolicy("p", "p", oldRule))
end
m:updatePolicies("p", "p", oldRules, newRules)
for _, oldRule in pairs(oldRules) do
assert.is.False(m:hasPolicy("p", "p", oldRule))
end
for _, newRule in pairs(newRules) do
assert.is.True(m:hasPolicy("p", "p", newRule))
end
local oldRules1 = {
{'admin', 'domain1', 'data4', 'read'},
{'admin', 'domain1', 'data5', 'read'},
}
local newRules1 = {
{'admin', 'domain1', 'data1', 'read'},
{'admin', 'domain1', 'data2', 'read'}
}
local resRules1 = {
{'admin', 'domain1', 'data1', 'read'},
{'admin', 'domain1', 'data2', 'read'},
{'admin', 'domain1', 'data6', 'read'}
}
for _, oldRule in pairs(oldRules1) do
assert.is.True(m:hasPolicy("p", "p", oldRule))
end
m:updatePolicies("p", "p", oldRules1, newRules1)
for _, oldRule in pairs(oldRules1) do
assert.is.False(m:hasPolicy("p", "p", oldRule))
end
for _, newRule in pairs(newRules1) do
assert.is.True(m:hasPolicy("p", "p", newRule))
end
assert.is.same(resRules1,m:getPolicy("p", "p"))
end)
it("test clearPolicy", function ()
local m = Model:new()
m:loadModel(basic_path)
local rule = {
{'admin', 'domain1', 'data1', 'read'},
{'admin', 'domain1', 'data2', 'read'}
}
m:addPolicies("p", "p", rule)
assert.are.same(rule, m:getPolicy("p", "p"))
m:clearPolicy()
assert.are.same({}, m:getPolicy("p", "p"))
end)
it("test removeFilteredPolicy", function ()
local m = Model:new()
m:loadModel(rbac_with_domains_path)
local rule = {'admin', 'domain1', 'data1', 'read'}
m:addPolicy("p", "p", rule)
local res = m:removeFilteredPolicy("p", "p", 1, {"domain1", "data1"})
assert.is.True(res)
res = m:removeFilteredPolicy("p", "p", 1, {"domain1", "data1"})
assert.is.False(res)
end)
it("test updateFilteredPolicies", function ()
local m = Model:new()
m:loadModel(rbac_with_domains_path)
local rules = {
{'admin', 'domain1', 'data1', 'read'},
{'admin1', 'domain1', 'data1', 'read'},
{'admin', 'domain2', 'data3', 'read'}
}
m:addPolicies("p", "p", rules)
local newRules = {
{'admin', 'domain1', 'data1', 'write'},
{'admin1', 'domain1', 'data1', 'write'},
}
m:updateFilteredPolicies("p", "p", 1, {"domain1", "data1"},newRules)
local resRules = {
{'admin', 'domain1', 'data1', 'write'},
{'admin1', 'domain1', 'data1', 'write'},
{'admin', 'domain2', 'data3', 'read'}
}
assert.are.same(resRules, m:getPolicy("p","p"))
end)
it("test getFilteredPolicy", function ()
local m = Model:new()
m:loadModel(rbac_with_domains_path)
local rules = {
{'admin', 'domain1', 'data1', 'read'},
{'admin', 'domain1', 'data2', 'read'},
{'admin', 'domain2', 'data3', 'read'}
}
m:addPolicies("p", "p", rules)
local res = m:getFilteredPolicy("p", "p", 1, "domain1")
local filteredRules = {
{'admin', 'domain1', 'data1', 'read'},
{'admin', 'domain1', 'data2', 'read'}
}
assert.are.same(filteredRules, res)
end)
it("test toText", function ()
local m = Model:new()
m:loadModel(basic_path)
local res = m:toText()
local saveText="[request_definition]\nr = sub, obj, act\n[policy_definition]\np = sub, obj, act\n[policy_effect]\ne = some(where (p.eft == allow))\n[matchers]\nm = r.sub == p.sub && r.obj == p.obj && r.act == p.act\n"
assert.are.same(saveText, res)
end)
it("test printPolicy and printModel", function ()
local m = Model:new()
m:loadModel(basic_path)
assert.has_no.errors(function ()
m:printModel()
m:printPolicy()
end)
end)
it("test copy", function ()
local m = Model:new()
m:loadModel(basic_path)
local rule = {'admin', 'domain1', 'data1', 'read'}
m:addPolicy("p", "p", rule)
assert.is.same(m.model,m:copy())
end)
end)