roles_controller_test.rb
263 lines
| 8.0 KiB
| text/x-ruby
|
RubyLexer
|
r6486 | # Redmine - project management software | ||
|
r14856 | # Copyright (C) 2006-2016 Jean-Philippe Lang | ||
|
r1237 | # | ||
# 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. | ||||
|
r6486 | # | ||
|
r1237 | # 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. | ||||
|
r6486 | # | ||
|
r1237 | # 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. | ||||
|
r4395 | require File.expand_path('../../test_helper', __FILE__) | ||
|
r1237 | |||
|
r15279 | class RolesControllerTest < Redmine::ControllerTest | ||
|
r5490 | fixtures :roles, :users, :members, :member_roles, :workflows, :trackers | ||
|
r6486 | |||
|
r1237 | def setup | ||
User.current = nil | ||||
@request.session[:user_id] = 1 # admin | ||||
end | ||||
|
r6486 | |||
|
r8025 | def test_index | ||
|
r1254 | get :index | ||
assert_response :success | ||||
|
r15342 | assert_select 'table.roles tbody' do | ||
assert_select 'tr', Role.count | ||||
assert_select 'a[href="/roles/1/edit"]', :text => 'Manager' | ||||
end | ||||
|
r1254 | end | ||
|
r6486 | |||
|
r8025 | def test_new | ||
|
r1237 | get :new | ||
assert_response :success | ||||
|
r15342 | assert_select 'input[name=?]', 'role[name]' | ||
|
r15382 | assert_select 'input[name=?]', 'role[permissions][]' | ||
end | ||||
def test_new_should_prefill_permissions_with_non_member_permissions | ||||
role = Role.non_member | ||||
role.permissions = [:view_issues, :view_documents] | ||||
role.save! | ||||
get :new | ||||
assert_response :success | ||||
assert_equal %w(view_documents view_issues), | ||||
css_select('input[name="role[permissions][]"][checked=checked]').map {|e| e.attr('value')}.sort | ||||
|
r1237 | end | ||
|
r6486 | |||
|
r10102 | def test_new_with_copy | ||
copy_from = Role.find(2) | ||||
|
r15284 | get :new, :params => {:copy => copy_from.id.to_s} | ||
|
r10102 | assert_response :success | ||
|
r15342 | assert_select 'input[name=?]', 'role[name]' | ||
|
r10102 | |||
assert_select 'form' do | ||||
# blank name | ||||
|
r13237 | assert_select 'input[name=?][value=""]', 'role[name]' | ||
|
r10102 | # edit_project permission checked | ||
assert_select 'input[type=checkbox][name=?][value=edit_project][checked=checked]', 'role[permissions][]' | ||||
# add_project permission not checked | ||||
assert_select 'input[type=checkbox][name=?][value=add_project]', 'role[permissions][]' | ||||
assert_select 'input[type=checkbox][name=?][value=add_project][checked=checked]', 'role[permissions][]', 0 | ||||
# workflow copy selected | ||||
assert_select 'select[name=?]', 'copy_workflow_from' do | ||||
|
r13237 | assert_select 'option[value="2"][selected=selected]' | ||
|
r10102 | end | ||
end | ||||
end | ||||
|
r8025 | def test_create_with_validaton_failure | ||
|
r15284 | post :create, :params => { | ||
:role => { | ||||
:name => '', | ||||
:permissions => ['add_issues', 'edit_issues', 'log_time', ''], | ||||
:assignable => '0' | ||||
} | ||||
} | ||||
|
r1237 | assert_response :success | ||
|
r15342 | assert_select_error /Name cannot be blank/ | ||
|
r1237 | end | ||
|
r6486 | |||
|
r8025 | def test_create_without_workflow_copy | ||
|
r15284 | post :create, :params => { | ||
:role => { | ||||
:name => 'RoleWithoutWorkflowCopy', | ||||
:permissions => ['add_issues', 'edit_issues', 'log_time', ''], | ||||
:assignable => '0' | ||||
} | ||||
} | ||||
|
r4293 | assert_redirected_to '/roles' | ||
|
r1237 | role = Role.find_by_name('RoleWithoutWorkflowCopy') | ||
assert_not_nil role | ||||
assert_equal [:add_issues, :edit_issues, :log_time], role.permissions | ||||
assert !role.assignable? | ||||
end | ||||
|
r8025 | def test_create_with_workflow_copy | ||
|
r15284 | post :create, :params => { | ||
:role => { | ||||
:name => 'RoleWithWorkflowCopy', | ||||
:permissions => ['add_issues', 'edit_issues', 'log_time', ''], | ||||
:assignable => '0' | ||||
}, | ||||
:copy_workflow_from => '1' | ||||
} | ||||
|
r4293 | assert_redirected_to '/roles' | ||
|
r1237 | role = Role.find_by_name('RoleWithWorkflowCopy') | ||
assert_not_nil role | ||||
|
r9794 | assert_equal Role.find(1).workflow_rules.size, role.workflow_rules.size | ||
|
r1237 | end | ||
|
r6486 | |||
|
r15530 | def test_create_with_managed_roles | ||
role = new_record(Role) do | ||||
post :create, :params => { | ||||
:role => { | ||||
:name => 'Role', | ||||
:all_roles_managed => '0', | ||||
:managed_role_ids => ['2', '3', ''] | ||||
} | ||||
} | ||||
assert_response 302 | ||||
end | ||||
assert_equal false, role.all_roles_managed | ||||
|
r15531 | assert_equal [2, 3], role.managed_role_ids.sort | ||
|
r15530 | end | ||
|
r8025 | def test_edit | ||
|
r15284 | get :edit, :params => {:id => 1} | ||
|
r1237 | assert_response :success | ||
|
r15342 | |||
assert_select 'input[name=?][value=?]', 'role[name]', 'Manager' | ||||
|
r10254 | assert_select 'select[name=?]', 'role[issues_visibility]' | ||
end | ||||
def test_edit_anonymous | ||||
|
r15284 | get :edit, :params => {:id => Role.anonymous.id} | ||
|
r10254 | assert_response :success | ||
|
r15342 | |||
assert_select 'input[name=?]', 'role[name]', 0 | ||||
|
r10254 | assert_select 'select[name=?]', 'role[issues_visibility]', 0 | ||
|
r1237 | end | ||
|
r8827 | def test_edit_invalid_should_respond_with_404 | ||
|
r15284 | get :edit, :params => {:id => 999} | ||
|
r8827 | assert_response 404 | ||
end | ||||
|
r8025 | def test_update | ||
|
r15284 | put :update, :params => { | ||
:id => 1, | ||||
:role => { | ||||
:name => 'Manager', | ||||
:permissions => ['edit_project', ''], | ||||
:assignable => '0' | ||||
} | ||||
} | ||||
|
r4293 | assert_redirected_to '/roles' | ||
|
r1237 | role = Role.find(1) | ||
assert_equal [:edit_project], role.permissions | ||||
end | ||||
|
r6486 | |||
|
r15082 | def test_update_trackers_permissions | ||
|
r15284 | put :update, :params => { | ||
:id => 1, | ||||
:role => { | ||||
:permissions_all_trackers => {'add_issues' => '0'}, | ||||
:permissions_tracker_ids => {'add_issues' => ['1', '3', '']} | ||||
} | ||||
|
r15082 | } | ||
assert_redirected_to '/roles' | ||||
role = Role.find(1) | ||||
assert_equal({'add_issues' => '0'}, role.permissions_all_trackers) | ||||
assert_equal({'add_issues' => ['1', '3']}, role.permissions_tracker_ids) | ||||
assert_equal false, role.permissions_all_trackers?(:add_issues) | ||||
assert_equal [1, 3], role.permissions_tracker_ids(:add_issues).sort | ||||
end | ||||
|
r8025 | def test_update_with_failure | ||
|
r15284 | put :update, :params => {:id => 1, :role => {:name => ''}} | ||
|
r8025 | assert_response :success | ||
|
r15342 | assert_select_error /Name cannot be blank/ | ||
|
r8025 | end | ||
|
r1254 | def test_destroy | ||
|
r8025 | r = Role.create!(:name => 'ToBeDestroyed', :permissions => [:view_wiki_pages]) | ||
|
r6486 | |||
|
r15284 | delete :destroy, :params => {:id => r} | ||
|
r4293 | assert_redirected_to '/roles' | ||
|
r1254 | assert_nil Role.find_by_id(r.id) | ||
end | ||||
|
r6486 | |||
|
r1254 | def test_destroy_role_in_use | ||
|
r15284 | delete :destroy, :params => {:id => 1} | ||
|
r4293 | assert_redirected_to '/roles' | ||
|
r8025 | assert_equal 'This role is in use and cannot be deleted.', flash[:error] | ||
|
r1254 | assert_not_nil Role.find_by_id(1) | ||
end | ||||
|
r6486 | |||
|
r8025 | def test_get_permissions | ||
get :permissions | ||||
|
r1254 | assert_response :success | ||
|
r6486 | |||
|
r13242 | assert_select 'input[name=?][type=checkbox][value=add_issues][checked=checked]', 'permissions[3][]' | ||
assert_select 'input[name=?][type=checkbox][value=delete_issues]:not([checked])', 'permissions[3][]' | ||||
|
r1254 | end | ||
|
r6486 | |||
|
r8025 | def test_post_permissions | ||
|
r15284 | post :permissions, :params => { | ||
:permissions => { | ||||
'0' => '', | ||||
'1' => ['edit_issues'], | ||||
'3' => ['add_issues', 'delete_issues'] | ||||
} | ||||
} | ||||
|
r4293 | assert_redirected_to '/roles' | ||
|
r6486 | |||
|
r1254 | assert_equal [:edit_issues], Role.find(1).permissions | ||
assert_equal [:add_issues, :delete_issues], Role.find(3).permissions | ||||
assert Role.find(2).permissions.empty? | ||||
end | ||||
|
r6486 | |||
|
r1254 | def test_clear_all_permissions | ||
|
r15284 | post :permissions, :params => {:permissions => { '0' => '' }} | ||
|
r4293 | assert_redirected_to '/roles' | ||
|
r1254 | assert Role.find(1).permissions.empty? | ||
end | ||||
|
r6486 | |||
|
r1254 | def test_move_highest | ||
|
r15284 | put :update, :params => {:id => 3, :role => {:position => 1}} | ||
|
r4293 | assert_redirected_to '/roles' | ||
|
r1254 | assert_equal 1, Role.find(3).position | ||
end | ||||
def test_move_higher | ||||
position = Role.find(3).position | ||||
|
r15284 | put :update, :params => {:id => 3, :role => {:position => position - 1}} | ||
|
r4293 | assert_redirected_to '/roles' | ||
|
r1254 | assert_equal position - 1, Role.find(3).position | ||
end | ||||
def test_move_lower | ||||
position = Role.find(2).position | ||||
|
r15284 | put :update, :params => {:id => 2, :role => {:position => position + 1}} | ||
|
r4293 | assert_redirected_to '/roles' | ||
|
r1254 | assert_equal position + 1, Role.find(2).position | ||
end | ||||
def test_move_lowest | ||||
|
r15284 | put :update, :params => {:id => 2, :role => {:position => Role.givable.count}} | ||
|
r4293 | assert_redirected_to '/roles' | ||
|
r14953 | assert_equal Role.givable.count, Role.find(2).position | ||
|
r1254 | end | ||
|
r1237 | end | ||