annotate test/functional/issue_moves_controller_test.rb @ 36:de76cd3e8c8e cc-branches

* Probably abortive experiments in extracting the branch from Hg
author Chris Cannam <chris.cannam@soundsoftware.ac.uk>
date Wed, 20 Oct 2010 10:07:29 +0100
parents 1d32c0a0efbf
children 94944d00e43c
rev   line source
Chris@14 1 require File.dirname(__FILE__) + '/../test_helper'
Chris@14 2
Chris@14 3 class IssueMovesControllerTest < ActionController::TestCase
Chris@14 4 fixtures :all
Chris@14 5
Chris@14 6 def setup
Chris@14 7 User.current = nil
Chris@14 8 end
Chris@14 9
Chris@14 10 def test_create_one_issue_to_another_project
Chris@14 11 @request.session[:user_id] = 2
Chris@14 12 post :create, :id => 1, :new_project_id => 2, :tracker_id => '', :assigned_to_id => '', :status_id => '', :start_date => '', :due_date => ''
Chris@14 13 assert_redirected_to :controller => 'issues', :action => 'index', :project_id => 'ecookbook'
Chris@14 14 assert_equal 2, Issue.find(1).project_id
Chris@14 15 end
Chris@14 16
Chris@14 17 def test_create_one_issue_to_another_project_should_follow_when_needed
Chris@14 18 @request.session[:user_id] = 2
Chris@14 19 post :create, :id => 1, :new_project_id => 2, :follow => '1'
Chris@14 20 assert_redirected_to '/issues/1'
Chris@14 21 end
Chris@14 22
Chris@14 23 def test_bulk_create_to_another_project
Chris@14 24 @request.session[:user_id] = 2
Chris@14 25 post :create, :ids => [1, 2], :new_project_id => 2
Chris@14 26 assert_redirected_to :controller => 'issues', :action => 'index', :project_id => 'ecookbook'
Chris@14 27 # Issues moved to project 2
Chris@14 28 assert_equal 2, Issue.find(1).project_id
Chris@14 29 assert_equal 2, Issue.find(2).project_id
Chris@14 30 # No tracker change
Chris@14 31 assert_equal 1, Issue.find(1).tracker_id
Chris@14 32 assert_equal 2, Issue.find(2).tracker_id
Chris@14 33 end
Chris@14 34
Chris@14 35 def test_bulk_create_to_another_tracker
Chris@14 36 @request.session[:user_id] = 2
Chris@14 37 post :create, :ids => [1, 2], :new_tracker_id => 2
Chris@14 38 assert_redirected_to :controller => 'issues', :action => 'index', :project_id => 'ecookbook'
Chris@14 39 assert_equal 2, Issue.find(1).tracker_id
Chris@14 40 assert_equal 2, Issue.find(2).tracker_id
Chris@14 41 end
Chris@14 42
Chris@14 43 def test_bulk_copy_to_another_project
Chris@14 44 @request.session[:user_id] = 2
Chris@14 45 assert_difference 'Issue.count', 2 do
Chris@14 46 assert_no_difference 'Project.find(1).issues.count' do
Chris@14 47 post :create, :ids => [1, 2], :new_project_id => 2, :copy_options => {:copy => '1'}
Chris@14 48 end
Chris@14 49 end
Chris@14 50 assert_redirected_to 'projects/ecookbook/issues'
Chris@14 51 end
Chris@14 52
Chris@14 53 context "#create via bulk copy" do
Chris@14 54 should "allow not changing the issue's attributes" do
Chris@14 55 @request.session[:user_id] = 2
Chris@14 56 issue_before_move = Issue.find(1)
Chris@14 57 assert_difference 'Issue.count', 1 do
Chris@14 58 assert_no_difference 'Project.find(1).issues.count' do
Chris@14 59 post :create, :ids => [1], :new_project_id => 2, :copy_options => {:copy => '1'}, :new_tracker_id => '', :assigned_to_id => '', :status_id => '', :start_date => '', :due_date => ''
Chris@14 60 end
Chris@14 61 end
Chris@14 62 issue_after_move = Issue.first(:order => 'id desc', :conditions => {:project_id => 2})
Chris@14 63 assert_equal issue_before_move.tracker_id, issue_after_move.tracker_id
Chris@14 64 assert_equal issue_before_move.status_id, issue_after_move.status_id
Chris@14 65 assert_equal issue_before_move.assigned_to_id, issue_after_move.assigned_to_id
Chris@14 66 end
Chris@14 67
Chris@14 68 should "allow changing the issue's attributes" do
Chris@14 69 # Fixes random test failure with Mysql
Chris@14 70 # where Issue.all(:limit => 2, :order => 'id desc', :conditions => {:project_id => 2}) doesn't return the expected results
Chris@14 71 Issue.delete_all("project_id=2")
Chris@14 72
Chris@14 73 @request.session[:user_id] = 2
Chris@14 74 assert_difference 'Issue.count', 2 do
Chris@14 75 assert_no_difference 'Project.find(1).issues.count' do
Chris@14 76 post :create, :ids => [1, 2], :new_project_id => 2, :copy_options => {:copy => '1'}, :new_tracker_id => '', :assigned_to_id => 4, :status_id => 3, :start_date => '2009-12-01', :due_date => '2009-12-31'
Chris@14 77 end
Chris@14 78 end
Chris@14 79
Chris@14 80 copied_issues = Issue.all(:limit => 2, :order => 'id desc', :conditions => {:project_id => 2})
Chris@14 81 assert_equal 2, copied_issues.size
Chris@14 82 copied_issues.each do |issue|
Chris@14 83 assert_equal 2, issue.project_id, "Project is incorrect"
Chris@14 84 assert_equal 4, issue.assigned_to_id, "Assigned to is incorrect"
Chris@14 85 assert_equal 3, issue.status_id, "Status is incorrect"
Chris@14 86 assert_equal '2009-12-01', issue.start_date.to_s, "Start date is incorrect"
Chris@14 87 assert_equal '2009-12-31', issue.due_date.to_s, "Due date is incorrect"
Chris@14 88 end
Chris@14 89 end
Chris@14 90 end
Chris@14 91
Chris@14 92 def test_copy_to_another_project_should_follow_when_needed
Chris@14 93 @request.session[:user_id] = 2
Chris@14 94 post :create, :ids => [1], :new_project_id => 2, :copy_options => {:copy => '1'}, :follow => '1'
Chris@14 95 issue = Issue.first(:order => 'id DESC')
Chris@14 96 assert_redirected_to :controller => 'issues', :action => 'show', :id => issue
Chris@14 97 end
Chris@14 98
Chris@14 99 end