summaryrefslogtreecommitdiffstats
path: root/test/unit/role_test.rb
diff options
context:
space:
mode:
authorGo MAEDA <maeda@farend.jp>2023-01-19 11:57:35 +0000
committerGo MAEDA <maeda@farend.jp>2023-01-19 11:57:35 +0000
commit6bd8970afb045e836789679c52b57f6a789c964e (patch)
tree8c7c3af610f3f7c5ba02d1c3b71788bebab6ad95 /test/unit/role_test.rb
parent5c2925bea66349ecefcf32f507ccef55017dbcfe (diff)
downloadredmine-6bd8970afb045e836789679c52b57f6a789c964e.tar.gz
redmine-6bd8970afb045e836789679c52b57f6a789c964e.zip
Merged r22063 from trunk to 4.2-stable (#38070).
git-svn-id: https://svn.redmine.org/redmine/branches/4.2-stable@22065 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'test/unit/role_test.rb')
-rw-r--r--test/unit/role_test.rb76
1 files changed, 76 insertions, 0 deletions
diff --git a/test/unit/role_test.rb b/test/unit/role_test.rb
index 472ff805f..7e907233d 100644
--- a/test/unit/role_test.rb
+++ b/test/unit/role_test.rb
@@ -101,6 +101,82 @@ class RoleTest < ActiveSupport::TestCase
assert_equal false, role.has_permission?(:delete_issues)
end
+ def test_permissions_all_trackers?
+ role = Role.create!(:name => 'Test', :permissions => [:view_issues])
+ assert_equal true, role.permissions_all_trackers?(:view_issues)
+ assert_equal false, role.permissions_all_trackers?(:edit_issues)
+
+ role.set_permission_trackers :view_issues, [1]
+ role.set_permission_trackers :edit_issues, [1]
+ assert_equal false, role.permissions_all_trackers?(:view_issues)
+ assert_equal false, role.permissions_all_trackers?(:edit_issues)
+
+ role.set_permission_trackers :view_issues, :all
+ role.set_permission_trackers :edit_issues, :all
+ assert_equal true, role.permissions_all_trackers?(:view_issues)
+ assert_equal false, role.permissions_all_trackers?(:edit_issues)
+ end
+
+ def test_permissions_all_trackers_considers_base_permission
+ role = Role.create!(:name => 'Test', :permissions => [:view_issues])
+ assert_equal true, role.permissions_all_trackers?(:view_issues)
+
+ role.remove_permission!(:view_issues)
+ assert_equal false, role.permissions_all_trackers?(:view_issues)
+ end
+
+ def test_permissions_tracker_ids?
+ role = Role.create!(:name => 'Test', :permissions => [:view_issues])
+ assert_equal false, role.permissions_tracker_ids?(:view_issues, 1)
+ assert_equal false, role.permissions_tracker_ids?(:edit_issues, 1)
+
+ role.set_permission_trackers :view_issues, [1, 2, 3]
+ role.set_permission_trackers :edit_issues, [1, 2, 3]
+
+ assert_equal true, role.permissions_tracker_ids?(:view_issues, 1)
+ assert_equal false, role.permissions_tracker_ids?(:edit_issues, 1)
+ end
+
+ def test_permissions_tracker_ids_considers_base_permission
+ role = Role.create!(:name => 'Test', :permissions => [:view_issues])
+ role.set_permission_trackers :view_issues, [1, 2, 3]
+ assert_equal true, role.permissions_tracker_ids?(:view_issues, 1)
+
+ role.remove_permission!(:view_issues)
+ assert_equal false, role.permissions_tracker_ids?(:view_issues, 1)
+ end
+
+ def test_permissions_tracker?
+ tracker = Tracker.find(1)
+ role = Role.create!(:name => 'Test', :permissions => [:view_issues])
+ assert_equal true, role.permissions_tracker?(:view_issues, 1)
+ assert_equal false, role.permissions_tracker?(:edit_issues, 1)
+
+ role.set_permission_trackers :view_issues, [1]
+ role.set_permission_trackers :edit_issues, [1]
+ assert_equal true, role.permissions_tracker?(:view_issues, tracker)
+ assert_equal false, role.permissions_tracker?(:edit_issues, tracker)
+
+ role.set_permission_trackers :view_issues, [2]
+ role.set_permission_trackers :edit_issues, [2]
+ assert_equal false, role.permissions_tracker?(:view_issues, tracker)
+ assert_equal false, role.permissions_tracker?(:edit_issues, tracker)
+
+ role.set_permission_trackers :view_issues, :all
+ role.set_permission_trackers :edit_issues, :all
+ assert_equal true, role.permissions_tracker?(:view_issues, tracker)
+ assert_equal false, role.permissions_tracker?(:edit_issues, tracker)
+ end
+
+ def test_permissions_tracker_considers_base_permission
+ role = Role.create!(:name => 'Test', :permissions => [:edit_isues])
+ role.set_permission_trackers :view_issues, [1, 2, 3]
+ assert_equal false, role.permissions_tracker_ids?(:view_issues, 1)
+
+ role.set_permission_trackers :view_issues, :all
+ assert_equal false, role.permissions_tracker_ids?(:view_issues, 1)
+ end
+
def test_has_permission_without_permissions
role = Role.create!(:name => 'Test')
assert_equal false, role.has_permission?(:delete_issues)