2019-03-16 15:03:47 +00:00
|
|
|
# frozen_string_literal: true
|
2019-03-15 01:32:57 +00:00
|
|
|
|
2011-04-05 22:37:45 +00:00
|
|
|
# Redmine - project management software
|
2024-02-26 22:55:54 +00:00
|
|
|
# Copyright (C) 2006- Jean-Philippe Lang
|
2008-03-15 08:27:38 +00:00
|
|
|
#
|
|
|
|
|
# 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.
|
2011-08-30 05:48:28 +00:00
|
|
|
#
|
2008-03-15 08:27:38 +00:00
|
|
|
# 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.
|
2011-08-30 05:48:28 +00:00
|
|
|
#
|
2008-03-15 08:27:38 +00:00
|
|
|
# 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.
|
|
|
|
|
|
2023-01-01 07:13:39 +00:00
|
|
|
require_relative '../test_helper'
|
2008-03-15 08:27:38 +00:00
|
|
|
|
2009-09-13 17:14:35 +00:00
|
|
|
class RoleTest < ActiveSupport::TestCase
|
2018-12-16 17:23:31 +00:00
|
|
|
def setup
|
|
|
|
|
User.current = nil
|
|
|
|
|
end
|
|
|
|
|
|
2012-05-25 20:43:18 +00:00
|
|
|
def test_sorted_scope
|
2014-10-22 17:37:16 +00:00
|
|
|
assert_equal Role.all.sort, Role.sorted.to_a
|
2012-05-25 20:43:18 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def test_givable_scope
|
2014-10-22 17:37:16 +00:00
|
|
|
assert_equal Role.all.reject(&:builtin?).sort, Role.givable.to_a
|
2012-05-25 20:43:18 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def test_builtin_scope
|
2014-10-22 17:37:16 +00:00
|
|
|
assert_equal Role.all.select(&:builtin?).sort, Role.builtin(true).to_a.sort
|
|
|
|
|
assert_equal Role.all.reject(&:builtin?).sort, Role.builtin(false).to_a.sort
|
2012-05-25 20:43:18 +00:00
|
|
|
end
|
|
|
|
|
|
2012-09-03 17:04:28 +00:00
|
|
|
def test_copy_from
|
|
|
|
|
role = Role.find(1)
|
|
|
|
|
copy = Role.new.copy_from(role)
|
|
|
|
|
|
|
|
|
|
assert_nil copy.id
|
|
|
|
|
assert_equal '', copy.name
|
|
|
|
|
assert_equal role.permissions, copy.permissions
|
|
|
|
|
|
|
|
|
|
copy.name = 'Copy'
|
|
|
|
|
assert copy.save
|
|
|
|
|
end
|
|
|
|
|
|
2016-10-20 17:00:04 +00:00
|
|
|
def test_copy_from_should_copy_managed_roles
|
|
|
|
|
orig = Role.generate!(:all_roles_managed => false, :managed_role_ids => [2, 3])
|
|
|
|
|
role = Role.new
|
|
|
|
|
role.copy_from orig
|
|
|
|
|
assert_equal [2, 3], role.managed_role_ids.sort
|
|
|
|
|
end
|
|
|
|
|
|
2008-03-15 08:27:38 +00:00
|
|
|
def test_copy_workflows
|
|
|
|
|
source = Role.find(1)
|
2015-07-26 08:30:19 +00:00
|
|
|
rule_count = source.workflow_rules.count
|
|
|
|
|
assert rule_count > 0
|
2011-08-30 05:48:28 +00:00
|
|
|
|
2008-03-15 08:27:38 +00:00
|
|
|
target = Role.new(:name => 'Target')
|
|
|
|
|
assert target.save
|
2017-06-03 08:04:13 +00:00
|
|
|
target.copy_workflow_rules(source)
|
2008-03-15 08:27:38 +00:00
|
|
|
target.reload
|
2015-07-26 08:30:19 +00:00
|
|
|
assert_equal rule_count, target.workflow_rules.size
|
2008-03-15 08:27:38 +00:00
|
|
|
end
|
2008-09-13 16:31:11 +00:00
|
|
|
|
2012-07-05 13:04:38 +00:00
|
|
|
def test_permissions_should_be_unserialized_with_its_coder
|
2014-12-21 11:57:01 +00:00
|
|
|
Role::PermissionsAttributeCoder.stubs(:load).returns([:foo, :bar])
|
|
|
|
|
role = Role.find(1)
|
|
|
|
|
assert_equal [:foo, :bar], role.permissions
|
2012-07-05 13:04:38 +00:00
|
|
|
end
|
|
|
|
|
|
2008-09-13 16:31:11 +00:00
|
|
|
def test_add_permission
|
|
|
|
|
role = Role.find(1)
|
|
|
|
|
size = role.permissions.size
|
|
|
|
|
role.add_permission!("apermission", "anotherpermission")
|
|
|
|
|
role.reload
|
|
|
|
|
assert role.permissions.include?(:anotherpermission)
|
|
|
|
|
assert_equal size + 2, role.permissions.size
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def test_remove_permission
|
|
|
|
|
role = Role.find(1)
|
|
|
|
|
size = role.permissions.size
|
|
|
|
|
perm = role.permissions[0..1]
|
|
|
|
|
role.remove_permission!(*perm)
|
|
|
|
|
role.reload
|
|
|
|
|
assert ! role.permissions.include?(perm[0])
|
|
|
|
|
assert_equal size - 2, role.permissions.size
|
|
|
|
|
end
|
2011-08-30 05:48:28 +00:00
|
|
|
|
2014-12-06 13:16:43 +00:00
|
|
|
def test_has_permission
|
|
|
|
|
role = Role.create!(:name => 'Test', :permissions => [:view_issues, :edit_issues])
|
|
|
|
|
assert_equal true, role.has_permission?(:view_issues)
|
|
|
|
|
assert_equal false, role.has_permission?(:delete_issues)
|
|
|
|
|
end
|
|
|
|
|
|
2023-01-19 11:54:03 +00:00
|
|
|
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
|
|
|
|
|
|
2014-12-06 13:16:43 +00:00
|
|
|
def test_has_permission_without_permissions
|
|
|
|
|
role = Role.create!(:name => 'Test')
|
|
|
|
|
assert_equal false, role.has_permission?(:delete_issues)
|
|
|
|
|
end
|
|
|
|
|
|
2011-04-05 22:37:45 +00:00
|
|
|
def test_name
|
|
|
|
|
I18n.locale = 'fr'
|
|
|
|
|
assert_equal 'Manager', Role.find(1).name
|
|
|
|
|
assert_equal 'Anonyme', Role.anonymous.name
|
|
|
|
|
assert_equal 'Non membre', Role.non_member.name
|
|
|
|
|
end
|
2008-09-13 16:31:11 +00:00
|
|
|
|
2012-05-25 20:43:18 +00:00
|
|
|
def test_find_all_givable
|
|
|
|
|
assert_equal Role.all.reject(&:builtin?).sort, Role.find_all_givable
|
|
|
|
|
end
|
|
|
|
|
|
2013-05-18 09:14:10 +00:00
|
|
|
def test_anonymous_should_return_the_anonymous_role
|
|
|
|
|
assert_no_difference('Role.count') do
|
2010-02-03 17:47:47 +00:00
|
|
|
role = Role.anonymous
|
|
|
|
|
assert role.builtin?
|
|
|
|
|
assert_equal Role::BUILTIN_ANONYMOUS, role.builtin
|
|
|
|
|
end
|
2013-05-18 09:14:10 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def test_anonymous_with_a_missing_anonymous_role_should_return_the_anonymous_role
|
|
|
|
|
Role.where(:builtin => Role::BUILTIN_ANONYMOUS).delete_all
|
2010-02-03 17:47:47 +00:00
|
|
|
|
2013-05-18 09:14:10 +00:00
|
|
|
assert_difference('Role.count') do
|
|
|
|
|
role = Role.anonymous
|
|
|
|
|
assert role.builtin?
|
|
|
|
|
assert_equal Role::BUILTIN_ANONYMOUS, role.builtin
|
2010-02-03 17:47:47 +00:00
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2013-05-18 09:14:10 +00:00
|
|
|
def test_non_member_should_return_the_non_member_role
|
|
|
|
|
assert_no_difference('Role.count') do
|
2010-02-03 17:47:47 +00:00
|
|
|
role = Role.non_member
|
|
|
|
|
assert role.builtin?
|
|
|
|
|
assert_equal Role::BUILTIN_NON_MEMBER, role.builtin
|
|
|
|
|
end
|
2013-05-18 09:14:10 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
|
|
def test_non_member_with_a_missing_non_member_role_should_return_the_non_member_role
|
|
|
|
|
Role.where(:builtin => Role::BUILTIN_NON_MEMBER).delete_all
|
2010-02-03 17:47:47 +00:00
|
|
|
|
2013-05-18 09:14:10 +00:00
|
|
|
assert_difference('Role.count') do
|
|
|
|
|
role = Role.non_member
|
|
|
|
|
assert role.builtin?
|
|
|
|
|
assert_equal Role::BUILTIN_NON_MEMBER, role.builtin
|
2010-02-03 17:47:47 +00:00
|
|
|
end
|
|
|
|
|
end
|
2022-02-28 21:16:08 +00:00
|
|
|
|
|
|
|
|
def test_destroy
|
|
|
|
|
role = Role.generate!
|
|
|
|
|
|
|
|
|
|
# generate some dependent objects
|
|
|
|
|
query = IssueQuery.generate!(:project => @ecookbook, :visibility => Query::VISIBILITY_ROLES, :roles => Role.where(:id => [1, 3, role.id]).to_a)
|
|
|
|
|
|
|
|
|
|
role.destroy
|
|
|
|
|
|
|
|
|
|
# make sure some related data was removed
|
|
|
|
|
assert_nil ActiveRecord::Base.connection.select_value("SELECT 1 FROM queries_roles WHERE role_id = #{role.id}")
|
|
|
|
|
assert [1, 3], query.roles
|
|
|
|
|
end
|
2008-03-15 08:27:38 +00:00
|
|
|
end
|