summaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
Diffstat (limited to 'test')
-rw-r--r--test/functional/members_controller_test.rb18
-rw-r--r--test/functional/projects_controller_test.rb12
-rw-r--r--test/integration/api_test/memberships_test.rb34
3 files changed, 50 insertions, 14 deletions
diff --git a/test/functional/members_controller_test.rb b/test/functional/members_controller_test.rb
index c9337e210..d132c8293 100644
--- a/test/functional/members_controller_test.rb
+++ b/test/functional/members_controller_test.rb
@@ -117,6 +117,16 @@ class MembersControllerTest < Redmine::ControllerTest
assert_redirected_to '/projects/ecookbook/settings/members'
end
+ def test_update_locked_member_should_be_allowed
+ User.find(3).lock!
+
+ put :update, :id => 2, :membership => {:role_ids => [1]}
+ assert_response 302
+ member = Member.find(2)
+ assert member.user.locked?
+ assert_equal [1], member.role_ids
+ end
+
def test_update_should_not_add_unmanaged_roles
role = Role.find(1)
role.update! :all_roles_managed => false
@@ -157,6 +167,14 @@ class MembersControllerTest < Redmine::ControllerTest
assert !User.find(3).member_of?(Project.find(1))
end
+ def test_destroy_locked_member_should_be_allowed
+ assert User.find(3).lock!
+
+ assert_difference 'Member.count', -1 do
+ delete :destroy, :id => 2
+ end
+ end
+
def test_destroy_should_fail_with_unmanaged_roles
role = Role.find(1)
role.update! :all_roles_managed => false
diff --git a/test/functional/projects_controller_test.rb b/test/functional/projects_controller_test.rb
index 01c68308f..da2818174 100644
--- a/test/functional/projects_controller_test.rb
+++ b/test/functional/projects_controller_test.rb
@@ -527,6 +527,18 @@ class ProjectsControllerTest < Redmine::ControllerTest
assert_select 'a#tab-versions[href=?]', '/projects/ecookbook/settings/versions?version_name=.1&version_status='
end
+ def test_settings_should_show_locked_members
+ user = User.generate!
+ member = User.add_to_project(user, Project.find(1))
+ user.lock!
+ assert user.reload.locked?
+ @request.session[:user_id] = 2
+
+ get :settings, :id => 'ecookbook', :tab => 'members'
+ assert_response :success
+ assert_select "tr#member-#{member.id}"
+ end
+
def test_update
@request.session[:user_id] = 2 # manager
post :update, :id => 1, :project => {:name => 'Test changed name',
diff --git a/test/integration/api_test/memberships_test.rb b/test/integration/api_test/memberships_test.rb
index 92d4b094c..dd259839d 100644
--- a/test/integration/api_test/memberships_test.rb
+++ b/test/integration/api_test/memberships_test.rb
@@ -37,20 +37,17 @@ class Redmine::ApiTest::MembershipsTest < Redmine::ApiTest::Base
assert_response :success
assert_equal 'application/json', @response.content_type
json = ActiveSupport::JSON.decode(response.body)
- assert_equal({
- "memberships" =>
- [{"id"=>1,
- "project" => {"name"=>"eCookbook", "id"=>1},
- "roles" => [{"name"=>"Manager", "id"=>1}],
- "user" => {"name"=>"John Smith", "id"=>2}},
- {"id"=>2,
- "project" => {"name"=>"eCookbook", "id"=>1},
- "roles" => [{"name"=>"Developer", "id"=>2}],
- "user" => {"name"=>"Dave Lopper", "id"=>3}}],
- "limit" => 25,
- "total_count" => 2,
- "offset" => 0},
- json)
+ assert_equal 3, json["total_count"]
+ assert_equal 25, json["limit"]
+ assert_equal 0, json["offset"]
+ assert_include({
+ "id"=>1,
+ "project" => {"name"=>"eCookbook", "id"=>1},
+ "roles" => [{"name"=>"Manager", "id"=>1}],
+ "user" => {"name"=>"John Smith", "id"=>2}
+ },
+ json["memberships"]
+ )
end
test "GET /projects/:project_id/memberships.xml should succeed for closed project" do
@@ -61,6 +58,15 @@ class Redmine::ApiTest::MembershipsTest < Redmine::ApiTest::Base
assert_response :success
end
+ test "GET /projects/:project_id/memberships.xml should include locked users" do
+ assert User.find(3).lock!
+ get '/projects/ecookbook/memberships.xml', {}, credentials('jsmith')
+ assert_response :success
+ assert_select 'memberships[type=array] membership id', :text => '2' do
+ assert_select '~ user[id="3"][name="Dave Lopper"]'
+ end
+ end
+
test "POST /projects/:project_id/memberships.xml should create the membership" do
assert_difference 'Member.count' do
post '/projects/1/memberships.xml', {:membership => {:user_id => 7, :role_ids => [2,3]}}, credentials('jsmith')