summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJean-Philippe Lang <jp_lang@yahoo.fr>2015-10-09 06:36:58 +0000
committerJean-Philippe Lang <jp_lang@yahoo.fr>2015-10-09 06:36:58 +0000
commit46b877296a71bee4f5c6cf4d62a5bfa56476b848 (patch)
tree64ecb561216e84217e75424e333c06cec87d1d41
parentd690cff576c3083ca75b7f3b7c177b0c65e8e0ff (diff)
downloadredmine-46b877296a71bee4f5c6cf4d62a5bfa56476b848.tar.gz
redmine-46b877296a71bee4f5c6cf4d62a5bfa56476b848.zip
Merged r14619 (#20282).
git-svn-id: http://svn.redmine.org/redmine/branches/3.1-stable@14649 e93f8b46-1217-0410-a6f0-8f06a7374b81
-rw-r--r--app/models/project.rb14
-rw-r--r--test/functional/projects_controller_test.rb11
-rw-r--r--test/object_helpers.rb5
3 files changed, 23 insertions, 7 deletions
diff --git a/app/models/project.rb b/app/models/project.rb
index aacb01c15..e30fc9fda 100644
--- a/app/models/project.rb
+++ b/app/models/project.rb
@@ -687,12 +687,14 @@ class Project < ActiveRecord::Base
attrs = attrs.deep_dup
@unallowed_parent_id = nil
- parent_id_param = attrs['parent_id'].to_s
- if parent_id_param.blank? || parent_id_param != parent_id.to_s
- p = parent_id_param.present? ? Project.find_by_id(parent_id_param) : nil
- unless allowed_parents(user).include?(p)
- attrs.delete('parent_id')
- @unallowed_parent_id = true
+ if new_record? || attrs.key?('parent_id')
+ parent_id_param = attrs['parent_id'].to_s
+ if new_record? || parent_id_param != parent_id.to_s
+ p = parent_id_param.present? ? Project.find_by_id(parent_id_param) : nil
+ unless allowed_parents(user).include?(p)
+ attrs.delete('parent_id')
+ @unallowed_parent_id = true
+ end
end
end
diff --git a/test/functional/projects_controller_test.rb b/test/functional/projects_controller_test.rb
index 2efb98ccd..e4e74521d 100644
--- a/test/functional/projects_controller_test.rb
+++ b/test/functional/projects_controller_test.rb
@@ -486,6 +486,17 @@ class ProjectsControllerTest < ActionController::TestCase
assert_equal 'eCookbook', Project.find(1).name
end
+ def test_update_child_project_without_parent_permission_should_not_show_validation_error
+ child = Project.generate_with_parent!
+ user = User.generate!
+ User.add_to_project(user, child, Role.generate!(:permissions => [:edit_project]))
+ @request.session[:user_id] = user.id
+
+ post :update, :id => child.id, :project => {:name => 'Updated'}
+ assert_response 302
+ assert_match /Successful update/, flash[:notice]
+ end
+
def test_modules
@request.session[:user_id] = 2
Project.find(1).enabled_module_names = ['issue_tracking', 'news']
diff --git a/test/object_helpers.rb b/test/object_helpers.rb
index 74f82b68b..0f4a78d50 100644
--- a/test/object_helpers.rb
+++ b/test/object_helpers.rb
@@ -39,7 +39,10 @@ module ObjectHelpers
project
end
- def Project.generate_with_parent!(parent, attributes={})
+ def Project.generate_with_parent!(*args)
+ attributes = args.last.is_a?(Hash) ? args.pop : {}
+ parent = args.size > 0 ? args.first : Project.generate!
+
project = Project.generate!(attributes) do |p|
p.parent = parent
end