@@ -0,0 +1,37 | |||
|
1 | # Redmine - project management software | |
|
2 | # Copyright (C) 2006-2011 Jean-Philippe Lang | |
|
3 | # | |
|
4 | # This program is free software; you can redistribute it and/or | |
|
5 | # modify it under the terms of the GNU General Public License | |
|
6 | # as published by the Free Software Foundation; either version 2 | |
|
7 | # of the License, or (at your option) any later version. | |
|
8 | # | |
|
9 | # This program is distributed in the hope that it will be useful, | |
|
10 | # but WITHOUT ANY WARRANTY; without even the implied warranty of | |
|
11 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
|
12 | # GNU General Public License for more details. | |
|
13 | # | |
|
14 | # You should have received a copy of the GNU General Public License | |
|
15 | # along with this program; if not, write to the Free Software | |
|
16 | # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | |
|
17 | ||
|
18 | require File.expand_path('../../test_helper', __FILE__) | |
|
19 | ||
|
20 | class WorkflowTest < ActiveSupport::TestCase | |
|
21 | fixtures :roles, :trackers, :issue_statuses | |
|
22 | ||
|
23 | def test_copy | |
|
24 | Workflow.delete_all | |
|
25 | Workflow.create!(:role_id => 1, :tracker_id => 2, :old_status_id => 1, :new_status_id => 2) | |
|
26 | Workflow.create!(:role_id => 1, :tracker_id => 2, :old_status_id => 1, :new_status_id => 3, :assignee => true) | |
|
27 | Workflow.create!(:role_id => 1, :tracker_id => 2, :old_status_id => 1, :new_status_id => 4, :author => true) | |
|
28 | ||
|
29 | assert_difference 'Workflow.count', 3 do | |
|
30 | Workflow.copy(Tracker.find(2), Role.find(1), Tracker.find(3), Role.find(2)) | |
|
31 | end | |
|
32 | ||
|
33 | assert Workflow.first(:conditions => {:role_id => 2, :tracker_id => 3, :old_status_id => 1, :new_status_id => 2, :author => false, :assignee => false}) | |
|
34 | assert Workflow.first(:conditions => {:role_id => 2, :tracker_id => 3, :old_status_id => 1, :new_status_id => 3, :author => false, :assignee => true}) | |
|
35 | assert Workflow.first(:conditions => {:role_id => 2, :tracker_id => 3, :old_status_id => 1, :new_status_id => 4, :author => true, :assignee => false}) | |
|
36 | end | |
|
37 | end |
@@ -89,8 +89,8 class Workflow < ActiveRecord::Base | |||
|
89 | 89 | else |
|
90 | 90 | transaction do |
|
91 | 91 | delete_all :tracker_id => target_tracker.id, :role_id => target_role.id |
|
92 | connection.insert "INSERT INTO #{Workflow.table_name} (tracker_id, role_id, old_status_id, new_status_id)" + | |
|
93 | " SELECT #{target_tracker.id}, #{target_role.id}, old_status_id, new_status_id" + | |
|
92 | connection.insert "INSERT INTO #{Workflow.table_name} (tracker_id, role_id, old_status_id, new_status_id, author, assignee)" + | |
|
93 | " SELECT #{target_tracker.id}, #{target_role.id}, old_status_id, new_status_id, author, assignee" + | |
|
94 | 94 | " FROM #{Workflow.table_name}" + |
|
95 | 95 | " WHERE tracker_id = #{source_tracker.id} AND role_id = #{source_role.id}" |
|
96 | 96 | end |
General Comments 0
You need to be logged in to leave comments.
Login now