You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

role_test.rb 8.3KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244
  1. # frozen_string_literal: true
  2. # Redmine - project management software
  3. # Copyright (C) 2006- Jean-Philippe Lang
  4. #
  5. # This program is free software; you can redistribute it and/or
  6. # modify it under the terms of the GNU General Public License
  7. # as published by the Free Software Foundation; either version 2
  8. # of the License, or (at your option) any later version.
  9. #
  10. # This program is distributed in the hope that it will be useful,
  11. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. # GNU General Public License for more details.
  14. #
  15. # You should have received a copy of the GNU General Public License
  16. # along with this program; if not, write to the Free Software
  17. # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  18. require_relative '../test_helper'
  19. class RoleTest < ActiveSupport::TestCase
  20. fixtures :roles, :workflows, :trackers, :users
  21. def setup
  22. User.current = nil
  23. end
  24. def test_sorted_scope
  25. assert_equal Role.all.sort, Role.sorted.to_a
  26. end
  27. def test_givable_scope
  28. assert_equal Role.all.reject(&:builtin?).sort, Role.givable.to_a
  29. end
  30. def test_builtin_scope
  31. assert_equal Role.all.select(&:builtin?).sort, Role.builtin(true).to_a.sort
  32. assert_equal Role.all.reject(&:builtin?).sort, Role.builtin(false).to_a.sort
  33. end
  34. def test_copy_from
  35. role = Role.find(1)
  36. copy = Role.new.copy_from(role)
  37. assert_nil copy.id
  38. assert_equal '', copy.name
  39. assert_equal role.permissions, copy.permissions
  40. copy.name = 'Copy'
  41. assert copy.save
  42. end
  43. def test_copy_from_should_copy_managed_roles
  44. orig = Role.generate!(:all_roles_managed => false, :managed_role_ids => [2, 3])
  45. role = Role.new
  46. role.copy_from orig
  47. assert_equal [2, 3], role.managed_role_ids.sort
  48. end
  49. def test_copy_workflows
  50. source = Role.find(1)
  51. rule_count = source.workflow_rules.count
  52. assert rule_count > 0
  53. target = Role.new(:name => 'Target')
  54. assert target.save
  55. target.copy_workflow_rules(source)
  56. target.reload
  57. assert_equal rule_count, target.workflow_rules.size
  58. end
  59. def test_permissions_should_be_unserialized_with_its_coder
  60. Role::PermissionsAttributeCoder.stubs(:load).returns([:foo, :bar])
  61. role = Role.find(1)
  62. assert_equal [:foo, :bar], role.permissions
  63. end
  64. def test_add_permission
  65. role = Role.find(1)
  66. size = role.permissions.size
  67. role.add_permission!("apermission", "anotherpermission")
  68. role.reload
  69. assert role.permissions.include?(:anotherpermission)
  70. assert_equal size + 2, role.permissions.size
  71. end
  72. def test_remove_permission
  73. role = Role.find(1)
  74. size = role.permissions.size
  75. perm = role.permissions[0..1]
  76. role.remove_permission!(*perm)
  77. role.reload
  78. assert ! role.permissions.include?(perm[0])
  79. assert_equal size - 2, role.permissions.size
  80. end
  81. def test_has_permission
  82. role = Role.create!(:name => 'Test', :permissions => [:view_issues, :edit_issues])
  83. assert_equal true, role.has_permission?(:view_issues)
  84. assert_equal false, role.has_permission?(:delete_issues)
  85. end
  86. def test_permissions_all_trackers?
  87. role = Role.create!(:name => 'Test', :permissions => [:view_issues])
  88. assert_equal true, role.permissions_all_trackers?(:view_issues)
  89. assert_equal false, role.permissions_all_trackers?(:edit_issues)
  90. role.set_permission_trackers :view_issues, [1]
  91. role.set_permission_trackers :edit_issues, [1]
  92. assert_equal false, role.permissions_all_trackers?(:view_issues)
  93. assert_equal false, role.permissions_all_trackers?(:edit_issues)
  94. role.set_permission_trackers :view_issues, :all
  95. role.set_permission_trackers :edit_issues, :all
  96. assert_equal true, role.permissions_all_trackers?(:view_issues)
  97. assert_equal false, role.permissions_all_trackers?(:edit_issues)
  98. end
  99. def test_permissions_all_trackers_considers_base_permission
  100. role = Role.create!(:name => 'Test', :permissions => [:view_issues])
  101. assert_equal true, role.permissions_all_trackers?(:view_issues)
  102. role.remove_permission!(:view_issues)
  103. assert_equal false, role.permissions_all_trackers?(:view_issues)
  104. end
  105. def test_permissions_tracker_ids?
  106. role = Role.create!(:name => 'Test', :permissions => [:view_issues])
  107. assert_equal false, role.permissions_tracker_ids?(:view_issues, 1)
  108. assert_equal false, role.permissions_tracker_ids?(:edit_issues, 1)
  109. role.set_permission_trackers :view_issues, [1, 2, 3]
  110. role.set_permission_trackers :edit_issues, [1, 2, 3]
  111. assert_equal true, role.permissions_tracker_ids?(:view_issues, 1)
  112. assert_equal false, role.permissions_tracker_ids?(:edit_issues, 1)
  113. end
  114. def test_permissions_tracker_ids_considers_base_permission
  115. role = Role.create!(:name => 'Test', :permissions => [:view_issues])
  116. role.set_permission_trackers :view_issues, [1, 2, 3]
  117. assert_equal true, role.permissions_tracker_ids?(:view_issues, 1)
  118. role.remove_permission!(:view_issues)
  119. assert_equal false, role.permissions_tracker_ids?(:view_issues, 1)
  120. end
  121. def test_permissions_tracker?
  122. tracker = Tracker.find(1)
  123. role = Role.create!(:name => 'Test', :permissions => [:view_issues])
  124. assert_equal true, role.permissions_tracker?(:view_issues, 1)
  125. assert_equal false, role.permissions_tracker?(:edit_issues, 1)
  126. role.set_permission_trackers :view_issues, [1]
  127. role.set_permission_trackers :edit_issues, [1]
  128. assert_equal true, role.permissions_tracker?(:view_issues, tracker)
  129. assert_equal false, role.permissions_tracker?(:edit_issues, tracker)
  130. role.set_permission_trackers :view_issues, [2]
  131. role.set_permission_trackers :edit_issues, [2]
  132. assert_equal false, role.permissions_tracker?(:view_issues, tracker)
  133. assert_equal false, role.permissions_tracker?(:edit_issues, tracker)
  134. role.set_permission_trackers :view_issues, :all
  135. role.set_permission_trackers :edit_issues, :all
  136. assert_equal true, role.permissions_tracker?(:view_issues, tracker)
  137. assert_equal false, role.permissions_tracker?(:edit_issues, tracker)
  138. end
  139. def test_permissions_tracker_considers_base_permission
  140. role = Role.create!(:name => 'Test', :permissions => [:edit_isues])
  141. role.set_permission_trackers :view_issues, [1, 2, 3]
  142. assert_equal false, role.permissions_tracker_ids?(:view_issues, 1)
  143. role.set_permission_trackers :view_issues, :all
  144. assert_equal false, role.permissions_tracker_ids?(:view_issues, 1)
  145. end
  146. def test_has_permission_without_permissions
  147. role = Role.create!(:name => 'Test')
  148. assert_equal false, role.has_permission?(:delete_issues)
  149. end
  150. def test_name
  151. I18n.locale = 'fr'
  152. assert_equal 'Manager', Role.find(1).name
  153. assert_equal 'Anonyme', Role.anonymous.name
  154. assert_equal 'Non membre', Role.non_member.name
  155. end
  156. def test_find_all_givable
  157. assert_equal Role.all.reject(&:builtin?).sort, Role.find_all_givable
  158. end
  159. def test_anonymous_should_return_the_anonymous_role
  160. assert_no_difference('Role.count') do
  161. role = Role.anonymous
  162. assert role.builtin?
  163. assert_equal Role::BUILTIN_ANONYMOUS, role.builtin
  164. end
  165. end
  166. def test_anonymous_with_a_missing_anonymous_role_should_return_the_anonymous_role
  167. Role.where(:builtin => Role::BUILTIN_ANONYMOUS).delete_all
  168. assert_difference('Role.count') do
  169. role = Role.anonymous
  170. assert role.builtin?
  171. assert_equal Role::BUILTIN_ANONYMOUS, role.builtin
  172. end
  173. end
  174. def test_non_member_should_return_the_non_member_role
  175. assert_no_difference('Role.count') do
  176. role = Role.non_member
  177. assert role.builtin?
  178. assert_equal Role::BUILTIN_NON_MEMBER, role.builtin
  179. end
  180. end
  181. def test_non_member_with_a_missing_non_member_role_should_return_the_non_member_role
  182. Role.where(:builtin => Role::BUILTIN_NON_MEMBER).delete_all
  183. assert_difference('Role.count') do
  184. role = Role.non_member
  185. assert role.builtin?
  186. assert_equal Role::BUILTIN_NON_MEMBER, role.builtin
  187. end
  188. end
  189. def test_destroy
  190. role = Role.generate!
  191. # generate some dependent objects
  192. query = IssueQuery.generate!(:project => @ecookbook, :visibility => Query::VISIBILITY_ROLES, :roles => Role.where(:id => [1, 3, role.id]).to_a)
  193. role.destroy
  194. # make sure some related data was removed
  195. assert_nil ActiveRecord::Base.connection.select_value("SELECT 1 FROM queries_roles WHERE role_id = #{role.id}")
  196. assert [1, 3], query.roles
  197. end
  198. end