Fixed: additional workflow transitions not available when set to both author and assignee (#8836).
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@6300 e93f8b46-1217-0410-a6f0-8f06a7374b81
This commit is contained in:
parent
cf56698d91
commit
5f79a6a190
|
@ -58,8 +58,7 @@ class IssueStatus < ActiveRecord::Base
|
||||||
transitions = workflows.select do |w|
|
transitions = workflows.select do |w|
|
||||||
role_ids.include?(w.role_id) &&
|
role_ids.include?(w.role_id) &&
|
||||||
w.tracker_id == tracker.id &&
|
w.tracker_id == tracker.id &&
|
||||||
(author || !w.author) &&
|
((!w.author && !w.assignee) || (author && w.author) || (assignee && w.assignee))
|
||||||
(assignee || !w.assignee)
|
|
||||||
end
|
end
|
||||||
transitions.collect{|w| w.new_status}.compact.sort
|
transitions.collect{|w| w.new_status}.compact.sort
|
||||||
else
|
else
|
||||||
|
@ -70,14 +69,17 @@ class IssueStatus < ActiveRecord::Base
|
||||||
# Same thing as above but uses a database query
|
# Same thing as above but uses a database query
|
||||||
# More efficient than the previous method if called just once
|
# More efficient than the previous method if called just once
|
||||||
def find_new_statuses_allowed_to(roles, tracker, author=false, assignee=false)
|
def find_new_statuses_allowed_to(roles, tracker, author=false, assignee=false)
|
||||||
if roles && tracker
|
if roles.present? && tracker
|
||||||
conditions = {:role_id => roles.collect(&:id), :tracker_id => tracker.id}
|
conditions = "(author = :false AND assignee = :false)"
|
||||||
conditions[:author] = false unless author
|
conditions << " OR author = :true" if author
|
||||||
conditions[:assignee] = false unless assignee
|
conditions << " OR assignee = :true" if assignee
|
||||||
|
|
||||||
workflows.find(:all,
|
workflows.find(:all,
|
||||||
:include => :new_status,
|
:include => :new_status,
|
||||||
:conditions => conditions).collect{|w| w.new_status}.compact.sort
|
:conditions => ["role_id IN (:role_ids) AND tracker_id = :tracker_id AND (#{conditions})",
|
||||||
|
{:role_ids => roles.collect(&:id), :tracker_id => tracker.id, :true => true, :false => false}
|
||||||
|
]
|
||||||
|
).collect{|w| w.new_status}.compact.sort
|
||||||
else
|
else
|
||||||
[]
|
[]
|
||||||
end
|
end
|
||||||
|
|
|
@ -83,11 +83,11 @@ class IssueStatusTest < ActiveSupport::TestCase
|
||||||
assert_equal [2], status.new_statuses_allowed_to([role], tracker, false, false).map(&:id)
|
assert_equal [2], status.new_statuses_allowed_to([role], tracker, false, false).map(&:id)
|
||||||
assert_equal [2], status.find_new_statuses_allowed_to([role], tracker, false, false).map(&:id)
|
assert_equal [2], status.find_new_statuses_allowed_to([role], tracker, false, false).map(&:id)
|
||||||
|
|
||||||
assert_equal [2, 3], status.new_statuses_allowed_to([role], tracker, true, false).map(&:id)
|
assert_equal [2, 3, 5], status.new_statuses_allowed_to([role], tracker, true, false).map(&:id)
|
||||||
assert_equal [2, 3], status.find_new_statuses_allowed_to([role], tracker, true, false).map(&:id)
|
assert_equal [2, 3, 5], status.find_new_statuses_allowed_to([role], tracker, true, false).map(&:id)
|
||||||
|
|
||||||
assert_equal [2, 4], status.new_statuses_allowed_to([role], tracker, false, true).map(&:id)
|
assert_equal [2, 4, 5], status.new_statuses_allowed_to([role], tracker, false, true).map(&:id)
|
||||||
assert_equal [2, 4], status.find_new_statuses_allowed_to([role], tracker, false, true).map(&:id)
|
assert_equal [2, 4, 5], status.find_new_statuses_allowed_to([role], tracker, false, true).map(&:id)
|
||||||
|
|
||||||
assert_equal [2, 3, 4, 5], status.new_statuses_allowed_to([role], tracker, true, true).map(&:id)
|
assert_equal [2, 3, 4, 5], status.new_statuses_allowed_to([role], tracker, true, true).map(&:id)
|
||||||
assert_equal [2, 3, 4, 5], status.find_new_statuses_allowed_to([role], tracker, true, true).map(&:id)
|
assert_equal [2, 3, 4, 5], status.find_new_statuses_allowed_to([role], tracker, true, true).map(&:id)
|
||||||
|
|
Loading…
Reference in New Issue