Browse Source

closed_on field of copied issue is always set to source issue's value (#23764).

Patch by Go MAEDA.

git-svn-id: http://svn.redmine.org/redmine/trunk@15848 e93f8b46-1217-0410-a6f0-8f06a7374b81
tags/3.4.0
Jean-Philippe Lang 7 years ago
parent
commit
752648ebf5
2 changed files with 13 additions and 3 deletions
  1. 2
    2
      app/models/issue.rb
  2. 11
    1
      test/unit/issue_test.rb

+ 2
- 2
app/models/issue.rb View File

@@ -262,7 +262,7 @@ class Issue < ActiveRecord::Base
# Copies attributes from another issue, arg can be an id or an Issue
def copy_from(arg, options={})
issue = arg.is_a?(Issue) ? arg : Issue.visible.find(arg)
self.attributes = issue.attributes.dup.except("id", "root_id", "parent_id", "lft", "rgt", "created_on", "updated_on")
self.attributes = issue.attributes.dup.except("id", "root_id", "parent_id", "lft", "rgt", "created_on", "updated_on", "closed_on")
self.custom_field_values = issue.custom_field_values.inject({}) {|h,v| h[v.custom_field_id] = v.value; h}
self.status = issue.status
self.author = User.current
@@ -1402,7 +1402,7 @@ class Issue < ActiveRecord::Base
end
Project.where(condition).having_trackers
end
# Returns a scope of trackers that user can assign the issue to
def allowed_target_trackers(user=User.current)
self.class.allowed_target_trackers(project, user, tracker_id_was)

+ 11
- 1
test/unit/issue_test.rb View File

@@ -762,7 +762,7 @@ class IssueTest < ActiveSupport::TestCase
user = User.find(2)
group = Group.generate!
group.users << user
issue = Issue.generate!(:author_id => 1, :assigned_to => group)
assert_include 4, issue.new_statuses_allowed_to(user).map(&:id)
end
@@ -1335,6 +1335,16 @@ class IssueTest < ActiveSupport::TestCase
end
end

def test_copy_should_clear_closed_on
copied_open = Issue.find(8).copy(:status_id => 1)
assert copied_open.save
assert_nil copied_open.closed_on

copied_closed = Issue.find(8).copy
assert copied_closed.save
assert_not_nil copied_closed.closed_on
end

def test_should_not_call_after_project_change_on_creation
issue = Issue.new(:project_id => 1, :tracker_id => 1, :status_id => 1,
:subject => 'Test', :author_id => 1)

Loading…
Cancel
Save