summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGo MAEDA <maeda@farend.jp>2020-05-14 14:33:07 +0000
committerGo MAEDA <maeda@farend.jp>2020-05-14 14:33:07 +0000
commitca2bde9fbf0176be069f4c64313216a23558bf89 (patch)
treea5a50705c1ceba85bde6ee14976076304a4c33a1
parenta924a3dfa1e25ff1acb062abf52525a92e2852d0 (diff)
downloadredmine-ca2bde9fbf0176be069f4c64313216a23558bf89.tar.gz
redmine-ca2bde9fbf0176be069f4c64313216a23558bf89.zip
Updating an issue via REST API causes internal server error if invalid project id is specified (#33417).
Patch by Go MAEDA. git-svn-id: http://svn.redmine.org/redmine/trunk@19777 e93f8b46-1217-0410-a6f0-8f06a7374b81
-rw-r--r--app/models/issue.rb7
-rw-r--r--test/integration/api_test/issues_test.rb28
2 files changed, 33 insertions, 2 deletions
diff --git a/app/models/issue.rb b/app/models/issue.rb
index 487b1b552..e665a46cb 100644
--- a/app/models/issue.rb
+++ b/app/models/issue.rb
@@ -723,7 +723,7 @@ class Issue < ActiveRecord::Base
errors.add :start_date, :earlier_than_minimum_start_date, :date => format_date(soonest_start)
end
- if fixed_version
+ if project && fixed_version
if !assignable_versions.include?(fixed_version)
errors.add :fixed_version_id, :inclusion
elsif reopening? && fixed_version.closed?
@@ -738,7 +738,7 @@ class Issue < ActiveRecord::Base
end
end
- if assigned_to_id_changed? && assigned_to_id.present?
+ if project && assigned_to_id_changed? && assigned_to_id.present?
unless assignable_users.include?(assigned_to)
errors.add :assigned_to_id, :invalid
end
@@ -938,6 +938,8 @@ class Issue < ActiveRecord::Base
# Users the issue can be assigned to
def assignable_users
+ return [] if project.nil?
+
users = project.assignable_users(tracker).to_a
users << author if author && author.active?
if assigned_to_id_was.present? && assignee = Principal.find_by_id(assigned_to_id_was)
@@ -949,6 +951,7 @@ class Issue < ActiveRecord::Base
# Versions that the issue can be assigned to
def assignable_versions
return @assignable_versions if @assignable_versions
+ return [] if project.nil?
versions = project.shared_versions.open.to_a
if fixed_version
diff --git a/test/integration/api_test/issues_test.rb b/test/integration/api_test/issues_test.rb
index fffbc4f7b..d040728f9 100644
--- a/test/integration/api_test/issues_test.rb
+++ b/test/integration/api_test/issues_test.rb
@@ -663,6 +663,34 @@ class Redmine::ApiTest::IssuesTest < Redmine::ApiTest::Base
assert_response 422
end
+ test "POST /issues.json with invalid project_id and any assigned_to_id should respond with 422" do
+ post(
+ '/issues.json',
+ :params => {
+ :issue => {
+ :project_id => 999,
+ :assigned_to_id => 1,
+ :subject => 'API'
+ }
+ },
+ :headers => credentials('jsmith'))
+ assert_response 422
+ end
+
+ test "POST /issues.json with invalid project_id and any fixed_version_id should respond with 422" do
+ post(
+ '/issues.json',
+ :params => {
+ :issue => {
+ :project_id => 999,
+ :fixed_version_id => 1,
+ :subject => 'API'
+ }
+ },
+ :headers => credentials('jsmith'))
+ assert_response 422
+ end
+
test "PUT /issues/:id.xml" do
assert_difference('Journal.count') do
put(