Skip to content

Commit

Permalink
Add tests on Access rules returning values
Browse files Browse the repository at this point in the history
  • Loading branch information
mremond committed Apr 7, 2016
1 parent 60c0c8e commit 373f9fb
Showing 1 changed file with 14 additions and 0 deletions.
14 changes: 14 additions & 0 deletions test/acl_test.exs
Expand Up @@ -70,6 +70,20 @@ defmodule ACLTest do
assert :acl.match_rule(:global, :user_rule_1, :jid.from_string("test1@domain2")) == :deny
end

# Access rules are sometimes used to provide values (i.e.: max_s2s_connections, max_user_sessions)
test "Access rules providing values" do
:acl.add(:global, :user_acl, {:user_regexp, ""})
:acl.add(:global, :admin_acl, {:user, "admin"})
:acl.add_access(:global, :value_rule_1, [{:admin_acl, 10}, {:user_acl, 5}])
assert :acl.match_rule(:global, :value_rule_1, :jid.from_string("test1@domain1")) == 5
assert :acl.match_rule(:global, :value_rule_1, :jid.from_string("admin@domain1")) == 10

# If we have no match, :deny is still the default value
# TODO maybe we should have a match rule which allow passing custom default value ?
assert :acl.match_rule(:global, :value_rule_1, :jid.from_string("user@otherdomain")) == :deny
end


# At the moment IP and user rules to no go well together:
test "mixing IP and user access rules" do
:acl.add(:global, :user_acl_1, {:user, "test1"})
Expand Down

0 comments on commit 373f9fb

Please sign in to comment.