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.

roles_controller_test.rb 8.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263
  1. # Redmine - project management software
  2. # Copyright (C) 2006-2017 Jean-Philippe Lang
  3. #
  4. # This program is free software; you can redistribute it and/or
  5. # modify it under the terms of the GNU General Public License
  6. # as published by the Free Software Foundation; either version 2
  7. # of the License, or (at your option) any later version.
  8. #
  9. # This program is distributed in the hope that it will be useful,
  10. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. # GNU General Public License for more details.
  13. #
  14. # You should have received a copy of the GNU General Public License
  15. # along with this program; if not, write to the Free Software
  16. # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  17. require File.expand_path('../../test_helper', __FILE__)
  18. class RolesControllerTest < Redmine::ControllerTest
  19. fixtures :roles, :users, :members, :member_roles, :workflows, :trackers
  20. def setup
  21. User.current = nil
  22. @request.session[:user_id] = 1 # admin
  23. end
  24. def test_index
  25. get :index
  26. assert_response :success
  27. assert_select 'table.roles tbody' do
  28. assert_select 'tr', Role.count
  29. assert_select 'a[href="/roles/1/edit"]', :text => 'Manager'
  30. end
  31. end
  32. def test_new
  33. get :new
  34. assert_response :success
  35. assert_select 'input[name=?]', 'role[name]'
  36. assert_select 'input[name=?]', 'role[permissions][]'
  37. end
  38. def test_new_should_prefill_permissions_with_non_member_permissions
  39. role = Role.non_member
  40. role.permissions = [:view_issues, :view_documents]
  41. role.save!
  42. get :new
  43. assert_response :success
  44. assert_equal %w(view_documents view_issues),
  45. css_select('input[name="role[permissions][]"][checked=checked]').map {|e| e.attr('value')}.sort
  46. end
  47. def test_new_with_copy
  48. copy_from = Role.find(2)
  49. get :new, :params => {:copy => copy_from.id.to_s}
  50. assert_response :success
  51. assert_select 'input[name=?]', 'role[name]'
  52. assert_select 'form' do
  53. # blank name
  54. assert_select 'input[name=?][value=""]', 'role[name]'
  55. # edit_project permission checked
  56. assert_select 'input[type=checkbox][name=?][value=edit_project][checked=checked]', 'role[permissions][]'
  57. # add_project permission not checked
  58. assert_select 'input[type=checkbox][name=?][value=add_project]', 'role[permissions][]'
  59. assert_select 'input[type=checkbox][name=?][value=add_project][checked=checked]', 'role[permissions][]', 0
  60. # workflow copy selected
  61. assert_select 'select[name=?]', 'copy_workflow_from' do
  62. assert_select 'option[value="2"][selected=selected]'
  63. end
  64. end
  65. end
  66. def test_create_with_validaton_failure
  67. post :create, :params => {
  68. :role => {
  69. :name => '',
  70. :permissions => ['add_issues', 'edit_issues', 'log_time', ''],
  71. :assignable => '0'
  72. }
  73. }
  74. assert_response :success
  75. assert_select_error /Name cannot be blank/
  76. end
  77. def test_create_without_workflow_copy
  78. post :create, :params => {
  79. :role => {
  80. :name => 'RoleWithoutWorkflowCopy',
  81. :permissions => ['add_issues', 'edit_issues', 'log_time', ''],
  82. :assignable => '0'
  83. }
  84. }
  85. assert_redirected_to '/roles'
  86. role = Role.find_by_name('RoleWithoutWorkflowCopy')
  87. assert_not_nil role
  88. assert_equal [:add_issues, :edit_issues, :log_time], role.permissions
  89. assert !role.assignable?
  90. end
  91. def test_create_with_workflow_copy
  92. post :create, :params => {
  93. :role => {
  94. :name => 'RoleWithWorkflowCopy',
  95. :permissions => ['add_issues', 'edit_issues', 'log_time', ''],
  96. :assignable => '0'
  97. },
  98. :copy_workflow_from => '1'
  99. }
  100. assert_redirected_to '/roles'
  101. role = Role.find_by_name('RoleWithWorkflowCopy')
  102. assert_not_nil role
  103. assert_equal Role.find(1).workflow_rules.size, role.workflow_rules.size
  104. end
  105. def test_create_with_managed_roles
  106. role = new_record(Role) do
  107. post :create, :params => {
  108. :role => {
  109. :name => 'Role',
  110. :all_roles_managed => '0',
  111. :managed_role_ids => ['2', '3', '']
  112. }
  113. }
  114. assert_response 302
  115. end
  116. assert_equal false, role.all_roles_managed
  117. assert_equal [2, 3], role.managed_role_ids.sort
  118. end
  119. def test_edit
  120. get :edit, :params => {:id => 1}
  121. assert_response :success
  122. assert_select 'input[name=?][value=?]', 'role[name]', 'Manager'
  123. assert_select 'select[name=?]', 'role[issues_visibility]'
  124. end
  125. def test_edit_anonymous
  126. get :edit, :params => {:id => Role.anonymous.id}
  127. assert_response :success
  128. assert_select 'input[name=?]', 'role[name]', 0
  129. assert_select 'select[name=?]', 'role[issues_visibility]', 0
  130. end
  131. def test_edit_invalid_should_respond_with_404
  132. get :edit, :params => {:id => 999}
  133. assert_response 404
  134. end
  135. def test_update
  136. put :update, :params => {
  137. :id => 1,
  138. :role => {
  139. :name => 'Manager',
  140. :permissions => ['edit_project', ''],
  141. :assignable => '0'
  142. }
  143. }
  144. assert_redirected_to '/roles'
  145. role = Role.find(1)
  146. assert_equal [:edit_project], role.permissions
  147. end
  148. def test_update_trackers_permissions
  149. put :update, :params => {
  150. :id => 1,
  151. :role => {
  152. :permissions_all_trackers => {'add_issues' => '0'},
  153. :permissions_tracker_ids => {'add_issues' => ['1', '3', '']}
  154. }
  155. }
  156. assert_redirected_to '/roles'
  157. role = Role.find(1)
  158. assert_equal({'add_issues' => '0'}, role.permissions_all_trackers)
  159. assert_equal({'add_issues' => ['1', '3']}, role.permissions_tracker_ids)
  160. assert_equal false, role.permissions_all_trackers?(:add_issues)
  161. assert_equal [1, 3], role.permissions_tracker_ids(:add_issues).sort
  162. end
  163. def test_update_with_failure
  164. put :update, :params => {:id => 1, :role => {:name => ''}}
  165. assert_response :success
  166. assert_select_error /Name cannot be blank/
  167. end
  168. def test_destroy
  169. r = Role.create!(:name => 'ToBeDestroyed', :permissions => [:view_wiki_pages])
  170. delete :destroy, :params => {:id => r}
  171. assert_redirected_to '/roles'
  172. assert_nil Role.find_by_id(r.id)
  173. end
  174. def test_destroy_role_in_use
  175. delete :destroy, :params => {:id => 1}
  176. assert_redirected_to '/roles'
  177. assert_equal 'This role is in use and cannot be deleted.', flash[:error]
  178. assert_not_nil Role.find_by_id(1)
  179. end
  180. def test_get_permissions
  181. get :permissions
  182. assert_response :success
  183. assert_select 'input[name=?][type=checkbox][value=add_issues][checked=checked]', 'permissions[3][]'
  184. assert_select 'input[name=?][type=checkbox][value=delete_issues]:not([checked])', 'permissions[3][]'
  185. end
  186. def test_post_permissions
  187. post :permissions, :params => {
  188. :permissions => {
  189. '0' => '',
  190. '1' => ['edit_issues'],
  191. '3' => ['add_issues', 'delete_issues']
  192. }
  193. }
  194. assert_redirected_to '/roles'
  195. assert_equal [:edit_issues], Role.find(1).permissions
  196. assert_equal [:add_issues, :delete_issues], Role.find(3).permissions
  197. assert Role.find(2).permissions.empty?
  198. end
  199. def test_clear_all_permissions
  200. post :permissions, :params => {:permissions => { '0' => '' }}
  201. assert_redirected_to '/roles'
  202. assert Role.find(1).permissions.empty?
  203. end
  204. def test_move_highest
  205. put :update, :params => {:id => 3, :role => {:position => 1}}
  206. assert_redirected_to '/roles'
  207. assert_equal 1, Role.find(3).position
  208. end
  209. def test_move_higher
  210. position = Role.find(3).position
  211. put :update, :params => {:id => 3, :role => {:position => position - 1}}
  212. assert_redirected_to '/roles'
  213. assert_equal position - 1, Role.find(3).position
  214. end
  215. def test_move_lower
  216. position = Role.find(2).position
  217. put :update, :params => {:id => 2, :role => {:position => position + 1}}
  218. assert_redirected_to '/roles'
  219. assert_equal position + 1, Role.find(2).position
  220. end
  221. def test_move_lowest
  222. put :update, :params => {:id => 2, :role => {:position => Role.givable.count}}
  223. assert_redirected_to '/roles'
  224. assert_equal Role.givable.count, Role.find(2).position
  225. end
  226. end