diff options
author | Mickael Remond <mremond@process-one.net> | 2016-04-06 13:59:33 +0200 |
---|---|---|
committer | Mickael Remond <mremond@process-one.net> | 2016-04-06 18:13:08 +0200 |
commit | d45ad3e3a57a5c4ea1f28f7df4b059ec8d766e6f (patch) | |
tree | 0d9070f7332e4f44dcf6ca359fb9db6d09e1c04a /test | |
parent | Export add_access/3 to allow setting ACL outside of yaml config file (diff) |
Add initial basic ACL test
Diffstat (limited to 'test')
-rw-r--r-- | test/acl_test.exs | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/test/acl_test.exs b/test/acl_test.exs new file mode 100644 index 00000000..0aca9bce --- /dev/null +++ b/test/acl_test.exs @@ -0,0 +1,42 @@ +# ---------------------------------------------------------------------- +# +# ejabberd, Copyright (C) 2002-2016 ProcessOne +# +# This program is free software; you can redistribute it and/or +# modify it under the terms of the GNU General Public License as +# published by the Free Software Foundation; either version 2 of the +# License, or (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# General Public License for more details. +# +# You should have received a copy of the GNU General Public License along +# with this program; if not, write to the Free Software Foundation, Inc., +# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. +# +# ---------------------------------------------------------------------- + +defmodule ACLTest do + @author "mremond@process-one.net" + + use ExUnit.Case, async: false + + setup_all do + :ok = :mnesia.start + :ok = :jid.start + :ok = :ejabberd_config.start(["domain1", "domain2"], []) + :ok = :acl.start + end + + test "simple user access rule matches" do + :acl.add(:global, :basic_acl_1, {:user, "test1"}) + :acl.add_access(:global, :basic_rule_1, [{:basic_acl_1, :allow}]) + assert :acl.match_rule(:global, :basic_rule_1, :jid.from_string("test1@domain1")) == :allow + assert :acl.match_rule(:global, :basic_rule_1, :jid.from_string("test1@domain2")) == :allow + # We match on user part only for local domain. As an implicit rule remote domain are not matched + assert :acl.match_rule(:global, :basic_rule_1, :jid.from_string("test1@otherdomain")) == :deny + assert :acl.match_rule(:global, :basic_rule_1, :jid.from_string("test11@domain1")) == :deny + end +end |