Mercurial > hg > soundsoftware-site
diff test/functional/trackers_controller_test.rb @ 909:cbb26bc654de redmine-1.3
Update to Redmine 1.3-stable branch (Redmine SVN rev 8964)
author | Chris Cannam |
---|---|
date | Fri, 24 Feb 2012 19:09:32 +0000 |
parents | 8661b858af72 |
children | 5f33065ddc4b |
line wrap: on
line diff
--- a/test/functional/trackers_controller_test.rb Fri Feb 24 18:36:29 2012 +0000 +++ b/test/functional/trackers_controller_test.rb Fri Feb 24 19:09:32 2012 +0000 @@ -1,16 +1,16 @@ # Redmine - project management software -# Copyright (C) 2006-2009 Jean-Philippe Lang +# Copyright (C) 2006-2011 Jean-Philippe Lang # # This program is free software; you can redistribute it and/or # modify it under the terms of the GNU General Public License # as published by the Free Software Foundation; either version 2 # of the License, or (at your option) any later version. -# +# # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. -# +# # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. @@ -23,7 +23,7 @@ class TrackersControllerTest < ActionController::TestCase fixtures :trackers, :projects, :projects_trackers, :users, :issues, :custom_fields - + def setup @controller = TrackersController.new @request = ActionController::TestRequest.new @@ -31,88 +31,113 @@ User.current = nil @request.session[:user_id] = 1 # admin end - + def test_index get :index assert_response :success assert_template 'index' end - def test_get_new + def test_index_by_anonymous_should_redirect_to_login_form + @request.session[:user_id] = nil + get :index + assert_redirected_to '/login?back_url=http%3A%2F%2Ftest.host%2Ftrackers' + end + + def test_index_by_user_should_respond_with_406 + @request.session[:user_id] = 2 + get :index + assert_response 406 + end + + def test_new get :new assert_response :success assert_template 'new' end - def test_post_new - post :new, :tracker => { :name => 'New tracker', :project_ids => ['1', '', ''], :custom_field_ids => ['1', '6', ''] } + def test_create + assert_difference 'Tracker.count' do + post :create, :tracker => { :name => 'New tracker', :project_ids => ['1', '', ''], :custom_field_ids => ['1', '6', ''] } + end assert_redirected_to :action => 'index' - tracker = Tracker.find_by_name('New tracker') + tracker = Tracker.first(:order => 'id DESC') + assert_equal 'New tracker', tracker.name assert_equal [1], tracker.project_ids.sort assert_equal [1, 6], tracker.custom_field_ids assert_equal 0, tracker.workflows.count end - def test_post_new_with_workflow_copy - post :new, :tracker => { :name => 'New tracker' }, :copy_workflow_from => 1 + def test_create_new_with_workflow_copy + assert_difference 'Tracker.count' do + post :create, :tracker => { :name => 'New tracker' }, :copy_workflow_from => 1 + end assert_redirected_to :action => 'index' tracker = Tracker.find_by_name('New tracker') assert_equal 0, tracker.projects.count assert_equal Tracker.find(1).workflows.count, tracker.workflows.count end - - def test_get_edit + + def test_create_new_failure + assert_no_difference 'Tracker.count' do + post :create, :tracker => { :name => '', :project_ids => ['1', '', ''], :custom_field_ids => ['1', '6', ''] } + end + assert_response :success + assert_template 'new' + end + + def test_edit Tracker.find(1).project_ids = [1, 3] - + get :edit, :id => 1 assert_response :success assert_template 'edit' - + assert_tag :input, :attributes => { :name => 'tracker[project_ids][]', :value => '1', :checked => 'checked' } - + assert_tag :input, :attributes => { :name => 'tracker[project_ids][]', :value => '2', :checked => nil } - + assert_tag :input, :attributes => { :name => 'tracker[project_ids][]', :value => '', :type => 'hidden'} end - def test_post_edit - post :edit, :id => 1, :tracker => { :name => 'Renamed', + def test_update + put :update, :id => 1, :tracker => { :name => 'Renamed', :project_ids => ['1', '2', ''] } assert_redirected_to :action => 'index' assert_equal [1, 2], Tracker.find(1).project_ids.sort end - def test_post_edit_without_projects - post :edit, :id => 1, :tracker => { :name => 'Renamed', + def test_update_without_projects + put :update, :id => 1, :tracker => { :name => 'Renamed', :project_ids => [''] } assert_redirected_to :action => 'index' assert Tracker.find(1).project_ids.empty? end - + def test_move_lower tracker = Tracker.find_by_position(1) - post :edit, :id => 1, :tracker => { :move_to => 'lower' } + put :update, :id => 1, :tracker => { :move_to => 'lower' } assert_equal 2, tracker.reload.position end - + def test_destroy tracker = Tracker.create!(:name => 'Destroyable') assert_difference 'Tracker.count', -1 do - post :destroy, :id => tracker.id + delete :destroy, :id => tracker.id end assert_redirected_to :action => 'index' assert_nil flash[:error] end - + def test_destroy_tracker_in_use assert_no_difference 'Tracker.count' do - post :destroy, :id => 1 + delete :destroy, :id => 1 end assert_redirected_to :action => 'index' assert_not_nil flash[:error]