diff options
author | Jean-Philippe Lang <jp_lang@yahoo.fr> | 2017-05-31 17:32:34 +0000 |
---|---|---|
committer | Jean-Philippe Lang <jp_lang@yahoo.fr> | 2017-05-31 17:32:34 +0000 |
commit | b834e81d7f41121fc6d9bef95ee090f8f466493e (patch) | |
tree | 61fddb6214c64e96fddd504301029bdb382ba439 /test | |
parent | 1d4300b674f739d671a8be22d3ea617922f16517 (diff) | |
download | redmine-b834e81d7f41121fc6d9bef95ee090f8f466493e.tar.gz redmine-b834e81d7f41121fc6d9bef95ee090f8f466493e.zip |
Use Rails 5 syntax for functional tests.
git-svn-id: http://svn.redmine.org/redmine/trunk@16585 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'test')
52 files changed, 5806 insertions, 1940 deletions
diff --git a/test/functional/account_controller_openid_test.rb b/test/functional/account_controller_openid_test.rb index b76e4bca2..7e467fd3d 100644 --- a/test/functional/account_controller_openid_test.rb +++ b/test/functional/account_controller_openid_test.rb @@ -41,13 +41,17 @@ class AccountControllerOpenidTest < Redmine::ControllerTest existing_user.login = 'cool_user' assert existing_user.save! - post :login, :openid_url => existing_user.identity_url + post :login, :params => { + :openid_url => existing_user.identity_url + } assert_redirected_to '/my/page' end def test_login_with_invalid_openid_provider Setting.self_registration = '0' - post :login, :openid_url => 'http;//openid.example.com/good_user' + post :login, :params => { + :openid_url => 'http;//openid.example.com/good_user' + } assert_redirected_to home_url end @@ -61,13 +65,17 @@ class AccountControllerOpenidTest < Redmine::ControllerTest existing_user.login = 'cool_user' assert existing_user.save! - post :login, :openid_url => existing_user.identity_url + post :login, :params => { + :openid_url => existing_user.identity_url + } assert_redirected_to '/login' end def test_login_with_openid_with_new_user_created Setting.self_registration = '3' - post :login, :openid_url => 'http://openid.example.com/good_user' + post :login, :params => { + :openid_url => 'http://openid.example.com/good_user' + } assert_redirected_to '/my/account' user = User.find_by_login('cool_user') assert user @@ -77,7 +85,9 @@ class AccountControllerOpenidTest < Redmine::ControllerTest def test_login_with_openid_with_new_user_and_self_registration_off Setting.self_registration = '0' - post :login, :openid_url => 'http://openid.example.com/good_user' + post :login, :params => { + :openid_url => 'http://openid.example.com/good_user' + } assert_redirected_to home_url user = User.find_by_login('cool_user') assert_nil user @@ -85,7 +95,9 @@ class AccountControllerOpenidTest < Redmine::ControllerTest def test_login_with_openid_with_new_user_created_with_email_activation_should_have_a_token Setting.self_registration = '1' - post :login, :openid_url => 'http://openid.example.com/good_user' + post :login, :params => { + :openid_url => 'http://openid.example.com/good_user' + } assert_redirected_to '/login' user = User.find_by_login('cool_user') assert user @@ -96,7 +108,9 @@ class AccountControllerOpenidTest < Redmine::ControllerTest def test_login_with_openid_with_new_user_created_with_manual_activation Setting.self_registration = '2' - post :login, :openid_url => 'http://openid.example.com/good_user' + post :login, :params => { + :openid_url => 'http://openid.example.com/good_user' + } assert_redirected_to '/login' user = User.find_by_login('cool_user') assert user @@ -109,7 +123,9 @@ class AccountControllerOpenidTest < Redmine::ControllerTest existing_user.login = 'cool_user' assert existing_user.save! - post :login, :openid_url => 'http://openid.example.com/good_user' + post :login, :params => { + :openid_url => 'http://openid.example.com/good_user' + } assert_response :success assert_select 'input[name=?][value=?]', 'user[identity_url]', 'http://openid.example.com/good_user' @@ -118,7 +134,9 @@ class AccountControllerOpenidTest < Redmine::ControllerTest def test_login_with_openid_with_new_user_with_missing_information_should_register Setting.self_registration = '3' - post :login, :openid_url => 'http://openid.example.com/good_blank_user' + post :login, :params => { + :openid_url => 'http://openid.example.com/good_blank_user' + } assert_response :success assert_select 'input[name=?]', 'user[login]' @@ -141,15 +159,18 @@ class AccountControllerOpenidTest < Redmine::ControllerTest Setting.self_registration = '3' assert_difference 'User.count' do - post :register, :user => { - :login => 'good_blank_user', - :password => '', - :password_confirmation => '', - :firstname => 'Cool', - :lastname => 'User', - :mail => 'user@somedomain.com', - :identity_url => 'http://openid.example.com/good_blank_user' - } + post :register, :params => { + :user => { + :login => 'good_blank_user', + :password => '', + :password_confirmation => '', + :firstname => 'Cool', + :lastname => 'User', + :mail => 'user@somedomain.com', + :identity_url => 'http://openid.example.com/good_blank_user' + + } + } assert_response 302 end diff --git a/test/functional/account_controller_test.rb b/test/functional/account_controller_test.rb index 01affec56..6bb6fddf9 100644 --- a/test/functional/account_controller_test.rb +++ b/test/functional/account_controller_test.rb @@ -36,7 +36,9 @@ class AccountControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 @request.env["HTTP_REFERER"] = 'http://test.host/issues/show/1' - get :login, :back_url => 'http://test.host/issues/show/1' + get :login, :params => { + :back_url => 'http://test.host/issues/show/1' + } assert_redirected_to '/issues/show/1' assert_equal 2, @request.session[:user_id] end @@ -66,7 +68,11 @@ class AccountControllerTest < Redmine::ControllerTest '/' ] back_urls.each do |back_url| - post :login, :username => 'jsmith', :password => 'jsmith', :back_url => back_url + post :login, :params => { + :username => 'jsmith', + :password => 'jsmith', + :back_url => back_url + } assert_redirected_to back_url end end @@ -80,7 +86,11 @@ class AccountControllerTest < Redmine::ControllerTest '/redmine' ] back_urls.each do |back_url| - post :login, :username => 'jsmith', :password => 'jsmith', :back_url => back_url + post :login, :params => { + :username => 'jsmith', + :password => 'jsmith', + :back_url => back_url + } assert_redirected_to back_url end ensure @@ -93,7 +103,11 @@ class AccountControllerTest < Redmine::ControllerTest '//test.foo/fake' ] back_urls.each do |back_url| - post :login, :username => 'jsmith', :password => 'jsmith', :back_url => back_url + post :login, :params => { + :username => 'jsmith', + :password => 'jsmith', + :back_url => back_url + } assert_redirected_to '/my/page' end end @@ -120,7 +134,11 @@ class AccountControllerTest < Redmine::ControllerTest '.test.foo' ] back_urls.each do |back_url| - post :login, :username => 'jsmith', :password => 'jsmith', :back_url => back_url + post :login, :params => { + :username => 'jsmith', + :password => 'jsmith', + :back_url => back_url + } assert_redirected_to '/my/page' end ensure @@ -128,7 +146,10 @@ class AccountControllerTest < Redmine::ControllerTest end def test_login_with_wrong_password - post :login, :username => 'admin', :password => 'bad' + post :login, :params => { + :username => 'admin', + :password => 'bad' + } assert_response :success assert_select 'div.flash.error', :text => /Invalid user or password/ @@ -140,7 +161,10 @@ class AccountControllerTest < Redmine::ControllerTest def test_login_with_locked_account_should_fail User.find(2).update_attribute :status, User::STATUS_LOCKED - post :login, :username => 'jsmith', :password => 'jsmith' + post :login, :params => { + :username => 'jsmith', + :password => 'jsmith' + } assert_redirected_to '/login' assert_include 'locked', flash[:error] assert_nil @request.session[:user_id] @@ -150,7 +174,10 @@ class AccountControllerTest < Redmine::ControllerTest User.find(2).update_attribute :status, User::STATUS_REGISTERED with_settings :self_registration => '2', :default_language => 'en' do - post :login, :username => 'jsmith', :password => 'jsmith' + post :login, :params => { + :username => 'jsmith', + :password => 'jsmith' + } assert_redirected_to '/login' assert_include 'pending administrator approval', flash[:error] end @@ -160,7 +187,10 @@ class AccountControllerTest < Redmine::ControllerTest User.find(2).update_attribute :status, User::STATUS_REGISTERED with_settings :self_registration => '1', :default_language => 'en' do - post :login, :username => 'jsmith', :password => 'jsmith' + post :login, :params => { + :username => 'jsmith', + :password => 'jsmith' + } assert_redirected_to '/login' assert_equal 2, @request.session[:registered_user_id] assert_include 'new activation email', flash[:error] @@ -172,7 +202,10 @@ class AccountControllerTest < Redmine::ControllerTest User.find(2).update_attribute :auth_source_id, source.id AuthSource.any_instance.stubs(:authenticate).raises(AuthSourceException.new("Something wrong")) - post :login, :username => 'jsmith', :password => 'jsmith' + post :login, :params => { + :username => 'jsmith', + :password => 'jsmith' + } assert_response 500 assert_select_error /Something wrong/ end @@ -180,7 +213,10 @@ class AccountControllerTest < Redmine::ControllerTest def test_login_should_reset_session @controller.expects(:reset_session).once - post :login, :username => 'jsmith', :password => 'jsmith' + post :login, :params => { + :username => 'jsmith', + :password => 'jsmith' + } assert_response 302 end @@ -257,14 +293,17 @@ class AccountControllerTest < Redmine::ControllerTest def test_post_register_with_registration_on with_settings :self_registration => '3' do assert_difference 'User.count' do - post :register, :user => { - :login => 'register', - :password => 'secret123', - :password_confirmation => 'secret123', - :firstname => 'John', - :lastname => 'Doe', - :mail => 'register@example.com' - } + post :register, :params => { + :user => { + :login => 'register', + :password => 'secret123', + :password_confirmation => 'secret123', + :firstname => 'John', + :lastname => 'Doe', + :mail => 'register@example.com' + + } + } assert_redirected_to '/my/account' end user = User.order('id DESC').first @@ -280,14 +319,17 @@ class AccountControllerTest < Redmine::ControllerTest def test_post_register_with_registration_off_should_redirect with_settings :self_registration => '0' do assert_no_difference 'User.count' do - post :register, :user => { - :login => 'register', - :password => 'test', - :password_confirmation => 'test', - :firstname => 'John', - :lastname => 'Doe', - :mail => 'register@example.com' - } + post :register, :params => { + :user => { + :login => 'register', + :password => 'test', + :password_confirmation => 'test', + :firstname => 'John', + :lastname => 'Doe', + :mail => 'register@example.com' + + } + } assert_redirected_to '/' end end @@ -296,14 +338,21 @@ class AccountControllerTest < Redmine::ControllerTest def test_post_register_should_create_user_with_hide_mail_preference with_settings :default_users_hide_mail => '0' do user = new_record(User) do - post :register, :user => { - :login => 'register', - :password => 'secret123', :password_confirmation => 'secret123', - :firstname => 'John', :lastname => 'Doe', - :mail => 'register@example.com' - }, :pref => { - :hide_mail => '1' - } + post :register, :params => { + :user => { + :login => 'register', + :password => 'secret123', + :password_confirmation => 'secret123', + :firstname => 'John', + :lastname => 'Doe', + :mail => 'register@example.com' + + }, + :pref => { + :hide_mail => '1' + + } + } end assert_equal true, user.pref.hide_mail end @@ -320,7 +369,9 @@ class AccountControllerTest < Redmine::ControllerTest ActionMailer::Base.deliveries.clear assert_difference 'ActionMailer::Base.deliveries.size' do assert_difference 'Token.count' do - post :lost_password, :mail => 'JSmith@somenet.foo' + post :lost_password, :params => { + :mail => 'JSmith@somenet.foo' + } assert_redirected_to '/login' end end @@ -340,7 +391,9 @@ class AccountControllerTest < Redmine::ControllerTest assert_difference 'ActionMailer::Base.deliveries.size' do assert_difference 'Token.count' do - post :lost_password, :mail => 'ANOTHERaddress@foo.bar' + post :lost_password, :params => { + :mail => 'ANOTHERaddress@foo.bar' + } assert_redirected_to '/login' end end @@ -351,7 +404,9 @@ class AccountControllerTest < Redmine::ControllerTest def test_lost_password_for_unknown_user_should_fail Token.delete_all assert_no_difference 'Token.count' do - post :lost_password, :mail => 'invalid@somenet.foo' + post :lost_password, :params => { + :mail => 'invalid@somenet.foo' + } assert_response :success end end @@ -361,7 +416,9 @@ class AccountControllerTest < Redmine::ControllerTest assert User.find(2).lock! assert_no_difference 'Token.count' do - post :lost_password, :mail => 'JSmith@somenet.foo' + post :lost_password, :params => { + :mail => 'JSmith@somenet.foo' + } assert_redirected_to '/account/lost_password' end end @@ -370,7 +427,9 @@ class AccountControllerTest < Redmine::ControllerTest User.any_instance.stubs(:change_password_allowed?).returns(false) assert_no_difference 'Token.count' do - post :lost_password, :mail => 'JSmith@somenet.foo' + post :lost_password, :params => { + :mail => 'JSmith@somenet.foo' + } assert_response :success end end @@ -379,7 +438,9 @@ class AccountControllerTest < Redmine::ControllerTest user = User.find(2) token = Token.create!(:action => 'recovery', :user => user) - get :lost_password, :token => token.value + get :lost_password, :params => { + :token => token.value + } assert_redirected_to '/account/lost_password' assert_equal token.value, request.session[:password_recovery_token] @@ -397,7 +458,9 @@ class AccountControllerTest < Redmine::ControllerTest end def test_get_lost_password_with_invalid_token_should_redirect - get :lost_password, :token => "abcdef" + get :lost_password, :params => { + :token => "abcdef" + } assert_redirected_to '/' end @@ -406,7 +469,11 @@ class AccountControllerTest < Redmine::ControllerTest user = User.find(2) token = Token.create!(:action => 'recovery', :user => user) - post :lost_password, :token => token.value, :new_password => 'newpass123', :new_password_confirmation => 'newpass123' + post :lost_password, :params => { + :token => token.value, + :new_password => 'newpass123', + :new_password_confirmation => 'newpass123' + } assert_redirected_to '/login' user.reload assert user.check_password?('newpass123') @@ -422,7 +489,11 @@ class AccountControllerTest < Redmine::ControllerTest token = Token.create!(:action => 'recovery', :user => user) user.lock! - post :lost_password, :token => token.value, :new_password => 'newpass123', :new_password_confirmation => 'newpass123' + post :lost_password, :params => { + :token => token.value, + :new_password => 'newpass123', + :new_password_confirmation => 'newpass123' + } assert_redirected_to '/' assert ! user.check_password?('newpass123') end @@ -431,7 +502,11 @@ class AccountControllerTest < Redmine::ControllerTest user = User.find(2) token = Token.create!(:action => 'recovery', :user => user) - post :lost_password, :token => token.value, :new_password => 'newpass', :new_password_confirmation => 'wrongpass' + post :lost_password, :params => { + :token => token.value, + :new_password => 'newpass', + :new_password_confirmation => 'wrongpass' + } assert_response :success assert_not_nil Token.find_by_id(token.id), "Token was deleted" @@ -445,7 +520,11 @@ class AccountControllerTest < Redmine::ControllerTest user.save! token = Token.create!(:action => 'recovery', :user => user) - post :lost_password, :token => token.value, :new_password => 'originalpassword', :new_password_confirmation => 'originalpassword' + post :lost_password, :params => { + :token => token.value, + :new_password => 'originalpassword', + :new_password_confirmation => 'originalpassword' + } assert_response :success assert_not_nil Token.find_by_id(token.id), "Token was deleted" @@ -460,14 +539,22 @@ class AccountControllerTest < Redmine::ControllerTest user.save! token = Token.create!(:action => 'recovery', :user => user) - post :lost_password, :token => token.value, :new_password => 'newpassword', :new_password_confirmation => 'newpassword' + post :lost_password, :params => { + :token => token.value, + :new_password => 'newpassword', + :new_password_confirmation => 'newpassword' + } assert_redirected_to '/login' assert_equal false, user.reload.must_change_passwd end def test_post_lost_password_with_invalid_token_should_redirect - post :lost_password, :token => "abcdef", :new_password => 'newpass', :new_password_confirmation => 'newpass' + post :lost_password, :params => { + :token => "abcdef", + :new_password => 'newpass', + :new_password_confirmation => 'newpass' + } assert_redirected_to '/' end diff --git a/test/functional/activities_controller_test.rb b/test/functional/activities_controller_test.rb index 230e46192..e92373739 100644 --- a/test/functional/activities_controller_test.rb +++ b/test/functional/activities_controller_test.rb @@ -30,7 +30,10 @@ class ActivitiesControllerTest < Redmine::ControllerTest def test_project_index - get :index, :id => 1, :with_subprojects => 0 + get :index, :params => { + :id => 1, + :with_subprojects => 0 + } assert_response :success assert_select 'h3', :text => /#{2.days.ago.to_date.day}/ @@ -38,12 +41,17 @@ class ActivitiesControllerTest < Redmine::ControllerTest end def test_project_index_with_invalid_project_id_should_respond_404 - get :index, :id => 299 + get :index, :params => { + :id => 299 + } assert_response 404 end def test_previous_project_index - get :index, :id => 1, :from => 2.days.ago.to_date + get :index, :params => { + :id => 1, + :from => 2.days.ago.to_date + } assert_response :success assert_select 'h3', :text => /#{3.days.ago.to_date.day}/ @@ -64,7 +72,9 @@ class ActivitiesControllerTest < Redmine::ControllerTest def test_user_index @request.session[:user_id] = 1 - get :index, :user_id => 2 + get :index, :params => { + :user_id => 2 + } assert_response :success assert_select 'h2 a[href="/users/2"]', :text => 'John Smith' @@ -77,12 +87,17 @@ class ActivitiesControllerTest < Redmine::ControllerTest end def test_user_index_with_invalid_user_id_should_respond_404 - get :index, :user_id => 299 + get :index, :params => { + :user_id => 299 + } assert_response 404 end def test_index_atom_feed - get :index, :format => 'atom', :with_subprojects => 0 + get :index, :params => { + :format => 'atom', + :with_subprojects => 0 + } assert_response :success assert_select 'feed' do @@ -95,15 +110,18 @@ class ActivitiesControllerTest < Redmine::ControllerTest end def test_index_atom_feed_with_explicit_selection - get :index, :format => 'atom', :with_subprojects => 0, - :show_changesets => 1, - :show_documents => 1, - :show_files => 1, - :show_issues => 1, - :show_messages => 1, - :show_news => 1, - :show_time_entries => 1, - :show_wiki_edits => 1 + get :index, :params => { + :format => 'atom', + :with_subprojects => 0, + :show_changesets => 1, + :show_documents => 1, + :show_files => 1, + :show_issues => 1, + :show_messages => 1, + :show_news => 1, + :show_time_entries => 1, + :show_wiki_edits => 1 + } assert_response :success @@ -118,7 +136,10 @@ class ActivitiesControllerTest < Redmine::ControllerTest def test_index_atom_feed_with_one_item_type with_settings :default_language => 'en' do - get :index, :format => 'atom', :show_issues => '1' + get :index, :params => { + :format => 'atom', + :show_issues => '1' + } assert_response :success assert_select 'title', :text => /Issues/ @@ -126,7 +147,10 @@ class ActivitiesControllerTest < Redmine::ControllerTest end def test_index_atom_feed_with_user - get :index, :user_id => 2, :format => 'atom' + get :index, :params => { + :user_id => 2, + :format => 'atom' + } assert_response :success assert_select 'title', :text => "Redmine: #{User.find(2).name}" @@ -149,7 +173,11 @@ class ActivitiesControllerTest < Redmine::ControllerTest def test_index_with_submitted_scope_should_save_as_preference @request.session[:user_id] = 2 - get :index, :show_issues => '1', :show_messages => '1', :submit => 'Apply' + get :index, :params => { + :show_issues => '1', + :show_messages => '1', + :submit => 'Apply' + } assert_response :success assert_equal %w(issues messages), User.find(2).pref.activity_scope.sort end @@ -182,7 +210,9 @@ class ActivitiesControllerTest < Redmine::ControllerTest def test_index_up_to_yesterday_should_show_next_page_link @request.session[:user_id] = 2 - get :index, :from => (User.find(2).today-1) + get :index, :params => { + :from => (User.find(2).today-1) + } assert_response :success assert_select '.pagination a', :text => /Previous/ assert_select '.pagination a', :text => /Next/ diff --git a/test/functional/admin_controller_test.rb b/test/functional/admin_controller_test.rb index 70a8ca683..523a8efaf 100644 --- a/test/functional/admin_controller_test.rb +++ b/test/functional/admin_controller_test.rb @@ -43,13 +43,18 @@ class AdminControllerTest < Redmine::ControllerTest end def test_projects_with_status_filter - get :projects, :status => 1 + get :projects, :params => { + :status => 1 + } assert_response :success assert_select 'tr.project.closed', 0 end def test_projects_with_name_filter - get :projects, :name => 'store', :status => '' + get :projects, :params => { + :name => 'store', + :status => '' + } assert_response :success assert_select 'tr.project td.name', :text => 'OnlineStore' @@ -58,7 +63,9 @@ class AdminControllerTest < Redmine::ControllerTest def test_load_default_configuration_data delete_configuration_data - post :default_configuration, :lang => 'fr' + post :default_configuration, :params => { + :lang => 'fr' + } assert_response :redirect assert_nil flash[:error] assert IssueStatus.find_by_name('Nouveau') @@ -67,7 +74,9 @@ class AdminControllerTest < Redmine::ControllerTest def test_load_default_configuration_data_should_rescue_error delete_configuration_data Redmine::DefaultData::Loader.stubs(:load).raises(Exception.new("Something went wrong")) - post :default_configuration, :lang => 'fr' + post :default_configuration, :params => { + :lang => 'fr' + } assert_response :redirect assert_not_nil flash[:error] assert_match /Something went wrong/, flash[:error] diff --git a/test/functional/attachments_controller_test.rb b/test/functional/attachments_controller_test.rb index 665eb1d9d..3eba761ae 100644 --- a/test/functional/attachments_controller_test.rb +++ b/test/functional/attachments_controller_test.rb @@ -36,7 +36,10 @@ class AttachmentsControllerTest < Redmine::ControllerTest def test_show_diff ['inline', 'sbs'].each do |dt| # 060719210727_changeset_utf8.diff - get :show, :id => 14, :type => dt + get :show, :params => { + :id => 14, + :type => dt + } assert_response :success assert_equal 'text/html', @response.content_type @@ -50,7 +53,10 @@ class AttachmentsControllerTest < Redmine::ControllerTest with_settings :repositories_encodings => 'UTF-8' do ['inline', 'sbs'].each do |dt| # 060719210727_changeset_iso8859-1.diff - get :show, :id => 5, :type => dt + get :show, :params => { + :id => 5, + :type => dt + } assert_response :success assert_equal 'text/html', @response.content_type @@ -65,7 +71,10 @@ class AttachmentsControllerTest < Redmine::ControllerTest with_settings :repositories_encodings => 'UTF-8,ISO-8859-1' do ['inline', 'sbs'].each do |dt| # 060719210727_changeset_iso8859-1.diff - get :show, :id => 5, :type => dt + get :show, :params => { + :id => 5, + :type => dt + } assert_response :success assert_equal 'text/html', @response.content_type @@ -84,12 +93,17 @@ class AttachmentsControllerTest < Redmine::ControllerTest assert_nil user.pref[:diff_type] @request.session[:user_id] = 1 # admin - get :show, :id => 5 + get :show, :params => { + :id => 5 + } assert_response :success user.reload assert_equal "inline", user.pref[:diff_type] - get :show, :id => 5, :type => 'sbs' + get :show, :params => { + :id => 5, + :type => 'sbs' + } assert_response :success user.reload assert_equal "sbs", user.pref[:diff_type] @@ -103,14 +117,19 @@ class AttachmentsControllerTest < Redmine::ControllerTest assert a.save assert_equal 'hg-export.diff', a.filename - get :show, :id => a.id, :type => 'inline' + get :show, :params => { + :id => a.id, + :type => 'inline' + } assert_response :success assert_equal 'text/html', @response.content_type assert_select 'th.filename', :text => 'test1.txt' end def test_show_text_file - get :show, :id => 4 + get :show, :params => { + :id => 4 + } assert_response :success assert_equal 'text/html', @response.content_type set_tmp_attachments_directory @@ -126,7 +145,9 @@ class AttachmentsControllerTest < Redmine::ControllerTest str_japanese = "\xe6\x97\xa5\xe6\x9c\xac\xe8\xaa\x9e".force_encoding('UTF-8') - get :show, :id => a.id + get :show, :params => { + :id => a.id + } assert_response :success assert_equal 'text/html', @response.content_type assert_select 'tr#L1' do @@ -144,7 +165,9 @@ class AttachmentsControllerTest < Redmine::ControllerTest assert a.save assert_equal 'iso8859-1.txt', a.filename - get :show, :id => a.id + get :show, :params => { + :id => a.id + } assert_response :success assert_equal 'text/html', @response.content_type assert_select 'tr#L7' do @@ -163,7 +186,9 @@ class AttachmentsControllerTest < Redmine::ControllerTest assert a.save assert_equal 'iso8859-1.txt', a.filename - get :show, :id => a.id + get :show, :params => { + :id => a.id + } assert_response :success assert_equal 'text/html', @response.content_type assert_select 'tr#L7' do @@ -177,7 +202,9 @@ class AttachmentsControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 with_settings :file_max_size_displayed => 512 do Attachment.find(4).update_attribute :filesize, 754.kilobyte - get :show, :id => 4 + get :show, :params => { + :id => 4 + } assert_response :success assert_equal 'text/html', @response.content_type assert_select '.nodata', :text => 'No preview available' @@ -187,7 +214,9 @@ class AttachmentsControllerTest < Redmine::ControllerTest def test_show_image @request.session[:user_id] = 2 - get :show, :id => 16 + get :show, :params => { + :id => 16 + } assert_response :success assert_equal 'text/html', @response.content_type assert_select 'img.filecontent', :src => attachments(:attachments_010).filename @@ -195,21 +224,27 @@ class AttachmentsControllerTest < Redmine::ControllerTest def test_show_other @request.session[:user_id] = 2 - get :show, :id => 6 + get :show, :params => { + :id => 6 + } assert_equal 'text/html', @response.content_type assert_select '.nodata', :text => 'No preview available' set_tmp_attachments_directory end def test_show_file_from_private_issue_without_permission - get :show, :id => 15 + get :show, :params => { + :id => 15 + } assert_redirected_to '/login?back_url=http%3A%2F%2Ftest.host%2Fattachments%2F15' set_tmp_attachments_directory end def test_show_file_from_private_issue_with_permission @request.session[:user_id] = 2 - get :show, :id => 15 + get :show, :params => { + :id => 15 + } assert_response :success assert_select 'h2', :text => /private.diff/ set_tmp_attachments_directory @@ -220,7 +255,9 @@ class AttachmentsControllerTest < Redmine::ControllerTest attachment = Attachment.create!(:file => uploaded_test_file("testfile.txt", "text/plain"), :author_id => 2) @request.session[:user_id] = 2 - get :show, :id => attachment.id + get :show, :params => { + :id => attachment.id + } assert_response 200 end @@ -229,24 +266,32 @@ class AttachmentsControllerTest < Redmine::ControllerTest attachment = Attachment.create!(:file => uploaded_test_file("testfile.txt", "text/plain"), :author_id => 2) @request.session[:user_id] = 3 - get :show, :id => attachment.id + get :show, :params => { + :id => attachment.id + } assert_response 403 end def test_show_invalid_should_respond_with_404 - get :show, :id => 999 + get :show, :params => { + :id => 999 + } assert_response 404 end def test_download_text_file - get :download, :id => 4 + get :download, :params => { + :id => 4 + } assert_response :success assert_equal 'application/x-ruby', @response.content_type etag = @response.etag assert_not_nil etag @request.env["HTTP_IF_NONE_MATCH"] = etag - get :download, :id => 4 + get :download, :params => { + :id => 4 + } assert_response 304 set_tmp_attachments_directory @@ -260,21 +305,27 @@ class AttachmentsControllerTest < Redmine::ControllerTest :container => Issue.find(1) ) - get :download, :id => attachment.id + get :download, :params => { + :id => attachment.id + } assert_response :success assert_equal 'text/javascript', @response.content_type end def test_download_version_file_with_issue_tracking_disabled Project.find(1).disable_module! :issue_tracking - get :download, :id => 9 + get :download, :params => { + :id => 9 + } assert_response :success end def test_download_should_assign_content_type_if_blank Attachment.find(4).update_attribute(:content_type, '') - get :download, :id => 4 + get :download, :params => { + :id => 4 + } assert_response :success assert_equal 'text/x-ruby', @response.content_type set_tmp_attachments_directory @@ -283,20 +334,26 @@ class AttachmentsControllerTest < Redmine::ControllerTest def test_download_should_assign_better_content_type_than_application_octet_stream Attachment.find(4).update! :content_type => "application/octet-stream" - get :download, :id => 4 + get :download, :params => { + :id => 4 + } assert_response :success assert_equal 'text/x-ruby', @response.content_type set_tmp_attachments_directory end def test_download_missing_file - get :download, :id => 2 + get :download, :params => { + :id => 2 + } assert_response 404 set_tmp_attachments_directory end def test_download_should_be_denied_without_permission - get :download, :id => 7 + get :download, :params => { + :id => 7 + } assert_redirected_to '/login?back_url=http%3A%2F%2Ftest.host%2Fattachments%2Fdownload%2F7' set_tmp_attachments_directory end @@ -305,7 +362,9 @@ class AttachmentsControllerTest < Redmine::ControllerTest def test_thumbnail Attachment.clear_thumbnails @request.session[:user_id] = 2 - get :thumbnail, :id => 16 + get :thumbnail, :params => { + :id => 16 + } assert_response :success assert_equal 'image/png', response.content_type @@ -313,7 +372,9 @@ class AttachmentsControllerTest < Redmine::ControllerTest assert_not_nil etag @request.env["HTTP_IF_NONE_MATCH"] = etag - get :thumbnail, :id => 16 + get :thumbnail, :params => { + :id => 16 + } assert_response 304 end @@ -321,20 +382,28 @@ class AttachmentsControllerTest < Redmine::ControllerTest Redmine::Thumbnail.expects(:generate).with {|source, target, size| size == 800} @request.session[:user_id] = 2 - get :thumbnail, :id => 16, :size => 2000 + get :thumbnail, :params => { + :id => 16, + :size => 2000 + } end def test_thumbnail_should_round_size Redmine::Thumbnail.expects(:generate).with {|source, target, size| size == 250} @request.session[:user_id] = 2 - get :thumbnail, :id => 16, :size => 260 + get :thumbnail, :params => { + :id => 16, + :size => 260 + } end def test_thumbnail_should_return_404_for_non_image_attachment @request.session[:user_id] = 2 - get :thumbnail, :id => 15 + get :thumbnail, :params => { + :id => 15 + } assert_response 404 end @@ -342,12 +411,16 @@ class AttachmentsControllerTest < Redmine::ControllerTest Attachment.any_instance.stubs(:thumbnail).returns(nil) @request.session[:user_id] = 2 - get :thumbnail, :id => 16 + get :thumbnail, :params => { + :id => 16 + } assert_response 404 end def test_thumbnail_should_be_denied_without_permission - get :thumbnail, :id => 16 + get :thumbnail, :params => { + :id => 16 + } assert_redirected_to '/login?back_url=http%3A%2F%2Ftest.host%2Fattachments%2Fthumbnail%2F16' end else @@ -356,7 +429,10 @@ class AttachmentsControllerTest < Redmine::ControllerTest def test_edit_all @request.session[:user_id] = 2 - get :edit_all, :object_type => 'issues', :object_id => '2' + get :edit_all, :params => { + :object_type => 'issues', + :object_id => '2' + } assert_response :success assert_select 'form[action=?]', '/attachments/issues/2' do @@ -372,25 +448,45 @@ class AttachmentsControllerTest < Redmine::ControllerTest end def test_edit_all_with_invalid_container_class_should_return_404 - get :edit_all, :object_type => 'nuggets', :object_id => '3' + get :edit_all, :params => { + :object_type => 'nuggets', + :object_id => '3' + } assert_response 404 end def test_edit_all_with_invalid_object_should_return_404 - get :edit_all, :object_type => 'issues', :object_id => '999' + get :edit_all, :params => { + :object_type => 'issues', + :object_id => '999' + } assert_response 404 end def test_edit_all_for_object_that_is_not_visible_should_return_403 - get :edit_all, :object_type => 'issues', :object_id => '4' + get :edit_all, :params => { + :object_type => 'issues', + :object_id => '4' + } assert_response 403 end def test_update_all @request.session[:user_id] = 2 - patch :update_all, :object_type => 'issues', :object_id => '2', :attachments => { - '1' => {:filename => 'newname.text', :description => ''}, - '4' => {:filename => 'newname.rb', :description => 'Renamed'}, + patch :update_all, :params => { + :object_type => 'issues', + :object_id => '2', + :attachments => { + '1' => { + :filename => 'newname.text', + :description => '' + }, + '4' => { + :filename => 'newname.rb', + :description => 'Renamed' + }, + + } } assert_response 302 @@ -401,9 +497,20 @@ class AttachmentsControllerTest < Redmine::ControllerTest def test_update_all_with_failure @request.session[:user_id] = 2 - patch :update_all, :object_type => 'issues', :object_id => '3', :attachments => { - '1' => {:filename => '', :description => ''}, - '4' => {:filename => 'newname.rb', :description => 'Renamed'}, + patch :update_all, :params => { + :object_type => 'issues', + :object_id => '3', + :attachments => { + '1' => { + :filename => '', + :description => '' + }, + '4' => { + :filename => 'newname.rb', + :description => 'Renamed' + }, + + } } assert_response :success @@ -422,7 +529,9 @@ class AttachmentsControllerTest < Redmine::ControllerTest assert_difference 'issue.attachments.count', -1 do assert_difference 'Journal.count' do - delete :destroy, :id => 1 + delete :destroy, :params => { + :id => 1 + } assert_redirected_to '/projects/ecookbook' end end @@ -439,7 +548,9 @@ class AttachmentsControllerTest < Redmine::ControllerTest set_tmp_attachments_directory @request.session[:user_id] = 2 assert_difference 'Attachment.count', -1 do - delete :destroy, :id => 3 + delete :destroy, :params => { + :id => 3 + } assert_response 302 end end @@ -448,7 +559,9 @@ class AttachmentsControllerTest < Redmine::ControllerTest set_tmp_attachments_directory @request.session[:user_id] = 2 assert_difference 'Attachment.count', -1 do - delete :destroy, :id => 8 + delete :destroy, :params => { + :id => 8 + } assert_response 302 end end @@ -457,7 +570,9 @@ class AttachmentsControllerTest < Redmine::ControllerTest set_tmp_attachments_directory @request.session[:user_id] = 2 assert_difference 'Attachment.count', -1 do - delete :destroy, :id => 9 + delete :destroy, :params => { + :id => 9 + } assert_response 302 end end @@ -467,7 +582,9 @@ class AttachmentsControllerTest < Redmine::ControllerTest set_tmp_attachments_directory @request.session[:user_id] = 2 assert_difference 'Attachment.count', -1 do - delete :destroy, :id => 9 + delete :destroy, :params => { + :id => 9 + } assert_response 302 end end @@ -475,7 +592,9 @@ class AttachmentsControllerTest < Redmine::ControllerTest def test_destroy_without_permission set_tmp_attachments_directory assert_no_difference 'Attachment.count' do - delete :destroy, :id => 3 + delete :destroy, :params => { + :id => 3 + } end assert_response 302 assert Attachment.find_by_id(3) diff --git a/test/functional/auth_sources_controller_test.rb b/test/functional/auth_sources_controller_test.rb index 1ad829655..b3fbef0a5 100644 --- a/test/functional/auth_sources_controller_test.rb +++ b/test/functional/auth_sources_controller_test.rb @@ -40,13 +40,23 @@ class AuthSourcesControllerTest < Redmine::ControllerTest end def test_new_with_invalid_type_should_respond_with_404 - get :new, :type => 'foo' + get :new, :params => { + :type => 'foo' + } assert_response 404 end def test_create assert_difference 'AuthSourceLdap.count' do - post :create, :type => 'AuthSourceLdap', :auth_source => {:name => 'Test', :host => '127.0.0.1', :port => '389', :attr_login => 'cn'} + post :create, :params => { + :type => 'AuthSourceLdap', + :auth_source => { + :name => 'Test', + :host => '127.0.0.1', + :port => '389', + :attr_login => 'cn' + } + } assert_redirected_to '/auth_sources' end @@ -59,16 +69,24 @@ class AuthSourcesControllerTest < Redmine::ControllerTest def test_create_with_failure assert_no_difference 'AuthSourceLdap.count' do - post :create, :type => 'AuthSourceLdap', - :auth_source => {:name => 'Test', :host => '', - :port => '389', :attr_login => 'cn'} + post :create, :params => { + :type => 'AuthSourceLdap', + :auth_source => { + :name => 'Test', + :host => '', + :port => '389', + :attr_login => 'cn' + } + } assert_response :success end assert_select_error /host cannot be blank/i end def test_edit - get :edit, :id => 1 + get :edit, :params => { + :id => 1 + } assert_response :success assert_select 'form#auth_source_form' do @@ -79,21 +97,31 @@ class AuthSourcesControllerTest < Redmine::ControllerTest def test_edit_should_not_contain_password AuthSource.find(1).update_column :account_password, 'secret' - get :edit, :id => 1 + get :edit, :params => { + :id => 1 + } assert_response :success assert_select 'input[value=secret]', 0 assert_select 'input[name=dummy_password][value^=xxxxxx]' end def test_edit_invalid_should_respond_with_404 - get :edit, :id => 99 + get :edit, :params => { + :id => 99 + } assert_response 404 end def test_update - put :update, :id => 1, - :auth_source => {:name => 'Renamed', :host => '192.168.0.10', - :port => '389', :attr_login => 'uid'} + put :update, :params => { + :id => 1, + :auth_source => { + :name => 'Renamed', + :host => '192.168.0.10', + :port => '389', + :attr_login => 'uid' + } + } assert_redirected_to '/auth_sources' source = AuthSourceLdap.find(1) assert_equal 'Renamed', source.name @@ -101,16 +129,24 @@ class AuthSourcesControllerTest < Redmine::ControllerTest end def test_update_with_failure - put :update, :id => 1, - :auth_source => {:name => 'Renamed', :host => '', - :port => '389', :attr_login => 'uid'} + put :update, :params => { + :id => 1, + :auth_source => { + :name => 'Renamed', + :host => '', + :port => '389', + :attr_login => 'uid' + } + } assert_response :success assert_select_error /host cannot be blank/i end def test_destroy assert_difference 'AuthSourceLdap.count', -1 do - delete :destroy, :id => 1 + delete :destroy, :params => { + :id => 1 + } assert_redirected_to '/auth_sources' end end @@ -119,7 +155,9 @@ class AuthSourcesControllerTest < Redmine::ControllerTest User.find(2).update_attribute :auth_source_id, 1 assert_no_difference 'AuthSourceLdap.count' do - delete :destroy, :id => 1 + delete :destroy, :params => { + :id => 1 + } assert_redirected_to '/auth_sources' end end @@ -127,7 +165,9 @@ class AuthSourcesControllerTest < Redmine::ControllerTest def test_test_connection AuthSourceLdap.any_instance.stubs(:test_connection).returns(true) - get :test_connection, :id => 1 + get :test_connection, :params => { + :id => 1 + } assert_redirected_to '/auth_sources' assert_not_nil flash[:notice] assert_match /successful/i, flash[:notice] @@ -136,7 +176,9 @@ class AuthSourcesControllerTest < Redmine::ControllerTest def test_test_connection_with_failure AuthSourceLdap.any_instance.stubs(:initialize_ldap_con).raises(Net::LDAP::LdapError.new("Something went wrong")) - get :test_connection, :id => 1 + get :test_connection, :params => { + :id => 1 + } assert_redirected_to '/auth_sources' assert_not_nil flash[:error] assert_include 'Something went wrong', flash[:error] @@ -148,7 +190,9 @@ class AuthSourcesControllerTest < Redmine::ControllerTest {:login => 'Smith', :firstname => 'John', :lastname => 'Doe', :mail => 'foo2@example.net', :auth_source_id => 1} ]) - get :autocomplete_for_new_user, :term => 'foo' + get :autocomplete_for_new_user, :params => { + :term => 'foo' + } assert_response :success assert_equal 'application/json', response.content_type json = ActiveSupport::JSON.decode(response.body) diff --git a/test/functional/auto_completes_controller_test.rb b/test/functional/auto_completes_controller_test.rb index d02addc1a..5b8260c75 100644 --- a/test/functional/auto_completes_controller_test.rb +++ b/test/functional/auto_completes_controller_test.rb @@ -29,49 +29,73 @@ class AutoCompletesControllerTest < Redmine::ControllerTest :journals, :journal_details def test_issues_should_not_be_case_sensitive - get :issues, :project_id => 'ecookbook', :q => 'ReCiPe' + get :issues, :params => { + :project_id => 'ecookbook', + :q => 'ReCiPe' + } assert_response :success assert_include "recipe", response.body end def test_issues_should_accept_term_param - get :issues, :project_id => 'ecookbook', :term => 'ReCiPe' + get :issues, :params => { + :project_id => 'ecookbook', + :term => 'ReCiPe' + } assert_response :success assert_include "recipe", response.body end def test_issues_should_return_issue_with_given_id - get :issues, :project_id => 'subproject1', :q => '13' + get :issues, :params => { + :project_id => 'subproject1', + :q => '13' + } assert_response :success assert_include "Bug #13", response.body end def test_issues_should_return_issue_with_given_id_preceded_with_hash - get :issues, :project_id => 'subproject1', :q => '#13' + get :issues, :params => { + :project_id => 'subproject1', + :q => '#13' + } assert_response :success assert_include "Bug #13", response.body end def test_auto_complete_with_scope_all_should_search_other_projects - get :issues, :project_id => 'ecookbook', :q => '13', :scope => 'all' + get :issues, :params => { + :project_id => 'ecookbook', + :q => '13', + :scope => 'all' + } assert_response :success assert_include "Bug #13", response.body end def test_auto_complete_without_project_should_search_all_projects - get :issues, :q => '13' + get :issues, :params => { + :q => '13' + } assert_response :success assert_include "Bug #13", response.body end def test_auto_complete_without_scope_all_should_not_search_other_projects - get :issues, :project_id => 'ecookbook', :q => '13' + get :issues, :params => { + :project_id => 'ecookbook', + :q => '13' + } assert_response :success assert_not_include "Bug #13", response.body end def test_issues_should_return_json - get :issues, :project_id => 'subproject1', :q => '13' + get :issues, :params => { + :project_id => 'subproject1', + :q => '13' + } assert_response :success json = ActiveSupport::JSON.decode(response.body) assert_kind_of Array, json @@ -83,21 +107,33 @@ class AutoCompletesControllerTest < Redmine::ControllerTest end def test_auto_complete_with_status_o_should_return_open_issues_only - get :issues, :project_id => 'ecookbook', :q => 'issue', :status => 'o' + get :issues, :params => { + :project_id => 'ecookbook', + :q => 'issue', + :status => 'o' + } assert_response :success assert_include "Issue due today", response.body assert_not_include "closed", response.body end def test_auto_complete_with_status_c_should_return_closed_issues_only - get :issues, :project_id => 'ecookbook', :q => 'issue', :status => 'c' + get :issues, :params => { + :project_id => 'ecookbook', + :q => 'issue', + :status => 'c' + } assert_response :success assert_include "closed", response.body assert_not_include "Issue due today", response.body end def test_auto_complete_with_issue_id_should_not_return_that_issue - get :issues, :project_id => 'ecookbook', :q => 'issue', :issue_id => '12' + get :issues, :params => { + :project_id => 'ecookbook', + :q => 'issue', + :issue_id => '12' + } assert_response :success assert_include "issue", response.body assert_not_include "Bug #12: Closed issue on a locked version", response.body diff --git a/test/functional/boards_controller_test.rb b/test/functional/boards_controller_test.rb index f395769ec..0b500249d 100644 --- a/test/functional/boards_controller_test.rb +++ b/test/functional/boards_controller_test.rb @@ -25,20 +25,26 @@ class BoardsControllerTest < Redmine::ControllerTest end def test_index - get :index, :project_id => 1 + get :index, :params => { + :project_id => 1 + } assert_response :success assert_select 'table.boards' end def test_index_not_found - get :index, :project_id => 97 + get :index, :params => { + :project_id => 97 + } assert_response 404 end def test_index_should_show_messages_if_only_one_board Project.find(1).boards.to_a.slice(1..-1).each(&:destroy) - get :index, :project_id => 1 + get :index, :params => { + :project_id => 1 + } assert_response :success assert_select 'table.boards', 0 @@ -46,7 +52,10 @@ class BoardsControllerTest < Redmine::ControllerTest end def test_show - get :show, :project_id => 1, :id => 1 + get :show, :params => { + :project_id => 1, + :id => 1 + } assert_response :success assert_select 'table.messages tbody' do @@ -58,7 +67,10 @@ class BoardsControllerTest < Redmine::ControllerTest Message.update_all(:sticky => 0) Message.where({:id => 1}).update_all({:sticky => 1}) - get :show, :project_id => 1, :id => 1 + get :show, :params => { + :project_id => 1, + :id => 1 + } assert_response :success assert_select 'table.messages tbody' do @@ -77,7 +89,10 @@ class BoardsControllerTest < Redmine::ControllerTest reply = Message.new(:board_id => 1, :subject => 'New reply', :content => 'New reply', :author_id => 2) old_topic.children << reply - get :show, :project_id => 1, :id => 1 + get :show, :params => { + :project_id => 1, + :id => 1 + } assert_response :success assert_select 'table.messages tbody' do @@ -88,7 +103,10 @@ class BoardsControllerTest < Redmine::ControllerTest def test_show_with_permission_should_display_the_new_message_form @request.session[:user_id] = 2 - get :show, :project_id => 1, :id => 1 + get :show, :params => { + :project_id => 1, + :id => 1 + } assert_response :success assert_select 'form#message-form' do @@ -97,20 +115,29 @@ class BoardsControllerTest < Redmine::ControllerTest end def test_show_atom - get :show, :project_id => 1, :id => 1, :format => 'atom' + get :show, :params => { + :project_id => 1, + :id => 1, + :format => 'atom' + } assert_response :success assert_select 'feed > entry > title', :text => 'Help: RE: post 2' end def test_show_not_found - get :index, :project_id => 1, :id => 97 + get :index, :params => { + :project_id => 1, + :id => 97 + } assert_response 404 end def test_new @request.session[:user_id] = 2 - get :new, :project_id => 1 + get :new, :params => { + :project_id => 1 + } assert_response :success assert_select 'select[name=?]', 'board[parent_id]' do @@ -128,7 +155,9 @@ class BoardsControllerTest < Redmine::ControllerTest Project.find(1).boards.delete_all @request.session[:user_id] = 2 - get :new, :project_id => 1 + get :new, :params => { + :project_id => 1 + } assert_response :success assert_select 'select[name=?]', 'board[parent_id]', 0 @@ -137,7 +166,13 @@ class BoardsControllerTest < Redmine::ControllerTest def test_create @request.session[:user_id] = 2 assert_difference 'Board.count' do - post :create, :project_id => 1, :board => { :name => 'Testing', :description => 'Testing board creation'} + post :create, :params => { + :project_id => 1, + :board => { + :name => 'Testing', + :description => 'Testing board creation' + } + } end assert_redirected_to '/projects/ecookbook/settings/boards' board = Board.order('id DESC').first @@ -148,7 +183,14 @@ class BoardsControllerTest < Redmine::ControllerTest def test_create_with_parent @request.session[:user_id] = 2 assert_difference 'Board.count' do - post :create, :project_id => 1, :board => { :name => 'Testing', :description => 'Testing', :parent_id => 2} + post :create, :params => { + :project_id => 1, + :board => { + :name => 'Testing', + :description => 'Testing', + :parent_id => 2 + } + } end assert_redirected_to '/projects/ecookbook/settings/boards' board = Board.order('id DESC').first @@ -158,7 +200,13 @@ class BoardsControllerTest < Redmine::ControllerTest def test_create_with_failure @request.session[:user_id] = 2 assert_no_difference 'Board.count' do - post :create, :project_id => 1, :board => { :name => '', :description => 'Testing board creation'} + post :create, :params => { + :project_id => 1, + :board => { + :name => '', + :description => 'Testing board creation' + } + } end assert_response :success assert_select_error /Name cannot be blank/ @@ -166,7 +214,10 @@ class BoardsControllerTest < Redmine::ControllerTest def test_edit @request.session[:user_id] = 2 - get :edit, :project_id => 1, :id => 2 + get :edit, :params => { + :project_id => 1, + :id => 2 + } assert_response :success assert_select 'input[name=?][value=?]', 'board[name]', 'Discussion' end @@ -174,7 +225,10 @@ class BoardsControllerTest < Redmine::ControllerTest def test_edit_with_parent board = Board.generate!(:project_id => 1, :parent_id => 2) @request.session[:user_id] = 2 - get :edit, :project_id => 1, :id => board.id + get :edit, :params => { + :project_id => 1, + :id => board.id + } assert_response :success assert_select 'select[name=?]', 'board[parent_id]' do @@ -185,7 +239,14 @@ class BoardsControllerTest < Redmine::ControllerTest def test_update @request.session[:user_id] = 2 assert_no_difference 'Board.count' do - put :update, :project_id => 1, :id => 2, :board => { :name => 'Testing', :description => 'Testing board update'} + put :update, :params => { + :project_id => 1, + :id => 2, + :board => { + :name => 'Testing', + :description => 'Testing board update' + } + } end assert_redirected_to '/projects/ecookbook/settings/boards' assert_equal 'Testing', Board.find(2).name @@ -193,7 +254,13 @@ class BoardsControllerTest < Redmine::ControllerTest def test_update_position @request.session[:user_id] = 2 - put :update, :project_id => 1, :id => 2, :board => { :position => 1} + put :update, :params => { + :project_id => 1, + :id => 2, + :board => { + :position => 1 + } + } assert_redirected_to '/projects/ecookbook/settings/boards' board = Board.find(2) assert_equal 1, board.position @@ -201,7 +268,14 @@ class BoardsControllerTest < Redmine::ControllerTest def test_update_with_failure @request.session[:user_id] = 2 - put :update, :project_id => 1, :id => 2, :board => { :name => '', :description => 'Testing board update'} + put :update, :params => { + :project_id => 1, + :id => 2, + :board => { + :name => '', + :description => 'Testing board update' + } + } assert_response :success assert_select_error /Name cannot be blank/ end @@ -209,7 +283,10 @@ class BoardsControllerTest < Redmine::ControllerTest def test_destroy @request.session[:user_id] = 2 assert_difference 'Board.count', -1 do - delete :destroy, :project_id => 1, :id => 2 + delete :destroy, :params => { + :project_id => 1, + :id => 2 + } end assert_redirected_to '/projects/ecookbook/settings/boards' assert_nil Board.find_by_id(2) diff --git a/test/functional/calendars_controller_test.rb b/test/functional/calendars_controller_test.rb index 453e51e23..7c3a5ffcd 100644 --- a/test/functional/calendars_controller_test.rb +++ b/test/functional/calendars_controller_test.rb @@ -32,14 +32,18 @@ class CalendarsControllerTest < Redmine::ControllerTest :enumerations def test_show - get :show, :project_id => 1 + get :show, :params => { + :project_id => 1 + } assert_response :success end def test_show_should_run_custom_queries @query = IssueQuery.create!(:name => 'Calendar Query', :visibility => IssueQuery::VISIBILITY_PUBLIC) - get :show, :query_id => @query.id + get :show, :params => { + :query_id => @query.id + } assert_response :success assert_select 'h2', :text => 'Calendar Query' end @@ -51,7 +55,10 @@ class CalendarsControllerTest < Redmine::ControllerTest def test_week_number_calculation with_settings :start_of_week => 7 do - get :show, :month => '1', :year => '2010' + get :show, :params => { + :month => '1', + :year => '2010' + } assert_response :success end @@ -68,7 +75,10 @@ class CalendarsControllerTest < Redmine::ControllerTest end with_settings :start_of_week => 1 do - get :show, :month => '1', :year => '2010' + get :show, :params => { + :month => '1', + :year => '2010' + } assert_response :success end diff --git a/test/functional/comments_controller_test.rb b/test/functional/comments_controller_test.rb index 9ba469eed..466617b8c 100644 --- a/test/functional/comments_controller_test.rb +++ b/test/functional/comments_controller_test.rb @@ -26,7 +26,12 @@ class CommentsControllerTest < Redmine::ControllerTest def test_add_comment @request.session[:user_id] = 2 - post :create, :id => 1, :comment => { :comments => 'This is a test comment' } + post :create, :params => { + :id => 1, + :comment => { + :comments => 'This is a test comment' + } + } assert_redirected_to '/news/1' comment = News.find(1).comments.last @@ -38,7 +43,12 @@ class CommentsControllerTest < Redmine::ControllerTest def test_empty_comment_should_not_be_added @request.session[:user_id] = 2 assert_no_difference 'Comment.count' do - post :create, :id => 1, :comment => { :comments => '' } + post :create, :params => { + :id => 1, + :comment => { + :comments => '' + } + } assert_response :redirect assert_redirected_to '/news/1' end @@ -48,7 +58,12 @@ class CommentsControllerTest < Redmine::ControllerTest News.any_instance.stubs(:commentable?).returns(false) @request.session[:user_id] = 2 assert_no_difference 'Comment.count' do - post :create, :id => 1, :comment => { :comments => 'This is a test comment' } + post :create, :params => { + :id => 1, + :comment => { + :comments => 'This is a test comment' + } + } assert_response 403 end end @@ -56,7 +71,10 @@ class CommentsControllerTest < Redmine::ControllerTest def test_destroy_comment comments_count = News.find(1).comments.size @request.session[:user_id] = 2 - delete :destroy, :id => 1, :comment_id => 2 + delete :destroy, :params => { + :id => 1, + :comment_id => 2 + } assert_redirected_to '/news/1' assert_nil Comment.find_by_id(2) assert_equal comments_count - 1, News.find(1).comments.size diff --git a/test/functional/context_menus_controller_test.rb b/test/functional/context_menus_controller_test.rb index 58ca8d094..0f91f00cb 100644 --- a/test/functional/context_menus_controller_test.rb +++ b/test/functional/context_menus_controller_test.rb @@ -35,7 +35,9 @@ class ContextMenusControllerTest < Redmine::ControllerTest def test_context_menu_one_issue @request.session[:user_id] = 2 - get :issues, :ids => [1] + get :issues, :params => { + :ids => [1] + } assert_response :success assert_select 'a.icon-edit[href=?]', '/issues/1/edit', :text => 'Edit' @@ -56,7 +58,9 @@ class ContextMenusControllerTest < Redmine::ControllerTest def test_context_menu_one_issue_by_anonymous with_settings :default_language => 'en' do - get :issues, :ids => [1] + get :issues, :params => { + :ids => [1] + } assert_response :success assert_select 'a.icon-del.disabled[href="#"]', :text => 'Delete' @@ -65,7 +69,9 @@ class ContextMenusControllerTest < Redmine::ControllerTest def test_context_menu_multiple_issues_of_same_project @request.session[:user_id] = 2 - get :issues, :ids => [1, 2] + get :issues, :params => { + :ids => [1, 2] + } assert_response :success ids = [1, 2].map {|i| "ids%5B%5D=#{i}"}.join('&') @@ -81,7 +87,9 @@ class ContextMenusControllerTest < Redmine::ControllerTest def test_context_menu_multiple_issues_of_different_projects @request.session[:user_id] = 2 - get :issues, :ids => [1, 2, 6] + get :issues, :params => { + :ids => [1, 2, 6] + } assert_response :success ids = [1, 2, 6].map {|i| "ids%5B%5D=#{i}"}.join('&') @@ -98,7 +106,9 @@ class ContextMenusControllerTest < Redmine::ControllerTest field = IssueCustomField.create!(:name => 'List', :field_format => 'list', :possible_values => ['Foo', 'Bar'], :is_for_all => true, :tracker_ids => [1, 2, 3]) @request.session[:user_id] = 2 - get :issues, :ids => [1] + get :issues, :params => { + :ids => [1] + } assert_select "li.cf_#{field.id}" do assert_select 'a[href="#"]', :text => 'List' @@ -114,7 +124,9 @@ class ContextMenusControllerTest < Redmine::ControllerTest field = IssueCustomField.create!(:name => 'List', :is_required => true, :field_format => 'list', :possible_values => ['Foo', 'Bar'], :is_for_all => true, :tracker_ids => [1, 2, 3]) @request.session[:user_id] = 2 - get :issues, :ids => [1, 2] + get :issues, :params => { + :ids => [1, 2] + } assert_select "li.cf_#{field.id}" do assert_select 'a[href="#"]', :text => 'List' @@ -132,7 +144,9 @@ class ContextMenusControllerTest < Redmine::ControllerTest issue.custom_field_values = {field.id => 'Bar'} issue.save! @request.session[:user_id] = 2 - get :issues, :ids => [1] + get :issues, :params => { + :ids => [1] + } assert_select "li.cf_#{field.id}" do assert_select 'a[href="#"]', :text => 'List' @@ -147,7 +161,9 @@ class ContextMenusControllerTest < Redmine::ControllerTest field = IssueCustomField.create!(:name => 'Bool', :field_format => 'bool', :is_for_all => true, :tracker_ids => [1, 2, 3]) @request.session[:user_id] = 2 - get :issues, :ids => [1] + get :issues, :params => { + :ids => [1] + } assert_select "li.cf_#{field.id}" do assert_select 'a[href="#"]', :text => 'Bool' @@ -164,7 +180,9 @@ class ContextMenusControllerTest < Redmine::ControllerTest field = IssueCustomField.create!(:name => 'User', :field_format => 'user', :is_for_all => true, :tracker_ids => [1, 2, 3]) @request.session[:user_id] = 2 - get :issues, :ids => [1] + get :issues, :params => { + :ids => [1] + } assert_select "li.cf_#{field.id}" do assert_select 'a[href="#"]', :text => 'User' @@ -179,7 +197,9 @@ class ContextMenusControllerTest < Redmine::ControllerTest def test_context_menu_should_include_version_custom_fields field = IssueCustomField.create!(:name => 'Version', :field_format => 'version', :is_for_all => true, :tracker_ids => [1, 2, 3]) @request.session[:user_id] = 2 - get :issues, :ids => [1] + get :issues, :params => { + :ids => [1] + } assert_select "li.cf_#{field.id}" do assert_select 'a[href="#"]', :text => 'Version' @@ -197,7 +217,9 @@ class ContextMenusControllerTest < Redmine::ControllerTest issue = Issue.generate!(:project_id => 1, :tracker_id => 1) @request.session[:user_id] = 2 - get :issues, :ids => [issue.id] + get :issues, :params => { + :ids => [issue.id] + } assert_select "li.cf_#{enabled_cf.id}" assert_select "li.cf_#{disabled_cf.id}", 0 @@ -205,7 +227,9 @@ class ContextMenusControllerTest < Redmine::ControllerTest def test_context_menu_by_assignable_user_should_include_assigned_to_me_link @request.session[:user_id] = 2 - get :issues, :ids => [1] + get :issues, :params => { + :ids => [1] + } assert_response :success assert_select 'a[href=?]', '/issues/bulk_update?ids%5B%5D=1&issue%5Bassigned_to_id%5D=2', :text => / me / @@ -215,14 +239,18 @@ class ContextMenusControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 version = Version.create!(:name => 'Shared', :sharing => 'system', :project_id => 1) - get :issues, :ids => [1, 4] + get :issues, :params => { + :ids => [1, 4] + } assert_response :success assert_select 'a', :text => 'eCookbook - Shared' end def test_context_menu_with_issue_that_is_not_visible_should_fail - get :issues, :ids => [1, 4] # issue 4 is not visible + get :issues, :params => { + :ids => [1, 4] # issue 4 is not visible + } assert_response 302 end @@ -233,7 +261,9 @@ class ContextMenusControllerTest < Redmine::ControllerTest def test_time_entries_context_menu @request.session[:user_id] = 2 - get :time_entries, :ids => [1, 2] + get :time_entries, :params => { + :ids => [1, 2] + } assert_response :success assert_select 'a:not(.disabled)', :text => 'Edit' @@ -241,7 +271,9 @@ class ContextMenusControllerTest < Redmine::ControllerTest def test_context_menu_for_one_time_entry @request.session[:user_id] = 2 - get :time_entries, :ids => [1] + get :time_entries, :params => { + :ids => [1] + } assert_response :success assert_select 'a:not(.disabled)', :text => 'Edit' @@ -251,7 +283,9 @@ class ContextMenusControllerTest < Redmine::ControllerTest field = TimeEntryCustomField.generate!(:name => "Field", :field_format => "list", :possible_values => ["foo", "bar"]) @request.session[:user_id] = 2 - get :time_entries, :ids => [1, 2] + get :time_entries, :params => { + :ids => [1, 2] + } assert_response :success assert_select "li.cf_#{field.id}" do @@ -271,7 +305,9 @@ class ContextMenusControllerTest < Redmine::ControllerTest Role.find_by_name('Manager').add_permission! :edit_own_time_entries ids = (0..1).map {TimeEntry.generate!(:user => User.find(2)).id} - get :time_entries, :ids => ids + get :time_entries, :params => { + :ids => ids + } assert_response :success assert_select 'a:not(.disabled)', :text => 'Edit' @@ -281,7 +317,9 @@ class ContextMenusControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 Role.find_by_name('Manager').remove_permission! :edit_time_entries - get :time_entries, :ids => [1, 2] + get :time_entries, :params => { + :ids => [1, 2] + } assert_response :success assert_select 'a.disabled', :text => 'Edit' diff --git a/test/functional/custom_field_enumerations_controller_test.rb b/test/functional/custom_field_enumerations_controller_test.rb index 539600125..913517ae1 100644 --- a/test/functional/custom_field_enumerations_controller_test.rb +++ b/test/functional/custom_field_enumerations_controller_test.rb @@ -30,7 +30,9 @@ class CustomFieldEnumerationsControllerTest < Redmine::ControllerTest end def test_index - get :index, :custom_field_id => @field.id + get :index, :params => { + :custom_field_id => @field.id + } assert_response :success assert_select 'ul#custom_field_enumerations' do @@ -40,7 +42,12 @@ class CustomFieldEnumerationsControllerTest < Redmine::ControllerTest def test_create assert_difference 'CustomFieldEnumeration.count' do - post :create, :custom_field_id => @field.id, :custom_field_enumeration => { :name => 'Baz' } + post :create, :params => { + :custom_field_id => @field.id, + :custom_field_enumeration => { + :name => 'Baz' + } + } assert_redirected_to "/custom_fields/#{@field.id}/enumerations" end @@ -53,16 +60,34 @@ class CustomFieldEnumerationsControllerTest < Redmine::ControllerTest def test_create_xhr assert_difference 'CustomFieldEnumeration.count' do - xhr :post, :create, :custom_field_id => @field.id, :custom_field_enumeration => { :name => 'Baz' } + post :create, :params => { + :custom_field_id => @field.id, + :custom_field_enumeration => { + :name => 'Baz' + } + }, + :xhr => true assert_response :success end end def test_update_each - put :update_each, :custom_field_id => @field.id, :custom_field_enumerations => { - @bar.id => {:position => "1", :name => "Baz", :active => "1"}, - @foo.id => {:position => "2", :name => "Foo", :active => "0"} - } + put :update_each, :params => { + :custom_field_id => @field.id, + :custom_field_enumerations => { + @bar.id => { + :position => "1", + :name => "Baz", + :active => "1" + }, + @foo.id => { + :position => "2", + :name => "Foo", + :active => "0" + } + + } + } assert_response 302 @bar.reload @@ -78,7 +103,10 @@ class CustomFieldEnumerationsControllerTest < Redmine::ControllerTest def test_destroy assert_difference 'CustomFieldEnumeration.count', -1 do - delete :destroy, :custom_field_id => @field.id, :id => @foo.id + delete :destroy, :params => { + :custom_field_id => @field.id, + :id => @foo.id + } assert_redirected_to "/custom_fields/#{@field.id}/enumerations" end @@ -93,7 +121,10 @@ class CustomFieldEnumerationsControllerTest < Redmine::ControllerTest group.save! assert_no_difference 'CustomFieldEnumeration.count' do - delete :destroy, :custom_field_id => @field.id, :id => @foo.id + delete :destroy, :params => { + :custom_field_id => @field.id, + :id => @foo.id + } assert_response :success assert_select 'select[name=?]', 'reassign_to_id' @@ -106,7 +137,11 @@ class CustomFieldEnumerationsControllerTest < Redmine::ControllerTest group.save! assert_difference 'CustomFieldEnumeration.count', -1 do - delete :destroy, :custom_field_id => @field.id, :id => @foo.id, :reassign_to_id => @bar.id + delete :destroy, :params => { + :custom_field_id => @field.id, + :id => @foo.id, + :reassign_to_id => @bar.id + } assert_response 302 end diff --git a/test/functional/custom_fields_controller_test.rb b/test/functional/custom_fields_controller_test.rb index 70fbb837e..f0227b12a 100644 --- a/test/functional/custom_fields_controller_test.rb +++ b/test/functional/custom_fields_controller_test.rb @@ -53,7 +53,12 @@ class CustomFieldsControllerTest < Redmine::ControllerTest def test_new_should_work_for_each_customized_class_and_format custom_field_classes.each do |klass| Redmine::FieldFormat.formats_for_custom_field_class(klass).each do |format| - get :new, :type => klass.name, :custom_field => {:field_format => format.name} + get :new, :params => { + :type => klass.name, + :custom_field => { + :field_format => format.name + } + } assert_response :success assert_select 'form#custom_field_form' do @@ -67,7 +72,9 @@ class CustomFieldsControllerTest < Redmine::ControllerTest end def test_new_should_have_string_default_format - get :new, :type => 'IssueCustomField' + get :new, :params => { + :type => 'IssueCustomField' + } assert_response :success assert_select 'select[name=?]', 'custom_field[field_format]' do @@ -76,7 +83,9 @@ class CustomFieldsControllerTest < Redmine::ControllerTest end def test_new_issue_custom_field - get :new, :type => 'IssueCustomField' + get :new, :params => { + :type => 'IssueCustomField' + } assert_response :success assert_select 'form#custom_field_form' do @@ -91,7 +100,9 @@ class CustomFieldsControllerTest < Redmine::ControllerTest end def test_new_time_entry_custom_field_should_not_show_trackers_and_projects - get :new, :type => 'TimeEntryCustomField' + get :new, :params => { + :type => 'TimeEntryCustomField' + } assert_response :success assert_select 'form#custom_field_form' do @@ -101,19 +112,34 @@ class CustomFieldsControllerTest < Redmine::ControllerTest end def test_default_value_should_be_an_input_for_string_custom_field - get :new, :type => 'IssueCustomField', :custom_field => {:field_format => 'string'} + get :new, :params => { + :type => 'IssueCustomField', + :custom_field => { + :field_format => 'string' + } + } assert_response :success assert_select 'input[name=?]', 'custom_field[default_value]' end def test_default_value_should_be_a_textarea_for_text_custom_field - get :new, :type => 'IssueCustomField', :custom_field => {:field_format => 'text'} + get :new, :params => { + :type => 'IssueCustomField', + :custom_field => { + :field_format => 'text' + } + } assert_response :success assert_select 'textarea[name=?]', 'custom_field[default_value]' end def test_default_value_should_be_a_checkbox_for_bool_custom_field - get :new, :type => 'IssueCustomField', :custom_field => {:field_format => 'bool'} + get :new, :params => { + :type => 'IssueCustomField', + :custom_field => { + :field_format => 'bool' + } + } assert_response :success assert_select 'select[name=?]', 'custom_field[default_value]' do assert_select 'option', 3 @@ -121,27 +147,54 @@ class CustomFieldsControllerTest < Redmine::ControllerTest end def test_default_value_should_not_be_present_for_user_custom_field - get :new, :type => 'IssueCustomField', :custom_field => {:field_format => 'user'} + get :new, :params => { + :type => 'IssueCustomField', + :custom_field => { + :field_format => 'user' + } + } assert_response :success assert_select '[name=?]', 'custom_field[default_value]', 0 end def test_setting_full_width_layout_shoul_be_present_only_for_long_text_issue_custom_field - get :new, :type => 'IssueCustomField', :custom_field => {:field_format => 'text'} + get :new, :params => { + :type => 'IssueCustomField', + :custom_field => { + :field_format => 'text' + } + } assert_response :success assert_select '[name=?]', 'custom_field[full_width_layout]' - get :new, :type => 'IssueCustomField', :custom_field => {:field_format => 'list'} + get :new, :params => { + :type => 'IssueCustomField', + :custom_field => { + :field_format => 'list' + } + } assert_response :success assert_select '[name=?]', 'custom_field[full_width_layout]', 0 - get :new, :type => 'TimeEntryCustomField', :custom_field => {:field_format => 'text'} + get :new, :params => { + :type => 'TimeEntryCustomField', + :custom_field => { + :field_format => 'text' + } + } assert_response :success assert_select '[name=?]', 'custom_field[full_width_layout]', 0 end def test_new_js - xhr :get, :new, :type => 'IssueCustomField', :custom_field => {:field_format => 'list'}, :format => 'js' + get :new, :params => { + :type => 'IssueCustomField', + :custom_field => { + :field_format => 'list' + }, + :format => 'js' + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type @@ -149,7 +202,9 @@ class CustomFieldsControllerTest < Redmine::ControllerTest end def test_new_with_invalid_custom_field_class_should_render_select_type - get :new, :type => 'UnknownCustomField' + get :new, :params => { + :type => 'UnknownCustomField' + } assert_response :success assert_select 'input[type=radio][name=type]' @@ -157,19 +212,23 @@ class CustomFieldsControllerTest < Redmine::ControllerTest def test_create_list_custom_field field = new_record(IssueCustomField) do - post :create, :type => "IssueCustomField", - :custom_field => {:name => "test_post_new_list", - :default_value => "", - :min_length => "0", - :searchable => "0", - :regexp => "", - :is_for_all => "1", - :possible_values => "0.1\n0.2\n", - :max_length => "0", - :is_filter => "0", - :is_required =>"0", - :field_format => "list", - :tracker_ids => ["1", ""]} + post :create, :params => { + :type => "IssueCustomField", + :custom_field => { + :name => "test_post_new_list", + :default_value => "", + :min_length => "0", + :searchable => "0", + :regexp => "", + :is_for_all => "1", + :possible_values => "0.1\n0.2\n", + :max_length => "0", + :is_filter => "0", + :is_required =>"0", + :field_format => "list", + :tracker_ids => ["1", ""] + } + } end assert_redirected_to "/custom_fields/#{field.id}/edit" assert_equal "test_post_new_list", field.name @@ -179,9 +238,16 @@ class CustomFieldsControllerTest < Redmine::ControllerTest def test_create_with_project_ids assert_difference 'CustomField.count' do - post :create, :type => "IssueCustomField", :custom_field => { - :name => "foo", :field_format => "string", :is_for_all => "0", :project_ids => ["1", "3", ""] - } + post :create, :params => { + :type => "IssueCustomField", + :custom_field => { + :name => "foo", + :field_format => "string", + :is_for_all => "0", + :project_ids => ["1", "3", ""] + + } + } assert_response 302 end field = IssueCustomField.order("id desc").first @@ -190,7 +256,12 @@ class CustomFieldsControllerTest < Redmine::ControllerTest def test_create_with_failure assert_no_difference 'CustomField.count' do - post :create, :type => "IssueCustomField", :custom_field => {:name => ''} + post :create, :params => { + :type => "IssueCustomField", + :custom_field => { + :name => '' + } + } end assert_response :success assert_select_error /name cannot be blank/i @@ -198,25 +269,38 @@ class CustomFieldsControllerTest < Redmine::ControllerTest def test_create_without_type_should_render_select_type assert_no_difference 'CustomField.count' do - post :create, :custom_field => {:name => ''} + post :create, :params => { + :custom_field => { + :name => '' + } + } end assert_response :success assert_select 'input[type=radio][name=type]' end def test_edit - get :edit, :id => 1 + get :edit, :params => { + :id => 1 + } assert_response :success assert_select 'input[name=?][value=?]', 'custom_field[name]', 'Database' end def test_edit_invalid_custom_field_should_render_404 - get :edit, :id => 99 + get :edit, :params => { + :id => 99 + } assert_response 404 end def test_update - put :update, :id => 1, :custom_field => {:name => 'New name'} + put :update, :params => { + :id => 1, + :custom_field => { + :name => 'New name' + } + } assert_redirected_to '/custom_fields/1/edit' field = CustomField.find(1) @@ -224,7 +308,12 @@ class CustomFieldsControllerTest < Redmine::ControllerTest end def test_update_with_failure - put :update, :id => 1, :custom_field => {:name => ''} + put :update, :params => { + :id => 1, + :custom_field => { + :name => '' + } + } assert_response :success assert_select_error /name cannot be blank/i end @@ -235,7 +324,9 @@ class CustomFieldsControllerTest < Redmine::ControllerTest assert_difference 'CustomField.count', -1 do assert_difference 'CustomValue.count', - custom_values_count do - delete :destroy, :id => 1 + delete :destroy, :params => { + :id => 1 + } end end diff --git a/test/functional/documents_controller_test.rb b/test/functional/documents_controller_test.rb index ad1e6b567..21c7c4f72 100644 --- a/test/functional/documents_controller_test.rb +++ b/test/functional/documents_controller_test.rb @@ -31,7 +31,9 @@ class DocumentsControllerTest < Redmine::ControllerTest e = Enumeration.find_by_name('Technical documentation') e.update_attributes(:is_default => true) - get :index, :project_id => 'ecookbook' + get :index, :params => { + :project_id => 'ecookbook' + } assert_response :success # Default category selected in the new document form @@ -44,19 +46,28 @@ class DocumentsControllerTest < Redmine::ControllerTest end def test_index_grouped_by_date - get :index, :project_id => 'ecookbook', :sort_by => 'date' + get :index, :params => { + :project_id => 'ecookbook', + :sort_by => 'date' + } assert_response :success assert_select 'h3', :text => '2007-02-12' end def test_index_grouped_by_title - get :index, :project_id => 'ecookbook', :sort_by => 'title' + get :index, :params => { + :project_id => 'ecookbook', + :sort_by => 'title' + } assert_response :success assert_select 'h3', :text => 'T' end def test_index_grouped_by_author - get :index, :project_id => 'ecookbook', :sort_by => 'author' + get :index, :params => { + :project_id => 'ecookbook', + :sort_by => 'author' + } assert_response :success assert_select 'h3', :text => 'John Smith' end @@ -70,7 +81,9 @@ Lorem ipsum dolor sit amet, consectetur adipiscing elit. Ut egestas, mi vehicula Vestibulum non velit mi. Aliquam scelerisque libero ut nulla fringilla a sollicitudin magna rhoncus. Praesent a nunc lorem, ac porttitor eros. Sed ac diam nec neque interdum adipiscing quis quis justo. Donec arcu nunc, fringilla eu dictum at, venenatis ac sem. Vestibulum quis elit urna, ac mattis sapien. Lorem ipsum dolor sit amet, consectetur adipiscing elit. LOREM - get :index, :project_id => 'ecookbook' + get :index, :params => { + :project_id => 'ecookbook' + } assert_response :success # should only truncate on new lines to avoid breaking wiki formatting @@ -79,13 +92,17 @@ LOREM end def test_show - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :success end def test_new @request.session[:user_id] = 2 - get :new, :project_id => 1 + get :new, :params => { + :project_id => 1 + } assert_response :success end @@ -95,11 +112,18 @@ LOREM set_tmp_attachments_directory with_settings :notified_events => %w(document_added) do - post :create, :project_id => 'ecookbook', - :document => { :title => 'DocumentsControllerTest#test_post_new', - :description => 'This is a new document', - :category_id => 2}, - :attachments => {'1' => {'file' => uploaded_test_file('testfile.txt', 'text/plain')}} + post :create, :params => { + :project_id => 'ecookbook', + :document => { + :title => 'DocumentsControllerTest#test_post_new', + :description => 'This is a new document', + :category_id => 2 + }, + :attachments => { + '1' => { + 'file' => uploaded_test_file('testfile.txt', 'text/plain')} + } + } end assert_redirected_to '/projects/ecookbook/documents' @@ -114,7 +138,12 @@ LOREM def test_create_with_failure @request.session[:user_id] = 2 assert_no_difference 'Document.count' do - post :create, :project_id => 'ecookbook', :document => { :title => ''} + post :create, :params => { + :project_id => 'ecookbook', + :document => { + :title => '' + } + } end assert_response :success assert_select_error /title cannot be blank/i @@ -125,11 +154,14 @@ LOREM category2 = Enumeration.find_by_name('User documentation') category2.update_attributes(:is_default => true) category1 = Enumeration.find_by_name('Uncategorized') - post :create, - :project_id => 'ecookbook', - :document => { :title => 'no default', - :description => 'This is a new document', - :category_id => category1.id } + post :create, :params => { + :project_id => 'ecookbook', + :document => { + :title => 'no default', + :description => 'This is a new document', + :category_id => category1.id + } + } assert_redirected_to '/projects/ecookbook/documents' doc = Document.find_by_title('no default') assert_not_nil doc @@ -139,13 +171,20 @@ LOREM def test_edit @request.session[:user_id] = 2 - get :edit, :id => 1 + get :edit, :params => { + :id => 1 + } assert_response :success end def test_update @request.session[:user_id] = 2 - put :update, :id => 1, :document => {:title => 'test_update'} + put :update, :params => { + :id => 1, + :document => { + :title => 'test_update' + } + } assert_redirected_to '/documents/1' document = Document.find(1) assert_equal 'test_update', document.title @@ -153,7 +192,12 @@ LOREM def test_update_with_failure @request.session[:user_id] = 2 - put :update, :id => 1, :document => {:title => ''} + put :update, :params => { + :id => 1, + :document => { + :title => '' + } + } assert_response :success assert_select_error /title cannot be blank/i end @@ -161,7 +205,9 @@ LOREM def test_destroy @request.session[:user_id] = 2 assert_difference 'Document.count', -1 do - delete :destroy, :id => 1 + delete :destroy, :params => { + :id => 1 + } end assert_redirected_to '/projects/ecookbook/documents' assert_nil Document.find_by_id(1) @@ -170,8 +216,13 @@ LOREM def test_add_attachment @request.session[:user_id] = 2 assert_difference 'Attachment.count' do - post :add_attachment, :id => 1, - :attachments => {'1' => {'file' => uploaded_test_file('testfile.txt', 'text/plain')}} + post :add_attachment, :params => { + :id => 1, + :attachments => { + '1' => { + 'file' => uploaded_test_file('testfile.txt', 'text/plain')} + } + } end attachment = Attachment.order('id DESC').first assert_equal Document.find(1), attachment.container diff --git a/test/functional/email_addresses_controller_test.rb b/test/functional/email_addresses_controller_test.rb index b6dda82da..300edcb04 100644 --- a/test/functional/email_addresses_controller_test.rb +++ b/test/functional/email_addresses_controller_test.rb @@ -26,7 +26,9 @@ class EmailAddressesControllerTest < Redmine::ControllerTest def test_index_with_no_additional_emails @request.session[:user_id] = 2 - get :index, :user_id => 2 + get :index, :params => { + :user_id => 2 + } assert_response :success end @@ -34,7 +36,9 @@ class EmailAddressesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 EmailAddress.create!(:user_id => 2, :address => 'another@somenet.foo') - get :index, :user_id => 2 + get :index, :params => { + :user_id => 2 + } assert_response :success assert_select '.email', :text => 'another@somenet.foo' end @@ -43,27 +47,39 @@ class EmailAddressesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 EmailAddress.create!(:user_id => 2, :address => 'another@somenet.foo') - xhr :get, :index, :user_id => 2 + get :index, :params => { + :user_id => 2 + }, + :xhr => true assert_response :success assert_include 'another@somenet.foo', response.body end def test_index_by_admin_should_be_allowed @request.session[:user_id] = 1 - get :index, :user_id => 2 + get :index, :params => { + :user_id => 2 + } assert_response :success end def test_index_by_another_user_should_be_denied @request.session[:user_id] = 3 - get :index, :user_id => 2 + get :index, :params => { + :user_id => 2 + } assert_response 403 end def test_create @request.session[:user_id] = 2 assert_difference 'EmailAddress.count' do - post :create, :user_id => 2, :email_address => {:address => 'another@somenet.foo'} + post :create, :params => { + :user_id => 2, + :email_address => { + :address => 'another@somenet.foo' + } + } assert_response 302 assert_redirected_to '/users/2/email_addresses' end @@ -75,7 +91,13 @@ class EmailAddressesControllerTest < Redmine::ControllerTest def test_create_as_js @request.session[:user_id] = 2 assert_difference 'EmailAddress.count' do - xhr :post, :create, :user_id => 2, :email_address => {:address => 'another@somenet.foo'} + post :create, :params => { + :user_id => 2, + :email_address => { + :address => 'another@somenet.foo' + } + }, + :xhr => true assert_response 200 end end @@ -83,7 +105,12 @@ class EmailAddressesControllerTest < Redmine::ControllerTest def test_create_with_failure @request.session[:user_id] = 2 assert_no_difference 'EmailAddress.count' do - post :create, :user_id => 2, :email_address => {:address => 'invalid'} + post :create, :params => { + :user_id => 2, + :email_address => { + :address => 'invalid' + } + } assert_response :success assert_select_error /email is invalid/i end @@ -92,7 +119,12 @@ class EmailAddressesControllerTest < Redmine::ControllerTest def test_create_should_send_security_notification @request.session[:user_id] = 2 ActionMailer::Base.deliveries.clear - post :create, :user_id => 2, :email_address => {:address => 'something@example.fr'} + post :create, :params => { + :user_id => 2, + :email_address => { + :address => 'something@example.fr' + } + } assert_not_nil (mail = ActionMailer::Base.deliveries.last) assert_mail_body_match '0.0.0.0', mail @@ -109,7 +141,11 @@ class EmailAddressesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 email = EmailAddress.create!(:user_id => 2, :address => 'another@somenet.foo') - put :update, :user_id => 2, :id => email.id, :notify => '0' + put :update, :params => { + :user_id => 2, + :id => email.id, + :notify => '0' + } assert_response 302 assert_equal false, email.reload.notify @@ -119,7 +155,12 @@ class EmailAddressesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 email = EmailAddress.create!(:user_id => 2, :address => 'another@somenet.foo') - xhr :put, :update, :user_id => 2, :id => email.id, :notify => '0' + put :update, :params => { + :user_id => 2, + :id => email.id, + :notify => '0' + }, + :xhr => true assert_response 200 assert_equal false, email.reload.notify @@ -130,7 +171,12 @@ class EmailAddressesControllerTest < Redmine::ControllerTest email = EmailAddress.create!(:user_id => 2, :address => 'another@somenet.foo') ActionMailer::Base.deliveries.clear - xhr :put, :update, :user_id => 2, :id => email.id, :notify => '0' + put :update, :params => { + :user_id => 2, + :id => email.id, + :notify => '0' + }, + :xhr => true assert_not_nil (mail = ActionMailer::Base.deliveries.last) assert_mail_body_match I18n.t(:mail_body_security_notification_notify_disabled, value: 'another@somenet.foo'), mail @@ -145,7 +191,10 @@ class EmailAddressesControllerTest < Redmine::ControllerTest email = EmailAddress.create!(:user_id => 2, :address => 'another@somenet.foo') assert_difference 'EmailAddress.count', -1 do - delete :destroy, :user_id => 2, :id => email.id + delete :destroy, :params => { + :user_id => 2, + :id => email.id + } assert_response 302 assert_redirected_to '/users/2/email_addresses' end @@ -156,7 +205,11 @@ class EmailAddressesControllerTest < Redmine::ControllerTest email = EmailAddress.create!(:user_id => 2, :address => 'another@somenet.foo') assert_difference 'EmailAddress.count', -1 do - xhr :delete, :destroy, :user_id => 2, :id => email.id + delete :destroy, :params => { + :user_id => 2, + :id => email.id + }, + :xhr => true assert_response 200 end end @@ -165,7 +218,10 @@ class EmailAddressesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_no_difference 'EmailAddress.count' do - delete :destroy, :user_id => 2, :id => User.find(2).email_address.id + delete :destroy, :params => { + :user_id => 2, + :id => User.find(2).email_address.id + } assert_response 404 end end @@ -175,7 +231,11 @@ class EmailAddressesControllerTest < Redmine::ControllerTest email = EmailAddress.create!(:user_id => 2, :address => 'another@somenet.foo') ActionMailer::Base.deliveries.clear - xhr :delete, :destroy, :user_id => 2, :id => email.id + delete :destroy, :params => { + :user_id => 2, + :id => email.id + }, + :xhr => true assert_not_nil (mail = ActionMailer::Base.deliveries.last) assert_mail_body_match I18n.t(:mail_body_security_notification_remove, field: I18n.t(:field_mail), value: 'another@somenet.foo'), mail diff --git a/test/functional/enumerations_controller_test.rb b/test/functional/enumerations_controller_test.rb index b44f3f4d1..1e4dca2f8 100644 --- a/test/functional/enumerations_controller_test.rb +++ b/test/functional/enumerations_controller_test.rb @@ -37,7 +37,9 @@ class EnumerationsControllerTest < Redmine::ControllerTest end def test_new - get :new, :type => 'IssuePriority' + get :new, :params => { + :type => 'IssuePriority' + } assert_response :success assert_select 'input[name=?][value=?]', 'enumeration[type]', 'IssuePriority' @@ -45,13 +47,20 @@ class EnumerationsControllerTest < Redmine::ControllerTest end def test_new_with_invalid_type_should_respond_with_404 - get :new, :type => 'UnknownType' + get :new, :params => { + :type => 'UnknownType' + } assert_response 404 end def test_create assert_difference 'IssuePriority.count' do - post :create, :enumeration => {:type => 'IssuePriority', :name => 'Lowest'} + post :create, :params => { + :enumeration => { + :type => 'IssuePriority', + :name => 'Lowest' + } + } end assert_redirected_to '/enumerations' e = IssuePriority.find_by_name('Lowest') @@ -60,26 +69,41 @@ class EnumerationsControllerTest < Redmine::ControllerTest def test_create_with_failure assert_no_difference 'IssuePriority.count' do - post :create, :enumeration => {:type => 'IssuePriority', :name => ''} + post :create, :params => { + :enumeration => { + :type => 'IssuePriority', + :name => '' + } + } end assert_response :success assert_select_error /name cannot be blank/i end def test_edit - get :edit, :id => 6 + get :edit, :params => { + :id => 6 + } assert_response :success assert_select 'input[name=?][value=?]', 'enumeration[name]', 'High' end def test_edit_invalid_should_respond_with_404 - get :edit, :id => 999 + get :edit, :params => { + :id => 999 + } assert_response 404 end def test_update assert_no_difference 'IssuePriority.count' do - put :update, :id => 6, :enumeration => {:type => 'IssuePriority', :name => 'New name'} + put :update, :params => { + :id => 6, + :enumeration => { + :type => 'IssuePriority', + :name => 'New name' + } + } end assert_redirected_to '/enumerations' e = IssuePriority.find(6) @@ -88,7 +112,13 @@ class EnumerationsControllerTest < Redmine::ControllerTest def test_update_with_failure assert_no_difference 'IssuePriority.count' do - put :update, :id => 6, :enumeration => {:type => 'IssuePriority', :name => ''} + put :update, :params => { + :id => 6, + :enumeration => { + :type => 'IssuePriority', + :name => '' + } + } end assert_response :success assert_select_error /name cannot be blank/i @@ -96,7 +126,9 @@ class EnumerationsControllerTest < Redmine::ControllerTest def test_destroy_enumeration_not_in_use assert_difference 'IssuePriority.count', -1 do - delete :destroy, :id => 7 + delete :destroy, :params => { + :id => 7 + } end assert_redirected_to :controller => 'enumerations', :action => 'index' assert_nil Enumeration.find_by_id(7) @@ -104,7 +136,9 @@ class EnumerationsControllerTest < Redmine::ControllerTest def test_destroy_enumeration_in_use assert_no_difference 'IssuePriority.count' do - delete :destroy, :id => 4 + delete :destroy, :params => { + :id => 4 + } end assert_response :success @@ -117,7 +151,10 @@ class EnumerationsControllerTest < Redmine::ControllerTest def test_destroy_enumeration_in_use_with_reassignment issue = Issue.where(:priority_id => 4).first assert_difference 'IssuePriority.count', -1 do - delete :destroy, :id => 4, :reassign_to_id => 6 + delete :destroy, :params => { + :id => 4, + :reassign_to_id => 6 + } end assert_redirected_to :controller => 'enumerations', :action => 'index' assert_nil Enumeration.find_by_id(4) @@ -127,7 +164,10 @@ class EnumerationsControllerTest < Redmine::ControllerTest def test_destroy_enumeration_in_use_with_blank_reassignment assert_no_difference 'IssuePriority.count' do - delete :destroy, :id => 4, :reassign_to_id => '' + delete :destroy, :params => { + :id => 4, + :reassign_to_id => '' + } end assert_response :success end diff --git a/test/functional/files_controller_test.rb b/test/functional/files_controller_test.rb index a24187db5..85cd61941 100644 --- a/test/functional/files_controller_test.rb +++ b/test/functional/files_controller_test.rb @@ -37,7 +37,9 @@ class FilesControllerTest < Redmine::ControllerTest end def test_index - get :index, :project_id => 1 + get :index, :params => { + :project_id => 1 + } assert_response :success # file attached to the project @@ -49,7 +51,9 @@ class FilesControllerTest < Redmine::ControllerTest def test_new @request.session[:user_id] = 2 - get :new, :project_id => 1 + get :new, :params => { + :project_id => 1 + } assert_response :success assert_select 'select[name=?]', 'version_id' @@ -58,7 +62,9 @@ class FilesControllerTest < Redmine::ControllerTest def test_new_without_versions Version.delete_all @request.session[:user_id] = 2 - get :new, :project_id => 1 + get :new, :params => { + :project_id => 1 + } assert_response :success assert_select 'select[name=?]', 'version_id', 0 @@ -71,8 +77,14 @@ class FilesControllerTest < Redmine::ControllerTest with_settings :notified_events => %w(file_added) do assert_difference 'Attachment.count' do - post :create, :project_id => 1, :version_id => '', - :attachments => {'1' => {'file' => uploaded_test_file('testfile.txt', 'text/plain')}} + post :create, :params => { + :project_id => 1, + :version_id => '', + :attachments => { + '1' => { + 'file' => uploaded_test_file('testfile.txt', 'text/plain')} + } + } assert_response :redirect end end @@ -92,8 +104,14 @@ class FilesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Attachment.count' do - post :create, :project_id => 1, :version_id => '2', - :attachments => {'1' => {'file' => uploaded_test_file('testfile.txt', 'text/plain')}} + post :create, :params => { + :project_id => 1, + :version_id => '2', + :attachments => { + '1' => { + 'file' => uploaded_test_file('testfile.txt', 'text/plain')} + } + } assert_response :redirect end assert_redirected_to '/projects/ecookbook/files' @@ -107,7 +125,10 @@ class FilesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_no_difference 'Attachment.count' do - post :create, :project_id => 1, :version_id => '' + post :create, :params => { + :project_id => 1, + :version_id => '' + } assert_response :success end assert_select 'div.error', 'File is invalid' diff --git a/test/functional/gantts_controller_test.rb b/test/functional/gantts_controller_test.rb index abb9ca10b..bcd31ee22 100644 --- a/test/functional/gantts_controller_test.rb +++ b/test/functional/gantts_controller_test.rb @@ -30,7 +30,9 @@ class GanttsControllerTest < Redmine::ControllerTest def test_gantt_should_work i2 = Issue.find(2) i2.update_attribute(:due_date, 1.month.from_now) - get :show, :project_id => 1 + get :show, :params => { + :project_id => 1 + } assert_response :success # Issue with start and due dates @@ -43,27 +45,37 @@ class GanttsControllerTest < Redmine::ControllerTest end def test_gantt_at_minimal_zoom - get :show, :project_id => 1, :zoom => 1 + get :show, :params => { + :project_id => 1, + :zoom => 1 + } assert_response :success assert_select 'input[type=hidden][name=zoom][value=?]', '1' end def test_gantt_at_maximal_zoom - get :show, :project_id => 1, :zoom => 4 + get :show, :params => { + :project_id => 1, + :zoom => 4 + } assert_response :success assert_select 'input[type=hidden][name=zoom][value=?]', '4' end def test_gantt_should_work_without_issue_due_dates Issue.update_all("due_date = NULL") - get :show, :project_id => 1 + get :show, :params => { + :project_id => 1 + } assert_response :success end def test_gantt_should_work_without_issue_and_version_due_dates Issue.update_all("due_date = NULL") Version.update_all("effective_date = NULL") - get :show, :project_id => 1 + get :show, :params => { + :project_id => 1 + } assert_response :success end @@ -97,14 +109,19 @@ class GanttsControllerTest < Redmine::ControllerTest end def test_gantt_should_export_to_pdf - get :show, :project_id => 1, :format => 'pdf' + get :show, :params => { + :project_id => 1, + :format => 'pdf' + } assert_response :success assert_equal 'application/pdf', @response.content_type assert @response.body.starts_with?('%PDF') end def test_gantt_should_export_to_pdf_cross_project - get :show, :format => 'pdf' + get :show, :params => { + :format => 'pdf' + } assert_response :success assert_equal 'application/pdf', @response.content_type assert @response.body.starts_with?('%PDF') @@ -112,7 +129,10 @@ class GanttsControllerTest < Redmine::ControllerTest if Object.const_defined?(:Magick) def test_gantt_should_export_to_png - get :show, :project_id => 1, :format => 'png' + get :show, :params => { + :project_id => 1, + :format => 'png' + } assert_response :success assert_equal 'image/png', @response.content_type end diff --git a/test/functional/groups_controller_test.rb b/test/functional/groups_controller_test.rb index 19f95d357..68d624331 100644 --- a/test/functional/groups_controller_test.rb +++ b/test/functional/groups_controller_test.rb @@ -39,19 +39,25 @@ class GroupsControllerTest < Redmine::ControllerTest def test_index_with_name_filter Group.generate!(:name => "Clients") - get :index, :name => "cli" + get :index, :params => { + :name => "cli" + } assert_response :success assert_select 'table.groups tbody tr', 1 assert_select 'table.groups tbody td.name', :text => 'Clients' end def test_show - get :show, :id => 10 + get :show, :params => { + :id => 10 + } assert_response :success end def test_show_invalid_should_return_404 - get :show, :id => 99 + get :show, :params => { + :id => 99 + } assert_response 404 end @@ -63,7 +69,11 @@ class GroupsControllerTest < Redmine::ControllerTest def test_create assert_difference 'Group.count' do - post :create, :group => {:name => 'New group'} + post :create, :params => { + :group => { + :name => 'New group' + } + } end assert_redirected_to '/groups' group = Group.order('id DESC').first @@ -73,7 +83,12 @@ class GroupsControllerTest < Redmine::ControllerTest def test_create_and_continue assert_difference 'Group.count' do - post :create, :group => {:name => 'New group'}, :continue => 'Create and continue' + post :create, :params => { + :group => { + :name => 'New group' + }, + :continue => 'Create and continue' + } end assert_redirected_to '/groups/new' group = Group.order('id DESC').first @@ -82,14 +97,20 @@ class GroupsControllerTest < Redmine::ControllerTest def test_create_with_failure assert_no_difference 'Group.count' do - post :create, :group => {:name => ''} + post :create, :params => { + :group => { + :name => '' + } + } end assert_response :success assert_select_error /Name cannot be blank/i end def test_edit - get :edit, :id => 10 + get :edit, :params => { + :id => 10 + } assert_response :success assert_select 'div#tab-content-users' @@ -100,46 +121,70 @@ class GroupsControllerTest < Redmine::ControllerTest def test_update new_name = 'New name' - put :update, :id => 10, :group => {:name => new_name} + put :update, :params => { + :id => 10, + :group => { + :name => new_name + } + } assert_redirected_to '/groups' group = Group.find(10) assert_equal new_name, group.name end def test_update_with_failure - put :update, :id => 10, :group => {:name => ''} + put :update, :params => { + :id => 10, + :group => { + :name => '' + } + } assert_response :success assert_select_error /Name cannot be blank/i end def test_destroy assert_difference 'Group.count', -1 do - post :destroy, :id => 10 + post :destroy, :params => { + :id => 10 + } end assert_redirected_to '/groups' end def test_new_users - get :new_users, :id => 10 + get :new_users, :params => { + :id => 10 + } assert_response :success assert_select 'input[name=?]', 'user_search' end def test_xhr_new_users - xhr :get, :new_users, :id => 10 + get :new_users, :params => { + :id => 10 + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end def test_add_users assert_difference 'Group.find(10).users.count', 2 do - post :add_users, :id => 10, :user_ids => ['2', '3'] + post :add_users, :params => { + :id => 10, + :user_ids => ['2', '3'] + } end end def test_xhr_add_users assert_difference 'Group.find(10).users.count', 2 do - xhr :post, :add_users, :id => 10, :user_ids => ['2', '3'] + post :add_users, :params => { + :id => 10, + :user_ids => ['2', '3'] + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end @@ -148,20 +193,32 @@ class GroupsControllerTest < Redmine::ControllerTest def test_remove_user assert_difference 'Group.find(10).users.count', -1 do - delete :remove_user, :id => 10, :user_id => '8' + delete :remove_user, :params => { + :id => 10, + :user_id => '8' + } end end def test_xhr_remove_user assert_difference 'Group.find(10).users.count', -1 do - xhr :delete, :remove_user, :id => 10, :user_id => '8' + delete :remove_user, :params => { + :id => 10, + :user_id => '8' + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end end def test_autocomplete_for_user - xhr :get, :autocomplete_for_user, :id => 10, :q => 'smi', :format => 'js' + get :autocomplete_for_user, :params => { + :id => 10, + :q => 'smi', + :format => 'js' + }, + :xhr => true assert_response :success assert_include 'John Smith', response.body end diff --git a/test/functional/imports_controller_test.rb b/test/functional/imports_controller_test.rb index 28ce703f5..ef9ab0c89 100644 --- a/test/functional/imports_controller_test.rb +++ b/test/functional/imports_controller_test.rb @@ -49,7 +49,9 @@ class ImportsControllerTest < Redmine::ControllerTest def test_create_should_save_the_file import = new_record(Import) do - post :create, :file => uploaded_test_file('import_issues.csv', 'text/csv') + post :create, :params => { + :file => uploaded_test_file('import_issues.csv', 'text/csv') + } assert_response 302 end assert_equal 2, import.user_id @@ -59,7 +61,9 @@ class ImportsControllerTest < Redmine::ControllerTest def test_get_settings_should_display_settings_form import = generate_import - get :settings, :id => import.to_param + get :settings, :params => { + :id => import.to_param + } assert_response :success assert_select 'select[name=?]', 'import_settings[separator]' assert_select 'select[name=?]', 'import_settings[wrapper]' @@ -70,8 +74,15 @@ class ImportsControllerTest < Redmine::ControllerTest def test_post_settings_should_update_settings import = generate_import - post :settings, :id => import.to_param, - :import_settings => {:separator => ":", :wrapper => "|", :encoding => "UTF-8", :date_format => '%m/%d/%Y'} + post :settings, :params => { + :id => import.to_param, + :import_settings => { + :separator => ":", + :wrapper => "|", + :encoding => "UTF-8", + :date_format => '%m/%d/%Y' + } + } assert_redirected_to "/imports/#{import.to_param}/mapping" import.reload @@ -84,8 +95,14 @@ class ImportsControllerTest < Redmine::ControllerTest def test_post_settings_should_update_total_items_count import = generate_import('import_iso8859-1.csv') - post :settings, :id => import.to_param, - :import_settings => {:separator => ";", :wrapper => '"', :encoding => "ISO-8859-1"} + post :settings, :params => { + :id => import.to_param, + :import_settings => { + :separator => ";", + :wrapper => '"', + :encoding => "ISO-8859-1" + } + } assert_response 302 import.reload assert_equal 2, import.total_items @@ -94,8 +111,14 @@ class ImportsControllerTest < Redmine::ControllerTest def test_post_settings_with_wrong_encoding_should_display_error import = generate_import('import_iso8859-1.csv') - post :settings, :id => import.to_param, - :import_settings => {:separator => ";", :wrapper => '"', :encoding => "UTF-8"} + post :settings, :params => { + :id => import.to_param, + :import_settings => { + :separator => ";", + :wrapper => '"', + :encoding => "UTF-8" + } + } assert_response 200 import.reload assert_nil import.total_items @@ -105,8 +128,14 @@ class ImportsControllerTest < Redmine::ControllerTest def test_post_settings_with_invalid_encoding_should_display_error import = generate_import('invalid-Shift_JIS.csv') - post :settings, :id => import.to_param, - :import_settings => {:separator => ";", :wrapper => '"', :encoding => "Shift_JIS"} + post :settings, :params => { + :id => import.to_param, + :import_settings => { + :separator => ";", + :wrapper => '"', + :encoding => "Shift_JIS" + } + } assert_response 200 import.reload assert_nil import.total_items @@ -118,7 +147,9 @@ class ImportsControllerTest < Redmine::ControllerTest import.settings = {'separator' => ";", 'wrapper' => '"', 'encoding' => "ISO-8859-1"} import.save! - get :mapping, :id => import.to_param + get :mapping, :params => { + :id => import.to_param + } assert_response :success assert_select 'select[name=?]', 'import_settings[mapping][subject]' do @@ -135,8 +166,15 @@ class ImportsControllerTest < Redmine::ControllerTest def test_post_mapping_should_update_mapping import = generate_import('import_iso8859-1.csv') - post :mapping, :id => import.to_param, - :import_settings => {:mapping => {:project_id => '1', :tracker_id => '2', :subject => '0'}} + post :mapping, :params => { + :id => import.to_param, + :import_settings => { + :mapping => { + :project_id => '1', + :tracker_id => '2', + :subject => '0'} + } + } assert_redirected_to "/imports/#{import.to_param}/run" import.reload mapping = import.settings['mapping'] @@ -149,7 +187,9 @@ class ImportsControllerTest < Redmine::ControllerTest def test_get_run import = generate_import_with_mapping - get :run, :id => import + get :run, :params => { + :id => import + } assert_response :success assert_select '#import-progress' end @@ -158,7 +198,9 @@ class ImportsControllerTest < Redmine::ControllerTest import = generate_import_with_mapping assert_difference 'Issue.count', 3 do - post :run, :id => import + post :run, :params => { + :id => import + } assert_redirected_to "/imports/#{import.to_param}" end @@ -175,12 +217,16 @@ class ImportsControllerTest < Redmine::ControllerTest import = generate_import_with_mapping assert_difference 'Issue.count', 2 do - post :run, :id => import + post :run, :params => { + :id => import + } assert_redirected_to "/imports/#{import.to_param}/run" end assert_difference 'Issue.count', 1 do - post :run, :id => import + post :run, :params => { + :id => import + } assert_redirected_to "/imports/#{import.to_param}" end @@ -193,7 +239,9 @@ class ImportsControllerTest < Redmine::ControllerTest import.run assert_equal 0, import.unsaved_items.count - get :show, :id => import.to_param + get :show, :params => { + :id => import.to_param + } assert_response :success assert_select 'ul#saved-items' @@ -207,7 +255,9 @@ class ImportsControllerTest < Redmine::ControllerTest import.run assert_not_equal 0, import.unsaved_items.count - get :show, :id => import.to_param + get :show, :params => { + :id => import.to_param + } assert_response :success assert_select 'table#unsaved-items' diff --git a/test/functional/issue_categories_controller_test.rb b/test/functional/issue_categories_controller_test.rb index 908d4d1c5..c18fd9cce 100644 --- a/test/functional/issue_categories_controller_test.rb +++ b/test/functional/issue_categories_controller_test.rb @@ -28,14 +28,19 @@ class IssueCategoriesControllerTest < Redmine::ControllerTest def test_new @request.session[:user_id] = 2 # manager - get :new, :project_id => '1' + get :new, :params => { + :project_id => '1' + } assert_response :success assert_select 'input[name=?]', 'issue_category[name]' end def test_new_from_issue_form @request.session[:user_id] = 2 # manager - xhr :get, :new, :project_id => '1' + get :new, :params => { + :project_id => '1' + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type @@ -44,7 +49,12 @@ class IssueCategoriesControllerTest < Redmine::ControllerTest def test_create @request.session[:user_id] = 2 # manager assert_difference 'IssueCategory.count' do - post :create, :project_id => '1', :issue_category => {:name => 'New category'} + post :create, :params => { + :project_id => '1', + :issue_category => { + :name => 'New category' + } + } end assert_redirected_to '/projects/ecookbook/settings/categories' category = IssueCategory.find_by_name('New category') @@ -54,7 +64,12 @@ class IssueCategoriesControllerTest < Redmine::ControllerTest def test_create_failure @request.session[:user_id] = 2 - post :create, :project_id => '1', :issue_category => {:name => ''} + post :create, :params => { + :project_id => '1', + :issue_category => { + :name => '' + } + } assert_response :success assert_select_error /Name cannot be blank/i end @@ -62,7 +77,13 @@ class IssueCategoriesControllerTest < Redmine::ControllerTest def test_create_from_issue_form @request.session[:user_id] = 2 # manager assert_difference 'IssueCategory.count' do - xhr :post, :create, :project_id => '1', :issue_category => {:name => 'New category'} + post :create, :params => { + :project_id => '1', + :issue_category => { + :name => 'New category' + } + }, + :xhr => true end category = IssueCategory.order('id DESC').first assert_equal 'New category', category.name @@ -74,7 +95,13 @@ class IssueCategoriesControllerTest < Redmine::ControllerTest def test_create_from_issue_form_with_failure @request.session[:user_id] = 2 # manager assert_no_difference 'IssueCategory.count' do - xhr :post, :create, :project_id => '1', :issue_category => {:name => ''} + post :create, :params => { + :project_id => '1', + :issue_category => { + :name => '' + } + }, + :xhr => true end assert_response :success @@ -84,38 +111,59 @@ class IssueCategoriesControllerTest < Redmine::ControllerTest def test_edit @request.session[:user_id] = 2 - get :edit, :id => 2 + get :edit, :params => { + :id => 2 + } assert_response :success assert_select 'input[name=?][value=?]', 'issue_category[name]', 'Recipes' end def test_update assert_no_difference 'IssueCategory.count' do - put :update, :id => 2, :issue_category => { :name => 'Testing' } + put :update, :params => { + :id => 2, + :issue_category => { + :name => 'Testing' + } + } end assert_redirected_to '/projects/ecookbook/settings/categories' assert_equal 'Testing', IssueCategory.find(2).name end def test_update_failure - put :update, :id => 2, :issue_category => { :name => '' } + put :update, :params => { + :id => 2, + :issue_category => { + :name => '' + } + } assert_response :success assert_select_error /Name cannot be blank/i end def test_update_not_found - put :update, :id => 97, :issue_category => { :name => 'Testing' } + put :update, :params => { + :id => 97, + :issue_category => { + :name => 'Testing' + } + } assert_response 404 end def test_destroy_category_not_in_use - delete :destroy, :id => 2 + delete :destroy, :params => { + :id => 2 + } assert_redirected_to '/projects/ecookbook/settings/categories' assert_nil IssueCategory.find_by_id(2) end def test_destroy_category_in_use - delete :destroy, :id => 1 + delete :destroy, :params => { + :id => 1 + } assert_response :success assert_not_nil IssueCategory.find_by_id(1) assert_select 'select[name=?]', 'reassign_to_id' @@ -123,7 +171,11 @@ class IssueCategoriesControllerTest < Redmine::ControllerTest def test_destroy_category_in_use_with_reassignment issue = Issue.where(:category_id => 1).first - delete :destroy, :id => 1, :todo => 'reassign', :reassign_to_id => 2 + delete :destroy, :params => { + :id => 1, + :todo => 'reassign', + :reassign_to_id => 2 + } assert_redirected_to '/projects/ecookbook/settings/categories' assert_nil IssueCategory.find_by_id(1) # check that the issue was reassign @@ -132,7 +184,10 @@ class IssueCategoriesControllerTest < Redmine::ControllerTest def test_destroy_category_in_use_without_reassignment issue = Issue.where(:category_id => 1).first - delete :destroy, :id => 1, :todo => 'nullify' + delete :destroy, :params => { + :id => 1, + :todo => 'nullify' + } assert_redirected_to '/projects/ecookbook/settings/categories' assert_nil IssueCategory.find_by_id(1) # check that the issue category was nullified diff --git a/test/functional/issue_relations_controller_test.rb b/test/functional/issue_relations_controller_test.rb index f740e2234..0bb87a127 100644 --- a/test/functional/issue_relations_controller_test.rb +++ b/test/functional/issue_relations_controller_test.rb @@ -38,8 +38,14 @@ class IssueRelationsControllerTest < Redmine::ControllerTest def test_create assert_difference 'IssueRelation.count' do - post :create, :issue_id => 1, - :relation => {:issue_to_id => '2', :relation_type => 'relates', :delay => ''} + post :create, :params => { + :issue_id => 1, + :relation => { + :issue_to_id => '2', + :relation_type => 'relates', + :delay => '' + } + } end relation = IssueRelation.order('id DESC').first assert_equal 1, relation.issue_from_id @@ -49,15 +55,29 @@ class IssueRelationsControllerTest < Redmine::ControllerTest def test_create_on_invalid_issue assert_no_difference 'IssueRelation.count' do - post :create, :issue_id => 999, - :relation => {:issue_to_id => '2', :relation_type => 'relates', :delay => ''} + post :create, :params => { + :issue_id => 999, + :relation => { + :issue_to_id => '2', + :relation_type => 'relates', + :delay => '' + } + } assert_response 404 end end def test_create_xhr assert_difference 'IssueRelation.count' do - xhr :post, :create, :issue_id => 3, :relation => {:issue_to_id => '1', :relation_type => 'relates', :delay => ''} + post :create, :params => { + :issue_id => 3, + :relation => { + :issue_to_id => '1', + :relation_type => 'relates', + :delay => '' + } + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end @@ -70,8 +90,14 @@ class IssueRelationsControllerTest < Redmine::ControllerTest def test_create_should_accept_id_with_hash assert_difference 'IssueRelation.count' do - post :create, :issue_id => 1, - :relation => {:issue_to_id => '#2', :relation_type => 'relates', :delay => ''} + post :create, :params => { + :issue_id => 1, + :relation => { + :issue_to_id => '#2', + :relation_type => 'relates', + :delay => '' + } + } end relation = IssueRelation.order('id DESC').first assert_equal 2, relation.issue_to_id @@ -79,8 +105,14 @@ class IssueRelationsControllerTest < Redmine::ControllerTest def test_create_should_strip_id assert_difference 'IssueRelation.count' do - post :create, :issue_id => 1, - :relation => {:issue_to_id => ' 2 ', :relation_type => 'relates', :delay => ''} + post :create, :params => { + :issue_id => 1, + :relation => { + :issue_to_id => ' 2 ', + :relation_type => 'relates', + :delay => '' + } + } end relation = IssueRelation.order('id DESC').first assert_equal 2, relation.issue_to_id @@ -89,8 +121,14 @@ class IssueRelationsControllerTest < Redmine::ControllerTest def test_create_should_not_break_with_non_numerical_id assert_no_difference 'IssueRelation.count' do assert_nothing_raised do - post :create, :issue_id => 1, - :relation => {:issue_to_id => 'foo', :relation_type => 'relates', :delay => ''} + post :create, :params => { + :issue_id => 1, + :relation => { + :issue_to_id => 'foo', + :relation_type => 'relates', + :delay => '' + } + } end end end @@ -100,8 +138,15 @@ class IssueRelationsControllerTest < Redmine::ControllerTest issue2 = Issue.generate! assert_difference 'IssueRelation.count' do - xhr :post, :create, :issue_id => issue2.id, - :relation => {:issue_to_id => issue1.id, :relation_type => 'follows', :delay => ''} + post :create, :params => { + :issue_id => issue2.id, + :relation => { + :issue_to_id => issue1.id, + :relation_type => 'follows', + :delay => '' + } + }, + :xhr => true end assert_include 'Followed issue', response.body end @@ -111,14 +156,28 @@ class IssueRelationsControllerTest < Redmine::ControllerTest assert_nil Issue.visible(User.find(3)).find_by_id(4) assert_no_difference 'IssueRelation.count' do - post :create, :issue_id => 1, - :relation => {:issue_to_id => '4', :relation_type => 'relates', :delay => ''} + post :create, :params => { + :issue_id => 1, + :relation => { + :issue_to_id => '4', + :relation_type => 'relates', + :delay => '' + } + } end end def test_create_xhr_with_failure assert_no_difference 'IssueRelation.count' do - xhr :post, :create, :issue_id => 3, :relation => {:issue_to_id => '999', :relation_type => 'relates', :delay => ''} + post :create, :params => { + :issue_id => 3, + :relation => { + :issue_to_id => '999', + :relation_type => 'relates', + :delay => '' + } + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type @@ -128,13 +187,17 @@ class IssueRelationsControllerTest < Redmine::ControllerTest def test_destroy assert_difference 'IssueRelation.count', -1 do - delete :destroy, :id => '2' + delete :destroy, :params => { + :id => '2' + } end end def test_destroy_invalid_relation assert_no_difference 'IssueRelation.count' do - delete :destroy, :id => '999' + delete :destroy, :params => { + :id => '999' + } assert_response 404 end end @@ -146,7 +209,10 @@ class IssueRelationsControllerTest < Redmine::ControllerTest end assert_difference 'IssueRelation.count', -1 do - xhr :delete, :destroy, :id => '2' + delete :destroy, :params => { + :id => '2' + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type diff --git a/test/functional/issue_statuses_controller_test.rb b/test/functional/issue_statuses_controller_test.rb index 047576705..f782f8ecf 100644 --- a/test/functional/issue_statuses_controller_test.rb +++ b/test/functional/issue_statuses_controller_test.rb @@ -51,7 +51,11 @@ class IssueStatusesControllerTest < Redmine::ControllerTest def test_create assert_difference 'IssueStatus.count' do - post :create, :issue_status => {:name => 'New status'} + post :create, :params => { + :issue_status => { + :name => 'New status' + } + } end assert_redirected_to :action => 'index' status = IssueStatus.order('id DESC').first @@ -59,26 +63,42 @@ class IssueStatusesControllerTest < Redmine::ControllerTest end def test_create_with_failure - post :create, :issue_status => {:name => ''} + post :create, :params => { + :issue_status => { + :name => '' + } + } assert_response :success assert_select_error /name cannot be blank/i end def test_edit - get :edit, :id => '3' + get :edit, :params => { + :id => '3' + } assert_response :success assert_select 'input[name=?][value=?]', 'issue_status[name]', 'Resolved' end def test_update - put :update, :id => '3', :issue_status => {:name => 'Renamed status'} + put :update, :params => { + :id => '3', + :issue_status => { + :name => 'Renamed status' + } + } assert_redirected_to :action => 'index' status = IssueStatus.find(3) assert_equal 'Renamed status', status.name end def test_update_with_failure - put :update, :id => '3', :issue_status => {:name => ''} + put :update, :params => { + :id => '3', + :issue_status => { + :name => '' + } + } assert_response :success assert_select_error /name cannot be blank/i end @@ -88,7 +108,9 @@ class IssueStatusesControllerTest < Redmine::ControllerTest Tracker.where(:default_status_id => 1).delete_all assert_difference 'IssueStatus.count', -1 do - delete :destroy, :id => '1' + delete :destroy, :params => { + :id => '1' + } end assert_redirected_to :action => 'index' assert_nil IssueStatus.find_by_id(1) @@ -99,7 +121,9 @@ class IssueStatusesControllerTest < Redmine::ControllerTest Tracker.where(:default_status_id => 1).delete_all assert_no_difference 'IssueStatus.count' do - delete :destroy, :id => '1' + delete :destroy, :params => { + :id => '1' + } end assert_redirected_to :action => 'index' assert_not_nil IssueStatus.find_by_id(1) @@ -110,7 +134,9 @@ class IssueStatusesControllerTest < Redmine::ControllerTest assert Tracker.where(:default_status_id => 1).any? assert_no_difference 'IssueStatus.count' do - delete :destroy, :id => '1' + delete :destroy, :params => { + :id => '1' + } end assert_redirected_to :action => 'index' assert_not_nil IssueStatus.find_by_id(1) diff --git a/test/functional/issues_controller_test.rb b/test/functional/issues_controller_test.rb index fef87a2c3..c6c58b684 100644 --- a/test/functional/issues_controller_test.rb +++ b/test/functional/issues_controller_test.rb @@ -77,7 +77,9 @@ class IssuesControllerTest < Redmine::ControllerTest end def test_index_should_list_visible_issues_only - get :index, :per_page => 100 + get :index, :params => { + :per_page => 100 + } assert_response :success Issue.open.each do |issue| @@ -87,7 +89,9 @@ class IssuesControllerTest < Redmine::ControllerTest def test_index_with_project Setting.display_subprojects_issues = 0 - get :index, :project_id => 1 + get :index, :params => { + :project_id => 1 + } assert_response :success assert_select 'a[href="/issues/1"]', :text => /Cannot print recipes/ @@ -96,7 +100,9 @@ class IssuesControllerTest < Redmine::ControllerTest def test_index_with_project_and_subprojects Setting.display_subprojects_issues = 1 - get :index, :project_id => 1 + get :index, :params => { + :project_id => 1 + } assert_response :success assert_select 'a[href="/issues/1"]', :text => /Cannot print recipes/ @@ -107,7 +113,9 @@ class IssuesControllerTest < Redmine::ControllerTest def test_index_with_project_and_subprojects_should_show_private_subprojects_with_permission @request.session[:user_id] = 2 Setting.display_subprojects_issues = 1 - get :index, :project_id => 1 + get :index, :params => { + :project_id => 1 + } assert_response :success assert_select 'a[href="/issues/1"]', :text => /Cannot print recipes/ @@ -116,7 +124,10 @@ class IssuesControllerTest < Redmine::ControllerTest end def test_index_with_project_and_default_filter - get :index, :project_id => 1, :set_filter => 1 + get :index, :params => { + :project_id => 1, + :set_filter => 1 + } assert_response :success # default filter @@ -124,10 +135,17 @@ class IssuesControllerTest < Redmine::ControllerTest end def test_index_with_project_and_filter - get :index, :project_id => 1, :set_filter => 1, - :f => ['tracker_id'], - :op => {'tracker_id' => '='}, - :v => {'tracker_id' => ['1']} + get :index, :params => { + :project_id => 1, + :set_filter => 1, + :f => ['tracker_id'], + :op => { + 'tracker_id' => '=' + }, + :v => { + 'tracker_id' => ['1'] + } + } assert_response :success assert_query_filters [['tracker_id', '=', '1']] @@ -189,7 +207,9 @@ class IssuesControllerTest < Redmine::ControllerTest to_test.each do |field, expression_and_expected| expression_and_expected.each do |filter_expression, expected| - get :index, :set_filter => 1, field => filter_expression + get :index, :params => { + :set_filter => 1, field => filter_expression + } assert_response :success expected_with_default = default_filter.merge({field => {:operator => expected[:op], :values => expected[:values]}}) @@ -199,7 +219,11 @@ class IssuesControllerTest < Redmine::ControllerTest end def test_index_with_project_and_empty_filters - get :index, :project_id => 1, :set_filter => 1, :fields => [''] + get :index, :params => { + :project_id => 1, + :set_filter => 1, + :fields => [''] + } assert_response :success # no filter @@ -213,47 +237,77 @@ class IssuesControllerTest < Redmine::ControllerTest filter_name = "project.cf_#{field.id}" @request.session[:user_id] = 1 - get :index, :set_filter => 1, - :f => [filter_name], - :op => {filter_name => '='}, - :v => {filter_name => ['Foo']}, - :c => ['project'] + get :index, :params => { + :set_filter => 1, + :f => [filter_name], + :op => { + filter_name => '=' + }, + :v => { + filter_name => ['Foo'] + }, + :c => ['project'] + } assert_response :success assert_equal [3, 5], issues_in_list.map(&:project_id).uniq.sort end def test_index_with_query - get :index, :project_id => 1, :query_id => 5 + get :index, :params => { + :project_id => 1, + :query_id => 5 + } assert_response :success end def test_index_with_query_grouped_by_tracker - get :index, :project_id => 1, :query_id => 6 + get :index, :params => { + :project_id => 1, + :query_id => 6 + } assert_response :success assert_select 'tr.group span.count' end def test_index_with_query_grouped_and_sorted_by_category - get :index, :project_id => 1, :set_filter => 1, :group_by => "category", :sort => "category" + get :index, :params => { + :project_id => 1, + :set_filter => 1, + :group_by => "category", + :sort => "category" + } assert_response :success assert_select 'tr.group span.count' end def test_index_with_query_grouped_and_sorted_by_fixed_version - get :index, :project_id => 1, :set_filter => 1, :group_by => "fixed_version", :sort => "fixed_version" + get :index, :params => { + :project_id => 1, + :set_filter => 1, + :group_by => "fixed_version", + :sort => "fixed_version" + } assert_response :success assert_select 'tr.group span.count' end def test_index_with_query_grouped_and_sorted_by_fixed_version_in_reverse_order - get :index, :project_id => 1, :set_filter => 1, :group_by => "fixed_version", :sort => "fixed_version:desc" + get :index, :params => { + :project_id => 1, + :set_filter => 1, + :group_by => "fixed_version", + :sort => "fixed_version:desc" + } assert_response :success assert_select 'tr.group span.count' end def test_index_with_query_grouped_by_list_custom_field - get :index, :project_id => 1, :query_id => 9 + get :index, :params => { + :project_id => 1, + :query_id => 9 + } assert_response :success assert_select 'tr.group span.count' end @@ -267,7 +321,11 @@ class IssuesControllerTest < Redmine::ControllerTest CustomValue.create!(:custom_field => cf, :customized => Issue.find(3), :value => valuea.id) CustomValue.create!(:custom_field => cf, :customized => Issue.find(5), :value => '') - get :index, :project_id => 1, :set_filter => 1, :group_by => "cf_#{cf.id}" + get :index, :params => { + :project_id => 1, + :set_filter => 1, + :group_by => "cf_#{cf.id}" + } assert_response :success assert_select 'tr.group', 3 @@ -288,7 +346,11 @@ class IssuesControllerTest < Redmine::ControllerTest CustomValue.create!(:custom_field => cf, :customized => Issue.find(3), :value => '3') CustomValue.create!(:custom_field => cf, :customized => Issue.find(5), :value => '') - get :index, :project_id => 1, :set_filter => 1, :group_by => "cf_#{cf.id}" + get :index, :params => { + :project_id => 1, + :set_filter => 1, + :group_by => "cf_#{cf.id}" + } assert_response :success assert_select 'tr.group', 3 @@ -309,7 +371,11 @@ class IssuesControllerTest < Redmine::ControllerTest CustomValue.create!(:custom_field => cf, :customized => Issue.find(3), :value => '') with_settings :default_language => 'en' do - get :index, :project_id => 1, :set_filter => 1, :group_by => "cf_#{cf.id}" + get :index, :params => { + :project_id => 1, + :set_filter => 1, + :group_by => "cf_#{cf.id}" + } assert_response :success end @@ -325,7 +391,11 @@ class IssuesControllerTest < Redmine::ControllerTest CustomValue.create!(:custom_field => cf, :customized => Issue.find(2), :value => '0') with_settings :default_language => 'en' do - get :index, :project_id => 1, :set_filter => 1, "cf_#{cf.id}" => "*", :group_by => "cf_#{cf.id}" + get :index, :params => { + :project_id => 1, + :set_filter => 1, "cf_#{cf.id}" => "*", + :group_by => "cf_#{cf.id}" + } assert_response :success end @@ -337,7 +407,11 @@ class IssuesControllerTest < Redmine::ControllerTest def test_index_with_query_grouped_by_tracker_in_normal_order 3.times {|i| Issue.generate!(:tracker_id => (i + 1))} - get :index, :set_filter => 1, :group_by => 'tracker', :sort => 'id:desc' + get :index, :params => { + :set_filter => 1, + :group_by => 'tracker', + :sort => 'id:desc' + } assert_response :success assert_equal ["Bug", "Feature request", "Support request"], @@ -347,7 +421,12 @@ class IssuesControllerTest < Redmine::ControllerTest def test_index_with_query_grouped_by_tracker_in_reverse_order 3.times {|i| Issue.generate!(:tracker_id => (i + 1))} - get :index, :set_filter => 1, :group_by => 'tracker', :c => ['tracker', 'subject'], :sort => 'id:desc,tracker:desc' + get :index, :params => { + :set_filter => 1, + :group_by => 'tracker', + :c => ['tracker', 'subject'], + :sort => 'id:desc,tracker:desc' + } assert_response :success assert_equal ["Bug", "Feature request", "Support request"].reverse, @@ -355,7 +434,10 @@ class IssuesControllerTest < Redmine::ControllerTest end def test_index_with_query_id_and_project_id_should_set_session_query - get :index, :project_id => 1, :query_id => 4 + get :index, :params => { + :project_id => 1, + :query_id => 4 + } assert_response :success assert_kind_of Hash, session[:issue_query] assert_equal 4, session[:issue_query][:id] @@ -363,7 +445,10 @@ class IssuesControllerTest < Redmine::ControllerTest end def test_index_with_invalid_query_id_should_respond_404 - get :index, :project_id => 1, :query_id => 999 + get :index, :params => { + :project_id => 1, + :query_id => 999 + } assert_response 404 end @@ -372,7 +457,9 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:issue_query] = {:id => q.id, :project_id => 1} with_settings :display_subprojects_issues => '0' do - get :index, :project_id => 1 + get :index, :params => { + :project_id => 1 + } end assert_response :success @@ -384,7 +471,9 @@ class IssuesControllerTest < Redmine::ControllerTest q = IssueQuery.create!(:name => "private", :user => User.find(2), :visibility => IssueQuery::VISIBILITY_PRIVATE, :project => nil) @request.session[:user_id] = 3 - get :index, :query_id => q.id + get :index, :params => { + :query_id => q.id + } assert_response 403 end @@ -392,7 +481,9 @@ class IssuesControllerTest < Redmine::ControllerTest q = IssueQuery.create!(:name => "private", :user => User.find(2), :visibility => IssueQuery::VISIBILITY_PRIVATE, :project => nil) @request.session[:user_id] = 2 - get :index, :query_id => q.id + get :index, :params => { + :query_id => q.id + } assert_response :success end @@ -400,12 +491,16 @@ class IssuesControllerTest < Redmine::ControllerTest q = IssueQuery.create!(:name => "public", :user => User.find(2), :visibility => IssueQuery::VISIBILITY_PUBLIC, :project => nil) @request.session[:user_id] = 3 - get :index, :query_id => q.id + get :index, :params => { + :query_id => q.id + } assert_response :success end def test_index_should_omit_page_param_in_export_links - get :index, :page => 2 + get :index, :params => { + :page => 2 + } assert_response :success assert_select 'a.atom[href="/issues.atom"]' assert_select 'a.csv[href="/issues.csv"]' @@ -428,7 +523,13 @@ class IssuesControllerTest < Redmine::ControllerTest end def test_index_should_include_query_params_as_hidden_fields_in_csv_export_form - get :index, :project_id => 1, :set_filter => "1", :tracker_id => "2", :sort => 'status', :c => ["status", "priority"] + get :index, :params => { + :project_id => 1, + :set_filter => "1", + :tracker_id => "2", + :sort => 'status', + :c => ["status", "priority"] + } assert_select '#csv-export-form[action=?]', '/projects/ecookbook/issues.csv' assert_select '#csv-export-form[method=?]', 'get' @@ -446,12 +547,18 @@ class IssuesControllerTest < Redmine::ControllerTest assert_select 'input[name=?][value=?]', 'sort', 'status' end - get :index, :project_id => 1, :set_filter => "1", :f => [] + get :index, :params => { + :project_id => 1, + :set_filter => "1", + :f => [''] + } assert_select '#csv-export-form input[name=?][value=?]', 'f[]', '' end def test_index_csv - get :index, :format => 'csv' + get :index, :params => { + :format => 'csv' + } assert_response :success assert_equal 'text/csv; header=present', @response.content_type @@ -462,7 +569,10 @@ class IssuesControllerTest < Redmine::ControllerTest end def test_index_csv_with_project - get :index, :project_id => 1, :format => 'csv' + get :index, :params => { + :project_id => 1, + :format => 'csv' + } assert_response :success assert_equal 'text/csv; header=present', @response.content_type @@ -471,7 +581,11 @@ class IssuesControllerTest < Redmine::ControllerTest def test_index_csv_without_any_filters @request.session[:user_id] = 1 Issue.create!(:project_id => 1, :tracker_id => 1, :status_id => 5, :subject => 'Closed issue', :author_id => 1) - get :index, :set_filter => 1, :f => [], :format => 'csv' + get :index, :params => { + :set_filter => 1, + :f => [''], + :format => 'csv' + } assert_response :success # -1 for headers assert_equal Issue.count, response.body.chomp.split("\n").size - 1 @@ -481,7 +595,11 @@ class IssuesControllerTest < Redmine::ControllerTest Issue.generate!(:description => 'test_index_csv_with_description') with_settings :default_language => 'en' do - get :index, :format => 'csv', :c => [:tracker, :description] + get :index, :params => { + :format => 'csv', + :c => [:tracker, + :description] + } assert_response :success end @@ -495,7 +613,11 @@ class IssuesControllerTest < Redmine::ControllerTest issue = Issue.create!(:project_id => 1, :tracker_id => 1, :subject => 'test_index_csv_with_spent_time_column', :author_id => 2) TimeEntry.create!(:project => issue.project, :issue => issue, :hours => 7.33, :user => User.find(2), :spent_on => Date.today) - get :index, :format => 'csv', :set_filter => '1', :c => %w(subject spent_hours) + get :index, :params => { + :format => 'csv', + :set_filter => '1', + :c => %w(subject spent_hours) + } assert_response :success assert_equal 'text/csv; header=present', @response.content_type lines = @response.body.chomp.split("\n") @@ -503,7 +625,10 @@ class IssuesControllerTest < Redmine::ControllerTest end def test_index_csv_with_all_columns - get :index, :format => 'csv', :c => ['all_inline'] + get :index, :params => { + :format => 'csv', + :c => ['all_inline'] + } assert_response :success assert_equal 'text/csv; header=present', @response.content_type @@ -518,7 +643,10 @@ class IssuesControllerTest < Redmine::ControllerTest issue.custom_field_values = {1 => ['MySQL', 'Oracle']} issue.save! - get :index, :format => 'csv', :c => ['tracker', "cf_1"] + get :index, :params => { + :format => 'csv', + :c => ['tracker', "cf_1"] + } assert_response :success lines = @response.body.chomp.split("\n") assert lines.detect {|line| line.include?('"MySQL, Oracle"')} @@ -529,14 +657,20 @@ class IssuesControllerTest < Redmine::ControllerTest issue = Issue.generate!(:project_id => 1, :tracker_id => 1, :custom_field_values => {field.id => '185.6'}) with_settings :default_language => 'fr' do - get :index, :format => 'csv', :c => ['id', 'tracker', "cf_#{field.id}"] + get :index, :params => { + :format => 'csv', + :c => ['id', 'tracker', "cf_#{field.id}"] + } assert_response :success issue_line = response.body.chomp.split("\n").map {|line| line.split(';')}.detect {|line| line[0]==issue.id.to_s} assert_include '185,60', issue_line end with_settings :default_language => 'en' do - get :index, :format => 'csv', :c => ['id', 'tracker', "cf_#{field.id}"] + get :index, :params => { + :format => 'csv', + :c => ['id', 'tracker', "cf_#{field.id}"] + } assert_response :success issue_line = response.body.chomp.split("\n").map {|line| line.split(',')}.detect {|line| line[0]==issue.id.to_s} assert_include '185.60', issue_line @@ -549,7 +683,10 @@ class IssuesControllerTest < Redmine::ControllerTest child = Issue.generate!(:parent_issue_id => parent.id) with_settings :default_language => 'en' do - get :index, :format => 'csv', :c => %w(parent) + get :index, :params => { + :format => 'csv', + :c => %w(parent) + } end lines = response.body.split("\n") assert_include "#{child.id},#{parent.id}", lines @@ -561,10 +698,11 @@ class IssuesControllerTest < Redmine::ControllerTest str_big5 = "\xa4@\xa4\xeb".force_encoding('Big5') issue = Issue.generate!(:subject => str_utf8) - get :index, :project_id => 1, - :f => ['subject'], - :op => '=', :values => [str_utf8], - :format => 'csv' + get :index, :params => { + :project_id => 1, + :subject => str_utf8, + :format => 'csv' + } assert_equal 'text/csv; header=present', @response.content_type lines = @response.body.chomp.split("\n") header = lines[0] @@ -580,12 +718,13 @@ class IssuesControllerTest < Redmine::ControllerTest str_utf8 = "\xe4\xbb\xa5\xe5\x86\x85".force_encoding('UTF-8') issue = Issue.generate!(:subject => str_utf8) - get :index, :project_id => 1, - :f => ['subject'], - :op => '=', :values => [str_utf8], - :c => ['status', 'subject'], - :format => 'csv', - :set_filter => 1 + get :index, :params => { + :project_id => 1, + :subject => str_utf8, + :c => ['status', 'subject'], + :format => 'csv', + :set_filter => 1 + } assert_equal 'text/csv; header=present', @response.content_type lines = @response.body.chomp.split("\n") header = lines[0] @@ -603,12 +742,13 @@ class IssuesControllerTest < Redmine::ControllerTest str1 = "test_index_csv_tw" issue = Issue.generate!(:subject => str1, :estimated_hours => '1234.5') - get :index, :project_id => 1, - :f => ['subject'], - :op => '=', :values => [str1], - :c => ['estimated_hours', 'subject'], - :format => 'csv', - :set_filter => 1 + get :index, :params => { + :project_id => 1, + :subject => str1, + :c => ['estimated_hours', 'subject'], + :format => 'csv', + :set_filter => 1 + } assert_equal 'text/csv; header=present', @response.content_type lines = @response.body.chomp.split("\n") assert_include "#{issue.id},1234.50,#{str1}", lines @@ -620,12 +760,13 @@ class IssuesControllerTest < Redmine::ControllerTest str1 = "test_index_csv_fr" issue = Issue.generate!(:subject => str1, :estimated_hours => '1234.5') - get :index, :project_id => 1, - :f => ['subject'], - :op => '=', :values => [str1], - :c => ['estimated_hours', 'subject'], - :format => 'csv', - :set_filter => 1 + get :index, :params => { + :project_id => 1, + :subject => str1, + :c => ['estimated_hours', 'subject'], + :format => 'csv', + :set_filter => 1 + } assert_equal 'text/csv; header=present', @response.content_type lines = @response.body.chomp.split("\n") assert_include "#{issue.id};1234,50;#{str1}", lines @@ -639,15 +780,24 @@ class IssuesControllerTest < Redmine::ControllerTest get :index assert_response :success - get :index, :format => 'pdf' + get :index, :params => { + :format => 'pdf' + } assert_response :success assert_equal 'application/pdf', @response.content_type - get :index, :project_id => 1, :format => 'pdf' + get :index, :params => { + :project_id => 1, + :format => 'pdf' + } assert_response :success assert_equal 'application/pdf', @response.content_type - get :index, :project_id => 1, :query_id => 6, :format => 'pdf' + get :index, :params => { + :project_id => 1, + :query_id => 6, + :format => 'pdf' + } assert_response :success assert_equal 'application/pdf', @response.content_type end @@ -655,13 +805,20 @@ class IssuesControllerTest < Redmine::ControllerTest end def test_index_pdf_with_query_grouped_by_list_custom_field - get :index, :project_id => 1, :query_id => 9, :format => 'pdf' + get :index, :params => { + :project_id => 1, + :query_id => 9, + :format => 'pdf' + } assert_response :success assert_equal 'application/pdf', @response.content_type end def test_index_atom - get :index, :project_id => 'ecookbook', :format => 'atom' + get :index, :params => { + :project_id => 'ecookbook', + :format => 'atom' + } assert_response :success assert_equal 'application/atom+xml', response.content_type @@ -673,13 +830,18 @@ class IssuesControllerTest < Redmine::ControllerTest end def test_index_should_include_back_url_input - get :index, :project_id => 'ecookbook', :foo => 'bar' + get :index, :params => { + :project_id => 'ecookbook', + :foo => 'bar' + } assert_response :success assert_select 'input[name=back_url][value=?]', '/projects/ecookbook/issues?foo=bar' end def test_index_sort - get :index, :sort => 'tracker,id:desc' + get :index, :params => { + :sort => 'tracker,id:desc' + } assert_response :success assert_equal issues_in_list.sort_by {|issue| [issue.tracker.position, -issue.id]}, issues_in_list @@ -688,13 +850,17 @@ class IssuesControllerTest < Redmine::ControllerTest def test_index_sort_by_field_not_included_in_columns with_settings :issue_list_default_columns => %w(subject author) do - get :index, :sort => 'tracker' + get :index, :params => { + :sort => 'tracker' + } assert_response :success end end def test_index_sort_by_assigned_to - get :index, :sort => 'assigned_to' + get :index, :params => { + :sort => 'assigned_to' + } assert_response :success assignees = issues_in_list.map(&:assigned_to).compact @@ -703,7 +869,9 @@ class IssuesControllerTest < Redmine::ControllerTest end def test_index_sort_by_assigned_to_desc - get :index, :sort => 'assigned_to:desc' + get :index, :params => { + :sort => 'assigned_to:desc' + } assert_response :success assignees = issues_in_list.map(&:assigned_to).compact @@ -712,12 +880,18 @@ class IssuesControllerTest < Redmine::ControllerTest end def test_index_group_by_assigned_to - get :index, :group_by => 'assigned_to', :sort => 'priority' + get :index, :params => { + :group_by => 'assigned_to', + :sort => 'priority' + } assert_response :success end def test_index_sort_by_author - get :index, :sort => 'author', :c => ['author'] + get :index, :params => { + :sort => 'author', + :c => ['author'] + } assert_response :success authors = issues_in_list.map(&:author) @@ -725,7 +899,9 @@ class IssuesControllerTest < Redmine::ControllerTest end def test_index_sort_by_author_desc - get :index, :sort => 'author:desc' + get :index, :params => { + :sort => 'author:desc' + } assert_response :success authors = issues_in_list.map(&:author) @@ -733,38 +909,51 @@ class IssuesControllerTest < Redmine::ControllerTest end def test_index_group_by_author - get :index, :group_by => 'author', :sort => 'priority' + get :index, :params => { + :group_by => 'author', + :sort => 'priority' + } assert_response :success end def test_index_sort_by_last_updated_by - get :index, :sort => 'last_updated_by' + get :index, :params => { + :sort => 'last_updated_by' + } assert_response :success assert_select 'table.issues.sort-by-last-updated-by.sort-asc' end def test_index_sort_by_last_updated_by_desc - get :index, :sort => 'last_updated_by:desc' + get :index, :params => { + :sort => 'last_updated_by:desc' + } assert_response :success assert_select 'table.issues.sort-by-last-updated-by.sort-desc' end def test_index_sort_by_spent_hours - get :index, :sort => 'spent_hours:desc' + get :index, :params => { + :sort => 'spent_hours:desc' + } assert_response :success hours = issues_in_list.map(&:spent_hours) assert_equal hours.sort.reverse, hours end def test_index_sort_by_total_spent_hours - get :index, :sort => 'total_spent_hours:desc' + get :index, :params => { + :sort => 'total_spent_hours:desc' + } assert_response :success hours = issues_in_list.map(&:total_spent_hours) assert_equal hours.sort.reverse, hours end def test_index_sort_by_total_estimated_hours - get :index, :sort => 'total_estimated_hours:desc' + get :index, :params => { + :sort => 'total_estimated_hours:desc' + } assert_response :success hours = issues_in_list.map(&:total_estimated_hours) assert_equal hours.sort.reverse, hours @@ -777,7 +966,11 @@ class IssuesControllerTest < Redmine::ControllerTest CustomValue.create!(:custom_field => cf, :customized => Issue.find(3), :value => '3') CustomValue.create!(:custom_field => cf, :customized => Issue.find(5), :value => '') - get :index, :project_id => 1, :set_filter => 1, :sort => "cf_#{cf.id},id" + get :index, :params => { + :project_id => 1, + :set_filter => 1, + :sort => "cf_#{cf.id},id" + } assert_response :success assert_equal [2, 3, 1], issues_in_list.select {|issue| issue.custom_field_value(cf).present?}.map(&:id) @@ -785,7 +978,10 @@ class IssuesControllerTest < Redmine::ControllerTest def test_index_with_columns columns = ['tracker', 'subject', 'assigned_to'] - get :index, :set_filter => 1, :c => columns + get :index, :params => { + :set_filter => 1, + :c => columns + } assert_response :success # query should use specified columns + id and checkbox @@ -806,7 +1002,9 @@ class IssuesControllerTest < Redmine::ControllerTest def test_index_without_project_should_implicitly_add_project_column_to_default_columns with_settings :issue_list_default_columns => ['tracker', 'subject', 'assigned_to'] do - get :index, :set_filter => 1 + get :index, :params => { + :set_filter => 1 + } end # query should use specified columns @@ -816,7 +1014,10 @@ class IssuesControllerTest < Redmine::ControllerTest def test_index_without_project_and_explicit_default_columns_should_not_add_project_column with_settings :issue_list_default_columns => ['tracker', 'subject', 'assigned_to'] do columns = ['id', 'tracker', 'subject', 'assigned_to'] - get :index, :set_filter => 1, :c => columns + get :index, :params => { + :set_filter => 1, + :c => columns + } end # query should use specified columns @@ -826,7 +1027,10 @@ class IssuesControllerTest < Redmine::ControllerTest def test_index_with_default_columns_should_respect_default_columns_order columns = ['assigned_to', 'subject', 'status', 'tracker'] with_settings :issue_list_default_columns => columns do - get :index, :project_id => 1, :set_filter => 1 + get :index, :params => { + :project_id => 1, + :set_filter => 1 + } assert_equal ["#", "Assignee", "Subject", "Status", "Tracker"], columns_in_issues_list end @@ -834,7 +1038,10 @@ class IssuesControllerTest < Redmine::ControllerTest def test_index_with_custom_field_column columns = %w(tracker subject cf_2) - get :index, :set_filter => 1, :c => columns + get :index, :params => { + :set_filter => 1, + :c => columns + } assert_response :success # query should use specified columns @@ -849,7 +1056,10 @@ class IssuesControllerTest < Redmine::ControllerTest issue.custom_field_values = {1 => ['MySQL', 'Oracle']} issue.save! - get :index, :set_filter => 1, :c => %w(tracker subject cf_1) + get :index, :params => { + :set_filter => 1, + :c => %w(tracker subject cf_1) + } assert_response :success assert_select 'table.issues td.cf_1', :text => 'MySQL, Oracle' @@ -862,7 +1072,10 @@ class IssuesControllerTest < Redmine::ControllerTest issue.custom_field_values = {field.id => ['2', '3']} issue.save! - get :index, :set_filter => 1, :c => ['tracker', 'subject', "cf_#{field.id}"] + get :index, :params => { + :set_filter => 1, + :c => ['tracker', 'subject', "cf_#{field.id}"] + } assert_response :success assert_select "table.issues td.cf_#{field.id}" do @@ -875,14 +1088,20 @@ class IssuesControllerTest < Redmine::ControllerTest def test_index_with_date_column with_settings :date_format => '%d/%m/%Y' do Issue.find(1).update_attribute :start_date, '1987-08-24' - get :index, :set_filter => 1, :c => %w(start_date) + get :index, :params => { + :set_filter => 1, + :c => %w(start_date) + } assert_select "table.issues td.start_date", :text => '24/08/1987' end end def test_index_with_done_ratio_column Issue.find(1).update_attribute :done_ratio, 40 - get :index, :set_filter => 1, :c => %w(done_ratio) + get :index, :params => { + :set_filter => 1, + :c => %w(done_ratio) + } assert_select 'table.issues td.done_ratio' do assert_select 'table.progress' do assert_select 'td.closed[style=?]', 'width: 40%;' @@ -892,29 +1111,44 @@ class IssuesControllerTest < Redmine::ControllerTest def test_index_with_spent_hours_column Issue.expects(:load_visible_spent_hours).once - get :index, :set_filter => 1, :c => %w(subject spent_hours) + get :index, :params => { + :set_filter => 1, + :c => %w(subject spent_hours) + } assert_select 'table.issues tr#issue-3 td.spent_hours', :text => '1.00' end def test_index_with_total_spent_hours_column Issue.expects(:load_visible_total_spent_hours).once - get :index, :set_filter => 1, :c => %w(subject total_spent_hours) + get :index, :params => { + :set_filter => 1, + :c => %w(subject total_spent_hours) + } assert_select 'table.issues tr#issue-3 td.total_spent_hours', :text => '1.00' end def test_index_with_total_estimated_hours_column - get :index, :set_filter => 1, :c => %w(subject total_estimated_hours) + get :index, :params => { + :set_filter => 1, + :c => %w(subject total_estimated_hours) + } assert_select 'table.issues td.total_estimated_hours' end def test_index_should_not_show_spent_hours_column_without_permission Role.anonymous.remove_permission! :view_time_entries - get :index, :set_filter => 1, :c => %w(subject spent_hours) + get :index, :params => { + :set_filter => 1, + :c => %w(subject spent_hours) + } assert_select 'td.spent_hours', 0 end def test_index_with_fixed_version_column - get :index, :set_filter => 1, :c => %w(fixed_version) + get :index, :params => { + :set_filter => 1, + :c => %w(fixed_version) + } assert_select 'table.issues td.fixed_version' do assert_select 'a[href=?]', '/versions/2', :text => 'eCookbook - 1.0' end @@ -927,7 +1161,10 @@ class IssuesControllerTest < Redmine::ControllerTest IssueRelation.create!(:relation_type => "blocks", :issue_from => Issue.find(1), :issue_to => Issue.find(11)) IssueRelation.create!(:relation_type => "blocks", :issue_from => Issue.find(12), :issue_to => Issue.find(2)) - get :index, :set_filter => 1, :c => %w(subject relations) + get :index, :params => { + :set_filter => 1, + :c => %w(subject relations) + } assert_response :success assert_select "tr#issue-1 td.relations" do assert_select "span", 3 @@ -943,7 +1180,11 @@ class IssuesControllerTest < Redmine::ControllerTest assert_select "span", 0 end - get :index, :set_filter => 1, :c => %w(relations), :format => 'csv' + get :index, :params => { + :set_filter => 1, + :c => %w(relations), + :format => 'csv' + } assert_response :success assert_equal 'text/csv; header=present', response.content_type lines = response.body.chomp.split("\n") @@ -951,24 +1192,38 @@ class IssuesControllerTest < Redmine::ControllerTest assert_include '2,Blocked by #12', lines assert_include '3,""', lines - get :index, :set_filter => 1, :c => %w(subject relations), :format => 'pdf' + get :index, :params => { + :set_filter => 1, + :c => %w(subject relations), + :format => 'pdf' + } assert_response :success assert_equal 'application/pdf', response.content_type end def test_index_with_description_column - get :index, :set_filter => 1, :c => %w(subject description) + get :index, :params => { + :set_filter => 1, + :c => %w(subject description) + } assert_select 'table.issues thead th', 3 # columns: chekbox + id + subject assert_select 'td.description[colspan="3"]', :text => 'Unable to print recipes' - get :index, :set_filter => 1, :c => %w(subject description), :format => 'pdf' + get :index, :params => { + :set_filter => 1, + :c => %w(subject description), + :format => 'pdf' + } assert_response :success assert_equal 'application/pdf', response.content_type end def test_index_with_last_notes_column - get :index, :set_filter => 1, :c => %w(subject last_notes) + get :index, :params => { + :set_filter => 1, + :c => %w(subject last_notes) + } assert_response :success assert_select 'table.issues thead th', 3 # columns: chekbox + id + subject @@ -976,7 +1231,11 @@ class IssuesControllerTest < Redmine::ControllerTest assert_select 'td.last_notes[colspan="3"]', :text => 'Some notes with Redmine links: #2, r2.' assert_select 'td.last_notes[colspan="3"]', :text => 'A comment with inline image: and a reference to #1 and r2.' - get :index, :set_filter => 1, :c => %w(subject last_notes), :format => 'pdf' + get :index, :params => { + :set_filter => 1, + :c => %w(subject last_notes), + :format => 'pdf' + } assert_response :success assert_equal 'application/pdf', response.content_type end @@ -986,19 +1245,28 @@ class IssuesControllerTest < Redmine::ControllerTest journal = Journal.create!(:journalized => Issue.find(2), :notes => 'Privates notes', :private_notes => true, :user_id => 1) @request.session[:user_id] = 2 - get :index, :set_filter => 1, :c => %w(subject last_notes) + get :index, :params => { + :set_filter => 1, + :c => %w(subject last_notes) + } assert_response :success assert_select 'td.last_notes[colspan="3"]', :text => 'Privates notes' Role.find(1).remove_permission! :view_private_notes - get :index, :set_filter => 1, :c => %w(subject last_notes) + get :index, :params => { + :set_filter => 1, + :c => %w(subject last_notes) + } assert_response :success assert_select 'td.last_notes[colspan="3"]', :text => 'Public notes' end def test_index_with_description_and_last_notes_columns_should_display_column_name - get :index, :set_filter => 1, :c => %w(subject last_notes description) + get :index, :params => { + :set_filter => 1, + :c => %w(subject last_notes description) + } assert_response :success assert_select 'td.last_notes[colspan="3"] span', :text => 'Last notes' @@ -1010,21 +1278,32 @@ class IssuesControllerTest < Redmine::ControllerTest parent = Issue.generate! child = Issue.generate!(:parent_issue_id => parent.id) - get :index, :c => %w(parent) + get :index, :params => { + :c => %w(parent) + } assert_select 'td.parent', :text => "#{parent.tracker} ##{parent.id}" assert_select 'td.parent a[title=?]', parent.subject end def test_index_with_last_updated_by_column - get :index, :c => %w(subject last_updated_by), :issue_id => '1,2,3', :sort => 'id', :set_filter => '1' + get :index, :params => { + :c => %w(subject last_updated_by), + :issue_id => '1,2,3', + :sort => 'id', + :set_filter => '1' + } assert_select 'td.last_updated_by' assert_equal ["John Smith", "John Smith", ""], css_select('td.last_updated_by').map(&:text) end def test_index_with_attachments_column - get :index, :c => %w(subject attachments), :set_filter => '1', :sort => 'id' + get :index, :params => { + :c => %w(subject attachments), + :set_filter => '1', + :sort => 'id' + } assert_response :success assert_select 'td.attachments' @@ -1037,7 +1316,12 @@ class IssuesControllerTest < Redmine::ControllerTest end def test_index_with_attachments_column_as_csv - get :index, :c => %w(subject attachments), :set_filter => '1', :sort => 'id', :format => 'csv' + get :index, :params => { + :c => %w(subject attachments), + :set_filter => '1', + :sort => 'id', + :format => 'csv' + } assert_response :success assert_include "\"source.rb\npicture.jpg\"", response.body @@ -1048,7 +1332,9 @@ class IssuesControllerTest < Redmine::ControllerTest Issue.generate!(:estimated_hours => 5.5) Issue.generate!(:estimated_hours => 1.1) - get :index, :t => %w(estimated_hours) + get :index, :params => { + :t => %w(estimated_hours) + } assert_response :success assert_select '.query-totals' assert_select '.total-for-estimated-hours span.value', :text => '6.60' @@ -1062,7 +1348,10 @@ class IssuesControllerTest < Redmine::ControllerTest Issue.generate!(:estimated_hours => 1.1, :category_id => 2) Issue.generate!(:estimated_hours => 4.6) - get :index, :t => %w(estimated_hours), :group_by => 'category' + get :index, :params => { + :t => %w(estimated_hours), + :group_by => 'category' + } assert_response :success assert_select '.query-totals' assert_select '.query-totals .total-for-estimated-hours span.value', :text => '13.50' @@ -1082,7 +1371,9 @@ class IssuesControllerTest < Redmine::ControllerTest CustomValue.create!(:customized => Issue.find(1), :custom_field => field, :value => '2') CustomValue.create!(:customized => Issue.find(2), :custom_field => field, :value => '7') - get :index, :t => ["cf_#{field.id}"] + get :index, :params => { + :t => ["cf_#{field.id}"] + } assert_response :success assert_select '.query-totals' assert_select ".total-for-cf-#{field.id} span.value", :text => '9' @@ -1098,20 +1389,33 @@ class IssuesControllerTest < Redmine::ControllerTest end def test_index_send_html_if_query_is_invalid - get :index, :f => ['start_date'], :op => {:start_date => '='} + get :index, :params => { + :f => ['start_date'], + :op => { + :start_date => '=' + } + } assert_equal 'text/html', @response.content_type assert_select_error /Start date cannot be blank/i end def test_index_send_nothing_if_query_is_invalid - get :index, :f => ['start_date'], :op => {:start_date => '='}, :format => 'csv' + get :index, :params => { + :f => ['start_date'], + :op => { + :start_date => '=' + }, + :format => 'csv' + } assert_equal 'text/csv', @response.content_type assert @response.body.blank? end def test_index_should_include_new_issue_link @request.session[:user_id] = 2 - get :index, :project_id => 1 + get :index, :params => { + :project_id => 1 + } assert_select '#content a.new-issue[href="/projects/ecookbook/issues/new"]', :text => 'New issue' end @@ -1119,7 +1423,9 @@ class IssuesControllerTest < Redmine::ControllerTest Project.find(1).trackers.clear @request.session[:user_id] = 2 - get :index, :project_id => 1 + get :index, :params => { + :project_id => 1 + } assert_select '#content a.new-issue', 0 end @@ -1129,7 +1435,9 @@ class IssuesControllerTest < Redmine::ControllerTest role.add_permission! :copy_issues @request.session[:user_id] = 2 - get :index, :project_id => 1 + get :index, :params => { + :project_id => 1 + } assert_select '#content a.new-issue', 0 end @@ -1142,7 +1450,9 @@ class IssuesControllerTest < Redmine::ControllerTest def test_index_should_not_include_new_issue_tab_when_disabled with_settings :new_item_menu_tab => '0' do @request.session[:user_id] = 2 - get :index, :project_id => 1 + get :index, :params => { + :project_id => 1 + } assert_select '#main-menu a.new-issue', 0 end end @@ -1150,7 +1460,9 @@ class IssuesControllerTest < Redmine::ControllerTest def test_index_should_include_new_issue_tab_when_enabled with_settings :new_item_menu_tab => '1' do @request.session[:user_id] = 2 - get :index, :project_id => 1 + get :index, :params => { + :project_id => 1 + } assert_select '#main-menu a.new-issue[href="/projects/ecookbook/issues/new"]', :text => 'New issue' end end @@ -1158,7 +1470,9 @@ class IssuesControllerTest < Redmine::ControllerTest def test_new_should_have_new_issue_tab_as_current_menu_item with_settings :new_item_menu_tab => '1' do @request.session[:user_id] = 2 - get :new, :project_id => 1 + get :new, :params => { + :project_id => 1 + } assert_select '#main-menu a.new-issue.selected' end end @@ -1168,7 +1482,9 @@ class IssuesControllerTest < Redmine::ControllerTest Project.find(1).trackers.clear @request.session[:user_id] = 2 - get :index, :project_id => 1 + get :index, :params => { + :project_id => 1 + } assert_select '#main-menu a.new-issue', 0 end end @@ -1180,13 +1496,17 @@ class IssuesControllerTest < Redmine::ControllerTest role.add_permission! :copy_issues @request.session[:user_id] = 2 - get :index, :project_id => 1 + get :index, :params => { + :project_id => 1 + } assert_select '#main-menu a.new-issue', 0 end end def test_show_by_anonymous - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :success assert_select 'div.issue div.description', :text => /Unable to print recipes/ @@ -1202,7 +1522,9 @@ class IssuesControllerTest < Redmine::ControllerTest def test_show_by_manager @request.session[:user_id] = 2 - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_select 'a', :text => /Quote/ assert_select 'form#issue-form' do @@ -1223,7 +1545,9 @@ class IssuesControllerTest < Redmine::ControllerTest def test_show_should_display_update_form @request.session[:user_id] = 2 - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :success assert_select 'form#issue-form' do @@ -1252,7 +1576,9 @@ class IssuesControllerTest < Redmine::ControllerTest WorkflowTransition.where(:role_id => 1).delete_all @request.session[:user_id] = 2 - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :success assert_select 'form#issue-form' do @@ -1280,7 +1606,9 @@ class IssuesControllerTest < Redmine::ControllerTest Role.find(1).update_attribute :permissions, [:view_issues] @request.session[:user_id] = 2 - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :success assert_select 'form#issue-form', 0 @@ -1290,7 +1618,9 @@ class IssuesControllerTest < Redmine::ControllerTest assert !IssuePriority.find(15).active? @request.session[:user_id] = 2 - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :success assert_select 'form#issue-form' do @@ -1303,7 +1633,9 @@ class IssuesControllerTest < Redmine::ControllerTest def test_update_form_should_allow_attachment_upload @request.session[:user_id] = 2 - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_select 'form#issue-form[method=post][enctype="multipart/form-data"]' do assert_select 'input[type=file][name=?]', 'attachments[dummy][file]' @@ -1312,55 +1644,71 @@ class IssuesControllerTest < Redmine::ControllerTest def test_show_should_deny_anonymous_access_without_permission Role.anonymous.remove_permission!(:view_issues) - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :redirect end def test_show_should_deny_anonymous_access_to_private_issue Issue.where(:id => 1).update_all(["is_private = ?", true]) - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :redirect end def test_show_should_deny_non_member_access_without_permission Role.non_member.remove_permission!(:view_issues) @request.session[:user_id] = 9 - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response 403 end def test_show_should_deny_non_member_access_to_private_issue Issue.where(:id => 1).update_all(["is_private = ?", true]) @request.session[:user_id] = 9 - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response 403 end def test_show_should_deny_member_access_without_permission Role.find(1).remove_permission!(:view_issues) @request.session[:user_id] = 2 - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response 403 end def test_show_should_deny_member_access_to_private_issue_without_permission Issue.where(:id => 1).update_all(["is_private = ?", true]) @request.session[:user_id] = 3 - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response 403 end def test_show_should_allow_author_access_to_private_issue Issue.where(:id => 1).update_all(["is_private = ?, author_id = 3", true]) @request.session[:user_id] = 3 - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :success end def test_show_should_allow_assignee_access_to_private_issue Issue.where(:id => 1).update_all(["is_private = ?, assigned_to_id = 3", true]) @request.session[:user_id] = 3 - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :success end @@ -1368,7 +1716,9 @@ class IssuesControllerTest < Redmine::ControllerTest Issue.where(:id => 1).update_all(["is_private = ?", true]) User.find(3).roles_for_project(Project.find(1)).first.update_attribute :issues_visibility, 'all' @request.session[:user_id] = 3 - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :success end @@ -1378,7 +1728,9 @@ class IssuesControllerTest < Redmine::ControllerTest # Relation to a private project issue IssueRelation.create!(:issue_from => Issue.find(1), :issue_to => Issue.find(4), :relation_type => 'relates') - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :success assert_select 'div#relations' do @@ -1390,7 +1742,9 @@ class IssuesControllerTest < Redmine::ControllerTest def test_show_should_list_subtasks Issue.create!(:project_id => 1, :author_id => 1, :tracker_id => 1, :parent_issue_id => 1, :subject => 'Child Issue') - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :success assert_select 'div#issue_tree' do @@ -1401,7 +1755,9 @@ class IssuesControllerTest < Redmine::ControllerTest def test_show_should_list_parents issue = Issue.create!(:project_id => 1, :author_id => 1, :tracker_id => 1, :parent_issue_id => 1, :subject => 'Child Issue') - get :show, :id => issue.id + get :show, :params => { + :id => issue.id + } assert_response :success assert_select 'div.subject' do @@ -1411,7 +1767,9 @@ class IssuesControllerTest < Redmine::ControllerTest end def test_show_should_not_display_prev_next_links_without_query_in_session - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :success assert_select 'div.next-prev-links', 0 @@ -1421,7 +1779,9 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:issue_query] = {:filters => {'status_id' => {:values => [''], :operator => 'o'}}, :project_id => nil, :sort => [['id', 'asc']]} with_settings :display_subprojects_issues => '0' do - get :show, :id => 3 + get :show, :params => { + :id => 3 + } end assert_response :success @@ -1441,7 +1801,9 @@ class IssuesControllerTest < Redmine::ControllerTest :sort_criteria => [['id', 'asc']]) @request.session[:issue_query] = {:id => query.id, :project_id => nil} - get :show, :id => 11 + get :show, :params => { + :id => 11 + } assert_response :success # Previous and next issues for all projects @@ -1457,7 +1819,9 @@ class IssuesControllerTest < Redmine::ControllerTest %w(project tracker status priority author assigned_to category fixed_version).each do |assoc_sort| @request.session[:issue_query][:sort] = [[assoc_sort, 'asc']] - get :show, :id => 3 + get :show, :params => { + :id => 3 + } assert_response :success, "Wrong response status for #{assoc_sort} sort" assert_select 'div.next-prev-links' do @@ -1470,7 +1834,9 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:issue_query] = {:filters => {'status_id' => {:values => [''], :operator => 'o'}}, :project_id => 1, :sort => [['id','asc']]} with_settings :display_subprojects_issues => '0' do - get :show, :id => 3 + get :show, :params => { + :id => 3 + } end assert_response :success @@ -1485,7 +1851,9 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:issue_query] = {:filters => {'status_id' => {:values => [''], :operator => 'o'}}, :project_id => 1, :sort => [['id', 'asc']]} with_settings :display_subprojects_issues => '0' do - get :show, :id => 1 + get :show, :params => { + :id => 1 + } end assert_response :success @@ -1498,7 +1866,9 @@ class IssuesControllerTest < Redmine::ControllerTest def test_show_should_not_display_prev_next_links_for_issue_not_in_query_results @request.session[:issue_query] = {:filters => {'status_id' => {:values => [''], :operator => 'c'}}, :project_id => 1, :sort => [['id', 'asc']]} - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :success assert_select 'a', :text => /Previous/, :count => 0 @@ -1516,7 +1886,9 @@ class IssuesControllerTest < Redmine::ControllerTest :sort_criteria => [["cf_#{cf.id}", 'asc'], ['id', 'asc']]) @request.session[:issue_query] = {:id => query.id, :project_id => nil} - get :show, :id => 3 + get :show, :params => { + :id => 3 + } assert_response :success assert_select 'div.next-prev-links' do @@ -1526,7 +1898,13 @@ class IssuesControllerTest < Redmine::ControllerTest end def test_show_should_display_prev_next_links_when_request_has_previous_and_next_issue_ids_params - get :show, :id => 1, :prev_issue_id => 1, :next_issue_id => 3, :issue_position => 2, :issue_count => 4 + get :show, :params => { + :id => 1, + :prev_issue_id => 1, + :next_issue_id => 3, + :issue_position => 2, + :issue_count => 4 + } assert_response :success assert_select 'div.next-prev-links' do @@ -1539,7 +1917,9 @@ class IssuesControllerTest < Redmine::ControllerTest def test_show_should_display_category_field_if_categories_are_defined Issue.update_all :category_id => nil - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :success assert_select '.attributes .category' end @@ -1547,13 +1927,17 @@ class IssuesControllerTest < Redmine::ControllerTest def test_show_should_not_display_category_field_if_no_categories_are_defined Project.find(1).issue_categories.delete_all - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :success assert_select 'table.attributes .category', 0 end def test_show_should_display_link_to_the_assignee - get :show, :id => 2 + get :show, :params => { + :id => 2 + } assert_response :success assert_select '.assigned-to' do assert_select 'a[href="/users/3"]' @@ -1570,7 +1954,9 @@ class IssuesControllerTest < Redmine::ControllerTest project.disable_module! :repository @request.session[:user_id] = 2 - get :show, :id => issue.id + get :show, :params => { + :id => issue.id + } assert_select 'a[href=?]', '/projects/ecookbook/repository/revisions/3' end @@ -1579,7 +1965,9 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 Issue.find(1).add_watcher User.find(2) - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_select 'div#watchers ul' do assert_select 'li' do assert_select 'a[href="/users/2"]' @@ -1593,7 +1981,9 @@ class IssuesControllerTest < Redmine::ControllerTest Issue.find(1).add_watcher User.find(2) with_settings :gravatar_enabled => '1' do - get :show, :id => 1 + get :show, :params => { + :id => 1 + } end assert_select 'div#watchers ul' do @@ -1609,7 +1999,9 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 with_settings :thumbnails_enabled => '1' do - get :show, :id => 14 + get :show, :params => { + :id => 14 + } assert_response :success end @@ -1624,7 +2016,9 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 with_settings :thumbnails_enabled => '0' do - get :show, :id => 14 + get :show, :params => { + :id => 14 + } assert_response :success end @@ -1638,7 +2032,9 @@ class IssuesControllerTest < Redmine::ControllerTest issue.custom_field_values = {1 => ['MySQL', 'Oracle']} issue.save! - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :success assert_select ".cf_1 .value", :text => 'MySQL, Oracle' @@ -1651,7 +2047,9 @@ class IssuesControllerTest < Redmine::ControllerTest issue.custom_field_values = {field.id => 'This is a long text'} issue.save! - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :success # long text custom field should not be render in the attributes div @@ -1670,7 +2068,9 @@ class IssuesControllerTest < Redmine::ControllerTest issue.custom_field_values = {field.id => ['2', '3']} issue.save! - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :success assert_select ".cf_#{field.id} .value", :text => 'Dave Lopper, John Smith' do @@ -1683,12 +2083,16 @@ class IssuesControllerTest < Redmine::ControllerTest journal = Journal.create!(:journalized => Issue.find(2), :notes => 'Privates notes', :private_notes => true, :user_id => 1) @request.session[:user_id] = 2 - get :show, :id => 2 + get :show, :params => { + :id => 2 + } assert_response :success assert_select "#change-#{journal.id}", 1 Role.find(1).remove_permission! :view_private_notes - get :show, :id => 2 + get :show, :params => { + :id => 2 + } assert_response :success assert_select "#change-#{journal.id}", 0 end @@ -1701,14 +2105,19 @@ class IssuesControllerTest < Redmine::ControllerTest not_visible = Journal.create!(:journalized => Issue.find(2), :notes => 'Private notes', :private_notes => true, :user_id => 1) @request.session[:user_id] = 3 - get :show, :id => 2 + get :show, :params => { + :id => 2 + } assert_response :success assert_select "#change-#{visible.id}", 1 assert_select "#change-#{not_visible.id}", 0 end def test_show_atom - get :show, :id => 2, :format => 'atom' + get :show, :params => { + :id => 2, + :format => 'atom' + } assert_response :success assert_equal 'application/atom+xml', response.content_type # Inline image @@ -1718,7 +2127,10 @@ class IssuesControllerTest < Redmine::ControllerTest def test_show_export_to_pdf issue = Issue.find(3) assert issue.relations.select{|r| r.other_issue(issue).visible?}.present? - get :show, :id => 3, :format => 'pdf' + get :show, :params => { + :id => 3, + :format => 'pdf' + } assert_response :success assert_equal 'application/pdf', @response.content_type assert @response.body.starts_with?('%PDF') @@ -1731,7 +2143,10 @@ class IssuesControllerTest < Redmine::ControllerTest issue = Issue.generate!(:subject => s) ["en", "zh", "zh-TW", "ja", "ko"].each do |lang| with_settings :default_language => lang do - get :show, :id => issue.id, :format => 'pdf' + get :show, :params => { + :id => issue.id, + :format => 'pdf' + } assert_response :success assert_equal 'application/pdf', @response.content_type assert @response.body.starts_with?('%PDF') @@ -1742,7 +2157,10 @@ class IssuesControllerTest < Redmine::ControllerTest def test_show_export_to_pdf_with_ancestors issue = Issue.generate!(:project_id => 1, :author_id => 2, :tracker_id => 1, :subject => 'child', :parent_issue_id => 1) - get :show, :id => issue.id, :format => 'pdf' + get :show, :params => { + :id => issue.id, + :format => 'pdf' + } assert_response :success assert_equal 'application/pdf', @response.content_type assert @response.body.starts_with?('%PDF') @@ -1753,14 +2171,20 @@ class IssuesControllerTest < Redmine::ControllerTest c2 = Issue.generate!(:project_id => 1, :author_id => 2, :tracker_id => 1, :subject => 'child', :parent_issue_id => 1) c3 = Issue.generate!(:project_id => 1, :author_id => 2, :tracker_id => 1, :subject => 'child', :parent_issue_id => c1.id) - get :show, :id => 1, :format => 'pdf' + get :show, :params => { + :id => 1, + :format => 'pdf' + } assert_response :success assert_equal 'application/pdf', @response.content_type assert @response.body.starts_with?('%PDF') end def test_show_export_to_pdf_with_journals - get :show, :id => 1, :format => 'pdf' + get :show, :params => { + :id => 1, + :format => 'pdf' + } assert_response :success assert_equal 'application/pdf', @response.content_type assert @response.body.starts_with?('%PDF') @@ -1773,7 +2197,10 @@ class IssuesControllerTest < Redmine::ControllerTest issue1.save! issue = Issue.find(3) assert_equal issue.changesets.count, cs.size - get :show, :id => 3, :format => 'pdf' + get :show, :params => { + :id => 3, + :format => 'pdf' + } assert_response :success assert_equal 'application/pdf', @response.content_type assert @response.body.starts_with?('%PDF') @@ -1781,14 +2208,18 @@ class IssuesControllerTest < Redmine::ControllerTest end def test_show_invalid_should_respond_with_404 - get :show, :id => 999 + get :show, :params => { + :id => 999 + } assert_response 404 end def test_show_on_active_project_should_display_edit_links @request.session[:user_id] = 1 - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :success assert_select 'a', :text => 'Edit' assert_select 'a', :text => 'Delete' @@ -1798,7 +2229,9 @@ class IssuesControllerTest < Redmine::ControllerTest Issue.find(1).project.close @request.session[:user_id] = 1 - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :success assert_select 'a', :text => 'Edit', :count => 0 assert_select 'a', :text => 'Delete', :count => 0 @@ -1806,7 +2239,10 @@ class IssuesControllerTest < Redmine::ControllerTest def test_get_new @request.session[:user_id] = 2 - get :new, :project_id => 1, :tracker_id => 1 + get :new, :params => { + :project_id => 1, + :tracker_id => 1 + } assert_response :success assert_select 'form#issue-form[action=?]', '/projects/ecookbook/issues' @@ -1841,7 +2277,10 @@ class IssuesControllerTest < Redmine::ControllerTest WorkflowTransition.where(:role_id => 1).delete_all @request.session[:user_id] = 2 - get :new, :project_id => 1, :tracker_id => 1 + get :new, :params => { + :project_id => 1, + :tracker_id => 1 + } assert_response :success assert_select 'form#issue-form' do @@ -1878,7 +2317,9 @@ class IssuesControllerTest < Redmine::ControllerTest def test_new_should_select_default_status @request.session[:user_id] = 2 - get :new, :project_id => 1 + get :new, :params => { + :project_id => 1 + } assert_response :success assert_select 'select[name=?]', 'issue[status_id]' do assert_select 'option[value="1"][selected=selected]' @@ -1892,7 +2333,9 @@ class IssuesControllerTest < Redmine::ControllerTest WorkflowTransition.create!(:tracker_id => 1, :role_id => 1, :old_status_id => 0, :new_status_id => 3) @request.session[:user_id] = 2 - get :new, :project_id => 1 + get :new, :params => { + :project_id => 1 + } assert_response :success assert_select 'select[name=?]', 'issue[status_id]' do assert_select 'option[value="1"]' @@ -1908,7 +2351,9 @@ class IssuesControllerTest < Redmine::ControllerTest assert_equal 1, Tracker.find(1).default_status_id @request.session[:user_id] = 2 - get :new, :project_id => 1 + get :new, :params => { + :project_id => 1 + } assert_response :success assert_select 'select[name=?]', 'issue[status_id]' do assert_select 'option[value="2"]' @@ -1923,7 +2368,9 @@ class IssuesControllerTest < Redmine::ControllerTest role.save! @request.session[:user_id] = 2 - get :new, :project_id => 1 + get :new, :params => { + :project_id => 1 + } assert_response :success assert_select 'select[name=?]', 'issue[tracker_id]' do assert_select 'option', 2 @@ -1935,7 +2382,9 @@ class IssuesControllerTest < Redmine::ControllerTest def test_new_should_default_to_first_tracker @request.session[:user_id] = 2 - get :new, :project_id => 1 + get :new, :params => { + :project_id => 1 + } assert_response :success assert_select 'select[name=?]', 'issue[tracker_id]' do assert_select 'option', 3 @@ -1949,7 +2398,12 @@ class IssuesControllerTest < Redmine::ControllerTest tracker.save! @request.session[:user_id] = 2 - get :new, :project_id => 1, :issue => {:parent_issue_id => 1} + get :new, :params => { + :project_id => 1, + :issue => { + :parent_issue_id => 1 + } + } assert_response :success assert_select 'select[name=?]', 'issue[tracker_id]' do assert_select 'option', 2 @@ -1964,7 +2418,9 @@ class IssuesControllerTest < Redmine::ControllerTest role.save! @request.session[:user_id] = 2 - get :new, :project_id => 1 + get :new, :params => { + :project_id => 1 + } assert_response 403 end @@ -1991,7 +2447,9 @@ class IssuesControllerTest < Redmine::ControllerTest Project.find(1).update_attribute :default_version_id, version.id @request.session[:user_id] = 2 - get :new, :project_id => 1 + get :new, :params => { + :project_id => 1 + } assert_response :success assert_select 'select[name=?]', 'issue[fixed_version_id]' do assert_select 'option[value=?][selected=selected]', version.id.to_s @@ -2000,7 +2458,10 @@ class IssuesControllerTest < Redmine::ControllerTest def test_get_new_with_list_custom_field @request.session[:user_id] = 2 - get :new, :project_id => 1, :tracker_id => 1 + get :new, :params => { + :project_id => 1, + :tracker_id => 1 + } assert_response :success assert_select 'select.list_cf[name=?]', 'issue[custom_field_values][1]' do @@ -2014,7 +2475,10 @@ class IssuesControllerTest < Redmine::ControllerTest field.update_attribute :multiple, true @request.session[:user_id] = 2 - get :new, :project_id => 1, :tracker_id => 1 + get :new, :params => { + :project_id => 1, + :tracker_id => 1 + } assert_response :success assert_select 'select[name=?][multiple=multiple]', 'issue[custom_field_values][1][]' do @@ -2029,7 +2493,10 @@ class IssuesControllerTest < Redmine::ControllerTest :tracker_ids => [1], :is_for_all => true) @request.session[:user_id] = 2 - get :new, :project_id => 1, :tracker_id => 1 + get :new, :params => { + :project_id => 1, + :tracker_id => 1 + } assert_response :success assert_select 'select[name=?][multiple=multiple]', "issue[custom_field_values][#{field.id}][]" do @@ -2043,7 +2510,10 @@ class IssuesControllerTest < Redmine::ControllerTest field = IssueCustomField.create!(:name => 'Date', :field_format => 'date', :tracker_ids => [1], :is_for_all => true) @request.session[:user_id] = 2 - get :new, :project_id => 1, :tracker_id => 1 + get :new, :params => { + :project_id => 1, + :tracker_id => 1 + } assert_response :success assert_select 'input[name=?]', "issue[custom_field_values][#{field.id}]" @@ -2053,7 +2523,10 @@ class IssuesControllerTest < Redmine::ControllerTest field = IssueCustomField.create!(:name => 'Text', :field_format => 'text', :tracker_ids => [1], :is_for_all => true) @request.session[:user_id] = 2 - get :new, :project_id => 1, :tracker_id => 1 + get :new, :params => { + :project_id => 1, + :tracker_id => 1 + } assert_response :success assert_select 'textarea[name=?]', "issue[custom_field_values][#{field.id}]" @@ -2062,7 +2535,10 @@ class IssuesControllerTest < Redmine::ControllerTest def test_get_new_without_default_start_date_is_creation_date with_settings :default_issue_start_date_to_creation_date => 0 do @request.session[:user_id] = 2 - get :new, :project_id => 1, :tracker_id => 1 + get :new, :params => { + :project_id => 1, + :tracker_id => 1 + } assert_response :success assert_select 'input[name=?]', 'issue[start_date]' assert_select 'input[name=?][value]', 'issue[start_date]', 0 @@ -2072,7 +2548,10 @@ class IssuesControllerTest < Redmine::ControllerTest def test_get_new_with_default_start_date_is_creation_date with_settings :default_issue_start_date_to_creation_date => 1 do @request.session[:user_id] = 2 - get :new, :project_id => 1, :tracker_id => 1 + get :new, :params => { + :project_id => 1, + :tracker_id => 1 + } assert_response :success assert_select 'input[name=?][value=?]', 'issue[start_date]', Date.today.to_s @@ -2081,7 +2560,10 @@ class IssuesControllerTest < Redmine::ControllerTest def test_get_new_form_should_allow_attachment_upload @request.session[:user_id] = 2 - get :new, :project_id => 1, :tracker_id => 1 + get :new, :params => { + :project_id => 1, + :tracker_id => 1 + } assert_response :success assert_select 'form[id=issue-form][method=post][enctype="multipart/form-data"]' do @@ -2091,8 +2573,15 @@ class IssuesControllerTest < Redmine::ControllerTest def test_get_new_should_prefill_the_form_from_params @request.session[:user_id] = 2 - get :new, :project_id => 1, - :issue => {:tracker_id => 3, :description => 'Prefilled', :custom_field_values => {'2' => 'Custom field value'}} + get :new, :params => { + :project_id => 1, + :issue => { + :tracker_id => 3, + :description => 'Prefilled', + :custom_field_values => { + '2' => 'Custom field value'} + } + } assert_select 'select[name=?]', 'issue[tracker_id]' do assert_select 'option[value="3"][selected=selected]' @@ -2109,7 +2598,9 @@ class IssuesControllerTest < Redmine::ControllerTest WorkflowPermission.create!(:old_status_id => 1, :tracker_id => 1, :role_id => 1, :field_name => cf2.id.to_s, :rule => 'required') @request.session[:user_id] = 2 - get :new, :project_id => 1 + get :new, :params => { + :project_id => 1 + } assert_response :success assert_select 'label[for=issue_start_date]' do @@ -2134,7 +2625,9 @@ class IssuesControllerTest < Redmine::ControllerTest WorkflowPermission.create!(:old_status_id => 1, :tracker_id => 1, :role_id => 1, :field_name => cf2.id.to_s, :rule => 'readonly') @request.session[:user_id] = 2 - get :new, :project_id => 1 + get :new, :params => { + :project_id => 1 + } assert_response :success assert_select 'input[name=?]', 'issue[start_date]' @@ -2150,7 +2643,12 @@ class IssuesControllerTest < Redmine::ControllerTest end @request.session[:user_id] = 2 - get :new, :project_id => 1, :issue => {:status_id => 2} + get :new, :params => { + :project_id => 1, + :issue => { + :status_id => 2 + } + } assert_select 'select[name=?]', 'issue[tracker_id]', 0 assert_select 'select[name=?]', 'issue[status_id]' do assert_select 'option[value=?][selected=selected]', '2' @@ -2159,7 +2657,9 @@ class IssuesControllerTest < Redmine::ControllerTest def test_get_new_without_tracker_id @request.session[:user_id] = 2 - get :new, :project_id => 1 + get :new, :params => { + :project_id => 1 + } assert_response :success assert_select 'select[name=?]', 'issue[tracker_id]' do @@ -2171,7 +2671,9 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 IssueStatus.delete_all - get :new, :project_id => 1 + get :new, :params => { + :project_id => 1 + } assert_response 500 assert_select_error /No default issue/ end @@ -2180,14 +2682,18 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 Tracker.delete_all - get :new, :project_id => 1 + get :new, :params => { + :project_id => 1 + } assert_response 500 assert_select_error /No tracker/ end def test_new_with_invalid_project_id @request.session[:user_id] = 1 - get :new, :project_id => 'invalid' + get :new, :params => { + :project_id => 'invalid' + } assert_response 404 end @@ -2196,25 +2702,36 @@ class IssuesControllerTest < Redmine::ControllerTest t = Tracker.find(3) assert !t.disabled_core_fields.include?('parent_issue_id') - get :new, :project_id => 1, issue: { parent_issue_id: 1 } + get :new, :params => { + :project_id => 1, issue: { parent_issue_id: 1 + } + } assert_response :success assert_select 'option', text: /#{t.name}/, count: 1 t.core_fields = Tracker::CORE_FIELDS - ['parent_issue_id'] t.save! assert t.disabled_core_fields.include?('parent_issue_id') - get :new, :project_id => 1, issue: { parent_issue_id: 1 } + get :new, :params => { + :project_id => 1, issue: { parent_issue_id: 1 + } + } assert_response :success assert_select 'option', text: /#{t.name}/, count: 0 end def test_update_form_for_new_issue @request.session[:user_id] = 2 - xhr :post, :new, :project_id => 1, - :issue => {:tracker_id => 2, - :subject => 'This is the test_new issue', - :description => 'This is the description', - :priority_id => 5} + post :new, :params => { + :project_id => 1, + :issue => { + :tracker_id => 2, + :subject => 'This is the test_new issue', + :description => 'This is the description', + :priority_id => 5 + } + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type assert_include 'This is the test_new issue', response.body @@ -2227,10 +2744,14 @@ class IssuesControllerTest < Redmine::ControllerTest WorkflowTransition.create!(:role_id => 1, :tracker_id => 1, :old_status_id => 0, :new_status_id => 5) WorkflowTransition.create!(:role_id => 1, :tracker_id => 1, :old_status_id => 5, :new_status_id => 4) - post :new, :project_id => 1, - :issue => {:tracker_id => 1, - :status_id => 5, - :subject => 'This is an issue'} + post :new, :params => { + :project_id => 1, + :issue => { + :tracker_id => 1, + :status_id => 5, + :subject => 'This is an issue' + } + } assert_select 'select[name=?]', 'issue[status_id]' do assert_select 'option[value=?][selected=selected]', '5' @@ -2245,10 +2766,14 @@ class IssuesControllerTest < Redmine::ControllerTest tracker.update! :default_status_id => 2 tracker.generate_transitions! 2 => 1, :clear => true - post :new, :project_id => 1, - :issue => {:tracker_id => 2, - :status_id => 1}, - :was_default_status => 1 + post :new, :params => { + :project_id => 1, + :issue => { + :tracker_id => 2, + :status_id => 1 + }, + :was_default_status => 1 + } assert_response :success assert_select 'select[name=?]', 'issue[status_id]' do @@ -2261,9 +2786,13 @@ class IssuesControllerTest < Redmine::ControllerTest Project.find(1).update_attribute :default_version_id, version.id @request.session[:user_id] = 2 - post :new, :issue => {:project_id => 1, - :fixed_version_id => ''}, - :form_update_triggered_by => 'issue_project_id' + post :new, :params => { + :issue => { + :project_id => 1, + :fixed_version_id => '' + }, + :form_update_triggered_by => 'issue_project_id' + } assert_response :success assert_select 'select[name=?]', 'issue[project_id]' do @@ -2278,15 +2807,20 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Issue.count' do assert_no_difference 'Journal.count' do - post :create, :project_id => 1, - :issue => {:tracker_id => 3, - :status_id => 2, - :subject => 'This is the test_new issue', - :description => 'This is the description', - :priority_id => 5, - :start_date => '2010-11-07', - :estimated_hours => '', - :custom_field_values => {'2' => 'Value for field 2'}} + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => 3, + :status_id => 2, + :subject => 'This is the test_new issue', + :description => 'This is the description', + :priority_id => 5, + :start_date => '2010-11-07', + :estimated_hours => '', + :custom_field_values => { + '2' => 'Value for field 2'} + } + } end end assert_redirected_to :controller => 'issues', :action => 'show', :id => Issue.last.id @@ -2311,11 +2845,15 @@ class IssuesControllerTest < Redmine::ControllerTest with_settings :issue_group_assignment => '1' do @request.session[:user_id] = 2 assert_difference 'Issue.count' do - post :create, :project_id => project.id, - :issue => {:tracker_id => 3, - :status_id => 1, - :subject => 'This is the test_new_with_group_assignment issue', - :assigned_to_id => group.id} + post :create, :params => { + :project_id => project.id, + :issue => { + :tracker_id => 3, + :status_id => 1, + :subject => 'This is the test_new_with_group_assignment issue', + :assigned_to_id => group.id + } + } end end assert_redirected_to :controller => 'issues', :action => 'show', :id => Issue.last.id @@ -2329,14 +2867,19 @@ class IssuesControllerTest < Redmine::ControllerTest with_settings :default_issue_start_date_to_creation_date => 0 do @request.session[:user_id] = 2 assert_difference 'Issue.count' do - post :create, :project_id => 1, - :issue => {:tracker_id => 3, - :status_id => 2, - :subject => 'This is the test_new issue', - :description => 'This is the description', - :priority_id => 5, - :estimated_hours => '', - :custom_field_values => {'2' => 'Value for field 2'}} + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => 3, + :status_id => 2, + :subject => 'This is the test_new issue', + :description => 'This is the description', + :priority_id => 5, + :estimated_hours => '', + :custom_field_values => { + '2' => 'Value for field 2'} + } + } end assert_redirected_to :controller => 'issues', :action => 'show', :id => Issue.last.id @@ -2350,14 +2893,19 @@ class IssuesControllerTest < Redmine::ControllerTest with_settings :default_issue_start_date_to_creation_date => 1 do @request.session[:user_id] = 2 assert_difference 'Issue.count' do - post :create, :project_id => 1, - :issue => {:tracker_id => 3, - :status_id => 2, - :subject => 'This is the test_new issue', - :description => 'This is the description', - :priority_id => 5, - :estimated_hours => '', - :custom_field_values => {'2' => 'Value for field 2'}} + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => 3, + :status_id => 2, + :subject => 'This is the test_new issue', + :description => 'This is the description', + :priority_id => 5, + :estimated_hours => '', + :custom_field_values => { + '2' => 'Value for field 2'} + } + } end assert_redirected_to :controller => 'issues', :action => 'show', :id => Issue.last.id @@ -2370,9 +2918,15 @@ class IssuesControllerTest < Redmine::ControllerTest def test_post_create_and_continue @request.session[:user_id] = 2 assert_difference 'Issue.count' do - post :create, :project_id => 1, - :issue => {:tracker_id => 3, :subject => 'This is first issue', :priority_id => 5}, - :continue => '' + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => 3, + :subject => 'This is first issue', + :priority_id => 5 + }, + :continue => '' + } end issue = Issue.order('id DESC').first @@ -2385,11 +2939,15 @@ class IssuesControllerTest < Redmine::ControllerTest def test_post_create_without_custom_fields_param @request.session[:user_id] = 2 assert_difference 'Issue.count' do - post :create, :project_id => 1, - :issue => {:tracker_id => 1, - :subject => 'This is the test_new issue', - :description => 'This is the description', - :priority_id => 5} + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => 1, + :subject => 'This is the test_new issue', + :description => 'This is the description', + :priority_id => 5 + } + } end assert_redirected_to :controller => 'issues', :action => 'show', :id => Issue.last.id end @@ -2400,12 +2958,17 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Issue.count' do - post :create, :project_id => 1, - :issue => {:tracker_id => 1, - :subject => 'This is the test_new issue', - :description => 'This is the description', - :priority_id => 5, - :custom_field_values => {'1' => ['', 'MySQL', 'Oracle']}} + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => 1, + :subject => 'This is the test_new issue', + :description => 'This is the description', + :priority_id => 5, + :custom_field_values => { + '1' => ['', 'MySQL', 'Oracle']} + } + } end assert_response 302 issue = Issue.order('id DESC').first @@ -2418,12 +2981,17 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Issue.count' do - post :create, :project_id => 1, - :issue => {:tracker_id => 1, - :subject => 'This is the test_new issue', - :description => 'This is the description', - :priority_id => 5, - :custom_field_values => {'1' => ['']}} + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => 1, + :subject => 'This is the test_new issue', + :description => 'This is the description', + :priority_id => 5, + :custom_field_values => { + '1' => ['']} + } + } end assert_response 302 issue = Issue.order('id DESC').first @@ -2436,12 +3004,17 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Issue.count' do - post :create, :project_id => 1, - :issue => {:tracker_id => 1, - :subject => 'This is the test_new issue', - :description => 'This is the description', - :priority_id => 5, - :custom_field_values => {field.id.to_s => ['', '2', '3']}} + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => 1, + :subject => 'This is the test_new issue', + :description => 'This is the description', + :priority_id => 5, + :custom_field_values => { + field.id.to_s => ['', '2', '3']} + } + } end assert_response 302 issue = Issue.order('id DESC').first @@ -2454,11 +3027,15 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_no_difference 'Issue.count' do - post :create, :project_id => 1, - :issue => {:tracker_id => 1, - :subject => 'This is the test_new issue', - :description => 'This is the description', - :priority_id => 5} + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => 1, + :subject => 'This is the test_new issue', + :description => 'This is the description', + :priority_id => 5 + } + } end assert_response :success assert_select_error /Database cannot be blank/ @@ -2473,14 +3050,20 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_no_difference 'Issue.count' do - post :create, :project_id => 1, :issue => { - :tracker_id => 2, - :status_id => 1, - :subject => 'Test', - :start_date => '', - :due_date => '', - :custom_field_values => {cf1.id.to_s => '', cf2.id.to_s => ''} - } + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => 2, + :status_id => 1, + :subject => 'Test', + :start_date => '', + :due_date => '', + :custom_field_values => { + cf1.id.to_s => '', cf2.id.to_s => '' + } + + } + } assert_response :success end @@ -2497,14 +3080,20 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_no_difference 'Issue.count' do - post :create, :project_id => 1, :issue => { - :tracker_id => 2, - :status_id => 1, - :subject => 'Test', - :start_date => '', - :due_date => '', - :custom_field_values => {cf1.id.to_s => '', cf2.id.to_s => ['']} - } + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => 2, + :status_id => 1, + :subject => 'Test', + :start_date => '', + :due_date => '', + :custom_field_values => { + cf1.id.to_s => '', cf2.id.to_s => [''] + } + + } + } assert_response :success end @@ -2521,14 +3110,20 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Issue.count' do - post :create, :project_id => 1, :issue => { - :tracker_id => 2, - :status_id => 1, - :subject => 'Test', - :start_date => '2012-07-14', - :due_date => '2012-07-16', - :custom_field_values => {cf1.id.to_s => 'value1', cf2.id.to_s => 'value2'} - } + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => 2, + :status_id => 1, + :subject => 'Test', + :start_date => '2012-07-14', + :due_date => '2012-07-16', + :custom_field_values => { + cf1.id.to_s => 'value1', cf2.id.to_s => 'value2' + } + + } + } assert_response 302 end @@ -2546,11 +3141,15 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 issue = new_record(Issue) do - post :create, :project_id => 1, :issue => { - :tracker_id => 1, - :status_id => 1, - :subject => 'Test' - } + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => 1, + :status_id => 1, + :subject => 'Test' + + } + } assert_response 302 end assert_equal 3, issue.tracker_id @@ -2562,12 +3161,16 @@ class IssuesControllerTest < Redmine::ControllerTest with_settings :notified_events => %w(issue_added) do assert_difference 'Watcher.count', 2 do - post :create, :project_id => 1, - :issue => {:tracker_id => 1, - :subject => 'This is a new issue with watchers', - :description => 'This is the description', - :priority_id => 5, - :watcher_user_ids => ['2', '3']} + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => 1, + :subject => 'This is a new issue with watchers', + :description => 'This is the description', + :priority_id => 5, + :watcher_user_ids => ['2', '3'] + } + } end end issue = Issue.find_by_subject('This is a new issue with watchers') @@ -2587,10 +3190,14 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Issue.count' do - post :create, :project_id => 1, - :issue => {:tracker_id => 1, - :subject => 'This is a child issue', - :parent_issue_id => '2'} + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => 1, + :subject => 'This is a child issue', + :parent_issue_id => '2' + } + } assert_response 302 end issue = Issue.order('id DESC').first @@ -2601,10 +3208,14 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Issue.count' do - post :create, :project_id => 1, - :issue => {:tracker_id => 1, - :subject => 'This is a child issue', - :parent_issue_id => '#2'} + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => 1, + :subject => 'This is a child issue', + :parent_issue_id => '#2' + } + } assert_response 302 end issue = Issue.order('id DESC').first @@ -2615,10 +3226,14 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_no_difference 'Issue.count' do - post :create, :project_id => 1, - :issue => {:tracker_id => 1, - :subject => 'This is a child issue', - :parent_issue_id => '4'} + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => 1, + :subject => 'This is a child issue', + :parent_issue_id => '4' + } + } assert_response :success assert_select 'input[name=?][value=?]', 'issue[parent_issue_id]', '4' @@ -2630,10 +3245,14 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_no_difference 'Issue.count' do - post :create, :project_id => 1, - :issue => {:tracker_id => 1, - :subject => 'This is a child issue', - :parent_issue_id => '01ABC'} + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => 1, + :subject => 'This is a child issue', + :parent_issue_id => '01ABC' + } + } assert_response :success assert_select 'input[name=?][value=?]', 'issue[parent_issue_id]', '01ABC' @@ -2645,10 +3264,14 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Issue.count' do - post :create, :project_id => 1, - :issue => {:tracker_id => 1, - :subject => 'This is a private issue', - :is_private => '1'} + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => 1, + :subject => 'This is a private issue', + :is_private => '1' + } + } end issue = Issue.order('id DESC').first assert issue.is_private? @@ -2662,10 +3285,14 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Issue.count' do - post :create, :project_id => 1, - :issue => {:tracker_id => 1, - :subject => 'This is a private issue', - :is_private => '1'} + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => 1, + :subject => 'This is a private issue', + :is_private => '1' + } + } end issue = Issue.order('id DESC').first assert issue.is_private? @@ -2675,10 +3302,13 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Issue.count' do - post :create, - :issue => {:project_id => 3, - :tracker_id => 2, - :subject => 'Foo'} + post :create, :params => { + :issue => { + :project_id => 3, + :tracker_id => 2, + :subject => 'Foo' + } + } assert_response 302 end issue = Issue.order('id DESC').first @@ -2690,11 +3320,14 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Issue.count' do - post :create, - :issue => {:project_id => 3, - :tracker_id => 2, - :subject => 'Foo'}, - :continue => '1' + post :create, :params => { + :issue => { + :project_id => 3, + :tracker_id => 2, + :subject => 'Foo' + }, + :continue => '1' + } assert_redirected_to '/issues/new?issue%5Bproject_id%5D=3&issue%5Btracker_id%5D=2' end end @@ -2705,10 +3338,13 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_no_difference 'Issue.count' do - post :create, - :issue => {:project_id => 3, - :tracker_id => 2, - :subject => 'Foo'} + post :create, :params => { + :issue => { + :project_id => 3, + :tracker_id => 2, + :subject => 'Foo' + } + } assert_response 422 end end @@ -2716,10 +3352,13 @@ class IssuesControllerTest < Redmine::ControllerTest def test_create_without_project_id_with_failure_should_not_set_project @request.session[:user_id] = 2 - post :create, - :issue => {:project_id => 3, - :tracker_id => 2, - :subject => ''} + post :create, :params => { + :issue => { + :project_id => 3, + :tracker_id => 2, + :subject => '' + } + } assert_response :success # no project menu assert_select '#main-menu a.overview', 0 @@ -2730,13 +3369,18 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 with_settings :notified_events => %w(issue_added) do assert_difference 'Issue.count' do - post :create, :project_id => 1, - :issue => {:tracker_id => 3, - :subject => 'This is the test_new issue', - :description => 'This is the description', - :priority_id => 5, - :estimated_hours => '', - :custom_field_values => {'2' => 'Value for field 2'}} + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => 3, + :subject => 'This is the test_new issue', + :description => 'This is the description', + :priority_id => 5, + :estimated_hours => '', + :custom_field_values => { + '2' => 'Value for field 2'} + } + } end assert_redirected_to :controller => 'issues', :action => 'show', :id => Issue.last.id @@ -2746,13 +3390,16 @@ class IssuesControllerTest < Redmine::ControllerTest def test_post_create_should_preserve_fields_values_on_validation_failure @request.session[:user_id] = 2 - post :create, :project_id => 1, - :issue => {:tracker_id => 1, - # empty subject - :subject => '', - :description => 'This is a description', - :priority_id => 6, - :custom_field_values => {'1' => 'Oracle', '2' => 'Value for field 2'}} + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => 1, + :subject => '', # empty subject + :description => 'This is a description', + :priority_id => 6, + :custom_field_values => {'1' => 'Oracle', '2' => 'Value for field 2'} + } + } assert_response :success assert_select 'textarea[name=?]', 'issue[description]', :text => 'This is a description' @@ -2770,9 +3417,13 @@ class IssuesControllerTest < Redmine::ControllerTest assert !User.find(8).member_of?(Project.find(1)) @request.session[:user_id] = 2 - post :create, :project_id => 1, - :issue => {:tracker_id => 1, - :watcher_user_ids => ['3', '8']} + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => 1, + :watcher_user_ids => ['3', '8'] + } + } assert_response :success assert_select 'input[name=?][value="2"]:not(checked)', 'issue[watcher_user_ids][]' @@ -2783,7 +3434,12 @@ class IssuesControllerTest < Redmine::ControllerTest def test_post_create_should_ignore_non_safe_attributes @request.session[:user_id] = 2 assert_nothing_raised do - post :create, :project_id => 1, :issue => { :tracker => "A param can not be a Tracker" } + post :create, :params => { + :project_id => 1, + :issue => { + :tracker => "A param can not be a Tracker" + } + } end end @@ -2794,9 +3450,17 @@ class IssuesControllerTest < Redmine::ControllerTest assert_difference 'Issue.count' do assert_difference 'Attachment.count' do assert_no_difference 'Journal.count' do - post :create, :project_id => 1, - :issue => { :tracker_id => '1', :subject => 'With attachment' }, - :attachments => {'1' => {'file' => uploaded_test_file('testfile.txt', 'text/plain'), 'description' => 'test file'}} + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => '1', + :subject => 'With attachment' + }, + :attachments => { + '1' => { + 'file' => uploaded_test_file('testfile.txt', 'text/plain'), 'description' => 'test file'} + } + } end end end @@ -2821,9 +3485,17 @@ class IssuesControllerTest < Redmine::ControllerTest with_settings :notified_events => %w(issue_added) do assert_difference 'Issue.count' do - post :create, :project_id => 1, - :issue => { :tracker_id => '1', :subject => 'With attachment' }, - :attachments => {'1' => {'file' => uploaded_test_file('testfile.txt', 'text/plain'), 'description' => 'test file'}} + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => '1', + :subject => 'With attachment' + }, + :attachments => { + '1' => { + 'file' => uploaded_test_file('testfile.txt', 'text/plain'), 'description' => 'test file'} + } + } end end @@ -2839,9 +3511,17 @@ class IssuesControllerTest < Redmine::ControllerTest assert_no_difference 'Issue.count' do assert_difference 'Attachment.count' do - post :create, :project_id => 1, - :issue => { :tracker_id => '1', :subject => '' }, - :attachments => {'1' => {'file' => uploaded_test_file('testfile.txt', 'text/plain'), 'description' => 'test file'}} + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => '1', + :subject => '' + }, + :attachments => { + '1' => { + 'file' => uploaded_test_file('testfile.txt', 'text/plain'), 'description' => 'test file'} + } + } assert_response :success end end @@ -2862,9 +3542,17 @@ class IssuesControllerTest < Redmine::ControllerTest assert_no_difference 'Issue.count' do assert_no_difference 'Attachment.count' do - post :create, :project_id => 1, - :issue => { :tracker_id => '1', :subject => '' }, - :attachments => {'p0' => {'token' => attachment.token}} + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => '1', + :subject => '' + }, + :attachments => { + 'p0' => { + 'token' => attachment.token} + } + } assert_response :success end end @@ -2880,9 +3568,17 @@ class IssuesControllerTest < Redmine::ControllerTest assert_difference 'Issue.count' do assert_no_difference 'Attachment.count' do - post :create, :project_id => 1, - :issue => { :tracker_id => '1', :subject => 'Saved attachments' }, - :attachments => {'p0' => {'token' => attachment.token}} + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => '1', + :subject => 'Saved attachments' + }, + :attachments => { + 'p0' => { + 'token' => attachment.token} + } + } assert_response 302 end end @@ -2902,7 +3598,9 @@ class IssuesControllerTest < Redmine::ControllerTest test "without workflow privilege #new should propose default status only" do setup_without_workflow_privilege - get :new, :project_id => 1 + get :new, :params => { + :project_id => 1 + } assert_response :success assert_select 'select[name=?]', 'issue[status_id]' do @@ -2914,10 +3612,14 @@ class IssuesControllerTest < Redmine::ControllerTest test "without workflow privilege #create should accept default status" do setup_without_workflow_privilege assert_difference 'Issue.count' do - post :create, :project_id => 1, - :issue => {:tracker_id => 1, - :subject => 'This is an issue', - :status_id => 1} + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => 1, + :subject => 'This is an issue', + :status_id => 1 + } + } end issue = Issue.order('id').last assert_not_nil issue.default_status @@ -2927,10 +3629,14 @@ class IssuesControllerTest < Redmine::ControllerTest test "without workflow privilege #create should ignore unauthorized status" do setup_without_workflow_privilege assert_difference 'Issue.count' do - post :create, :project_id => 1, - :issue => {:tracker_id => 1, - :subject => 'This is an issue', - :status_id => 3} + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => 1, + :subject => 'This is an issue', + :status_id => 3 + } + } end issue = Issue.order('id').last assert_not_nil issue.default_status @@ -2940,7 +3646,13 @@ class IssuesControllerTest < Redmine::ControllerTest test "without workflow privilege #update should ignore status change" do setup_without_workflow_privilege assert_difference 'Journal.count' do - put :update, :id => 1, :issue => {:status_id => 3, :notes => 'just trying'} + put :update, :params => { + :id => 1, + :issue => { + :status_id => 3, + :notes => 'just trying' + } + } end assert_equal 1, Issue.find(1).status_id end @@ -2948,9 +3660,14 @@ class IssuesControllerTest < Redmine::ControllerTest test "without workflow privilege #update ignore attributes changes" do setup_without_workflow_privilege assert_difference 'Journal.count' do - put :update, :id => 1, - :issue => {:subject => 'changed', :assigned_to_id => 2, - :notes => 'just trying'} + put :update, :params => { + :id => 1, + :issue => { + :subject => 'changed', + :assigned_to_id => 2, + :notes => 'just trying' + } + } end issue = Issue.find(1) assert_equal "Cannot print recipes", issue.subject @@ -2976,7 +3693,13 @@ class IssuesControllerTest < Redmine::ControllerTest test "with workflow privilege and :edit_issues permission should accept authorized status" do setup_with_workflow_privilege_and_edit_issues_permission assert_difference 'Journal.count' do - put :update, :id => 1, :issue => {:status_id => 3, :notes => 'just trying'} + put :update, :params => { + :id => 1, + :issue => { + :status_id => 3, + :notes => 'just trying' + } + } end assert_equal 3, Issue.find(1).status_id end @@ -2984,7 +3707,13 @@ class IssuesControllerTest < Redmine::ControllerTest test "with workflow privilege and :edit_issues permission should ignore unauthorized status" do setup_with_workflow_privilege_and_edit_issues_permission assert_difference 'Journal.count' do - put :update, :id => 1, :issue => {:status_id => 2, :notes => 'just trying'} + put :update, :params => { + :id => 1, + :issue => { + :status_id => 2, + :notes => 'just trying' + } + } end assert_equal 1, Issue.find(1).status_id end @@ -2992,9 +3721,14 @@ class IssuesControllerTest < Redmine::ControllerTest test "with workflow privilege and :edit_issues permission should accept authorized attributes changes" do setup_with_workflow_privilege_and_edit_issues_permission assert_difference 'Journal.count' do - put :update, :id => 1, - :issue => {:subject => 'changed', :assigned_to_id => 2, - :notes => 'just trying'} + put :update, :params => { + :id => 1, + :issue => { + :subject => 'changed', + :assigned_to_id => 2, + :notes => 'just trying' + } + } end issue = Issue.find(1) assert_equal "changed", issue.subject @@ -3005,7 +3739,10 @@ class IssuesControllerTest < Redmine::ControllerTest orig = Issue.find(1) @request.session[:user_id] = 2 - get :new, :project_id => 1, :copy_from => orig.id + get :new, :params => { + :project_id => 1, + :copy_from => orig.id + } assert_response :success assert_select 'form[id=issue-form][action="/projects/ecookbook/issues"]' do @@ -3022,7 +3759,10 @@ class IssuesControllerTest < Redmine::ControllerTest user = setup_user_with_copy_but_not_add_permission @request.session[:user_id] = user.id - get :new, :project_id => 1, :copy_from => 1 + get :new, :params => { + :project_id => 1, + :copy_from => 1 + } assert_response :success assert_select 'select[name=?]', 'issue[project_id]' do @@ -3035,7 +3775,10 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 issue = Issue.find(3) assert issue.attachments.count > 0 - get :new, :project_id => 1, :copy_from => 3 + get :new, :params => { + :project_id => 1, + :copy_from => 3 + } assert_select 'input[name=copy_attachments][type=checkbox][checked=checked][value="1"]' end @@ -3044,7 +3787,10 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 issue = Issue.find(3) issue.attachments.delete_all - get :new, :project_id => 1, :copy_from => 3 + get :new, :params => { + :project_id => 1, + :copy_from => 3 + } assert_select 'input[name=copy_attachments]', 0 end @@ -3052,7 +3798,10 @@ class IssuesControllerTest < Redmine::ControllerTest def test_new_as_copy_should_preserve_parent_id @request.session[:user_id] = 2 issue = Issue.generate!(:parent_issue_id => 2) - get :new, :project_id => 1, :copy_from => issue.id + get :new, :params => { + :project_id => 1, + :copy_from => issue.id + } assert_select 'input[name=?][value="2"]', 'issue[parent_issue_id]' end @@ -3060,7 +3809,10 @@ class IssuesControllerTest < Redmine::ControllerTest def test_new_as_copy_with_subtasks_should_show_copy_subtasks_checkbox @request.session[:user_id] = 2 issue = Issue.generate_with_descendants! - get :new, :project_id => 1, :copy_from => issue.id + get :new, :params => { + :project_id => 1, + :copy_from => issue.id + } assert_select 'input[type=checkbox][name=copy_subtasks][checked=checked][value="1"]' end @@ -3069,7 +3821,10 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 user = User.generate! Watcher.create!(:watchable => Issue.find(1), :user => user) - get :new, :project_id => 1, :copy_from => 1 + get :new, :params => { + :project_id => 1, + :copy_from => 1 + } assert_select 'input[type=checkbox][name=?][checked=checked]', 'issue[watcher_user_ids][]', 1 assert_select 'input[type=checkbox][name=?][checked=checked][value=?]', 'issue[watcher_user_ids][]', user.id.to_s @@ -3077,15 +3832,26 @@ class IssuesControllerTest < Redmine::ControllerTest def test_new_as_copy_with_invalid_issue_should_respond_with_404 @request.session[:user_id] = 2 - get :new, :project_id => 1, :copy_from => 99999 + get :new, :params => { + :project_id => 1, + :copy_from => 99999 + } assert_response 404 end def test_create_as_copy_on_different_project @request.session[:user_id] = 2 assert_difference 'Issue.count' do - post :create, :project_id => 1, :copy_from => 1, - :issue => {:project_id => '2', :tracker_id => '3', :status_id => '1', :subject => 'Copy'} + post :create, :params => { + :project_id => 1, + :copy_from => 1, + :issue => { + :project_id => '2', + :tracker_id => '3', + :status_id => '1', + :subject => 'Copy' + } + } end issue = Issue.order('id DESC').first assert_redirected_to "/issues/#{issue.id}" @@ -3101,9 +3867,16 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Issue.count' do - post :create, :project_id => 1, :copy_from => copied.id, - :issue => {:project_id => '1', :tracker_id => '1', :status_id => '1'}, - :was_default_status => '1' + post :create, :params => { + :project_id => 1, + :copy_from => copied.id, + :issue => { + :project_id => '1', + :tracker_id => '1', + :status_id => '1' + }, + :was_default_status => '1' + } end issue = Issue.order('id DESC').first assert_equal 1, issue.status_id @@ -3119,8 +3892,13 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 3 assert_no_difference 'Issue.count' do - post :create, :project_id => 1, :copy_from => issue.id, - :issue => {:project_id => '1'} + post :create, :params => { + :project_id => 1, + :copy_from => issue.id, + :issue => { + :project_id => '1' + } + } end assert_select_error 'Tracker is invalid' end @@ -3132,10 +3910,17 @@ class IssuesControllerTest < Redmine::ControllerTest assert count > 0 assert_difference 'Issue.count' do assert_difference 'Attachment.count', count do - post :create, :project_id => 1, :copy_from => 3, - :issue => {:project_id => '1', :tracker_id => '3', - :status_id => '1', :subject => 'Copy with attachments'}, - :copy_attachments => '1' + post :create, :params => { + :project_id => 1, + :copy_from => 3, + :issue => { + :project_id => '1', + :tracker_id => '3', + :status_id => '1', + :subject => 'Copy with attachments' + }, + :copy_attachments => '1' + } end end copy = Issue.order('id DESC').first @@ -3150,9 +3935,16 @@ class IssuesControllerTest < Redmine::ControllerTest assert count > 0 assert_difference 'Issue.count' do assert_no_difference 'Attachment.count' do - post :create, :project_id => 1, :copy_from => 3, - :issue => {:project_id => '1', :tracker_id => '3', - :status_id => '1', :subject => 'Copy with attachments'} + post :create, :params => { + :project_id => 1, + :copy_from => 3, + :issue => { + :project_id => '1', + :tracker_id => '3', + :status_id => '1', + :subject => 'Copy with attachments' + } + } end end copy = Issue.order('id DESC').first @@ -3166,13 +3958,23 @@ class IssuesControllerTest < Redmine::ControllerTest assert count > 0 assert_difference 'Issue.count' do assert_difference 'Attachment.count', count + 1 do - post :create, :project_id => 1, :copy_from => 3, - :issue => {:project_id => '1', :tracker_id => '3', - :status_id => '1', :subject => 'Copy with attachments'}, - :copy_attachments => '1', - :attachments => {'1' => - {'file' => uploaded_test_file('testfile.txt', 'text/plain'), - 'description' => 'test file'}} + post :create, :params => { + :project_id => 1, + :copy_from => 3, + :issue => { + :project_id => '1', + :tracker_id => '3', + :status_id => '1', + :subject => 'Copy with attachments' + }, + :copy_attachments => '1', + :attachments => { + '1' => { + 'file' => uploaded_test_file('testfile.txt', 'text/plain'), + 'description' => 'test file' + } + } + } end end copy = Issue.order('id DESC').first @@ -3183,9 +3985,17 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Issue.count' do assert_difference 'IssueRelation.count' do - post :create, :project_id => 1, :copy_from => 1, :link_copy => '1', - :issue => {:project_id => '1', :tracker_id => '3', - :status_id => '1', :subject => 'Copy'} + post :create, :params => { + :project_id => 1, + :copy_from => 1, + :link_copy => '1', + :issue => { + :project_id => '1', + :tracker_id => '3', + :status_id => '1', + :subject => 'Copy' + } + } end end copy = Issue.order('id DESC').first @@ -3196,8 +4006,13 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Issue.count' do assert_no_difference 'IssueRelation.count' do - post :create, :project_id => 1, :copy_from => 1, - :issue => {:subject => 'Copy'} + post :create, :params => { + :project_id => 1, + :copy_from => 1, + :issue => { + :subject => 'Copy' + } + } end end end @@ -3207,8 +4022,13 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Issue.count' do assert_difference 'IssueRelation.count' do - post :create, :project_id => 1, :copy_from => 1, - :issue => {:subject => 'Copy'} + post :create, :params => { + :project_id => 1, + :copy_from => 1, + :issue => { + :subject => 'Copy' + } + } end end end @@ -3219,8 +4039,14 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Issue.count' do assert_no_difference 'IssueRelation.count' do - post :create, :project_id => 1, :copy_from => 1, :link_copy => '1', - :issue => {:subject => 'Copy'} + post :create, :params => { + :project_id => 1, + :copy_from => 1, + :link_copy => '1', + :issue => { + :subject => 'Copy' + } + } end end end @@ -3231,10 +4057,17 @@ class IssuesControllerTest < Redmine::ControllerTest issue = Issue.generate_with_descendants! count = issue.descendants.count assert_difference 'Issue.count', count + 1 do - post :create, :project_id => 1, :copy_from => issue.id, - :issue => {:project_id => '1', :tracker_id => '3', - :status_id => '1', :subject => 'Copy with subtasks'}, - :copy_subtasks => '1' + post :create, :params => { + :project_id => 1, + :copy_from => issue.id, + :issue => { + :project_id => '1', + :tracker_id => '3', + :status_id => '1', + :subject => 'Copy with subtasks' + }, + :copy_subtasks => '1' + } end copy = Issue.where(:parent_id => nil).order('id DESC').first assert_equal count, copy.descendants.count @@ -3247,10 +4080,19 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 1 assert_difference 'Issue.count', 2 do - post :create, :project_id => 'ecookbook', :copy_from => issue.id, - :issue => {:project_id => '2', :tracker_id => 1, :status_id => '1', - :subject => 'Copy with subtasks', :custom_field_values => {'2' => 'Foo'}}, - :copy_subtasks => '1' + post :create, :params => { + :project_id => 'ecookbook', + :copy_from => issue.id, + :issue => { + :project_id => '2', + :tracker_id => 1, + :status_id => '1', + :subject => 'Copy with subtasks', + :custom_field_values => { + '2' => 'Foo'} + }, + :copy_subtasks => '1' + } end child_copy, issue_copy = Issue.order(:id => :desc).limit(2).to_a @@ -3263,9 +4105,16 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 issue = Issue.generate_with_descendants! assert_difference 'Issue.count', 1 do - post :create, :project_id => 1, :copy_from => 3, - :issue => {:project_id => '1', :tracker_id => '3', - :status_id => '1', :subject => 'Copy with subtasks'} + post :create, :params => { + :project_id => 1, + :copy_from => 3, + :issue => { + :project_id => '1', + :tracker_id => '3', + :status_id => '1', + :subject => 'Copy with subtasks' + } + } end copy = Issue.where(:parent_id => nil).order('id DESC').first assert_equal 0, copy.descendants.count @@ -3273,8 +4122,16 @@ class IssuesControllerTest < Redmine::ControllerTest def test_create_as_copy_with_failure @request.session[:user_id] = 2 - post :create, :project_id => 1, :copy_from => 1, - :issue => {:project_id => '2', :tracker_id => '3', :status_id => '1', :subject => ''} + post :create, :params => { + :project_id => 1, + :copy_from => 1, + :issue => { + :project_id => '2', + :tracker_id => '3', + :status_id => '1', + :subject => '' + } + } assert_response :success @@ -3292,8 +4149,16 @@ class IssuesControllerTest < Redmine::ControllerTest assert !User.find(2).member_of?(Project.find(4)) assert_difference 'Issue.count' do - post :create, :project_id => 1, :copy_from => 1, - :issue => {:project_id => '4', :tracker_id => '3', :status_id => '1', :subject => 'Copy'} + post :create, :params => { + :project_id => 1, + :copy_from => 1, + :issue => { + :project_id => '4', + :tracker_id => '3', + :status_id => '1', + :subject => 'Copy' + } + } end issue = Issue.order('id DESC').first assert_equal 1, issue.project_id @@ -3301,7 +4166,9 @@ class IssuesControllerTest < Redmine::ControllerTest def test_get_edit @request.session[:user_id] = 2 - get :edit, :id => 1 + get :edit, :params => { + :id => 1 + } assert_response :success assert_select 'select[name=?]', 'issue[project_id]' @@ -3316,7 +4183,9 @@ class IssuesControllerTest < Redmine::ControllerTest WorkflowPermission.create!(:role_id => 1, :tracker_id => 1, :old_status_id => 1, :field_name => 'project_id', :rule => 'readonly') @request.session[:user_id] = 2 - get :edit, :id => 1 + get :edit, :params => { + :id => 1 + } assert_response :success assert_select 'select[name=?]', 'issue[project_id]', 0 end @@ -3326,7 +4195,12 @@ class IssuesControllerTest < Redmine::ControllerTest issue = Issue.generate!(:project_id => 2) @request.session[:user_id] = 2 - get :edit, :id => issue.id, :issue => {:project_id => 1} + get :edit, :params => { + :id => issue.id, + :issue => { + :project_id => 1 + } + } assert_response :success assert_select 'select[name=?]', 'issue[project_id]' end @@ -3335,7 +4209,9 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 Role.find_by_name('Manager').update_attribute :permissions, [:view_issues, :edit_issues, :log_time] - get :edit, :id => 1 + get :edit, :params => { + :id => 1 + } assert_select 'input[name=?]', 'time_entry[hours]' end @@ -3343,14 +4219,26 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 Role.find_by_name('Manager').remove_permission! :log_time - get :edit, :id => 1 + get :edit, :params => { + :id => 1 + } assert_select 'input[name=?]', 'time_entry[hours]', 0 end def test_get_edit_with_params @request.session[:user_id] = 2 - get :edit, :id => 1, :issue => { :status_id => 5, :priority_id => 7 }, - :time_entry => { :hours => '2.5', :comments => 'test_get_edit_with_params', :activity_id => 10 } + get :edit, :params => { + :id => 1, + :issue => { + :status_id => 5, + :priority_id => 7 + }, + :time_entry => { + :hours => '2.5', + :comments => 'test_get_edit_with_params', + :activity_id => 10 + } + } assert_response :success assert_select 'select[name=?]', 'issue[status_id]' do @@ -3376,7 +4264,9 @@ class IssuesControllerTest < Redmine::ControllerTest issue.save! @request.session[:user_id] = 2 - get :edit, :id => 1 + get :edit, :params => { + :id => 1 + } assert_response :success assert_select 'select[name=?][multiple=multiple]', 'issue[custom_field_values][1][]' do @@ -3389,11 +4279,16 @@ class IssuesControllerTest < Redmine::ControllerTest def test_update_form_for_existing_issue @request.session[:user_id] = 2 - xhr :patch, :edit, :id => 1, - :issue => {:tracker_id => 2, - :subject => 'This is the test_new issue', - :description => 'This is the description', - :priority_id => 5} + patch :edit, :params => { + :id => 1, + :issue => { + :tracker_id => 2, + :subject => 'This is the test_new issue', + :description => 'This is the description', + :priority_id => 5 + } + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type @@ -3402,7 +4297,12 @@ class IssuesControllerTest < Redmine::ControllerTest def test_update_form_for_existing_issue_should_keep_issue_author @request.session[:user_id] = 3 - patch :edit, :id => 1, :issue => {:subject => 'Changed'} + patch :edit, :params => { + :id => 1, + :issue => { + :subject => 'Changed' + } + } assert_response :success assert_equal User.find(2), Issue.find(1).author @@ -3415,10 +4315,14 @@ class IssuesControllerTest < Redmine::ControllerTest WorkflowTransition.create!(:role_id => 1, :tracker_id => 2, :old_status_id => 2, :new_status_id => 5) WorkflowTransition.create!(:role_id => 1, :tracker_id => 2, :old_status_id => 5, :new_status_id => 4) - patch :edit, :id => 2, - :issue => {:tracker_id => 2, - :status_id => 5, - :subject => 'This is an issue'} + patch :edit, :params => { + :id => 2, + :issue => { + :tracker_id => 2, + :status_id => 5, + :subject => 'This is an issue' + } + } assert_select 'select[name=?]', 'issue[status_id]' do assert_select 'option[value="1"]' @@ -3430,12 +4334,16 @@ class IssuesControllerTest < Redmine::ControllerTest def test_update_form_for_existing_issue_with_project_change @request.session[:user_id] = 2 - patch :edit, :id => 1, - :issue => {:project_id => 2, - :tracker_id => 2, - :subject => 'This is the test_new issue', - :description => 'This is the description', - :priority_id => 5} + patch :edit, :params => { + :id => 1, + :issue => { + :project_id => 2, + :tracker_id => 2, + :subject => 'This is the test_new issue', + :description => 'This is the description', + :priority_id => 5 + } + } assert_response :success assert_select 'select[name=?]', 'issue[project_id]' do assert_select 'option[value="2"][selected=selected]' @@ -3454,8 +4362,13 @@ class IssuesControllerTest < Redmine::ControllerTest issue = Issue.generate!(:project => source, :category => source_category) @request.session[:user_id] = 1 - patch :edit, :id => issue.id, - :issue => {:project_id => target.id, :category_id => source_category.id} + patch :edit, :params => { + :id => issue.id, + :issue => { + :project_id => target.id, + :category_id => source_category.id + } + } assert_response :success assert_select 'select[name=?]', 'issue[category_id]' do @@ -3468,7 +4381,9 @@ class IssuesControllerTest < Redmine::ControllerTest WorkflowTransition.delete_all WorkflowTransition.create!(:role_id => 1, :tracker_id => 2, :old_status_id => 2, :new_status_id => 3) - patch :edit, :id => 2 + patch :edit, :params => { + :id => 2 + } assert_response :success assert_select 'select[name=?]', 'issue[status_id]' do assert_select 'option[value="2"]' @@ -3485,7 +4400,12 @@ class IssuesControllerTest < Redmine::ControllerTest assert_difference('Journal.count') do assert_difference('JournalDetail.count') do - put :update, :id => 1, :issue => {:subject => 'New subject'} + put :update, :params => { + :id => 1, + :issue => { + :subject => 'New subject' + } + } end end assert_redirected_to :action => 'show', :id => '1' @@ -3502,11 +4422,15 @@ class IssuesControllerTest < Redmine::ControllerTest with_settings :notified_events => %w(issue_updated) do assert_difference('Journal.count') do assert_difference('JournalDetail.count', 3) do - put :update, :id => 1, :issue => {:project_id => '2', - :tracker_id => '1', # no change - :priority_id => '6', - :category_id => '3' - } + put :update, :params => { + :id => 1, + :issue => { + :project_id => '2', + :tracker_id => '1', # no change + :priority_id => '6', + :category_id => '3' + } + } end end end @@ -3529,7 +4453,12 @@ class IssuesControllerTest < Redmine::ControllerTest issue = Issue.generate! @request.session[:user_id] = 1 - put :update, :id => issue.id, :issue => {:project_id => target.id} + put :update, :params => { + :id => issue.id, + :issue => { + :project_id => target.id + } + } assert_response 302 end @@ -3540,10 +4469,15 @@ class IssuesControllerTest < Redmine::ControllerTest with_settings :notified_events => %w(issue_updated) do assert_difference('Journal.count') do assert_difference('JournalDetail.count', 3) do - put :update, :id => 1, :issue => {:project_id => '1', - :tracker_id => '2', - :priority_id => '6' - } + put :update, :params => { + :id => 1, + :issue => { + :project_id => '1', + :tracker_id => '2', + :priority_id => '6' + + } + } end end end @@ -3568,11 +4502,15 @@ class IssuesControllerTest < Redmine::ControllerTest with_settings :notified_events => %w(issue_updated) do assert_difference('Journal.count') do assert_difference('JournalDetail.count', 3) do - put :update, :id => 1, :issue => {:subject => 'Custom field change', - :priority_id => '6', - :category_id => '1', # no change - :custom_field_values => { '2' => 'New custom value' } - } + put :update, :params => { + :id => 1, + :issue => { + :subject => 'Custom field change', + :priority_id => '6', + :category_id => '1', # no change + :custom_field_values => { '2' => 'New custom value' } + } + } end end end @@ -3595,10 +4533,15 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference('Journal.count') do assert_difference('JournalDetail.count', 3) do - put :update, :id => 1, - :issue => { - :subject => 'Custom field change', - :custom_field_values => { '1' => ['', 'Oracle', 'PostgreSQL'] } + put :update, :params => { + :id => 1, + :issue => { + :subject => 'Custom field change', + :custom_field_values => { + '1' => ['', 'Oracle', 'PostgreSQL'] + } + + } } end end @@ -3613,10 +4556,19 @@ class IssuesControllerTest < Redmine::ControllerTest with_settings :notified_events => %w(issue_updated) do assert_difference('TimeEntry.count', 0) do - put :update, - :id => 1, - :issue => { :status_id => 2, :assigned_to_id => 3, :notes => 'Assigned to dlopper' }, - :time_entry => { :hours => '', :comments => '', :activity_id => TimeEntryActivity.first } + put :update, :params => { + :id => 1, + :issue => { + :status_id => 2, + :assigned_to_id => 3, + :notes => 'Assigned to dlopper' + }, + :time_entry => { + :hours => '', + :comments => '', + :activity_id => TimeEntryActivity.first + } + } end end assert_redirected_to :action => 'show', :id => '1' @@ -3637,9 +4589,12 @@ class IssuesControllerTest < Redmine::ControllerTest with_settings :notified_events => %w(issue_updated) do # anonymous user - put :update, - :id => 1, - :issue => { :notes => notes } + put :update, :params => { + :id => 1, + :issue => { + :notes => notes + } + } end assert_redirected_to :action => 'show', :id => '1' j = Journal.order('id DESC').first @@ -3656,7 +4611,13 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Journal.count' do - put :update, :id => 1, :issue => {:notes => notes, :private_notes => '1'} + put :update, :params => { + :id => 1, + :issue => { + :notes => notes, + :private_notes => '1' + } + } assert_redirected_to :action => 'show', :id => '1' end @@ -3670,7 +4631,14 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Journal.count', 2 do - put :update, :id => 1, :issue => {:subject => 'New subject', :notes => notes, :private_notes => '1'} + put :update, :params => { + :id => 1, + :issue => { + :subject => 'New subject', + :notes => notes, + :private_notes => '1' + } + } assert_redirected_to :action => 'show', :id => '1' end @@ -3689,10 +4657,17 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 spent_hours_before = Issue.find(1).spent_hours assert_difference('TimeEntry.count') do - put :update, - :id => 1, - :issue => { :notes => '2.5 hours added' }, - :time_entry => { :hours => '2.5', :comments => 'test_put_update_with_note_and_spent_time', :activity_id => TimeEntryActivity.first.id } + put :update, :params => { + :id => 1, + :issue => { + :notes => '2.5 hours added' + }, + :time_entry => { + :hours => '2.5', + :comments => 'test_put_update_with_note_and_spent_time', + :activity_id => TimeEntryActivity.first.id + } + } end assert_redirected_to :action => 'show', :id => '1' @@ -3714,10 +4689,18 @@ class IssuesControllerTest < Redmine::ControllerTest assert !parent.visible?(User.find(3)) @request.session[:user_id] = 3 - get :edit, :id => issue.id + get :edit, :params => { + :id => issue.id + } assert_select 'input[name=?][value=?]', 'issue[parent_issue_id]', parent.id.to_s - put :update, :id => issue.id, :issue => {:subject => 'New subject', :parent_issue_id => parent.id.to_s} + put :update, :params => { + :id => issue.id, + :issue => { + :subject => 'New subject', + :parent_issue_id => parent.id.to_s + } + } assert_response 302 assert_equal parent, issue.parent end @@ -3732,9 +4715,16 @@ class IssuesControllerTest < Redmine::ControllerTest with_settings :notified_events => %w(issue_updated) do # anonymous user assert_difference 'Attachment.count' do - put :update, :id => 1, - :issue => {:notes => ''}, - :attachments => {'1' => {'file' => uploaded_test_file('testfile.txt', 'text/plain'), 'description' => 'test file'}} + put :update, :params => { + :id => 1, + :issue => { + :notes => '' + }, + :attachments => { + '1' => { + 'file' => uploaded_test_file('testfile.txt', 'text/plain'), 'description' => 'test file'} + } + } end end @@ -3765,9 +4755,16 @@ class IssuesControllerTest < Redmine::ControllerTest assert_no_difference 'Journal.count' do assert_difference 'Attachment.count' do - put :update, :id => 1, - :issue => { :subject => '' }, - :attachments => {'1' => {'file' => uploaded_test_file('testfile.txt', 'text/plain'), 'description' => 'test file'}} + put :update, :params => { + :id => 1, + :issue => { + :subject => '' + }, + :attachments => { + '1' => { + 'file' => uploaded_test_file('testfile.txt', 'text/plain'), 'description' => 'test file'} + } + } assert_response :success end end @@ -3788,9 +4785,16 @@ class IssuesControllerTest < Redmine::ControllerTest assert_no_difference 'Journal.count' do assert_no_difference 'Attachment.count' do - put :update, :id => 1, - :issue => { :subject => '' }, - :attachments => {'p0' => {'token' => attachment.token}} + put :update, :params => { + :id => 1, + :issue => { + :subject => '' + }, + :attachments => { + 'p0' => { + 'token' => attachment.token} + } + } assert_response :success end end @@ -3807,9 +4811,16 @@ class IssuesControllerTest < Redmine::ControllerTest assert_difference 'Journal.count' do assert_difference 'JournalDetail.count' do assert_no_difference 'Attachment.count' do - put :update, :id => 1, - :issue => {:notes => 'Attachment added'}, - :attachments => {'p0' => {'token' => attachment.token}} + put :update, :params => { + :id => 1, + :issue => { + :notes => 'Attachment added' + }, + :attachments => { + 'p0' => { + 'token' => attachment.token} + } + } assert_redirected_to '/issues/1' end end @@ -3828,10 +4839,16 @@ class IssuesControllerTest < Redmine::ControllerTest # anonymous user with_settings :attachment_max_size => 0 do - put :update, - :id => 1, - :issue => {:notes => ''}, - :attachments => {'1' => {'file' => uploaded_test_file('testfile.txt', 'text/plain')}} + put :update, :params => { + :id => 1, + :issue => { + :notes => '' + }, + :attachments => { + '1' => { + 'file' => uploaded_test_file('testfile.txt', 'text/plain')} + } + } assert_redirected_to :action => 'show', :id => '1' assert_equal '1 file(s) could not be saved.', flash[:warning] end @@ -3844,12 +4861,14 @@ class IssuesControllerTest < Redmine::ControllerTest journal = new_record(Journal) do assert_difference 'Attachment.count', -2 do - put :update, + put :update, :params => { :id => 3, :issue => { :notes => 'Removing attachments', :deleted_attachment_ids => ['1', '5'] + } + } end end assert_equal 'Removing attachments', journal.notes @@ -3868,13 +4887,15 @@ class IssuesControllerTest < Redmine::ControllerTest assert_no_difference 'Journal.count' do assert_no_difference 'Attachment.count' do - put :update, + put :update, :params => { :id => 3, :issue => { :subject => '', :notes => 'Removing attachments', :deleted_attachment_ids => ['1', '5'] + } + } end end assert_select 'input[name=?][value="1"][checked=checked]', 'issue[deleted_attachment_ids][]' @@ -3887,9 +4908,12 @@ class IssuesControllerTest < Redmine::ControllerTest issue.journals.clear ActionMailer::Base.deliveries.clear - put :update, - :id => 1, - :issue => {:notes => ''} + put :update, :params => { + :id => 1, + :issue => { + :notes => '' + } + } assert_redirected_to :action => 'show', :id => '1' issue.reload @@ -3906,10 +4930,15 @@ class IssuesControllerTest < Redmine::ControllerTest new_subject = 'Subject modified by IssuesControllerTest#test_post_edit' with_settings :notified_events => %w(issue_updated) do - put :update, :id => 1, :issue => {:subject => new_subject, - :priority_id => '6', - :category_id => '1' # no change - } + put :update, :params => { + :id => 1, + :issue => { + :subject => new_subject, + :priority_id => '6', + :category_id => '1' # no change + + } + } assert_equal 1, ActionMailer::Base.deliveries.size end end @@ -3919,10 +4948,15 @@ class IssuesControllerTest < Redmine::ControllerTest notes = 'Note added by IssuesControllerTest#test_post_edit_with_invalid_spent_time' assert_no_difference('Journal.count') do - put :update, - :id => 1, - :issue => {:notes => notes}, - :time_entry => {"comments"=>"", "activity_id"=>"", "hours"=>"2z"} + put :update, :params => { + :id => 1, + :issue => { + :notes => notes + }, + :time_entry => { + "comments"=>"", "activity_id"=>"", "hours"=>"2z" + } + } end assert_response :success @@ -3936,10 +4970,15 @@ class IssuesControllerTest < Redmine::ControllerTest notes = 'Note added by IssuesControllerTest#test_post_edit_with_invalid_spent_time' assert_no_difference('Journal.count') do - put :update, - :id => 1, - :issue => {:notes => notes}, - :time_entry => {"comments"=>"this is my comment", "activity_id"=>"", "hours"=>""} + put :update, :params => { + :id => 1, + :issue => { + :notes => notes + }, + :time_entry => { + "comments"=>"this is my comment", "activity_id"=>"", "hours"=>"" + } + } end assert_response :success @@ -3953,11 +4992,13 @@ class IssuesControllerTest < Redmine::ControllerTest issue = Issue.find(2) @request.session[:user_id] = 2 - put :update, - :id => issue.id, - :issue => { - :fixed_version_id => 4 - } + put :update, :params => { + :id => issue.id, + :issue => { + :fixed_version_id => 4 + + } + } assert_response :redirect issue.reload @@ -3969,12 +5010,14 @@ class IssuesControllerTest < Redmine::ControllerTest issue = Issue.find(2) @request.session[:user_id] = 2 - put :update, - :id => issue.id, - :issue => { - :fixed_version_id => 4 - }, - :back_url => '/issues' + put :update, :params => { + :id => issue.id, + :issue => { + :fixed_version_id => 4 + + }, + :back_url => '/issues' + } assert_response :redirect assert_redirected_to '/issues' @@ -3984,12 +5027,14 @@ class IssuesControllerTest < Redmine::ControllerTest issue = Issue.find(2) @request.session[:user_id] = 2 - put :update, - :id => issue.id, - :issue => { - :fixed_version_id => 4 - }, - :back_url => 'http://google.com' + put :update, :params => { + :id => issue.id, + :issue => { + :fixed_version_id => 4 + + }, + :back_url => 'http://google.com' + } assert_response :redirect assert_redirected_to :controller => 'issues', :action => 'show', :id => issue.id @@ -3998,12 +5043,17 @@ class IssuesControllerTest < Redmine::ControllerTest def test_put_update_should_redirect_with_previous_and_next_issue_ids_params @request.session[:user_id] = 2 - put :update, :id => 11, - :issue => {:status_id => 6, :notes => 'Notes'}, - :prev_issue_id => 8, - :next_issue_id => 12, - :issue_position => 2, - :issue_count => 3 + put :update, :params => { + :id => 11, + :issue => { + :status_id => 6, + :notes => 'Notes' + }, + :prev_issue_id => 8, + :next_issue_id => 12, + :issue_position => 2, + :issue_count => 3 + } assert_redirected_to '/issues/11?issue_count=3&issue_position=2&next_issue_id=12&prev_issue_id=8' end @@ -4015,7 +5065,12 @@ class IssuesControllerTest < Redmine::ControllerTest issue = Issue.generate!(:project_id => 1, :tracker_id => 1, :subject => 'Original subject') @request.session[:user_id] = 2 - put :update, :id => issue.id, :issue => {:subject => 'Changed subject'} + put :update, :params => { + :id => issue.id, + :issue => { + :subject => 'Changed subject' + } + } assert_response 302 assert_equal 'Changed subject', issue.reload.subject end @@ -4027,14 +5082,21 @@ class IssuesControllerTest < Redmine::ControllerTest issue = Issue.generate!(:project_id => 1, :tracker_id => 2, :subject => 'Original subject') @request.session[:user_id] = 2 - put :update, :id => issue.id, :issue => {:subject => 'Changed subject'} + put :update, :params => { + :id => issue.id, + :issue => { + :subject => 'Changed subject' + } + } assert_response 302 assert_equal 'Original subject', issue.reload.subject end def test_get_bulk_edit @request.session[:user_id] = 2 - get :bulk_edit, :ids => [1, 3] + get :bulk_edit, :params => { + :ids => [1, 3] + } assert_response :success assert_select 'ul#bulk-selection' do @@ -4069,7 +5131,9 @@ class IssuesControllerTest < Redmine::ControllerTest def test_get_bulk_edit_on_different_projects @request.session[:user_id] = 2 - get :bulk_edit, :ids => [1, 2, 6] + get :bulk_edit, :params => { + :ids => [1, 2, 6] + } assert_response :success # Can not set issues from different projects as children of an issue @@ -4086,7 +5150,9 @@ class IssuesControllerTest < Redmine::ControllerTest field = IssueCustomField.create!(:name => 'Tester', :field_format => 'user', :is_for_all => true, :tracker_ids => [1,2,3]) @request.session[:user_id] = 2 - get :bulk_edit, :ids => [1, 2] + get :bulk_edit, :params => { + :ids => [1, 2] + } assert_response :success assert_select 'select.user_cf[name=?]', "issue[custom_field_values][#{field.id}]" do @@ -4098,7 +5164,9 @@ class IssuesControllerTest < Redmine::ControllerTest field = IssueCustomField.create!(:name => 'Affected version', :field_format => 'version', :is_for_all => true, :tracker_ids => [1,2,3]) @request.session[:user_id] = 2 - get :bulk_edit, :ids => [1, 2] + get :bulk_edit, :params => { + :ids => [1, 2] + } assert_response :success assert_select 'select.version_cf[name=?]', "issue[custom_field_values][#{field.id}]" do @@ -4111,7 +5179,9 @@ class IssuesControllerTest < Redmine::ControllerTest field.update_attribute :multiple, true @request.session[:user_id] = 2 - get :bulk_edit, :ids => [1, 3] + get :bulk_edit, :params => { + :ids => [1, 3] + } assert_response :success assert_select 'select[name=?]', 'issue[custom_field_values][1][]' do @@ -4121,7 +5191,9 @@ class IssuesControllerTest < Redmine::ControllerTest def test_bulk_edit_should_propose_to_clear_text_custom_fields @request.session[:user_id] = 2 - get :bulk_edit, :ids => [1, 3] + get :bulk_edit, :params => { + :ids => [1, 3] + } assert_response :success assert_select 'input[name=?][value=?]', 'issue[custom_field_values][2]', '__none__' @@ -4142,7 +5214,9 @@ class IssuesControllerTest < Redmine::ControllerTest WorkflowTransition.create!(:role_id => 1, :tracker_id => 2, :old_status_id => 2, :new_status_id => 5) @request.session[:user_id] = 2 - get :bulk_edit, :ids => [1, 2] + get :bulk_edit, :params => { + :ids => [1, 2] + } assert_select 'select[name=?]', 'issue[status_id]' do assert_select 'option[value=""]' @@ -4154,7 +5228,12 @@ class IssuesControllerTest < Redmine::ControllerTest def test_bulk_edit_should_propose_target_project_open_shared_versions @request.session[:user_id] = 2 - post :bulk_edit, :ids => [1, 2, 6], :issue => {:project_id => 1} + post :bulk_edit, :params => { + :ids => [1, 2, 6], + :issue => { + :project_id => 1 + } + } assert_response :success expected_versions = Project.find(1).shared_versions.open.to_a.sort @@ -4171,7 +5250,12 @@ class IssuesControllerTest < Redmine::ControllerTest def test_bulk_edit_should_propose_target_project_categories @request.session[:user_id] = 2 - post :bulk_edit, :ids => [1, 2, 6], :issue => {:project_id => 1} + post :bulk_edit, :params => { + :ids => [1, 2, 6], + :issue => { + :project_id => 1 + } + } assert_response :success expected_categories = Project.find(1).issue_categories.sort @@ -4193,7 +5277,9 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 issue_ids = Issue.where(:project_id => 1, :tracker_id => 1).limit(2).ids - get :bulk_edit, :ids => issue_ids + get :bulk_edit, :params => { + :ids => issue_ids + } assert_response :success assert_select 'input[name=?]', "issue[custom_field_values][#{field1.id}]" @@ -4207,7 +5293,12 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 issue_ids = Issue.where(:project_id => 1, :tracker_id => 1).limit(2).ids - get :bulk_edit, :ids => issue_ids, :issue => {:tracker_id => 2} + get :bulk_edit, :params => { + :ids => issue_ids, + :issue => { + :tracker_id => 2 + } + } assert_response :success assert_select 'input[name=?]', "issue[custom_field_values][#{field1.id}]", 0 @@ -4224,7 +5315,12 @@ class IssuesControllerTest < Redmine::ControllerTest CustomValue.create!(:customized => Issue.find(2), :custom_field => not_cleared, :value => 'bar') @request.session[:user_id] = 2 - get :bulk_edit, :ids => [1, 2], :issue => {:tracker_id => 3} + get :bulk_edit, :params => { + :ids => [1, 2], + :issue => { + :tracker_id => 3 + } + } assert_response :success assert_select '.warning', :text => /automatic deletion of values/ assert_select '.warning span', :text => 'Cleared (1)' @@ -4234,10 +5330,16 @@ class IssuesControllerTest < Redmine::ControllerTest def test_bulk_update @request.session[:user_id] = 2 # update issues priority - post :bulk_update, :ids => [1, 2], :notes => 'Bulk editing', - :issue => {:priority_id => 7, - :assigned_to_id => '', - :custom_field_values => {'2' => ''}} + post :bulk_update, :params => { + :ids => [1, 2], + :notes => 'Bulk editing', + :issue => { + :priority_id => 7, + :assigned_to_id => '', + :custom_field_values => { + '2' => ''} + } + } assert_response 302 # check that the issues were updated @@ -4258,10 +5360,16 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 # update issues assignee with_settings :issue_group_assignment => '1' do - post :bulk_update, :ids => [1, 2], :notes => 'Bulk editing', - :issue => {:priority_id => '', - :assigned_to_id => group.id, - :custom_field_values => {'2' => ''}} + post :bulk_update, :params => { + :ids => [1, 2], + :notes => 'Bulk editing', + :issue => { + :priority_id => '', + :assigned_to_id => group.id, + :custom_field_values => { + '2' => ''} + } + } assert_response 302 assert_equal [group, group], Issue.where(:id => [1, 2]).collect {|i| i.assigned_to} @@ -4271,10 +5379,16 @@ class IssuesControllerTest < Redmine::ControllerTest def test_bulk_update_on_different_projects @request.session[:user_id] = 2 # update issues priority - post :bulk_update, :ids => [1, 2, 6], :notes => 'Bulk editing', - :issue => {:priority_id => 7, - :assigned_to_id => '', - :custom_field_values => {'2' => ''}} + post :bulk_update, :params => { + :ids => [1, 2, 6], + :notes => 'Bulk editing', + :issue => { + :priority_id => 7, + :assigned_to_id => '', + :custom_field_values => { + '2' => ''} + } + } assert_response 302 # check that the issues were updated @@ -4293,10 +5407,16 @@ class IssuesControllerTest < Redmine::ControllerTest action = { :controller => "issues", :action => "bulk_update" } assert user.allowed_to?(action, Issue.find(1).project) assert ! user.allowed_to?(action, Issue.find(6).project) - post :bulk_update, :ids => [1, 6], :notes => 'Bulk should fail', - :issue => {:priority_id => 7, - :assigned_to_id => '', - :custom_field_values => {'2' => ''}} + post :bulk_update, :params => { + :ids => [1, 6], + :notes => 'Bulk should fail', + :issue => { + :priority_id => 7, + :assigned_to_id => '', + :custom_field_values => { + '2' => ''} + } + } assert_response 403 assert_not_equal "Bulk should fail", Journal.last.notes end @@ -4305,16 +5425,15 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 ActionMailer::Base.deliveries.clear with_settings :notified_events => %w(issue_updated) do - post(:bulk_update, - { - :ids => [1, 2], - :notes => 'Bulk editing', - :issue => { - :priority_id => 7, - :assigned_to_id => '', - :custom_field_values => {'2' => ''} - } - }) + post :bulk_update, :params => { + :ids => [1, 2], + :notes => 'Bulk editing', + :issue => { + :priority_id => 7, + :assigned_to_id => '', + :custom_field_values => {'2' => ''} + } + } assert_response 302 assert_equal 2, ActionMailer::Base.deliveries.size end @@ -4322,7 +5441,12 @@ class IssuesControllerTest < Redmine::ControllerTest def test_bulk_update_project @request.session[:user_id] = 2 - post :bulk_update, :ids => [1, 2], :issue => {:project_id => '2'} + post :bulk_update, :params => { + :ids => [1, 2], + :issue => { + :project_id => '2' + } + } assert_redirected_to :controller => 'issues', :action => 'index', :project_id => 'ecookbook' # Issues moved to project 2 assert_equal 2, Issue.find(1).project_id @@ -4334,19 +5458,36 @@ class IssuesControllerTest < Redmine::ControllerTest def test_bulk_update_project_on_single_issue_should_follow_when_needed @request.session[:user_id] = 2 - post :bulk_update, :id => 1, :issue => {:project_id => '2'}, :follow => '1' + post :bulk_update, :params => { + :id => 1, + :issue => { + :project_id => '2' + }, + :follow => '1' + } assert_redirected_to '/issues/1' end def test_bulk_update_project_on_multiple_issues_should_follow_when_needed @request.session[:user_id] = 2 - post :bulk_update, :id => [1, 2], :issue => {:project_id => '2'}, :follow => '1' + post :bulk_update, :params => { + :id => [1, 2], + :issue => { + :project_id => '2' + }, + :follow => '1' + } assert_redirected_to '/projects/onlinestore/issues' end def test_bulk_update_tracker @request.session[:user_id] = 2 - post :bulk_update, :ids => [1, 2], :issue => {:tracker_id => '2'} + post :bulk_update, :params => { + :ids => [1, 2], + :issue => { + :tracker_id => '2' + } + } assert_redirected_to :controller => 'issues', :action => 'index', :project_id => 'ecookbook' assert_equal 2, Issue.find(1).tracker_id assert_equal 2, Issue.find(2).tracker_id @@ -4355,10 +5496,15 @@ class IssuesControllerTest < Redmine::ControllerTest def test_bulk_update_status @request.session[:user_id] = 2 # update issues priority - post :bulk_update, :ids => [1, 2], :notes => 'Bulk editing status', - :issue => {:priority_id => '', - :assigned_to_id => '', - :status_id => '5'} + post :bulk_update, :params => { + :ids => [1, 2], + :notes => 'Bulk editing status', + :issue => { + :priority_id => '', + :assigned_to_id => '', + :status_id => '5' + } + } assert_response 302 issue = Issue.find(1) @@ -4367,7 +5513,12 @@ class IssuesControllerTest < Redmine::ControllerTest def test_bulk_update_priority @request.session[:user_id] = 2 - post :bulk_update, :ids => [1, 2], :issue => {:priority_id => 6} + post :bulk_update, :params => { + :ids => [1, 2], + :issue => { + :priority_id => 6 + } + } assert_redirected_to :controller => 'issues', :action => 'index', :project_id => 'ecookbook' assert_equal 6, Issue.find(1).priority_id @@ -4376,7 +5527,10 @@ class IssuesControllerTest < Redmine::ControllerTest def test_bulk_update_with_notes @request.session[:user_id] = 2 - post :bulk_update, :ids => [1, 2], :notes => 'Moving two issues' + post :bulk_update, :params => { + :ids => [1, 2], + :notes => 'Moving two issues' + } assert_redirected_to :controller => 'issues', :action => 'index', :project_id => 'ecookbook' assert_equal 'Moving two issues', Issue.find(1).journals.sort_by(&:id).last.notes @@ -4386,10 +5540,16 @@ class IssuesControllerTest < Redmine::ControllerTest def test_bulk_update_parent_id IssueRelation.delete_all @request.session[:user_id] = 2 - post :bulk_update, :ids => [1, 3], - :notes => 'Bulk editing parent', - :issue => {:priority_id => '', :assigned_to_id => '', - :status_id => '', :parent_issue_id => '2'} + post :bulk_update, :params => { + :ids => [1, 3], + :notes => 'Bulk editing parent', + :issue => { + :priority_id => '', + :assigned_to_id => '', + :status_id => '', + :parent_issue_id => '2' + } + } assert_response 302 parent = Issue.find(2) assert_equal parent.id, Issue.find(1).parent_id @@ -4399,7 +5559,12 @@ class IssuesControllerTest < Redmine::ControllerTest def test_bulk_update_estimated_hours @request.session[:user_id] = 2 - post :bulk_update, :ids => [1, 2], :issue => {:estimated_hours => 4.25} + post :bulk_update, :params => { + :ids => [1, 2], + :issue => { + :estimated_hours => 4.25 + } + } assert_redirected_to :controller => 'issues', :action => 'index', :project_id => 'ecookbook' assert_equal 4.25, Issue.find(1).estimated_hours @@ -4409,10 +5574,16 @@ class IssuesControllerTest < Redmine::ControllerTest def test_bulk_update_custom_field @request.session[:user_id] = 2 # update issues priority - post :bulk_update, :ids => [1, 2], :notes => 'Bulk editing custom field', - :issue => {:priority_id => '', - :assigned_to_id => '', - :custom_field_values => {'2' => '777'}} + post :bulk_update, :params => { + :ids => [1, 2], + :notes => 'Bulk editing custom field', + :issue => { + :priority_id => '', + :assigned_to_id => '', + :custom_field_values => { + '2' => '777'} + } + } assert_response 302 @@ -4426,10 +5597,16 @@ class IssuesControllerTest < Redmine::ControllerTest def test_bulk_update_custom_field_to_blank @request.session[:user_id] = 2 - post :bulk_update, :ids => [1, 3], :notes => 'Bulk editing custom field', - :issue => {:priority_id => '', - :assigned_to_id => '', - :custom_field_values => {'1' => '__none__'}} + post :bulk_update, :params => { + :ids => [1, 3], + :notes => 'Bulk editing custom field', + :issue => { + :priority_id => '', + :assigned_to_id => '', + :custom_field_values => { + '1' => '__none__'} + } + } assert_response 302 assert_equal '', Issue.find(1).custom_field_value(1) assert_equal '', Issue.find(3).custom_field_value(1) @@ -4440,10 +5617,16 @@ class IssuesControllerTest < Redmine::ControllerTest field.update_attribute :multiple, true @request.session[:user_id] = 2 - post :bulk_update, :ids => [1, 2, 3], :notes => 'Bulk editing multi custom field', - :issue => {:priority_id => '', - :assigned_to_id => '', - :custom_field_values => {'1' => ['MySQL', 'Oracle']}} + post :bulk_update, :params => { + :ids => [1, 2, 3], + :notes => 'Bulk editing multi custom field', + :issue => { + :priority_id => '', + :assigned_to_id => '', + :custom_field_values => { + '1' => ['MySQL', 'Oracle']} + } + } assert_response 302 @@ -4458,10 +5641,16 @@ class IssuesControllerTest < Redmine::ControllerTest field.update_attribute :multiple, true @request.session[:user_id] = 2 - post :bulk_update, :ids => [1, 3], :notes => 'Bulk editing multi custom field', - :issue => {:priority_id => '', - :assigned_to_id => '', - :custom_field_values => {'1' => ['__none__']}} + post :bulk_update, :params => { + :ids => [1, 3], + :notes => 'Bulk editing multi custom field', + :issue => { + :priority_id => '', + :assigned_to_id => '', + :custom_field_values => { + '1' => ['__none__']} + } + } assert_response 302 assert_equal [''], Issue.find(1).custom_field_value(1) assert_equal [''], Issue.find(3).custom_field_value(1) @@ -4471,7 +5660,13 @@ class IssuesControllerTest < Redmine::ControllerTest assert_not_nil Issue.find(2).assigned_to @request.session[:user_id] = 2 # unassign issues - post :bulk_update, :ids => [1, 2], :notes => 'Bulk unassigning', :issue => {:assigned_to_id => 'none'} + post :bulk_update, :params => { + :ids => [1, 2], + :notes => 'Bulk unassigning', + :issue => { + :assigned_to_id => 'none' + } + } assert_response 302 # check that the issues were updated assert_nil Issue.find(2).assigned_to @@ -4480,7 +5675,12 @@ class IssuesControllerTest < Redmine::ControllerTest def test_post_bulk_update_should_allow_fixed_version_to_be_set_to_a_subproject @request.session[:user_id] = 2 - post :bulk_update, :ids => [1,2], :issue => {:fixed_version_id => 4} + post :bulk_update, :params => { + :ids => [1,2], + :issue => { + :fixed_version_id => 4 + } + } assert_response :redirect issues = Issue.find([1,2]) @@ -4492,7 +5692,10 @@ class IssuesControllerTest < Redmine::ControllerTest def test_post_bulk_update_should_redirect_back_using_the_back_url_parameter @request.session[:user_id] = 2 - post :bulk_update, :ids => [1,2], :back_url => '/issues' + post :bulk_update, :params => { + :ids => [1,2], + :back_url => '/issues' + } assert_response :redirect assert_redirected_to '/issues' @@ -4500,7 +5703,10 @@ class IssuesControllerTest < Redmine::ControllerTest def test_post_bulk_update_should_not_redirect_back_using_the_back_url_parameter_off_the_host @request.session[:user_id] = 2 - post :bulk_update, :ids => [1,2], :back_url => 'http://google.com' + post :bulk_update, :params => { + :ids => [1,2], + :back_url => 'http://google.com' + } assert_response :redirect assert_redirected_to :controller => 'issues', :action => 'index', :project_id => Project.find(1).identifier @@ -4508,7 +5714,12 @@ class IssuesControllerTest < Redmine::ControllerTest def test_bulk_update_with_all_failures_should_show_errors @request.session[:user_id] = 2 - post :bulk_update, :ids => [1, 2], :issue => {:start_date => 'foo'} + post :bulk_update, :params => { + :ids => [1, 2], + :issue => { + :start_date => 'foo' + } + } assert_response :success assert_select '#errorExplanation span', :text => 'Failed to save 2 issue(s) on 2 selected: #1, #2.' @@ -4520,8 +5731,12 @@ class IssuesControllerTest < Redmine::ControllerTest issue2 = Issue.generate!(:start_date => '2013-05-15') issue3 = Issue.generate! @request.session[:user_id] = 2 - post :bulk_update, :ids => [issue1.id, issue2.id, issue3.id], - :issue => {:due_date => '2013-05-01'} + post :bulk_update, :params => { + :ids => [issue1.id, issue2.id, issue3.id], + :issue => { + :due_date => '2013-05-01' + } + } assert_response :success assert_select '#errorExplanation span', @@ -4534,7 +5749,13 @@ class IssuesControllerTest < Redmine::ControllerTest def test_bulk_update_with_failure_should_preserved_form_values @request.session[:user_id] = 2 - post :bulk_update, :ids => [1, 2], :issue => {:tracker_id => '2', :start_date => 'foo'} + post :bulk_update, :params => { + :ids => [1, 2], + :issue => { + :tracker_id => '2', + :start_date => 'foo' + } + } assert_response :success assert_select 'select[name=?]', 'issue[tracker_id]' do @@ -4545,7 +5766,10 @@ class IssuesControllerTest < Redmine::ControllerTest def test_get_bulk_copy @request.session[:user_id] = 2 - get :bulk_edit, :ids => [1, 2, 3], :copy => '1' + get :bulk_edit, :params => { + :ids => [1, 2, 3], + :copy => '1' + } assert_response :success assert_select '#bulk-selection li', 3 @@ -4560,7 +5784,10 @@ class IssuesControllerTest < Redmine::ControllerTest user = setup_user_with_copy_but_not_add_permission @request.session[:user_id] = user.id - get :bulk_edit, :ids => [1, 2, 3], :copy => '1' + get :bulk_edit, :params => { + :ids => [1, 2, 3], + :copy => '1' + } assert_response :success assert_select 'select[name=?]', 'issue[project_id]' do @@ -4573,7 +5800,13 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Issue.count', 2 do assert_no_difference 'Project.find(1).issues.count' do - post :bulk_update, :ids => [1, 2], :issue => {:project_id => '2'}, :copy => '1' + post :bulk_update, :params => { + :ids => [1, 2], + :issue => { + :project_id => '2' + }, + :copy => '1' + } end end assert_redirected_to '/projects/ecookbook/issues' @@ -4589,7 +5822,13 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = user.id assert_difference 'Issue.count', 3 do - post :bulk_update, :ids => [1, 2, 3], :issue => {:project_id => '2'}, :copy => '1' + post :bulk_update, :params => { + :ids => [1, 2, 3], + :issue => { + :project_id => '2' + }, + :copy => '1' + } assert_response 302 end end @@ -4598,7 +5837,13 @@ class IssuesControllerTest < Redmine::ControllerTest user = setup_user_with_copy_but_not_add_permission @request.session[:user_id] = user.id - post :bulk_update, :ids => [1, 2, 3], :issue => {:project_id => ''}, :copy => '1' + post :bulk_update, :params => { + :ids => [1, 2, 3], + :issue => { + :project_id => '' + }, + :copy => '1' + } assert_response 403 end @@ -4606,7 +5851,13 @@ class IssuesControllerTest < Redmine::ControllerTest user = setup_user_with_copy_but_not_add_permission @request.session[:user_id] = user.id - post :bulk_update, :ids => [1, 2, 3], :issue => {:project_id => '1'}, :copy => '1' + post :bulk_update, :params => { + :ids => [1, 2, 3], + :issue => { + :project_id => '1' + }, + :copy => '1' + } assert_response 403 end @@ -4621,11 +5872,19 @@ class IssuesControllerTest < Redmine::ControllerTest :assigned_to_id => 2) ] assert_difference 'Issue.count', issues.size do - post :bulk_update, :ids => issues.map(&:id), :copy => '1', - :issue => { - :project_id => '', :tracker_id => '', :assigned_to_id => '', - :status_id => '', :start_date => '', :due_date => '' - } + post :bulk_update, :params => { + :ids => issues.map(&:id), + :copy => '1', + :issue => { + :project_id => '', + :tracker_id => '', + :assigned_to_id => '', + :status_id => '', + :start_date => '', + :due_date => '' + + } + } end copies = Issue.order('id DESC').limit(issues.size) @@ -4653,11 +5912,19 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Issue.count', 2 do assert_no_difference 'Project.find(1).issues.count' do - post :bulk_update, :ids => [1, 2], :copy => '1', - :issue => { - :project_id => '2', :tracker_id => '', :assigned_to_id => '2', - :status_id => '1', :start_date => '2009-12-01', :due_date => '2009-12-31' - } + post :bulk_update, :params => { + :ids => [1, 2], + :copy => '1', + :issue => { + :project_id => '2', + :tracker_id => '', + :assigned_to_id => '2', + :status_id => '1', + :start_date => '2009-12-01', + :due_date => '2009-12-31' + + } + } end end @@ -4675,12 +5942,19 @@ class IssuesControllerTest < Redmine::ControllerTest def test_bulk_copy_should_allow_adding_a_note @request.session[:user_id] = 2 assert_difference 'Issue.count', 1 do - post :bulk_update, :ids => [1], :copy => '1', - :notes => 'Copying one issue', - :issue => { - :project_id => '', :tracker_id => '', - :status_id => '3', :start_date => '2009-12-01', :due_date => '2009-12-31' - } + post :bulk_update, :params => { + :ids => [1], + :copy => '1', + :notes => 'Copying one issue', + :issue => { + :project_id => '', + :tracker_id => '', + :status_id => '3', + :start_date => '2009-12-01', + :due_date => '2009-12-31' + + } + } end issue = Issue.order('id DESC').first assert_equal 1, issue.journals.size @@ -4695,10 +5969,15 @@ class IssuesControllerTest < Redmine::ControllerTest assert_difference 'Issue.count', 1 do assert_no_difference 'Attachment.count' do - post :bulk_update, :ids => [3], :copy => '1', :copy_attachments => '0', - :issue => { - :project_id => '' - } + post :bulk_update, :params => { + :ids => [3], + :copy => '1', + :copy_attachments => '0', + :issue => { + :project_id => '' + + } + } end end end @@ -4710,10 +5989,15 @@ class IssuesControllerTest < Redmine::ControllerTest assert_difference 'Issue.count', 1 do assert_difference 'Attachment.count', attachment_count do - post :bulk_update, :ids => [3], :copy => '1', :copy_attachments => '1', - :issue => { - :project_id => '' - } + post :bulk_update, :params => { + :ids => [3], + :copy => '1', + :copy_attachments => '1', + :issue => { + :project_id => '' + + } + } end end end @@ -4723,10 +6007,15 @@ class IssuesControllerTest < Redmine::ControllerTest assert_difference 'Issue.count', 2 do assert_difference 'IssueRelation.count', 2 do - post :bulk_update, :ids => [1, 3], :copy => '1', :link_copy => '1', - :issue => { - :project_id => '1' - } + post :bulk_update, :params => { + :ids => [1, 3], + :copy => '1', + :link_copy => '1', + :issue => { + :project_id => '1' + + } + } end end end @@ -4736,10 +6025,15 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Issue.count', 1 do - post :bulk_update, :ids => [issue.id], :copy => '1', :copy_subtasks => '0', - :issue => { - :project_id => '' - } + post :bulk_update, :params => { + :ids => [issue.id], + :copy => '1', + :copy_subtasks => '0', + :issue => { + :project_id => '' + + } + } end end @@ -4749,10 +6043,15 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Issue.count', count+1 do - post :bulk_update, :ids => [issue.id], :copy => '1', :copy_subtasks => '1', - :issue => { - :project_id => '' - } + post :bulk_update, :params => { + :ids => [issue.id], + :copy => '1', + :copy_subtasks => '1', + :issue => { + :project_id => '' + + } + } end copy = Issue.where(:parent_id => nil).order("id DESC").first assert_equal count, copy.descendants.count @@ -4763,10 +6062,15 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Issue.count' do - post :bulk_update, :ids => [1], :copy => '1', :copy_watchers => '1', - :issue => { - :project_id => '' - } + post :bulk_update, :params => { + :ids => [1], + :copy => '1', + :copy_watchers => '1', + :issue => { + :project_id => '' + + } + } end copy = Issue.order(:id => :desc).first assert_equal 1, copy.watchers.count @@ -4778,10 +6082,15 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Issue.count', count+1 do - post :bulk_update, :ids => issue.self_and_descendants.map(&:id), :copy => '1', :copy_subtasks => '1', - :issue => { - :project_id => '' - } + post :bulk_update, :params => { + :ids => issue.self_and_descendants.map(&:id), + :copy => '1', + :copy_subtasks => '1', + :issue => { + :project_id => '' + + } + } end copy = Issue.where(:parent_id => nil).order("id DESC").first assert_equal count, copy.descendants.count @@ -4789,14 +6098,27 @@ class IssuesControllerTest < Redmine::ControllerTest def test_bulk_copy_to_another_project_should_follow_when_needed @request.session[:user_id] = 2 - post :bulk_update, :ids => [1], :copy => '1', :issue => {:project_id => 2}, :follow => '1' + post :bulk_update, :params => { + :ids => [1], + :copy => '1', + :issue => { + :project_id => 2 + }, + :follow => '1' + } issue = Issue.order('id DESC').first assert_redirected_to :controller => 'issues', :action => 'show', :id => issue end def test_bulk_copy_with_all_failures_should_display_errors @request.session[:user_id] = 2 - post :bulk_update, :ids => [1, 2], :copy => '1', :issue => {:start_date => 'foo'} + post :bulk_update, :params => { + :ids => [1, 2], + :copy => '1', + :issue => { + :start_date => 'foo' + } + } assert_response :success end @@ -4806,7 +6128,9 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Issue.count', -1 do - delete :destroy, :id => 2 + delete :destroy, :params => { + :id => 2 + } end assert_redirected_to :action => 'index', :project_id => 'ecookbook' assert_nil Issue.find_by_id(2) @@ -4816,7 +6140,9 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_no_difference 'Issue.count' do - delete :destroy, :ids => [1, 3] + delete :destroy, :params => { + :ids => [1, 3] + } end assert_response :success @@ -4833,7 +6159,9 @@ class IssuesControllerTest < Redmine::ControllerTest TimeEntry.generate!(:issue => leaf) @request.session[:user_id] = 2 - delete :destroy, :ids => [parent.id, leaf.id] + delete :destroy, :params => { + :ids => [parent.id, leaf.id] + } assert_response :success assert_select 'p', :text => /3\.00 hours were reported/ @@ -4844,7 +6172,10 @@ class IssuesControllerTest < Redmine::ControllerTest assert_difference 'Issue.count', -2 do assert_difference 'TimeEntry.count', -3 do - delete :destroy, :ids => [1, 3], :todo => 'destroy' + delete :destroy, :params => { + :ids => [1, 3], + :todo => 'destroy' + } end end assert_redirected_to :action => 'index', :project_id => 'ecookbook' @@ -4857,7 +6188,10 @@ class IssuesControllerTest < Redmine::ControllerTest assert_difference 'Issue.count', -2 do assert_no_difference 'TimeEntry.count' do - delete :destroy, :ids => [1, 3], :todo => 'nullify' + delete :destroy, :params => { + :ids => [1, 3], + :todo => 'nullify' + } end end assert_redirected_to :action => 'index', :project_id => 'ecookbook' @@ -4871,7 +6205,11 @@ class IssuesControllerTest < Redmine::ControllerTest assert_difference 'Issue.count', -2 do assert_no_difference 'TimeEntry.count' do - delete :destroy, :ids => [1, 3], :todo => 'reassign', :reassign_to_id => 2 + delete :destroy, :params => { + :ids => [1, 3], + :todo => 'reassign', + :reassign_to_id => 2 + } end end assert_redirected_to :action => 'index', :project_id => 'ecookbook' @@ -4891,7 +6229,11 @@ class IssuesControllerTest < Redmine::ControllerTest assert_difference 'Issue.count', -3 do assert_no_difference 'TimeEntry.count' do - delete :destroy, :ids => [parent.id, leaf.id], :todo => 'reassign', :reassign_to_id => target.id + delete :destroy, :params => { + :ids => [parent.id, leaf.id], + :todo => 'reassign', + :reassign_to_id => target.id + } assert_response 302 end end @@ -4904,7 +6246,11 @@ class IssuesControllerTest < Redmine::ControllerTest assert_no_difference 'Issue.count' do assert_no_difference 'TimeEntry.count' do # try to reassign time to an issue of another project - delete :destroy, :ids => [1, 3], :todo => 'reassign', :reassign_to_id => 4 + delete :destroy, :params => { + :ids => [1, 3], + :todo => 'reassign', + :reassign_to_id => 4 + } end end assert_response :success @@ -4915,7 +6261,11 @@ class IssuesControllerTest < Redmine::ControllerTest assert_no_difference 'Issue.count' do assert_no_difference 'TimeEntry.count' do - delete :destroy, :ids => [1, 3], :todo => 'reassign', :reassign_to_id => 3 + delete :destroy, :params => { + :ids => [1, 3], + :todo => 'reassign', + :reassign_to_id => 3 + } end end assert_response :success @@ -4926,7 +6276,10 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Issue.count', -3 do - delete :destroy, :ids => [1, 2, 6], :todo => 'destroy' + delete :destroy, :params => { + :ids => [1, 2, 6], + :todo => 'destroy' + } end assert_redirected_to :controller => 'issues', :action => 'index' assert !(Issue.find_by_id(1) || Issue.find_by_id(2) || Issue.find_by_id(6)) @@ -4939,7 +6292,10 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Issue.count', -2 do - delete :destroy, :ids => [parent.id, child.id], :todo => 'destroy' + delete :destroy, :params => { + :ids => [parent.id, child.id], + :todo => 'destroy' + } end assert_response 302 end @@ -4947,7 +6303,9 @@ class IssuesControllerTest < Redmine::ControllerTest def test_destroy_invalid_should_respond_with_404 @request.session[:user_id] = 2 assert_no_difference 'Issue.count' do - delete :destroy, :id => 999 + delete :destroy, :params => { + :id => 999 + } end assert_response 404 end @@ -4960,7 +6318,9 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Issue.count', -1 do - delete :destroy, :id => issue.id + delete :destroy, :params => { + :id => issue.id + } end assert_response 302 end @@ -4973,7 +6333,9 @@ class IssuesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_no_difference 'Issue.count' do - delete :destroy, :id => issue.id + delete :destroy, :params => { + :id => issue.id + } end assert_response 403 end @@ -4998,7 +6360,9 @@ class IssuesControllerTest < Redmine::ControllerTest def test_cancel_edit_link_for_issue_show_action_should_have_onclick_action @request.session[:user_id] = 1 - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :success assert_select 'a[href=?][onclick=?]', "/issues/1", "$('#update').hide(); return false;", :text => 'Cancel' end @@ -5006,7 +6370,9 @@ class IssuesControllerTest < Redmine::ControllerTest def test_cancel_edit_link_for_issue_edit_action_should_not_have_onclick_action @request.session[:user_id] = 1 - get :edit, :id => 1 + get :edit, :params => { + :id => 1 + } assert_response :success assert_select 'a[href=?][onclick=?]', "/issues/1", "", :text => 'Cancel' end diff --git a/test/functional/issues_controller_transaction_test.rb b/test/functional/issues_controller_transaction_test.rb index b43572014..a48663164 100644 --- a/test/functional/issues_controller_transaction_test.rb +++ b/test/functional/issues_controller_transaction_test.rb @@ -56,14 +56,20 @@ class IssuesControllerTransactionTest < Redmine::ControllerTest assert_no_difference 'Journal.count' do assert_no_difference 'TimeEntry.count' do - put :update, - :id => issue.id, - :issue => { - :fixed_version_id => 4, - :notes => 'My notes', - :lock_version => (issue.lock_version - 1) - }, - :time_entry => { :hours => '2.5', :comments => '', :activity_id => TimeEntryActivity.first.id } + put :update, :params => { + :id => issue.id, + :issue => { + :fixed_version_id => 4, + :notes => 'My notes', + :lock_version => (issue.lock_version - 1) + + }, + :time_entry => { + :hours => '2.5', + :comments => '', + :activity_id => TimeEntryActivity.first.id + } + } end end @@ -86,15 +92,24 @@ class IssuesControllerTransactionTest < Redmine::ControllerTest assert_no_difference 'Journal.count' do assert_no_difference 'TimeEntry.count' do assert_difference 'Attachment.count' do - put :update, - :id => issue.id, - :issue => { - :fixed_version_id => 4, - :notes => 'My notes', - :lock_version => (issue.lock_version - 1) - }, - :attachments => {'1' => {'file' => uploaded_test_file('testfile.txt', 'text/plain')}}, - :time_entry => { :hours => '2.5', :comments => '', :activity_id => TimeEntryActivity.first.id } + put :update, :params => { + :id => issue.id, + :issue => { + :fixed_version_id => 4, + :notes => 'My notes', + :lock_version => (issue.lock_version - 1) + + }, + :attachments => { + '1' => { + 'file' => uploaded_test_file('testfile.txt', 'text/plain')} + }, + :time_entry => { + :hours => '2.5', + :comments => '', + :activity_id => TimeEntryActivity.first.id + } + } end end end @@ -110,12 +125,15 @@ class IssuesControllerTransactionTest < Redmine::ControllerTest issue = Issue.find(2) @request.session[:user_id] = 2 - put :update, :id => issue.id, - :issue => { - :fixed_version_id => 4, - :notes => '', - :lock_version => (issue.lock_version - 1) - } + put :update, :params => { + :id => issue.id, + :issue => { + :fixed_version_id => 4, + :notes => '', + :lock_version => (issue.lock_version - 1) + + } + } assert_response :success assert_select 'div.conflict' @@ -127,13 +145,16 @@ class IssuesControllerTransactionTest < Redmine::ControllerTest def test_update_stale_issue_should_show_conflicting_journals @request.session[:user_id] = 2 - put :update, :id => 1, - :issue => { - :fixed_version_id => 4, - :notes => '', - :lock_version => 2 - }, - :last_journal_id => 1 + put :update, :params => { + :id => 1, + :issue => { + :fixed_version_id => 4, + :notes => '', + :lock_version => 2 + + }, + :last_journal_id => 1 + } assert_response :success assert_select '.conflict-journal', 1 @@ -143,13 +164,16 @@ class IssuesControllerTransactionTest < Redmine::ControllerTest def test_update_stale_issue_without_previous_journal_should_show_all_journals @request.session[:user_id] = 2 - put :update, :id => 1, - :issue => { - :fixed_version_id => 4, - :notes => '', - :lock_version => 2 - }, - :last_journal_id => '' + put :update, :params => { + :id => 1, + :issue => { + :fixed_version_id => 4, + :notes => '', + :lock_version => 2 + + }, + :last_journal_id => '' + } assert_response :success assert_select '.conflict-journal', 2 @@ -161,12 +185,26 @@ class IssuesControllerTransactionTest < Redmine::ControllerTest journal = Journal.create!(:journalized => Issue.find(1), :notes => 'Privates notes', :private_notes => true, :user_id => 1) @request.session[:user_id] = 2 - put :update, :id => 1, :issue => {:fixed_version_id => 4, :lock_version => 2}, :last_journal_id => '' + put :update, :params => { + :id => 1, + :issue => { + :fixed_version_id => 4, + :lock_version => 2 + }, + :last_journal_id => '' + } assert_response :success assert_select '.conflict-journal', :text => /Privates notes/ Role.find(1).remove_permission! :view_private_notes - put :update, :id => 1, :issue => {:fixed_version_id => 4, :lock_version => 2}, :last_journal_id => '' + put :update, :params => { + :id => 1, + :issue => { + :fixed_version_id => 4, + :lock_version => 2 + }, + :last_journal_id => '' + } assert_response :success assert_select '.conflict-journal', :text => /Privates notes/, :count => 0 end @@ -175,13 +213,16 @@ class IssuesControllerTransactionTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Journal.count' do - put :update, :id => 1, - :issue => { - :fixed_version_id => 4, - :notes => 'overwrite_conflict_resolution', - :lock_version => 2 - }, - :conflict_resolution => 'overwrite' + put :update, :params => { + :id => 1, + :issue => { + :fixed_version_id => 4, + :notes => 'overwrite_conflict_resolution', + :lock_version => 2 + + }, + :conflict_resolution => 'overwrite' + } end assert_response 302 @@ -196,13 +237,16 @@ class IssuesControllerTransactionTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Journal.count' do - put :update, :id => 1, - :issue => { - :fixed_version_id => 4, - :notes => 'add_notes_conflict_resolution', - :lock_version => 2 - }, - :conflict_resolution => 'add_notes' + put :update, :params => { + :id => 1, + :issue => { + :fixed_version_id => 4, + :notes => 'add_notes_conflict_resolution', + :lock_version => 2 + + }, + :conflict_resolution => 'add_notes' + } end assert_response 302 @@ -218,14 +262,17 @@ class IssuesControllerTransactionTest < Redmine::ControllerTest @request.session[:user_id] = 2 journal = new_record(Journal) do - put :update, :id => 1, - :issue => { - :fixed_version_id => 4, - :notes => 'add_privates_notes_conflict_resolution', - :private_notes => '1', - :lock_version => 2 - }, - :conflict_resolution => 'add_notes' + put :update, :params => { + :id => 1, + :issue => { + :fixed_version_id => 4, + :notes => 'add_privates_notes_conflict_resolution', + :private_notes => '1', + :lock_version => 2 + + }, + :conflict_resolution => 'add_notes' + } end assert_response 302 @@ -238,13 +285,16 @@ class IssuesControllerTransactionTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_no_difference 'Journal.count' do - put :update, :id => 1, - :issue => { - :fixed_version_id => 4, - :notes => 'add_notes_conflict_resolution', - :lock_version => 2 - }, - :conflict_resolution => 'cancel' + put :update, :params => { + :id => 1, + :issue => { + :fixed_version_id => 4, + :notes => 'add_notes_conflict_resolution', + :lock_version => 2 + + }, + :conflict_resolution => 'cancel' + } end assert_redirected_to '/issues/1' @@ -256,10 +306,17 @@ class IssuesControllerTransactionTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_no_difference('TimeEntry.count') do - put :update, - :id => 1, - :issue => { :subject => '' }, - :time_entry => { :hours => '2.5', :comments => 'should not be added', :activity_id => TimeEntryActivity.first.id } + put :update, :params => { + :id => 1, + :issue => { + :subject => '' + }, + :time_entry => { + :hours => '2.5', + :comments => 'should not be added', + :activity_id => TimeEntryActivity.first.id + } + } assert_response :success end diff --git a/test/functional/issues_custom_fields_visibility_test.rb b/test/functional/issues_custom_fields_visibility_test.rb index cd395d88c..31fc2175e 100644 --- a/test/functional/issues_custom_fields_visibility_test.rb +++ b/test/functional/issues_custom_fields_visibility_test.rb @@ -65,7 +65,9 @@ class IssuesCustomFieldsVisibilityTest < Redmine::ControllerTest def test_show_should_show_visible_custom_fields_only @users_to_test.each do |user, fields| @request.session[:user_id] = user.id - get :show, :id => @issue.id + get :show, :params => { + :id => @issue.id + } @fields.each_with_index do |field, i| if fields.include?(field) assert_select '.value', {:text => "Value#{i}", :count => 1}, "User #{user.id} was not able to view #{field.name}" @@ -79,7 +81,12 @@ class IssuesCustomFieldsVisibilityTest < Redmine::ControllerTest def test_show_should_show_visible_custom_fields_only_in_api @users_to_test.each do |user, fields| with_settings :rest_api_enabled => '1' do - get :show, :id => @issue.id, :format => 'xml', :include => 'custom_fields', :key => user.api_key + get :show, :params => { + :id => @issue.id, + :format => 'xml', + :include => 'custom_fields', + :key => user.api_key + } end @fields.each_with_index do |field, i| if fields.include?(field) @@ -98,7 +105,9 @@ class IssuesCustomFieldsVisibilityTest < Redmine::ControllerTest @users_to_test.each do |user, fields| @request.session[:user_id] = user.id - get :show, :id => @issue.id + get :show, :params => { + :id => @issue.id + } @fields.each_with_index do |field, i| if fields.include?(field) assert_select 'ul.details i', {:text => "Value#{i}", :count => 1}, "User #{user.id} was not able to view #{field.name} change" @@ -116,7 +125,12 @@ class IssuesCustomFieldsVisibilityTest < Redmine::ControllerTest @users_to_test.each do |user, fields| with_settings :rest_api_enabled => '1' do - get :show, :id => @issue.id, :format => 'xml', :include => 'journals', :key => user.api_key + get :show, :params => { + :id => @issue.id, + :format => 'xml', + :include => 'journals', + :key => user.api_key + } end @fields.each_with_index do |field, i| if fields.include?(field) @@ -133,7 +147,9 @@ class IssuesCustomFieldsVisibilityTest < Redmine::ControllerTest @users_to_test.each do |user, fields| @request.session[:user_id] = user.id - get :edit, :id => @issue.id + get :edit, :params => { + :id => @issue.id + } @fields.each_with_index do |field, i| if fields.include?(field) assert_select 'input[value=?]', "Value#{i}", 1, "User #{user.id} was not able to edit #{field.name}" @@ -149,12 +165,16 @@ class IssuesCustomFieldsVisibilityTest < Redmine::ControllerTest @users_to_test.each do |user, fields| @request.session[:user_id] = user.id - put :update, :id => @issue.id, - :issue => {:custom_field_values => { - @field1.id.to_s => "User#{user.id}Value0", - @field2.id.to_s => "User#{user.id}Value1", - @field3.id.to_s => "User#{user.id}Value2", - }} + put :update, :params => { + :id => @issue.id, + :issue => { + :custom_field_values => { + @field1.id.to_s => "User#{user.id}Value0", + @field2.id.to_s => "User#{user.id}Value1", + @field3.id.to_s => "User#{user.id}Value2", + } + } + } @issue.reload @fields.each_with_index do |field, i| if fields.include?(field) @@ -169,7 +189,9 @@ class IssuesCustomFieldsVisibilityTest < Redmine::ControllerTest def test_index_should_show_visible_custom_fields_only @users_to_test.each do |user, fields| @request.session[:user_id] = user.id - get :index, :c => (["subject"] + @fields.map{|f| "cf_#{f.id}"}) + get :index, :params => { + :c => (["subject"] + @fields.map{|f| "cf_#{f.id}"}) + } @fields.each_with_index do |field, i| if fields.include?(field) assert_select 'td', {:text => "Value#{i}", :count => 1}, "User #{user.id} was not able to view #{field.name}" @@ -183,7 +205,10 @@ class IssuesCustomFieldsVisibilityTest < Redmine::ControllerTest def test_index_as_csv_should_show_visible_custom_fields_only @users_to_test.each do |user, fields| @request.session[:user_id] = user.id - get :index, :c => (["subject"] + @fields.map{|f| "cf_#{f.id}"}), :format => 'csv' + get :index, :params => { + :c => (["subject"] + @fields.map{|f| "cf_#{f.id}"}), + :format => 'csv' + } @fields.each_with_index do |field, i| if fields.include?(field) assert_include "Value#{i}", response.body, "User #{user.id} was not able to view #{field.name} in CSV" @@ -206,20 +231,29 @@ class IssuesCustomFieldsVisibilityTest < Redmine::ControllerTest Issue.generate!(:project => p1, :tracker_id => 1, :custom_field_values => {@field2.id => 'ValueC'}) @request.session[:user_id] = user.id - get :index, :c => ["subject", "cf_#{@field2.id}"] + get :index, :params => { + :c => ["subject", "cf_#{@field2.id}"] + } assert_select 'td', :text => 'ValueA' assert_select 'td', :text => 'ValueB', :count => 0 assert_select 'td', :text => 'ValueC' - get :index, :sort => "cf_#{@field2.id}" + get :index, :params => { + :sort => "cf_#{@field2.id}" + } # ValueB is not visible to user and ignored while sorting assert_equal %w(ValueB ValueA ValueC), issues_in_list.map{|i| i.custom_field_value(@field2)} - get :index, :set_filter => '1', "cf_#{@field2.id}" => '*', :sort => "cf_#{@field2.id}" + get :index, :params => { + :set_filter => '1', "cf_#{@field2.id}" => '*', + :sort => "cf_#{@field2.id}" + } assert_equal %w(ValueA ValueC), issues_in_list.map{|i| i.custom_field_value(@field2)} CustomField.update_all(:field_format => 'list') - get :index, :group => "cf_#{@field2.id}" + get :index, :params => { + :group => "cf_#{@field2.id}" + } assert_equal %w(ValueA ValueC), issues_in_list.map{|i| i.custom_field_value(@field2)} end @@ -231,15 +265,19 @@ class IssuesCustomFieldsVisibilityTest < Redmine::ControllerTest @request.session[:user_id] = 1 with_settings :bcc_recipients => '1' do assert_difference 'Issue.count' do - post :create, - :project_id => 1, - :issue => { - :tracker_id => 1, - :status_id => 1, - :subject => 'New issue', - :priority_id => 5, - :custom_field_values => {@field1.id.to_s => 'Value0', @field2.id.to_s => 'Value1', @field3.id.to_s => 'Value2'}, - :watcher_user_ids => users_to_test.keys.map(&:id) + post :create, :params => { + :project_id => 1, + :issue => { + :tracker_id => 1, + :status_id => 1, + :subject => 'New issue', + :priority_id => 5, + :custom_field_values => { + @field1.id.to_s => 'Value0', @field2.id.to_s => 'Value1', @field3.id.to_s => 'Value2' + }, + :watcher_user_ids => users_to_test.keys.map(&:id) + + } } assert_response 302 end @@ -270,10 +308,14 @@ class IssuesCustomFieldsVisibilityTest < Redmine::ControllerTest ActionMailer::Base.deliveries.clear @request.session[:user_id] = 1 with_settings :bcc_recipients => '1' do - put :update, - :id => @issue.id, - :issue => { - :custom_field_values => {@field1.id.to_s => 'NewValue0', @field2.id.to_s => 'NewValue1', @field3.id.to_s => 'NewValue2'} + put :update, :params => { + :id => @issue.id, + :issue => { + :custom_field_values => { + @field1.id.to_s => 'NewValue0', @field2.id.to_s => 'NewValue1', @field3.id.to_s => 'NewValue2' + } + + } } assert_response 302 end @@ -303,10 +345,14 @@ class IssuesCustomFieldsVisibilityTest < Redmine::ControllerTest ActionMailer::Base.deliveries.clear @request.session[:user_id] = 1 with_settings :bcc_recipients => '1' do - put :update, - :id => @issue.id, - :issue => { - :custom_field_values => {@field2.id.to_s => 'NewValue1', @field3.id.to_s => 'NewValue2'} + put :update, :params => { + :id => @issue.id, + :issue => { + :custom_field_values => { + @field2.id.to_s => 'NewValue1', @field3.id.to_s => 'NewValue2' + } + + } } assert_response 302 end diff --git a/test/functional/journals_controller_test.rb b/test/functional/journals_controller_test.rb index 446cdcc83..a4f06b7d1 100644 --- a/test/functional/journals_controller_test.rb +++ b/test/functional/journals_controller_test.rb @@ -26,13 +26,18 @@ class JournalsControllerTest < Redmine::ControllerTest end def test_index - get :index, :project_id => 1 + get :index, :params => { + :project_id => 1 + } assert_response :success assert_equal 'application/atom+xml', @response.content_type end def test_index_with_invalid_query_id - get :index, :project_id => 1, :query_id => 999 + get :index, :params => { + :project_id => 1, + :query_id => 999 + } assert_response 404 end @@ -40,18 +45,23 @@ class JournalsControllerTest < Redmine::ControllerTest journal = Journal.create!(:journalized => Issue.find(2), :notes => 'Privates notes', :private_notes => true, :user_id => 1) @request.session[:user_id] = 2 - get :index, :project_id => 1 + get :index, :params => { + :project_id => 1 + } assert_response :success assert_select 'entry>id', :text => "http://test.host/issues/2?journal_id=#{journal.id}" Role.find(1).remove_permission! :view_private_notes - get :index, :project_id => 1 + get :index, :params => { + :project_id => 1 + } assert_response :success assert_select 'entry>id', :text => "http://test.host/issues/2?journal_id=#{journal.id}", :count => 0 end def test_index_should_show_visible_custom_fields_only Issue.destroy_all + Journal.delete_all field_attributes = {:field_format => 'string', :is_for_all => true, :is_filter => true, :trackers => Tracker.all} @fields = [] @fields << (@field1 = IssueCustomField.create!(field_attributes.merge(:name => 'Field 1', :visible => true))) @@ -64,8 +74,8 @@ class JournalsControllerTest < Redmine::ControllerTest :custom_field_values => {@field1.id => 'Value0', @field2.id => 'Value1', @field3.id => 'Value2'} ) @issue.init_journal(User.find(1)) - @issue.update_attribute :custom_field_values, {@field1.id => 'NewValue0', @field2.id => 'NewValue1', @field3.id => 'NewValue2'} - + @issue.custom_field_values = {@field1.id => 'NewValue0', @field2.id => 'NewValue1', @field3.id => 'NewValue2'} + @issue.save! user_with_role_on_other_project = User.generate! User.add_to_project(user_with_role_on_other_project, Project.find(2), Role.find(3)) @@ -78,7 +88,10 @@ class JournalsControllerTest < Redmine::ControllerTest } users_to_test.each do |user, visible_fields| - get :index, :format => 'atom', :key => user.rss_key + get :index, :params => { + :format => 'atom', + :key => user.rss_key + } @fields.each_with_index do |field, i| if visible_fields.include?(field) assert_select "content[type=html]", { :text => /NewValue#{i}/, :count => 1 }, "User #{user.id} was not able to view #{field.name} in API" @@ -91,7 +104,10 @@ class JournalsControllerTest < Redmine::ControllerTest end def test_diff_for_description_change - get :diff, :id => 3, :detail_id => 4 + get :diff, :params => { + :id => 3, + :detail_id => 4 + } assert_response :success assert_select 'span.diff_out', :text => /removed/ @@ -104,7 +120,10 @@ class JournalsControllerTest < Redmine::ControllerTest detail = JournalDetail.create!(:journal => journal, :property => 'cf', :prop_key => field.id, :old_value => 'Foo', :value => 'Bar') - get :diff, :id => journal.id, :detail_id => detail.id + get :diff, :params => { + :id => journal.id, + :detail_id => detail.id + } assert_response :success assert_select 'span.diff_out', :text => /Foo/ @@ -117,12 +136,17 @@ class JournalsControllerTest < Redmine::ControllerTest detail = JournalDetail.create!(:journal => journal, :property => 'cf', :prop_key => field.id, :old_value => 'Foo', :value => 'Bar') - get :diff, :id => journal.id, :detail_id => detail.id + get :diff, :params => { + :id => journal.id, + :detail_id => detail.id + } assert_response 302 end def test_diff_should_default_to_description_diff - get :diff, :id => 3 + get :diff, :params => { + :id => 3 + } assert_response :success assert_select 'span.diff_out', :text => /removed/ @@ -131,7 +155,10 @@ class JournalsControllerTest < Redmine::ControllerTest def test_reply_to_issue @request.session[:user_id] = 2 - xhr :get, :new, :id => 6 + get :new, :params => { + :id => 6 + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type @@ -140,13 +167,20 @@ class JournalsControllerTest < Redmine::ControllerTest def test_reply_to_issue_without_permission @request.session[:user_id] = 7 - xhr :get, :new, :id => 6 + get :new, :params => { + :id => 6 + }, + :xhr => true assert_response 403 end def test_reply_to_note @request.session[:user_id] = 2 - xhr :get, :new, :id => 6, :journal_id => 4 + get :new, :params => { + :id => 6, + :journal_id => 4 + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type assert_include '> A comment with a private version', response.body @@ -156,19 +190,30 @@ class JournalsControllerTest < Redmine::ControllerTest journal = Journal.create!(:journalized => Issue.find(2), :notes => 'Privates notes', :private_notes => true) @request.session[:user_id] = 2 - xhr :get, :new, :id => 2, :journal_id => journal.id + get :new, :params => { + :id => 2, + :journal_id => journal.id + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type assert_include '> Privates notes', response.body Role.find(1).remove_permission! :view_private_notes - xhr :get, :new, :id => 2, :journal_id => journal.id + get :new, :params => { + :id => 2, + :journal_id => journal.id + }, + :xhr => true assert_response 404 end def test_edit_xhr @request.session[:user_id] = 1 - xhr :get, :edit, :id => 2 + get :edit, :params => { + :id => 2 + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type assert_include 'textarea', response.body @@ -179,19 +224,31 @@ class JournalsControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 Role.find(1).add_permission! :edit_issue_notes - xhr :get, :edit, :id => journal.id + get :edit, :params => { + :id => journal.id + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type assert_include 'textarea', response.body Role.find(1).remove_permission! :view_private_notes - xhr :get, :edit, :id => journal.id + get :edit, :params => { + :id => journal.id + }, + :xhr => true assert_response 404 end def test_update_xhr @request.session[:user_id] = 1 - xhr :post, :update, :id => 2, :journal => {:notes => 'Updated notes'} + post :update, :params => { + :id => 2, + :journal => { + :notes => 'Updated notes' + } + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type assert_equal 'Updated notes', Journal.find(2).notes @@ -200,7 +257,13 @@ class JournalsControllerTest < Redmine::ControllerTest def test_update_xhr_with_private_notes_checked @request.session[:user_id] = 1 - xhr :post, :update, :id => 2, :journal => {:private_notes => '1'} + post :update, :params => { + :id => 2, + :journal => { + :private_notes => '1' + } + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type assert_equal true, Journal.find(2).private_notes @@ -211,7 +274,13 @@ class JournalsControllerTest < Redmine::ControllerTest def test_update_xhr_with_private_notes_unchecked Journal.find(2).update_attributes(:private_notes => true) @request.session[:user_id] = 1 - xhr :post, :update, :id => 2, :journal => {:private_notes => '0'} + post :update, :params => { + :id => 2, + :journal => { + :private_notes => '0' + } + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type assert_equal false, Journal.find(2).private_notes @@ -225,7 +294,13 @@ class JournalsControllerTest < Redmine::ControllerTest Role.find(1).add_permission! :view_private_notes Role.find(1).remove_permission! :set_notes_private - xhr :post, :update, :id => 2, :journal => {:private_notes => '1'} + post :update, :params => { + :id => 2, + :journal => { + :private_notes => '1' + } + }, + :xhr => true assert_response :success assert_equal false, Journal.find(2).private_notes end @@ -233,7 +308,13 @@ class JournalsControllerTest < Redmine::ControllerTest def test_update_xhr_with_empty_notes_should_delete_the_journal @request.session[:user_id] = 1 assert_difference 'Journal.count', -1 do - xhr :post, :update, :id => 2, :journal => {:notes => ''} + post :update, :params => { + :id => 2, + :journal => { + :notes => '' + } + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end diff --git a/test/functional/mail_handler_controller_test.rb b/test/functional/mail_handler_controller_test.rb index 91d31b56c..5f4c6bb3a 100644 --- a/test/functional/mail_handler_controller_test.rb +++ b/test/functional/mail_handler_controller_test.rb @@ -33,7 +33,10 @@ class MailHandlerControllerTest < Redmine::ControllerTest Setting.mail_handler_api_key = 'secret' assert_difference 'Issue.count' do - post :index, :key => 'secret', :email => IO.read(File.join(FIXTURES_PATH, 'ticket_on_given_project.eml')) + post :index, :params => { + :key => 'secret', + :email => IO.read(File.join(FIXTURES_PATH, 'ticket_on_given_project.eml')) + } end assert_response 201 end @@ -44,9 +47,13 @@ class MailHandlerControllerTest < Redmine::ControllerTest Setting.mail_handler_api_key = 'secret' assert_difference 'Issue.count' do - post :index, :key => 'secret', - :email => IO.read(File.join(FIXTURES_PATH, 'ticket_on_given_project.eml')), - :issue => {:is_private => '1'} + post :index, :params => { + :key => 'secret', + :email => IO.read(File.join(FIXTURES_PATH, 'ticket_on_given_project.eml')), + :issue => { + :is_private => '1' + } + } end assert_response 201 issue = Issue.order(:id => :desc).first @@ -60,7 +67,10 @@ class MailHandlerControllerTest < Redmine::ControllerTest Setting.mail_handler_api_key = 'secret' assert_no_difference 'Issue.count' do - post :index, :key => 'secret', :email => IO.read(File.join(FIXTURES_PATH, 'ticket_on_given_project.eml')) + post :index, :params => { + :key => 'secret', + :email => IO.read(File.join(FIXTURES_PATH, 'ticket_on_given_project.eml')) + } end assert_response 422 end @@ -71,7 +81,10 @@ class MailHandlerControllerTest < Redmine::ControllerTest Setting.mail_handler_api_key = 'secret' assert_no_difference 'Issue.count' do - post :index, :key => 'secret', :email => IO.read(File.join(FIXTURES_PATH, 'ticket_on_given_project.eml')) + post :index, :params => { + :key => 'secret', + :email => IO.read(File.join(FIXTURES_PATH, 'ticket_on_given_project.eml')) + } end assert_response 403 assert_include 'Access denied', response.body @@ -82,7 +95,10 @@ class MailHandlerControllerTest < Redmine::ControllerTest Setting.mail_handler_api_key = 'secret' assert_no_difference 'Issue.count' do - post :index, :key => 'wrong', :email => IO.read(File.join(FIXTURES_PATH, 'ticket_on_given_project.eml')) + post :index, :params => { + :key => 'wrong', + :email => IO.read(File.join(FIXTURES_PATH, 'ticket_on_given_project.eml')) + } end assert_response 403 assert_include 'Access denied', response.body @@ -92,7 +108,9 @@ class MailHandlerControllerTest < Redmine::ControllerTest Setting.mail_handler_api_enabled = 1 Setting.mail_handler_api_key = 'secret' - get :new, :key => 'secret' + get :new, :params => { + :key => 'secret' + } assert_response :success end end diff --git a/test/functional/members_controller_test.rb b/test/functional/members_controller_test.rb index 6de763fd1..19bff8199 100644 --- a/test/functional/members_controller_test.rb +++ b/test/functional/members_controller_test.rb @@ -26,7 +26,9 @@ class MembersControllerTest < Redmine::ControllerTest end def test_new - get :new, :project_id => 1 + get :new, :params => { + :project_id => 1 + } assert_response :success end @@ -35,7 +37,9 @@ class MembersControllerTest < Redmine::ControllerTest role.update! :all_roles_managed => false role.managed_roles = Role.where(:id => [2, 3]).to_a - get :new, :project_id => 1 + get :new, :params => { + :project_id => 1 + } assert_response :success assert_select 'div.roles-selection' do assert_select 'label', :text => 'Manager', :count => 0 @@ -45,14 +49,23 @@ class MembersControllerTest < Redmine::ControllerTest end def test_xhr_new - xhr :get, :new, :project_id => 1 + get :new, :params => { + :project_id => 1 + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end def test_create assert_difference 'Member.count' do - post :create, :project_id => 1, :membership => {:role_ids => [1], :user_id => 7} + post :create, :params => { + :project_id => 1, + :membership => { + :role_ids => [1], + :user_id => 7 + } + } end assert_redirected_to '/projects/ecookbook/settings/members' assert User.find(7).member_of?(Project.find(1)) @@ -60,7 +73,13 @@ class MembersControllerTest < Redmine::ControllerTest def test_create_multiple assert_difference 'Member.count', 3 do - post :create, :project_id => 1, :membership => {:role_ids => [1], :user_ids => [7, 8, 9]} + post :create, :params => { + :project_id => 1, + :membership => { + :role_ids => [1], + :user_ids => [7, 8, 9] + } + } end assert_redirected_to '/projects/ecookbook/settings/members' assert User.find(7).member_of?(Project.find(1)) @@ -72,7 +91,13 @@ class MembersControllerTest < Redmine::ControllerTest role.managed_roles = Role.where(:id => [2, 3]).to_a assert_difference 'Member.count' do - post :create, :project_id => 1, :membership => {:role_ids => [1, 2], :user_id => 7} + post :create, :params => { + :project_id => 1, + :membership => { + :role_ids => [1, 2], + :user_id => 7 + } + } end member = Member.order(:id => :desc).first assert_equal [2], member.role_ids @@ -83,7 +108,13 @@ class MembersControllerTest < Redmine::ControllerTest @request.session[:user_id] = 1 assert_difference 'Member.count' do - post :create, :project_id => 1, :membership => {:role_ids => [1, 2], :user_id => 7} + post :create, :params => { + :project_id => 1, + :membership => { + :role_ids => [1, 2], + :user_id => 7 + } + } end member = Member.order(:id => :desc).first assert_equal [1, 2], member.role_ids @@ -91,7 +122,14 @@ class MembersControllerTest < Redmine::ControllerTest def test_xhr_create assert_difference 'Member.count', 3 do - xhr :post, :create, :project_id => 1, :membership => {:role_ids => [1], :user_ids => [7, 8, 9]} + post :create, :params => { + :project_id => 1, + :membership => { + :role_ids => [1], + :user_ids => [7, 8, 9] + } + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end @@ -103,7 +141,14 @@ class MembersControllerTest < Redmine::ControllerTest def test_xhr_create_with_failure assert_no_difference 'Member.count' do - xhr :post, :create, :project_id => 1, :membership => {:role_ids => [], :user_ids => [7, 8, 9]} + post :create, :params => { + :project_id => 1, + :membership => { + :role_ids => [], + :user_ids => [7, 8, 9] + } + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end @@ -111,19 +156,30 @@ class MembersControllerTest < Redmine::ControllerTest end def test_edit - get :edit, :id => 2 + get :edit, :params => { + :id => 2 + } assert_response :success assert_select 'input[name=?][value=?][checked=checked]', 'membership[role_ids][]', '2' end def test_xhr_edit - xhr :get, :edit, :id => 2 + get :edit, :params => { + :id => 2 + }, + :xhr => true assert_response :success end def test_update assert_no_difference 'Member.count' do - put :update, :id => 2, :membership => {:role_ids => [1], :user_id => 3} + put :update, :params => { + :id => 2, + :membership => { + :role_ids => [1], + :user_id => 3 + } + } end assert_redirected_to '/projects/ecookbook/settings/members' end @@ -131,7 +187,12 @@ class MembersControllerTest < Redmine::ControllerTest def test_update_locked_member_should_be_allowed User.find(3).lock! - put :update, :id => 2, :membership => {:role_ids => [1]} + put :update, :params => { + :id => 2, + :membership => { + :role_ids => [1] + } + } assert_response 302 member = Member.find(2) assert member.user.locked? @@ -144,7 +205,12 @@ class MembersControllerTest < Redmine::ControllerTest role.managed_roles = Role.where(:id => [2, 3]).to_a member = Member.create!(:user => User.find(9), :role_ids => [3], :project_id => 1) - put :update, :id => member.id, :membership => {:role_ids => [1, 2, 3]} + put :update, :params => { + :id => member.id, + :membership => { + :role_ids => [1, 2, 3] + } + } assert_equal [2, 3], member.reload.role_ids.sort end @@ -154,13 +220,25 @@ class MembersControllerTest < Redmine::ControllerTest role.managed_roles = Role.where(:id => [2, 3]).to_a member = Member.create!(:user => User.find(9), :role_ids => [1, 3], :project_id => 1) - put :update, :id => member.id, :membership => {:role_ids => [2]} + put :update, :params => { + :id => member.id, + :membership => { + :role_ids => [2] + } + } assert_equal [1, 2], member.reload.role_ids.sort end def test_xhr_update assert_no_difference 'Member.count' do - xhr :put, :update, :id => 2, :membership => {:role_ids => [1], :user_id => 3} + put :update, :params => { + :id => 2, + :membership => { + :role_ids => [1], + :user_id => 3 + } + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end @@ -172,7 +250,9 @@ class MembersControllerTest < Redmine::ControllerTest def test_destroy assert_difference 'Member.count', -1 do - delete :destroy, :id => 2 + delete :destroy, :params => { + :id => 2 + } end assert_redirected_to '/projects/ecookbook/settings/members' assert !User.find(3).member_of?(Project.find(1)) @@ -182,7 +262,9 @@ class MembersControllerTest < Redmine::ControllerTest assert User.find(3).lock! assert_difference 'Member.count', -1 do - delete :destroy, :id => 2 + delete :destroy, :params => { + :id => 2 + } end end @@ -193,7 +275,9 @@ class MembersControllerTest < Redmine::ControllerTest member = Member.create!(:user => User.find(9), :role_ids => [1, 3], :project_id => 1) assert_no_difference 'Member.count' do - delete :destroy, :id => member.id + delete :destroy, :params => { + :id => member.id + } end end @@ -204,13 +288,18 @@ class MembersControllerTest < Redmine::ControllerTest member = Member.create!(:user => User.find(9), :role_ids => [3], :project_id => 1) assert_difference 'Member.count', -1 do - delete :destroy, :id => member.id + delete :destroy, :params => { + :id => member.id + } end end def test_xhr_destroy assert_difference 'Member.count', -1 do - xhr :delete, :destroy, :id => 2 + delete :destroy, :params => { + :id => 2 + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end @@ -219,7 +308,12 @@ class MembersControllerTest < Redmine::ControllerTest end def test_autocomplete - xhr :get, :autocomplete, :project_id => 1, :q => 'mis', :format => 'js' + get :autocomplete, :params => { + :project_id => 1, + :q => 'mis', + :format => 'js' + }, + :xhr => true assert_response :success assert_include 'User Misc', response.body end diff --git a/test/functional/messages_controller_test.rb b/test/functional/messages_controller_test.rb index 7609f4052..d47e41bc0 100644 --- a/test/functional/messages_controller_test.rb +++ b/test/functional/messages_controller_test.rb @@ -25,7 +25,10 @@ class MessagesControllerTest < Redmine::ControllerTest end def test_show - get :show, :board_id => 1, :id => 1 + get :show, :params => { + :board_id => 1, + :id => 1 + } assert_response :success assert_select 'h2', :text => 'First post' @@ -33,7 +36,10 @@ class MessagesControllerTest < Redmine::ControllerTest def test_show_should_contain_reply_field_tags_for_quoting @request.session[:user_id] = 2 - get :show, :board_id => 1, :id => 1 + get :show, :params => { + :board_id => 1, + :id => 1 + } assert_response :success # tags required by MessagesController#quote @@ -54,7 +60,11 @@ class MessagesControllerTest < Redmine::ControllerTest end reply_ids = message.children.map(&:id).sort - get :show, :board_id => 1, :id => 1, :r => reply_ids.last + get :show, :params => { + :board_id => 1, + :id => 1, + :r => reply_ids.last + } assert_response :success assert_select 'a[href=?]', "/boards/1/topics/1?r=#{reply_ids.last}#message-#{reply_ids.last}" @@ -63,25 +73,36 @@ class MessagesControllerTest < Redmine::ControllerTest def test_show_with_reply_permission @request.session[:user_id] = 2 - get :show, :board_id => 1, :id => 1 + get :show, :params => { + :board_id => 1, + :id => 1 + } assert_response :success assert_select 'div#reply textarea#message_content' end def test_show_message_not_found - get :show, :board_id => 1, :id => 99999 + get :show, :params => { + :board_id => 1, + :id => 99999 + } assert_response 404 end def test_show_message_from_invalid_board_should_respond_with_404 - get :show, :board_id => 999, :id => 1 + get :show, :params => { + :board_id => 999, + :id => 1 + } assert_response 404 end def test_get_new @request.session[:user_id] = 2 - get :new, :board_id => 1 + get :new, :params => { + :board_id => 1 + } assert_response :success assert_select 'input[name=?]', 'message[subject]' @@ -89,7 +110,9 @@ class MessagesControllerTest < Redmine::ControllerTest def test_get_new_with_invalid_board @request.session[:user_id] = 2 - get :new, :board_id => 99 + get :new, :params => { + :board_id => 99 + } assert_response 404 end @@ -98,9 +121,13 @@ class MessagesControllerTest < Redmine::ControllerTest ActionMailer::Base.deliveries.clear with_settings :notified_events => %w(message_posted) do - post :new, :board_id => 1, - :message => { :subject => 'Test created message', - :content => 'Message body'} + post :new, :params => { + :board_id => 1, + :message => { + :subject => 'Test created message', + :content => 'Message body' + } + } end message = Message.find_by_subject('Test created message') assert_not_nil message @@ -121,7 +148,10 @@ class MessagesControllerTest < Redmine::ControllerTest def test_get_edit @request.session[:user_id] = 2 - get :edit, :board_id => 1, :id => 1 + get :edit, :params => { + :board_id => 1, + :id => 1 + } assert_response :success assert_select 'input[name=?][value=?]', 'message[subject]', 'First post' @@ -129,9 +159,14 @@ class MessagesControllerTest < Redmine::ControllerTest def test_post_edit @request.session[:user_id] = 2 - post :edit, :board_id => 1, :id => 1, - :message => { :subject => 'New subject', - :content => 'New body'} + post :edit, :params => { + :board_id => 1, + :id => 1, + :message => { + :subject => 'New subject', + :content => 'New body' + } + } assert_redirected_to '/boards/1/topics/1' message = Message.find(1) assert_equal 'New subject', message.subject @@ -140,11 +175,16 @@ class MessagesControllerTest < Redmine::ControllerTest def test_post_edit_sticky_and_locked @request.session[:user_id] = 2 - post :edit, :board_id => 1, :id => 1, - :message => { :subject => 'New subject', - :content => 'New body', - :locked => '1', - :sticky => '1'} + post :edit, :params => { + :board_id => 1, + :id => 1, + :message => { + :subject => 'New subject', + :content => 'New body', + :locked => '1', + :sticky => '1' + } + } assert_redirected_to '/boards/1/topics/1' message = Message.find(1) assert_equal true, message.sticky? @@ -153,10 +193,15 @@ class MessagesControllerTest < Redmine::ControllerTest def test_post_edit_should_allow_to_change_board @request.session[:user_id] = 2 - post :edit, :board_id => 1, :id => 1, - :message => { :subject => 'New subject', - :content => 'New body', - :board_id => 2} + post :edit, :params => { + :board_id => 1, + :id => 1, + :message => { + :subject => 'New subject', + :content => 'New body', + :board_id => 2 + } + } assert_redirected_to '/boards/2/topics/1' message = Message.find(1) assert_equal Board.find(2), message.board @@ -164,7 +209,14 @@ class MessagesControllerTest < Redmine::ControllerTest def test_reply @request.session[:user_id] = 2 - post :reply, :board_id => 1, :id => 1, :reply => { :content => 'This is a test reply', :subject => 'Test reply' } + post :reply, :params => { + :board_id => 1, + :id => 1, + :reply => { + :content => 'This is a test reply', + :subject => 'Test reply' + } + } reply = Message.order('id DESC').first assert_redirected_to "/boards/1/topics/1?r=#{reply.id}" assert Message.find_by_subject('Test reply') @@ -173,7 +225,10 @@ class MessagesControllerTest < Redmine::ControllerTest def test_destroy_topic @request.session[:user_id] = 2 assert_difference 'Message.count', -3 do - post :destroy, :board_id => 1, :id => 1 + post :destroy, :params => { + :board_id => 1, + :id => 1 + } end assert_redirected_to '/projects/ecookbook/boards/1' assert_nil Message.find_by_id(1) @@ -182,7 +237,10 @@ class MessagesControllerTest < Redmine::ControllerTest def test_destroy_reply @request.session[:user_id] = 2 assert_difference 'Message.count', -1 do - post :destroy, :board_id => 1, :id => 2 + post :destroy, :params => { + :board_id => 1, + :id => 2 + } end assert_redirected_to '/boards/1/topics/1?r=2' assert_nil Message.find_by_id(2) @@ -190,7 +248,11 @@ class MessagesControllerTest < Redmine::ControllerTest def test_quote @request.session[:user_id] = 2 - xhr :get, :quote, :board_id => 1, :id => 3 + get :quote, :params => { + :board_id => 1, + :id => 3 + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type @@ -200,19 +262,27 @@ class MessagesControllerTest < Redmine::ControllerTest def test_preview_new @request.session[:user_id] = 2 - post :preview, - :board_id => 1, - :message => {:subject => "", :content => "Previewed text"} + post :preview, :params => { + :board_id => 1, + :message => { + :subject => "", + :content => "Previewed text" + } + } assert_response :success assert_include 'Previewed text', response.body end def test_preview_edit @request.session[:user_id] = 2 - post :preview, - :id => 4, - :board_id => 1, - :message => {:subject => "", :content => "Previewed text"} + post :preview, :params => { + :id => 4, + :board_id => 1, + :message => { + :subject => "", + :content => "Previewed text" + } + } assert_response :success assert_include 'Previewed text', response.body end diff --git a/test/functional/my_controller_test.rb b/test/functional/my_controller_test.rb index c35ff9043..19bad27ef 100644 --- a/test/functional/my_controller_test.rb +++ b/test/functional/my_controller_test.rb @@ -238,13 +238,17 @@ class MyControllerTest < Redmine::ControllerTest end def test_update_account - post :account, - :user => { - :firstname => "Joe", - :login => "root", - :admin => 1, - :group_ids => ['10'], - :custom_field_values => {"4" => "0100562500"} + post :account, :params => { + :user => { + :firstname => "Joe", + :login => "root", + :admin => 1, + :group_ids => ['10'], + :custom_field_values => { + "4" => "0100562500" + } + + } } assert_redirected_to '/my/account' @@ -259,9 +263,11 @@ class MyControllerTest < Redmine::ControllerTest def test_update_account_should_send_security_notification ActionMailer::Base.deliveries.clear - post :account, - :user => { - :mail => 'foobar@example.com' + post :account, :params => { + :user => { + :mail => 'foobar@example.com' + + } } assert_not_nil (mail = ActionMailer::Base.deliveries.last) @@ -297,7 +303,9 @@ class MyControllerTest < Redmine::ControllerTest def test_post_destroy_without_confirmation_should_destroy_account assert_difference 'User.count', -1 do - post :destroy, :confirm => '1' + post :destroy, :params => { + :confirm => '1' + } end assert_redirected_to '/' assert_match /deleted/i, flash[:notice] @@ -307,7 +315,9 @@ class MyControllerTest < Redmine::ControllerTest User.any_instance.stubs(:own_account_deletable?).returns(false) assert_no_difference 'User.count' do - post :destroy, :confirm => '1' + post :destroy, :params => { + :confirm => '1' + } end assert_redirected_to '/my/account' end @@ -321,17 +331,21 @@ class MyControllerTest < Redmine::ControllerTest end def test_update_password - post :password, :password => 'jsmith', - :new_password => 'secret123', - :new_password_confirmation => 'secret123' + post :password, :params => { + :password => 'jsmith', + :new_password => 'secret123', + :new_password_confirmation => 'secret123' + } assert_redirected_to '/my/account' assert User.try_to_login('jsmith', 'secret123') end def test_update_password_with_non_matching_confirmation - post :password, :password => 'jsmith', - :new_password => 'secret123', - :new_password_confirmation => 'secret1234' + post :password, :params => { + :password => 'jsmith', + :new_password => 'secret123', + :new_password_confirmation => 'secret1234' + } assert_response :success assert_select_error /Password doesn.*t match confirmation/ assert User.try_to_login('jsmith', 'jsmith') @@ -339,9 +353,11 @@ class MyControllerTest < Redmine::ControllerTest def test_update_password_with_wrong_password # wrong password - post :password, :password => 'wrongpassword', - :new_password => 'secret123', - :new_password_confirmation => 'secret123' + post :password, :params => { + :password => 'wrongpassword', + :new_password => 'secret123', + :new_password_confirmation => 'secret123' + } assert_response :success assert_equal 'Wrong password', flash[:error] assert User.try_to_login('jsmith', 'jsmith') @@ -357,9 +373,11 @@ class MyControllerTest < Redmine::ControllerTest def test_update_password_should_send_security_notification ActionMailer::Base.deliveries.clear - post :password, :password => 'jsmith', - :new_password => 'secret123', - :new_password_confirmation => 'secret123' + post :password, :params => { + :password => 'jsmith', + :new_password => 'secret123', + :new_password_confirmation => 'secret123' + } assert_not_nil (mail = ActionMailer::Base.deliveries.last) assert_mail_body_no_match 'secret123', mail # just to be sure: pw should never be sent! @@ -372,7 +390,13 @@ class MyControllerTest < Redmine::ControllerTest user = User.generate!(:language => 'en') @request.session[:user_id] = user.id - xhr :post, :update_page, :settings => {'issuesassignedtome' => {'columns' => ['subject', 'due_date']}} + post :update_page, :params => { + :settings => { + 'issuesassignedtome' => { + 'columns' => ['subject', 'due_date']} + } + }, + :xhr => true assert_response :success assert_include '$("#block-issuesassignedtome").replaceWith(', response.body assert_include 'Due date', response.body @@ -381,30 +405,42 @@ class MyControllerTest < Redmine::ControllerTest end def test_add_block - post :add_block, :block => 'issueswatched' + post :add_block, :params => { + :block => 'issueswatched' + } assert_redirected_to '/my/page' assert User.find(2).pref[:my_page_layout]['top'].include?('issueswatched') end def test_add_block_xhr - xhr :post, :add_block, :block => 'issueswatched' + post :add_block, :params => { + :block => 'issueswatched' + }, + :xhr => true assert_response :success assert_include 'issueswatched', User.find(2).pref[:my_page_layout]['top'] end def test_add_invalid_block_should_error - post :add_block, :block => 'invalid' + post :add_block, :params => { + :block => 'invalid' + } assert_response 422 end def test_remove_block - post :remove_block, :block => 'issuesassignedtome' + post :remove_block, :params => { + :block => 'issuesassignedtome' + } assert_redirected_to '/my/page' assert !User.find(2).pref[:my_page_layout].values.flatten.include?('issuesassignedtome') end def test_remove_block_xhr - xhr :post, :remove_block, :block => 'issuesassignedtome' + post :remove_block, :params => { + :block => 'issuesassignedtome' + }, + :xhr => true assert_response :success assert_include '$("#block-issuesassignedtome").remove();', response.body assert !User.find(2).pref[:my_page_layout].values.flatten.include?('issuesassignedtome') @@ -415,7 +451,11 @@ class MyControllerTest < Redmine::ControllerTest pref.my_page_layout = {'left' => ['news', 'calendar','documents']} pref.save! - xhr :post, :order_blocks, :group => 'left', :blocks => ['documents', 'calendar', 'news'] + post :order_blocks, :params => { + :group => 'left', + :blocks => ['documents', 'calendar', 'news'] + }, + :xhr => true assert_response :success assert_equal ['documents', 'calendar', 'news'], User.find(2).pref.my_page_layout['left'] end @@ -425,7 +465,11 @@ class MyControllerTest < Redmine::ControllerTest pref.my_page_layout = {'left' => ['news','documents'], 'right' => ['calendar']} pref.save! - xhr :post, :order_blocks, :group => 'left', :blocks => ['news', 'calendar', 'documents'] + post :order_blocks, :params => { + :group => 'left', + :blocks => ['news', 'calendar', 'documents'] + }, + :xhr => true assert_response :success assert_equal({'left' => ['news', 'calendar', 'documents'], 'right' => []}, User.find(2).pref.my_page_layout) end diff --git a/test/functional/news_controller_test.rb b/test/functional/news_controller_test.rb index 6ef39317a..8cb9d86bb 100644 --- a/test/functional/news_controller_test.rb +++ b/test/functional/news_controller_test.rb @@ -33,18 +33,24 @@ class NewsControllerTest < Redmine::ControllerTest end def test_index_with_project - get :index, :project_id => 1 + get :index, :params => { + :project_id => 1 + } assert_response :success assert_select 'h3 a', :text => 'eCookbook first release !' end def test_index_with_invalid_project_should_respond_with_404 - get :index, :project_id => 999 + get :index, :params => { + :project_id => 999 + } assert_response 404 end def test_show - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :success assert_select 'h2', :text => 'eCookbook first release !' end @@ -54,7 +60,9 @@ class NewsControllerTest < Redmine::ControllerTest attachment.container = News.find(1) attachment.save! - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :success assert_select 'a', :text => attachment.filename end @@ -65,7 +73,9 @@ class NewsControllerTest < Redmine::ControllerTest user.pref.save! @request.session[:user_id] = 1 - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :success comments = css_select('#comments .wiki').map(&:text).map(&:strip) @@ -73,13 +83,17 @@ class NewsControllerTest < Redmine::ControllerTest end def test_show_not_found - get :show, :id => 999 + get :show, :params => { + :id => 999 + } assert_response 404 end def test_get_new @request.session[:user_id] = 2 - get :new, :project_id => 1 + get :new, :params => { + :project_id => 1 + } assert_response :success assert_select 'input[name=?]', 'news[title]' end @@ -89,9 +103,14 @@ class NewsControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 with_settings :notified_events => %w(news_added) do - post :create, :project_id => 1, :news => { :title => 'NewsControllerTest', - :description => 'This is the description', - :summary => '' } + post :create, :params => { + :project_id => 1, + :news => { + :title => 'NewsControllerTest', + :description => 'This is the description', + :summary => '' + } + } end assert_redirected_to '/projects/ecookbook/news' @@ -108,9 +127,17 @@ class NewsControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'News.count' do assert_difference 'Attachment.count' do - post :create, :project_id => 1, - :news => { :title => 'Test', :description => 'This is the description' }, - :attachments => {'1' => {'file' => uploaded_test_file('testfile.txt', 'text/plain')}} + post :create, :params => { + :project_id => 1, + :news => { + :title => 'Test', + :description => 'This is the description' + }, + :attachments => { + '1' => { + 'file' => uploaded_test_file('testfile.txt', 'text/plain')} + } + } end end attachment = Attachment.order('id DESC').first @@ -120,23 +147,35 @@ class NewsControllerTest < Redmine::ControllerTest def test_post_create_with_validation_failure @request.session[:user_id] = 2 - post :create, :project_id => 1, :news => { :title => '', - :description => 'This is the description', - :summary => '' } + post :create, :params => { + :project_id => 1, + :news => { + :title => '', + :description => 'This is the description', + :summary => '' + } + } assert_response :success assert_select_error /title cannot be blank/i end def test_get_edit @request.session[:user_id] = 2 - get :edit, :id => 1 + get :edit, :params => { + :id => 1 + } assert_response :success assert_select 'input[name=?][value=?]', 'news[title]', 'eCookbook first release !' end def test_put_update @request.session[:user_id] = 2 - put :update, :id => 1, :news => { :description => 'Description changed by test_post_edit' } + put :update, :params => { + :id => 1, + :news => { + :description => 'Description changed by test_post_edit' + } + } assert_redirected_to '/news/1' news = News.find(1) assert_equal 'Description changed by test_post_edit', news.description @@ -147,9 +186,16 @@ class NewsControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_no_difference 'News.count' do assert_difference 'Attachment.count' do - put :update, :id => 1, - :news => { :description => 'This is the description' }, - :attachments => {'1' => {'file' => uploaded_test_file('testfile.txt', 'text/plain')}} + put :update, :params => { + :id => 1, + :news => { + :description => 'This is the description' + }, + :attachments => { + '1' => { + 'file' => uploaded_test_file('testfile.txt', 'text/plain')} + } + } end end attachment = Attachment.order('id DESC').first @@ -158,14 +204,21 @@ class NewsControllerTest < Redmine::ControllerTest def test_update_with_failure @request.session[:user_id] = 2 - put :update, :id => 1, :news => { :description => '' } + put :update, :params => { + :id => 1, + :news => { + :description => '' + } + } assert_response :success assert_select_error /description cannot be blank/i end def test_destroy @request.session[:user_id] = 2 - delete :destroy, :id => 1 + delete :destroy, :params => { + :id => 1 + } assert_redirected_to '/projects/ecookbook/news' assert_nil News.find_by_id(1) end diff --git a/test/functional/previews_controller_test.rb b/test/functional/previews_controller_test.rb index e75a670fe..231d9519d 100644 --- a/test/functional/previews_controller_test.rb +++ b/test/functional/previews_controller_test.rb @@ -30,7 +30,12 @@ class PreviewsControllerTest < Redmine::ControllerTest def test_preview_new_issue @request.session[:user_id] = 2 - post :issue, :project_id => '1', :issue => {:description => 'Foo'} + post :issue, :params => { + :project_id => '1', + :issue => { + :description => 'Foo' + } + } assert_response :success assert_select 'fieldset' do assert_select 'legend', :text => 'Description' @@ -40,8 +45,14 @@ class PreviewsControllerTest < Redmine::ControllerTest def test_preview_issue_notes_with_no_change_to_description @request.session[:user_id] = 2 - post :issue, :project_id => '1', :id => 1, - :issue => {:description => Issue.find(1).description, :notes => 'Foo'} + post :issue, :params => { + :project_id => '1', + :id => 1, + :issue => { + :description => Issue.find(1).description, + :notes => 'Foo' + } + } assert_response :success assert_select 'legend', :text => 'Description', :count => 0 assert_select 'legend', :text => 'Notes' @@ -49,8 +60,14 @@ class PreviewsControllerTest < Redmine::ControllerTest def test_preview_issue_notes_with_change_to_description @request.session[:user_id] = 2 - post :issue, :project_id => '1', :id => 1, - :issue => {:description => 'Changed description', :notes => 'Foo'} + post :issue, :params => { + :project_id => '1', + :id => 1, + :issue => { + :description => 'Changed description', + :notes => 'Foo' + } + } assert_response :success assert_select 'legend', :text => 'Description' assert_select 'legend', :text => 'Notes' @@ -58,7 +75,13 @@ class PreviewsControllerTest < Redmine::ControllerTest def test_preview_journal_notes_for_update @request.session[:user_id] = 2 - post :issue, :project_id => '1', :id => 1, :journal => {:notes => 'Foo'} + post :issue, :params => { + :project_id => '1', + :id => 1, + :journal => { + :notes => 'Foo' + } + } assert_response :success assert_select 'legend', :text => 'Notes' assert_select 'p', :text => 'Foo' @@ -67,32 +90,54 @@ class PreviewsControllerTest < Redmine::ControllerTest def test_preview_issue_notes_should_support_links_to_existing_attachments Attachment.generate!(:container => Issue.find(1), :filename => 'foo.bar') @request.session[:user_id] = 2 - post :issue, :project_id => '1', :id => 1, :issue => {:notes => 'attachment:foo.bar'} + post :issue, :params => { + :project_id => '1', + :id => 1, + :issue => { + :notes => 'attachment:foo.bar' + } + } assert_response :success assert_select 'a.attachment', :text => 'foo.bar' end def test_preview_issue_with_project_changed @request.session[:user_id] = 2 - post :issue, :project_id => '1', :id => 1, :issue => {:notes => 'notes', :project_id => 2} + post :issue, :params => { + :project_id => '1', + :id => 1, + :issue => { + :notes => 'notes', + :project_id => 2 + } + } assert_response :success assert_select 'legend', :text => 'Notes' end def test_preview_new_news - get :news, :project_id => 1, - :news => {:title => '', - :description => 'News description', - :summary => ''} + get :news, :params => { + :project_id => 1, + :news => { + :title => '', + :description => 'News description', + :summary => '' + } + } assert_response :success assert_select 'fieldset.preview', :text => /News description/ end def test_preview_existing_news - get :news, :project_id => 1, :id => 2, - :news => {:title => '', - :description => 'News description', - :summary => ''} + get :news, :params => { + :project_id => 1, + :id => 2, + :news => { + :title => '', + :description => 'News description', + :summary => '' + } + } assert_response :success assert_select 'fieldset.preview', :text => /News description/ end diff --git a/test/functional/principal_memberships_controller_test.rb b/test/functional/principal_memberships_controller_test.rb index ca0b2c53a..753b1e2bb 100644 --- a/test/functional/principal_memberships_controller_test.rb +++ b/test/functional/principal_memberships_controller_test.rb @@ -25,7 +25,9 @@ class PrincipalMembershipsControllerTest < Redmine::ControllerTest end def test_new_user_membership - get :new, :user_id => 7 + get :new, :params => { + :user_id => 7 + } assert_response :success assert_select 'label', :text => 'eCookbook' do assert_select 'input[name=?][value="1"]:not([disabled])', 'membership[project_ids][]' @@ -35,7 +37,9 @@ class PrincipalMembershipsControllerTest < Redmine::ControllerTest def test_new_user_membership_should_disable_user_projects Member.create!(:user_id => 7, :project_id => 1, :role_ids => [1]) - get :new, :user_id => 7 + get :new, :params => { + :user_id => 7 + } assert_response :success assert_select 'label', :text => 'eCookbook' do assert_select 'input[name=?][value="1"][disabled=disabled]', 'membership[project_ids][]' @@ -43,14 +47,23 @@ class PrincipalMembershipsControllerTest < Redmine::ControllerTest end def test_xhr_new_user_membership - xhr :get, :new, :user_id => 7 + get :new, :params => { + :user_id => 7 + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end def test_create_user_membership assert_difference 'Member.count' do - post :create, :user_id => 7, :membership => {:project_ids => [3], :role_ids => [2]} + post :create, :params => { + :user_id => 7, + :membership => { + :project_ids => [3], + :role_ids => [2] + } + } end assert_redirected_to '/users/7/edit?tab=memberships' member = Member.order('id DESC').first @@ -61,7 +74,13 @@ class PrincipalMembershipsControllerTest < Redmine::ControllerTest def test_create_user_membership_with_multiple_roles assert_difference 'Member.count' do - post :create, :user_id => 7, :membership => {:project_ids => [3], :role_ids => [2, 3]} + post :create, :params => { + :user_id => 7, + :membership => { + :project_ids => [3], + :role_ids => [2, 3] + } + } end member = Member.order('id DESC').first assert_equal User.find(7), member.principal @@ -71,7 +90,13 @@ class PrincipalMembershipsControllerTest < Redmine::ControllerTest def test_create_user_membership_with_multiple_projects_and_roles assert_difference 'Member.count', 2 do - post :create, :user_id => 7, :membership => {:project_ids => [1, 3], :role_ids => [2, 3]} + post :create, :params => { + :user_id => 7, + :membership => { + :project_ids => [1, 3], + :role_ids => [2, 3] + } + } end members = Member.order('id DESC').limit(2).sort_by(&:project_id) assert_equal 1, members[0].project_id @@ -84,7 +109,15 @@ class PrincipalMembershipsControllerTest < Redmine::ControllerTest def test_xhr_create_user_membership assert_difference 'Member.count' do - xhr :post, :create, :user_id => 7, :membership => {:project_ids => [3], :role_ids => [2]}, :format => 'js' + post :create, :params => { + :user_id => 7, + :membership => { + :project_ids => [3], + :role_ids => [2] + }, + :format => 'js' + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end @@ -97,7 +130,14 @@ class PrincipalMembershipsControllerTest < Redmine::ControllerTest def test_xhr_create_user_membership_with_failure assert_no_difference 'Member.count' do - xhr :post, :create, :user_id => 7, :membership => {:project_ids => [3]}, :format => 'js' + post :create, :params => { + :user_id => 7, + :membership => { + :project_ids => [3] + }, + :format => 'js' + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end @@ -106,19 +146,32 @@ class PrincipalMembershipsControllerTest < Redmine::ControllerTest end def test_edit_user_membership - get :edit, :user_id => 2, :id => 1 + get :edit, :params => { + :user_id => 2, + :id => 1 + } assert_response :success assert_select 'input[name=?][value=?][checked=checked]', 'membership[role_ids][]', '1' end def test_xhr_edit_user_membership - xhr :get, :edit, :user_id => 2, :id => 1 + get :edit, :params => { + :user_id => 2, + :id => 1 + }, + :xhr => true assert_response :success end def test_update_user_membership assert_no_difference 'Member.count' do - put :update, :user_id => 2, :id => 1, :membership => {:role_ids => [2]} + put :update, :params => { + :user_id => 2, + :id => 1, + :membership => { + :role_ids => [2] + } + } assert_redirected_to '/users/2/edit?tab=memberships' end assert_equal [2], Member.find(1).role_ids @@ -126,7 +179,15 @@ class PrincipalMembershipsControllerTest < Redmine::ControllerTest def test_xhr_update_user_membership assert_no_difference 'Member.count' do - xhr :put, :update, :user_id => 2, :id => 1, :membership => {:role_ids => [2]}, :format => 'js' + put :update, :params => { + :user_id => 2, + :id => 1, + :membership => { + :role_ids => [2] + }, + :format => 'js' + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end @@ -136,7 +197,10 @@ class PrincipalMembershipsControllerTest < Redmine::ControllerTest def test_destroy_user_membership assert_difference 'Member.count', -1 do - delete :destroy, :user_id => 2, :id => 1 + delete :destroy, :params => { + :user_id => 2, + :id => 1 + } end assert_redirected_to '/users/2/edit?tab=memberships' assert_nil Member.find_by_id(1) @@ -144,7 +208,11 @@ class PrincipalMembershipsControllerTest < Redmine::ControllerTest def test_xhr_destroy_user_membership_js_format assert_difference 'Member.count', -1 do - xhr :delete, :destroy, :user_id => 2, :id => 1 + delete :destroy, :params => { + :user_id => 2, + :id => 1 + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end @@ -153,20 +221,36 @@ class PrincipalMembershipsControllerTest < Redmine::ControllerTest end def test_xhr_new_group_membership - xhr :get, :new, :group_id => 10 + get :new, :params => { + :group_id => 10 + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end def test_create_group_membership assert_difference 'Group.find(10).members.count' do - post :create, :group_id => 10, :membership => {:project_ids => [2], :role_ids => ['1', '2']} + post :create, :params => { + :group_id => 10, + :membership => { + :project_ids => [2], + :role_ids => ['1', '2'] + } + } end end def test_xhr_create_group_membership assert_difference 'Group.find(10).members.count' do - xhr :post, :create, :group_id => 10, :membership => {:project_ids => [2], :role_ids => ['1', '2']} + post :create, :params => { + :group_id => 10, + :membership => { + :project_ids => [2], + :role_ids => ['1', '2'] + } + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end @@ -175,7 +259,14 @@ class PrincipalMembershipsControllerTest < Redmine::ControllerTest def test_xhr_create_group_membership_with_failure assert_no_difference 'Group.find(10).members.count' do - xhr :post, :create, :group_id => 10, :membership => {:project_ids => [999], :role_ids => ['1', '2']} + post :create, :params => { + :group_id => 10, + :membership => { + :project_ids => [999], + :role_ids => ['1', '2'] + } + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end @@ -184,13 +275,26 @@ class PrincipalMembershipsControllerTest < Redmine::ControllerTest def test_update_group_membership assert_no_difference 'Group.find(10).members.count' do - put :update, :group_id => 10, :id => 6, :membership => {:role_ids => ['1', '3']} + put :update, :params => { + :group_id => 10, + :id => 6, + :membership => { + :role_ids => ['1', '3'] + } + } end end def test_xhr_update_group_membership assert_no_difference 'Group.find(10).members.count' do - xhr :post, :update, :group_id => 10, :id => 6, :membership => {:role_ids => ['1', '3']} + post :update, :params => { + :group_id => 10, + :id => 6, + :membership => { + :role_ids => ['1', '3'] + } + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end @@ -198,13 +302,20 @@ class PrincipalMembershipsControllerTest < Redmine::ControllerTest def test_destroy_group_membership assert_difference 'Group.find(10).members.count', -1 do - delete :destroy, :group_id => 10, :id => 6 + delete :destroy, :params => { + :group_id => 10, + :id => 6 + } end end def test_xhr_destroy_group_membership assert_difference 'Group.find(10).members.count', -1 do - xhr :delete, :destroy, :group_id => 10, :id => 6 + delete :destroy, :params => { + :group_id => 10, + :id => 6 + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end diff --git a/test/functional/project_enumerations_controller_test.rb b/test/functional/project_enumerations_controller_test.rb index c098b2b30..81a9d81a7 100644 --- a/test/functional/project_enumerations_controller_test.rb +++ b/test/functional/project_enumerations_controller_test.rb @@ -40,12 +40,15 @@ class ProjectEnumerationsControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 # manager billable_field = TimeEntryActivityCustomField.find_by_name("Billable") - put :update, :project_id => 1, :enumerations => { - "9"=> {"parent_id"=>"9", "custom_field_values"=>{"7" => "1"}, "active"=>"0"}, # Design, De-activate - "10"=> {"parent_id"=>"10", "custom_field_values"=>{"7"=>"0"}, "active"=>"1"}, # Development, Change custom value - "14"=>{"parent_id"=>"14", "custom_field_values"=>{"7"=>"1"}, "active"=>"1"}, # Inactive Activity, Activate with custom value - "11"=>{"parent_id"=>"11", "custom_field_values"=>{"7"=>"1"}, "active"=>"1"} # QA, no changes - } + put :update, :params => { + :project_id => 1, + :enumerations => { + "9"=> {"parent_id"=>"9", "custom_field_values"=> {"7" => "1"}, "active"=>"0"}, # Design, De-activate + "10"=> {"parent_id"=>"10", "custom_field_values"=>{"7"=>"0"}, "active"=>"1"}, # Development, Change custom value + "14"=>{"parent_id"=>"14", "custom_field_values"=>{"7"=>"1"}, "active"=>"1"}, # Inactive Activity, Activate with custom value + "11"=>{"parent_id"=>"11", "custom_field_values"=>{"7"=>"1"}, "active"=>"1"} # QA, no changes + } + } assert_response :redirect assert_redirected_to '/projects/ecookbook/settings/activities' @@ -105,10 +108,13 @@ class ProjectEnumerationsControllerTest < Redmine::ControllerTest assert project_activity_two.save - put :update, :project_id => 1, :enumerations => { - project_activity.id => {"custom_field_values"=>{"7" => "1"}, "active"=>"0"}, # De-activate - project_activity_two.id => {"custom_field_values"=>{"7" => "1"}, "active"=>"0"} # De-activate - } + put :update, :params => { + :project_id => 1, + :enumerations => { + project_activity.id => {"custom_field_values"=> {"7" => "1"}, "active"=>"0"}, # De-activate + project_activity_two.id => {"custom_field_values"=>{"7" => "1"}, "active"=>"0"} # De-activate + } + } assert_response :redirect assert_redirected_to '/projects/ecookbook/settings/activities' @@ -132,9 +138,15 @@ class ProjectEnumerationsControllerTest < Redmine::ControllerTest assert_equal 3, TimeEntry.where(:activity_id => 9, :project_id => 1).count @request.session[:user_id] = 2 # manager - put :update, :project_id => 1, :enumerations => { - "9"=> {"parent_id"=>"9", "custom_field_values"=>{"7" => "1"}, "active"=>"0"} # Design, De-activate - } + put :update, :params => { + :project_id => 1, + :enumerations => { + "9"=> { + "parent_id"=>"9", "custom_field_values"=> { + "7" => "1"}, "active"=>"0"} # Design, De-activate + + } + } assert_response :redirect # No more TimeEntries using the system activity @@ -160,12 +172,15 @@ class ProjectEnumerationsControllerTest < Redmine::ControllerTest assert_equal 1, TimeEntry.where(:activity_id => 10, :project_id => 1).count @request.session[:user_id] = 2 # manager - put :update, :project_id => 1, :enumerations => { - # Design - "9"=> {"parent_id"=>"9", "custom_field_values"=>{"7" => "1"}, "active"=>"0"}, - # Development, Change custom value - "10"=> {"parent_id"=>"10", "custom_field_values"=>{"7"=>"0"}, "active"=>"1"} - } + put :update, :params => { + :project_id => 1, + :enumerations => { + # Design + "9"=> {"parent_id"=>"9", "custom_field_values"=>{"7" => "1"}, "active"=>"0"}, + # Development, Change custom value + "10"=> {"parent_id"=>"10", "custom_field_values"=>{"7"=>"0"}, "active"=>"1"} + } + } assert_response :redirect # TimeEntries shouldn't have been reassigned on the failed record @@ -195,7 +210,9 @@ class ProjectEnumerationsControllerTest < Redmine::ControllerTest }) assert project_activity_two.save - delete :destroy, :project_id => 1 + delete :destroy, :params => { + :project_id => 1 + } assert_response :redirect assert_redirected_to '/projects/ecookbook/settings/activities' @@ -216,7 +233,9 @@ class ProjectEnumerationsControllerTest < Redmine::ControllerTest update_all("activity_id = '#{project_activity.id}'") assert_equal 3, TimeEntry.where(:activity_id => project_activity.id, :project_id => 1).count - delete :destroy, :project_id => 1 + delete :destroy, :params => { + :project_id => 1 + } assert_response :redirect assert_redirected_to '/projects/ecookbook/settings/activities' diff --git a/test/functional/projects_controller_test.rb b/test/functional/projects_controller_test.rb index 92d5f4a56..be79f5e60 100644 --- a/test/functional/projects_controller_test.rb +++ b/test/functional/projects_controller_test.rb @@ -46,14 +46,20 @@ class ProjectsControllerTest < Redmine::ControllerTest end def test_index_atom - get :index, :format => 'atom' + get :index, :params => { + :format => 'atom' + } assert_response :success assert_select 'feed>title', :text => 'Redmine: Latest projects' assert_select 'feed>entry', :count => Project.visible(User.current).count end def test_autocomplete_js - xhr :get, :autocomplete, :format => 'js', :q => 'coo' + get :autocomplete, :params => { + :format => 'js', + :q => 'coo' + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end @@ -106,7 +112,9 @@ class ProjectsControllerTest < Redmine::ControllerTest Role.find(1).add_permission! :add_subprojects @request.session[:user_id] = 2 - get :new, :parent_id => 'ecookbook' + get :new, :params => { + :parent_id => 'ecookbook' + } assert_response :success assert_select 'select[name=?]', 'project[parent_id]' do @@ -145,18 +153,21 @@ class ProjectsControllerTest < Redmine::ControllerTest test "#create by admin user should create a new project" do @request.session[:user_id] = 1 - post :create, - :project => { - :name => "blog", - :description => "weblog", - :homepage => 'http://weblog', - :identifier => "blog", - :is_public => 1, - :custom_field_values => { '3' => 'Beta' }, - :tracker_ids => ['1', '3'], - # an issue custom field that is not for all project - :issue_custom_field_ids => ['9'], - :enabled_module_names => ['issue_tracking', 'news', 'repository'] + post :create, :params => { + :project => { + :name => "blog", + :description => "weblog", + :homepage => 'http://weblog', + :identifier => "blog", + :is_public => 1, + :custom_field_values => { + '3' => 'Beta' + }, + :tracker_ids => ['1', '3'], + # an issue custom field that is not for all project + :issue_custom_field_ids => ['9'], + :enabled_module_names => ['issue_tracking', 'news', 'repository'] + } } assert_redirected_to '/projects/blog/settings' @@ -177,13 +188,19 @@ class ProjectsControllerTest < Redmine::ControllerTest @request.session[:user_id] = 1 assert_difference 'Project.count' do - post :create, :project => { :name => "blog", - :description => "weblog", - :identifier => "blog", - :is_public => 1, - :custom_field_values => { '3' => 'Beta' }, - :parent_id => 1 - } + post :create, :params => { + :project => { + :name => "blog", + :description => "weblog", + :identifier => "blog", + :is_public => 1, + :custom_field_values => { + '3' => 'Beta' + }, + :parent_id => 1 + + } + } assert_redirected_to '/projects/blog/settings' end @@ -196,7 +213,13 @@ class ProjectsControllerTest < Redmine::ControllerTest @request.session[:user_id] = 1 assert_difference 'Project.count' do - post :create, :project => {:name => "blog", :identifier => "blog"}, :continue => 'Create and continue' + post :create, :params => { + :project => { + :name => "blog", + :identifier => "blog" + }, + :continue => 'Create and continue' + } end assert_redirected_to '/projects/new' end @@ -205,14 +228,20 @@ class ProjectsControllerTest < Redmine::ControllerTest Role.non_member.add_permission! :add_project @request.session[:user_id] = 9 - post :create, :project => { :name => "blog", - :description => "weblog", - :identifier => "blog", - :is_public => 1, - :custom_field_values => { '3' => 'Beta' }, - :tracker_ids => ['1', '3'], - :enabled_module_names => ['issue_tracking', 'news', 'repository'] - } + post :create, :params => { + :project => { + :name => "blog", + :description => "weblog", + :identifier => "blog", + :is_public => 1, + :custom_field_values => { + '3' => 'Beta' + }, + :tracker_ids => ['1', '3'], + :enabled_module_names => ['issue_tracking', 'news', 'repository'] + + } + } assert_redirected_to '/projects/blog/settings' @@ -234,13 +263,19 @@ class ProjectsControllerTest < Redmine::ControllerTest @request.session[:user_id] = 9 assert_no_difference 'Project.count' do - post :create, :project => { :name => "blog", - :description => "weblog", - :identifier => "blog", - :is_public => 1, - :custom_field_values => { '3' => 'Beta' }, - :parent_id => 1 - } + post :create, :params => { + :project => { + :name => "blog", + :description => "weblog", + :identifier => "blog", + :is_public => 1, + :custom_field_values => { + '3' => 'Beta' + }, + :parent_id => 1 + + } + } end assert_response :success assert_select_error /Subproject of is invalid/ @@ -251,13 +286,19 @@ class ProjectsControllerTest < Redmine::ControllerTest Role.find(1).add_permission! :add_subprojects @request.session[:user_id] = 2 - post :create, :project => { :name => "blog", - :description => "weblog", - :identifier => "blog", - :is_public => 1, - :custom_field_values => { '3' => 'Beta' }, - :parent_id => 1 - } + post :create, :params => { + :project => { + :name => "blog", + :description => "weblog", + :identifier => "blog", + :is_public => 1, + :custom_field_values => { + '3' => 'Beta' + }, + :parent_id => 1 + + } + } assert_redirected_to '/projects/blog/settings' project = Project.find_by_name('blog') assert_equal 1, project.parent_id @@ -269,12 +310,18 @@ class ProjectsControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_no_difference 'Project.count' do - post :create, :project => { :name => "blog", - :description => "weblog", - :identifier => "blog", - :is_public => 1, - :custom_field_values => { '3' => 'Beta' } - } + post :create, :params => { + :project => { + :name => "blog", + :description => "weblog", + :identifier => "blog", + :is_public => 1, + :custom_field_values => { + '3' => 'Beta' + } + + } + } end assert_response :success assert_select_error /Subproject of is invalid/ @@ -287,13 +334,19 @@ class ProjectsControllerTest < Redmine::ControllerTest assert !User.find(2).member_of?(Project.find(6)) assert_no_difference 'Project.count' do - post :create, :project => { :name => "blog", - :description => "weblog", - :identifier => "blog", - :is_public => 1, - :custom_field_values => { '3' => 'Beta' }, - :parent_id => 6 - } + post :create, :params => { + :project => { + :name => "blog", + :description => "weblog", + :identifier => "blog", + :is_public => 1, + :custom_field_values => { + '3' => 'Beta' + }, + :parent_id => 6 + + } + } end assert_response :success assert_select_error /Subproject of is invalid/ @@ -307,20 +360,26 @@ class ProjectsControllerTest < Redmine::ControllerTest with_settings :new_project_user_role_id => default_role.id.to_s, :default_projects_modules => %w(news files) do project = new_record(Project) do - post :create, :project => { - :name => "blog1", - :identifier => "blog1", - :enabled_module_names => ["issue_tracking", "repository"] + post :create, :params => { + :project => { + :name => "blog1", + :identifier => "blog1", + :enabled_module_names => ["issue_tracking", "repository"] + + } } end assert_equal %w(files news), project.enabled_module_names.sort default_role.add_permission!(:select_project_modules) project = new_record(Project) do - post :create, :project => { - :name => "blog2", - :identifier => "blog2", - :enabled_module_names => ["issue_tracking", "repository"] + post :create, :params => { + :project => { + :name => "blog2", + :identifier => "blog2", + :enabled_module_names => ["issue_tracking", "repository"] + + } } end assert_equal %w(issue_tracking repository), project.enabled_module_names.sort @@ -333,9 +392,15 @@ class ProjectsControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Project.count' do - post :create, :project => { - :name => 'inherited', :identifier => 'inherited', :parent_id => parent.id, :inherit_members => '1' - } + post :create, :params => { + :project => { + :name => 'inherited', + :identifier => 'inherited', + :parent_id => parent.id, + :inherit_members => '1' + + } + } assert_response 302 end @@ -350,11 +415,14 @@ class ProjectsControllerTest < Redmine::ControllerTest with_settings :default_projects_modules => ['issue_tracking', 'repository'] do @request.session[:user_id] = 1 assert_no_difference 'Project.count' do - post :create, :project => { - :name => "blog", - :identifier => "", - :enabled_module_names => %w(issue_tracking news) - } + post :create, :params => { + :project => { + :name => "blog", + :identifier => "", + :enabled_module_names => %w(issue_tracking news) + + } + } end assert_response :success %w(issue_tracking news).each do |mod| @@ -365,13 +433,17 @@ class ProjectsControllerTest < Redmine::ControllerTest end def test_show_by_id - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :success assert_select '#header h1', :text => "eCookbook" end def test_show_by_identifier - get :show, :id => 'ecookbook' + get :show, :params => { + :id => 'ecookbook' + } assert_response :success assert_select '#header h1', :text => "eCookbook" end @@ -381,14 +453,18 @@ class ProjectsControllerTest < Redmine::ControllerTest p.enabled_module_names = [] p.save! - get :show, :id => 'ecookbook' + get :show, :params => { + :id => 'ecookbook' + } assert_response :success assert_select '#main.nosidebar' end def test_show_should_display_visible_custom_fields ProjectCustomField.find_by_name('Development status').update_attribute :visible, true - get :show, :id => 'ecookbook' + get :show, :params => { + :id => 'ecookbook' + } assert_response :success assert_select 'li', :text => /Development status/ @@ -396,7 +472,9 @@ class ProjectsControllerTest < Redmine::ControllerTest def test_show_should_not_display_hidden_custom_fields ProjectCustomField.find_by_name('Development status').update_attribute :visible, false - get :show, :id => 'ecookbook' + get :show, :params => { + :id => 'ecookbook' + } assert_response :success assert_select 'li', :text => /Development status/, :count => 0 @@ -407,7 +485,9 @@ class ProjectsControllerTest < Redmine::ControllerTest f2 = ProjectCustomField.generate! :field_format => 'list', :possible_values => %w(Baz Qux), :multiple => true project = Project.generate!(:custom_field_values => {f2.id.to_s => %w(Qux)}) - get :show, :id => project.id + get :show, :params => { + :id => project.id + } assert_response :success assert_select 'li', :text => /#{f1.name}/, :count => 0 @@ -417,7 +497,9 @@ class ProjectsControllerTest < Redmine::ControllerTest def test_show_should_not_display_blank_text_custom_fields f1 = ProjectCustomField.generate! :field_format => 'text' - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_response :success assert_select 'li', :text => /#{f1.name}/, :count => 0 @@ -426,7 +508,9 @@ class ProjectsControllerTest < Redmine::ControllerTest def test_show_should_not_fail_when_custom_values_are_nil project = Project.find_by_identifier('ecookbook') project.custom_values.first.update_attribute(:value, nil) - get :show, :id => 'ecookbook' + get :show, :params => { + :id => 'ecookbook' + } assert_response :success end @@ -434,28 +518,36 @@ class ProjectsControllerTest < Redmine::ControllerTest project = Project.find_by_identifier('ecookbook') project.archive! - get :show, :id => 'ecookbook' + get :show, :params => { + :id => 'ecookbook' + } assert_response 403 assert_select 'p', :text => /archived/ assert_not_include project.name, response.body end def test_show_should_not_show_private_subprojects_that_are_not_visible - get :show, :id => 'ecookbook' + get :show, :params => { + :id => 'ecookbook' + } assert_response :success assert_select 'a', :text => /Private child/, :count => 0 end def test_show_should_show_private_subprojects_that_are_visible @request.session[:user_id] = 2 # manager who is a member of the private subproject - get :show, :id => 'ecookbook' + get :show, :params => { + :id => 'ecookbook' + } assert_response :success assert_select 'a', :text => /Private child/ end def test_settings @request.session[:user_id] = 2 # manager - get :settings, :id => 1 + get :settings, :params => { + :id => 1 + } assert_response :success assert_select 'input[name=?]', 'project[name]' @@ -463,7 +555,9 @@ class ProjectsControllerTest < Redmine::ControllerTest def test_settings_of_subproject @request.session[:user_id] = 2 - get :settings, :id => 'private-child' + get :settings, :params => { + :id => 'private-child' + } assert_response :success assert_select 'input[type=checkbox][name=?]', 'project[inherit_members]' @@ -473,14 +567,18 @@ class ProjectsControllerTest < Redmine::ControllerTest Project.find(1).close @request.session[:user_id] = 2 # manager - get :settings, :id => 1 + get :settings, :params => { + :id => 1 + } assert_response 403 end def test_settings_should_be_denied_for_anonymous_on_closed_project Project.find(1).close - get :settings, :id => 1 + get :settings, :params => { + :id => 1 + } assert_response 302 end @@ -489,7 +587,9 @@ class ProjectsControllerTest < Redmine::ControllerTest Role.find(1).add_permission! :manage_wiki @request.session[:user_id] = 2 - get :settings, :id => 1 + get :settings, :params => { + :id => 1 + } assert_response :success assert_select 'form[action=?]', '/projects/ecookbook/wiki' do @@ -500,7 +600,11 @@ class ProjectsControllerTest < Redmine::ControllerTest def test_settings_should_accept_version_status_filter @request.session[:user_id] = 2 - get :settings, :id => 'ecookbook', :tab => 'versions', :version_status => 'locked' + get :settings, :params => { + :id => 'ecookbook', + :tab => 'versions', + :version_status => 'locked' + } assert_response :success assert_select 'select[name=version_status]' do @@ -516,7 +620,12 @@ class ProjectsControllerTest < Redmine::ControllerTest def test_settings_should_accept_version_name_filter @request.session[:user_id] = 2 - get :settings, :id => 'ecookbook', :tab => 'versions', :version_status => '', :version_name => '.1' + get :settings, :params => { + :id => 'ecookbook', + :tab => 'versions', + :version_status => '', + :version_name => '.1' + } assert_response :success assert_select 'input[name=version_name][value=?]', '.1' @@ -534,15 +643,23 @@ class ProjectsControllerTest < Redmine::ControllerTest assert user.reload.locked? @request.session[:user_id] = 2 - get :settings, :id => 'ecookbook', :tab => 'members' + get :settings, :params => { + :id => 'ecookbook', + :tab => 'members' + } assert_response :success assert_select "tr#member-#{member.id}" end def test_update @request.session[:user_id] = 2 # manager - post :update, :id => 1, :project => {:name => 'Test changed name', - :issue_custom_field_ids => ['']} + post :update, :params => { + :id => 1, + :project => { + :name => 'Test changed name', + :issue_custom_field_ids => [''] + } + } assert_redirected_to '/projects/ecookbook/settings' project = Project.find(1) assert_equal 'Test changed name', project.name @@ -550,7 +667,12 @@ class ProjectsControllerTest < Redmine::ControllerTest def test_update_with_failure @request.session[:user_id] = 2 # manager - post :update, :id => 1, :project => {:name => ''} + post :update, :params => { + :id => 1, + :project => { + :name => '' + } + } assert_response :success assert_select_error /name cannot be blank/i end @@ -559,7 +681,12 @@ class ProjectsControllerTest < Redmine::ControllerTest Project.find(1).close @request.session[:user_id] = 2 # manager - post :update, :id => 1, :project => {:name => 'Closed'} + post :update, :params => { + :id => 1, + :project => { + :name => 'Closed' + } + } assert_response 403 assert_equal 'eCookbook', Project.find(1).name end @@ -567,7 +694,12 @@ class ProjectsControllerTest < Redmine::ControllerTest def test_update_should_be_denied_for_anonymous_on_closed_project Project.find(1).close - post :update, :id => 1, :project => {:name => 'Closed'} + post :update, :params => { + :id => 1, + :project => { + :name => 'Closed' + } + } assert_response 302 assert_equal 'eCookbook', Project.find(1).name end @@ -578,7 +710,12 @@ class ProjectsControllerTest < Redmine::ControllerTest User.add_to_project(user, child, Role.generate!(:permissions => [:edit_project])) @request.session[:user_id] = user.id - post :update, :id => child.id, :project => {:name => 'Updated'} + post :update, :params => { + :id => child.id, + :project => { + :name => 'Updated' + } + } assert_response 302 assert_match /Successful update/, flash[:notice] end @@ -587,7 +724,10 @@ class ProjectsControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 Project.find(1).enabled_module_names = ['issue_tracking', 'news'] - post :modules, :id => 1, :enabled_module_names => ['issue_tracking', 'repository', 'documents'] + post :modules, :params => { + :id => 1, + :enabled_module_names => ['issue_tracking', 'repository', 'documents'] + } assert_redirected_to '/projects/ecookbook/settings/modules' assert_equal ['documents', 'issue_tracking', 'repository'], Project.find(1).enabled_module_names.sort end @@ -596,7 +736,9 @@ class ProjectsControllerTest < Redmine::ControllerTest @request.session[:user_id] = 1 # admin assert_no_difference 'Project.count' do - delete :destroy, :id => 2 + delete :destroy, :params => { + :id => 2 + } assert_response :success end assert_select '.warning', :text => /Are you sure you want to delete this project/ @@ -606,7 +748,9 @@ class ProjectsControllerTest < Redmine::ControllerTest @request.session[:user_id] = 1 # admin assert_no_difference 'Project.count' do - delete :destroy, :id => 1 + delete :destroy, :params => { + :id => 1 + } assert_response :success end assert_select 'strong', @@ -619,7 +763,10 @@ class ProjectsControllerTest < Redmine::ControllerTest @request.session[:user_id] = 1 # admin assert_difference 'Project.count', -5 do - delete :destroy, :id => 1, :confirm => 1 + delete :destroy, :params => { + :id => 1, + :confirm => 1 + } assert_redirected_to '/admin/projects' end assert_nil Project.find_by_id(1) @@ -627,7 +774,9 @@ class ProjectsControllerTest < Redmine::ControllerTest def test_archive @request.session[:user_id] = 1 # admin - post :archive, :id => 1 + post :archive, :params => { + :id => 1 + } assert_redirected_to '/admin/projects' assert !Project.find(1).active? end @@ -635,7 +784,9 @@ class ProjectsControllerTest < Redmine::ControllerTest def test_archive_with_failure @request.session[:user_id] = 1 Project.any_instance.stubs(:archive).returns(false) - post :archive, :id => 1 + post :archive, :params => { + :id => 1 + } assert_redirected_to '/admin/projects' assert_match /project cannot be archived/i, flash[:error] end @@ -643,14 +794,18 @@ class ProjectsControllerTest < Redmine::ControllerTest def test_unarchive @request.session[:user_id] = 1 # admin Project.find(1).archive - post :unarchive, :id => 1 + post :unarchive, :params => { + :id => 1 + } assert_redirected_to '/admin/projects' assert Project.find(1).active? end def test_close @request.session[:user_id] = 2 - post :close, :id => 1 + post :close, :params => { + :id => 1 + } assert_redirected_to '/projects/ecookbook' assert_equal Project::STATUS_CLOSED, Project.find(1).status end @@ -658,7 +813,9 @@ class ProjectsControllerTest < Redmine::ControllerTest def test_reopen Project.find(1).close @request.session[:user_id] = 2 - post :reopen, :id => 1 + post :reopen, :params => { + :id => 1 + } assert_redirected_to '/projects/ecookbook' assert Project.find(1).active? end @@ -668,7 +825,9 @@ class ProjectsControllerTest < Redmine::ControllerTest parent = nil 6.times do |i| p = Project.generate_with_parent!(parent) - get :show, :id => p + get :show, :params => { + :id => p + } assert_select '#header h1' do assert_select 'a', :count => [i, 3].min end @@ -681,7 +840,9 @@ class ProjectsControllerTest < Redmine::ControllerTest @request.session[:user_id] = 1 # admin orig = Project.find(1) - get :copy, :id => orig.id + get :copy, :params => { + :id => orig.id + } assert_response :success assert_select 'textarea[name=?]', 'project[description]', :text => orig.description @@ -690,7 +851,9 @@ class ProjectsControllerTest < Redmine::ControllerTest def test_get_copy_with_invalid_source_should_respond_with_404 @request.session[:user_id] = 1 - get :copy, :id => 99 + get :copy, :params => { + :id => 99 + } assert_response 404 end @@ -700,7 +863,9 @@ class ProjectsControllerTest < Redmine::ControllerTest source = Project.generate!(:issue_custom_fields => [field1]) @request.session[:user_id] = 1 - get :copy, :id => source.id + get :copy, :params => { + :id => source.id + } assert_response :success assert_select 'fieldset#project_issue_custom_fields' do assert_select 'input[type=checkbox][value=?][checked=checked]', field1.id.to_s @@ -713,14 +878,17 @@ class ProjectsControllerTest < Redmine::ControllerTest CustomField.delete_all assert_difference 'Project.count' do - post :copy, :id => 1, - :project => { - :name => 'Copy', - :identifier => 'unique-copy', - :tracker_ids => ['1', '2', '3', ''], - :enabled_module_names => %w(issue_tracking time_tracking) - }, - :only => %w(issues versions) + post :copy, :params => { + :id => 1, + :project => { + :name => 'Copy', + :identifier => 'unique-copy', + :tracker_ids => ['1', '2', '3', ''], + :enabled_module_names => %w(issue_tracking time_tracking) + + }, + :only => %w(issues versions) + } end project = Project.find('unique-copy') source = Project.find(1) @@ -733,45 +901,72 @@ class ProjectsControllerTest < Redmine::ControllerTest def test_post_copy_should_redirect_to_settings_when_successful @request.session[:user_id] = 1 # admin - post :copy, :id => 1, :project => {:name => 'Copy', :identifier => 'unique-copy'} + post :copy, :params => { + :id => 1, + :project => { + :name => 'Copy', + :identifier => 'unique-copy' + } + } assert_response :redirect assert_redirected_to :controller => 'projects', :action => 'settings', :id => 'unique-copy' end def test_post_copy_with_failure @request.session[:user_id] = 1 - post :copy, :id => 1, :project => {:name => 'Copy', :identifier => ''} + post :copy, :params => { + :id => 1, + :project => { + :name => 'Copy', + :identifier => '' + } + } assert_response :success assert_select_error /Identifier cannot be blank/ end def test_jump_without_project_id_should_redirect_to_active_tab - get :index, :jump => 'issues' + get :index, :params => { + :jump => 'issues' + } assert_redirected_to '/issues' end def test_jump_should_not_redirect_to_unknown_tab - get :index, :jump => 'foobar' + get :index, :params => { + :jump => 'foobar' + } assert_response :success end def test_jump_should_redirect_to_active_tab - get :show, :id => 1, :jump => 'issues' + get :show, :params => { + :id => 1, + :jump => 'issues' + } assert_redirected_to '/projects/ecookbook/issues' end def test_jump_should_not_redirect_to_inactive_tab - get :show, :id => 3, :jump => 'documents' + get :show, :params => { + :id => 3, + :jump => 'documents' + } assert_response :success end def test_jump_should_not_redirect_to_unknown_tab - get :show, :id => 3, :jump => 'foobar' + get :show, :params => { + :id => 3, + :jump => 'foobar' + } assert_response :success end def test_body_should_have_project_css_class - get :show, :id => 1 + get :show, :params => { + :id => 1 + } assert_select 'body.project-ecookbook' end end diff --git a/test/functional/queries_controller_test.rb b/test/functional/queries_controller_test.rb index cabdab968..8bc42e890 100644 --- a/test/functional/queries_controller_test.rb +++ b/test/functional/queries_controller_test.rb @@ -37,7 +37,9 @@ class QueriesControllerTest < Redmine::ControllerTest def test_new_project_query @request.session[:user_id] = 2 - get :new, :project_id => 1 + get :new, :params => { + :project_id => 1 + } assert_response :success assert_select 'input[name=?][value="0"][checked=checked]', 'query[visibility]' @@ -59,26 +61,38 @@ class QueriesControllerTest < Redmine::ControllerTest def test_new_on_invalid_project @request.session[:user_id] = 2 - get :new, :project_id => 'invalid' + get :new, :params => { + :project_id => 'invalid' + } assert_response 404 end def test_new_time_entry_query @request.session[:user_id] = 2 - get :new, :project_id => 1, :type => 'TimeEntryQuery' + get :new, :params => { + :project_id => 1, + :type => 'TimeEntryQuery' + } assert_response :success assert_select 'input[name=type][value=?]', 'TimeEntryQuery' end def test_create_project_public_query @request.session[:user_id] = 2 - post :create, - :project_id => 'ecookbook', - :default_columns => '1', - :f => ["status_id", "assigned_to_id"], - :op => {"assigned_to_id" => "=", "status_id" => "o"}, - :v => { "assigned_to_id" => ["1"], "status_id" => ["1"]}, - :query => {"name" => "test_new_project_public_query", "visibility" => "2"} + post :create, :params => { + :project_id => 'ecookbook', + :default_columns => '1', + :f => ["status_id", "assigned_to_id"], + :op => { + "assigned_to_id" => "=", "status_id" => "o" + }, + :v => { + "assigned_to_id" => ["1"], "status_id" => ["1"] + }, + :query => { + "name" => "test_new_project_public_query", "visibility" => "2" + } + } q = Query.find_by_name('test_new_project_public_query') assert_redirected_to :controller => 'issues', :action => 'index', :project_id => 'ecookbook', :query_id => q @@ -89,13 +103,20 @@ class QueriesControllerTest < Redmine::ControllerTest def test_create_project_private_query @request.session[:user_id] = 3 - post :create, - :project_id => 'ecookbook', - :default_columns => '1', - :fields => ["status_id", "assigned_to_id"], - :operators => {"assigned_to_id" => "=", "status_id" => "o"}, - :values => { "assigned_to_id" => ["1"], "status_id" => ["1"]}, - :query => {"name" => "test_new_project_private_query", "visibility" => "0"} + post :create, :params => { + :project_id => 'ecookbook', + :default_columns => '1', + :fields => ["status_id", "assigned_to_id"], + :operators => { + "assigned_to_id" => "=", "status_id" => "o" + }, + :values => { + "assigned_to_id" => ["1"], "status_id" => ["1"] + }, + :query => { + "name" => "test_new_project_private_query", "visibility" => "0" + } + } q = Query.find_by_name('test_new_project_private_query') assert_redirected_to :controller => 'issues', :action => 'index', :project_id => 'ecookbook', :query_id => q @@ -106,13 +127,20 @@ class QueriesControllerTest < Redmine::ControllerTest def test_create_project_roles_query @request.session[:user_id] = 2 - post :create, - :project_id => 'ecookbook', - :default_columns => '1', - :fields => ["status_id", "assigned_to_id"], - :operators => {"assigned_to_id" => "=", "status_id" => "o"}, - :values => { "assigned_to_id" => ["1"], "status_id" => ["1"]}, - :query => {"name" => "test_create_project_roles_query", "visibility" => "1", "role_ids" => ["1", "2", ""]} + post :create, :params => { + :project_id => 'ecookbook', + :default_columns => '1', + :fields => ["status_id", "assigned_to_id"], + :operators => { + "assigned_to_id" => "=", "status_id" => "o" + }, + :values => { + "assigned_to_id" => ["1"], "status_id" => ["1"] + }, + :query => { + "name" => "test_create_project_roles_query", "visibility" => "1", "role_ids" => ["1", "2", ""] + } + } q = Query.find_by_name('test_create_project_roles_query') assert_redirected_to :controller => 'issues', :action => 'index', :project_id => 'ecookbook', :query_id => q @@ -122,12 +150,19 @@ class QueriesControllerTest < Redmine::ControllerTest def test_create_global_private_query_with_custom_columns @request.session[:user_id] = 3 - post :create, - :fields => ["status_id", "assigned_to_id"], - :operators => {"assigned_to_id" => "=", "status_id" => "o"}, - :values => { "assigned_to_id" => ["me"], "status_id" => ["1"]}, - :query => {"name" => "test_new_global_private_query", "visibility" => "0"}, - :c => ["", "tracker", "subject", "priority", "category"] + post :create, :params => { + :fields => ["status_id", "assigned_to_id"], + :operators => { + "assigned_to_id" => "=", "status_id" => "o" + }, + :values => { + "assigned_to_id" => ["me"], "status_id" => ["1"] + }, + :query => { + "name" => "test_new_global_private_query", "visibility" => "0" + }, + :c => ["", "tracker", "subject", "priority", "category"] + } q = Query.find_by_name('test_new_global_private_query') assert_redirected_to :controller => 'issues', :action => 'index', :project_id => nil, :query_id => q @@ -139,11 +174,18 @@ class QueriesControllerTest < Redmine::ControllerTest def test_create_global_query_with_custom_filters @request.session[:user_id] = 3 - post :create, - :fields => ["assigned_to_id"], - :operators => {"assigned_to_id" => "="}, - :values => { "assigned_to_id" => ["me"]}, - :query => {"name" => "test_new_global_query"} + post :create, :params => { + :fields => ["assigned_to_id"], + :operators => { + "assigned_to_id" => "=" + }, + :values => { + "assigned_to_id" => ["me"] + }, + :query => { + "name" => "test_new_global_query" + } + } q = Query.find_by_name('test_new_global_query') assert_redirected_to :controller => 'issues', :action => 'index', :project_id => nil, :query_id => q @@ -155,13 +197,21 @@ class QueriesControllerTest < Redmine::ControllerTest def test_create_with_sort @request.session[:user_id] = 1 - post :create, - :default_columns => '1', - :operators => {"status_id" => "o"}, - :values => {"status_id" => ["1"]}, - :query => {:name => "test_new_with_sort", - :visibility => "2", - :sort_criteria => {"0" => ["due_date", "desc"], "1" => ["tracker", ""]}} + post :create, :params => { + :default_columns => '1', + :operators => { + "status_id" => "o" + }, + :values => { + "status_id" => ["1"] + }, + :query => { + :name => "test_new_with_sort", + :visibility => "2", + :sort_criteria => { + "0" => ["due_date", "desc"], "1" => ["tracker", ""]} + } + } query = Query.find_by_name("test_new_with_sort") assert_not_nil query @@ -171,7 +221,12 @@ class QueriesControllerTest < Redmine::ControllerTest def test_create_with_failure @request.session[:user_id] = 2 assert_no_difference '::Query.count' do - post :create, :project_id => 'ecookbook', :query => {:name => ''} + post :create, :params => { + :project_id => 'ecookbook', + :query => { + :name => '' + } + } end assert_response :success @@ -181,13 +236,20 @@ class QueriesControllerTest < Redmine::ControllerTest def test_create_global_query_from_gantt @request.session[:user_id] = 1 assert_difference 'IssueQuery.count' do - post :create, - :gantt => 1, - :operators => {"status_id" => "o"}, - :values => {"status_id" => ["1"]}, - :query => {:name => "test_create_from_gantt", - :draw_relations => '1', - :draw_progress_line => '1'} + post :create, :params => { + :gantt => 1, + :operators => { + "status_id" => "o" + }, + :values => { + "status_id" => ["1"] + }, + :query => { + :name => "test_create_from_gantt", + :draw_relations => '1', + :draw_progress_line => '1' + } + } assert_response 302 end query = IssueQuery.order('id DESC').first @@ -199,14 +261,21 @@ class QueriesControllerTest < Redmine::ControllerTest def test_create_project_query_from_gantt @request.session[:user_id] = 1 assert_difference 'IssueQuery.count' do - post :create, - :project_id => 'ecookbook', - :gantt => 1, - :operators => {"status_id" => "o"}, - :values => {"status_id" => ["1"]}, - :query => {:name => "test_create_from_gantt", - :draw_relations => '0', - :draw_progress_line => '0'} + post :create, :params => { + :project_id => 'ecookbook', + :gantt => 1, + :operators => { + "status_id" => "o" + }, + :values => { + "status_id" => ["1"] + }, + :query => { + :name => "test_create_from_gantt", + :draw_relations => '0', + :draw_progress_line => '0' + } + } assert_response 302 end query = IssueQuery.order('id DESC').first @@ -218,9 +287,12 @@ class QueriesControllerTest < Redmine::ControllerTest def test_create_project_public_query_should_force_private_without_manage_public_queries_permission @request.session[:user_id] = 3 query = new_record(Query) do - post :create, - :project_id => 'ecookbook', - :query => {"name" => "name", "visibility" => "2"} + post :create, :params => { + :project_id => 'ecookbook', + :query => { + "name" => "name", "visibility" => "2" + } + } assert_response 302 end assert_not_nil query.project @@ -230,9 +302,13 @@ class QueriesControllerTest < Redmine::ControllerTest def test_create_global_public_query_should_force_private_without_manage_public_queries_permission @request.session[:user_id] = 3 query = new_record(Query) do - post :create, - :project_id => 'ecookbook', :query_is_for_all => '1', - :query => {"name" => "name", "visibility" => "2"} + post :create, :params => { + :project_id => 'ecookbook', + :query_is_for_all => '1', + :query => { + "name" => "name", "visibility" => "2" + } + } assert_response 302 end assert_nil query.project @@ -242,9 +318,12 @@ class QueriesControllerTest < Redmine::ControllerTest def test_create_project_public_query_with_manage_public_queries_permission @request.session[:user_id] = 2 query = new_record(Query) do - post :create, - :project_id => 'ecookbook', - :query => {"name" => "name", "visibility" => "2"} + post :create, :params => { + :project_id => 'ecookbook', + :query => { + "name" => "name", "visibility" => "2" + } + } assert_response 302 end assert_not_nil query.project @@ -254,9 +333,13 @@ class QueriesControllerTest < Redmine::ControllerTest def test_create_global_public_query_should_force_private_with_manage_public_queries_permission @request.session[:user_id] = 2 query = new_record(Query) do - post :create, - :project_id => 'ecookbook', :query_is_for_all => '1', - :query => {"name" => "name", "visibility" => "2"} + post :create, :params => { + :project_id => 'ecookbook', + :query_is_for_all => '1', + :query => { + "name" => "name", "visibility" => "2" + } + } assert_response 302 end assert_nil query.project @@ -266,9 +349,13 @@ class QueriesControllerTest < Redmine::ControllerTest def test_create_global_public_query_by_admin @request.session[:user_id] = 1 query = new_record(Query) do - post :create, - :project_id => 'ecookbook', :query_is_for_all => '1', - :query => {"name" => "name", "visibility" => "2"} + post :create, :params => { + :project_id => 'ecookbook', + :query_is_for_all => '1', + :query => { + "name" => "name", "visibility" => "2" + } + } assert_response 302 end assert_nil query.project @@ -279,14 +366,21 @@ class QueriesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 q = new_record(TimeEntryQuery) do - post :create, - :project_id => 'ecookbook', - :type => 'TimeEntryQuery', - :default_columns => '1', - :f => ["spent_on"], - :op => {"spent_on" => "="}, - :v => { "spent_on" => ["2016-07-14"]}, - :query => {"name" => "test_new_project_public_query", "visibility" => "2"} + post :create, :params => { + :project_id => 'ecookbook', + :type => 'TimeEntryQuery', + :default_columns => '1', + :f => ["spent_on"], + :op => { + "spent_on" => "=" + }, + :v => { + "spent_on" => ["2016-07-14"] + }, + :query => { + "name" => "test_new_project_public_query", "visibility" => "2" + } + } end assert_redirected_to :controller => 'timelog', :action => 'index', :project_id => 'ecookbook', :query_id => q.id @@ -297,7 +391,9 @@ class QueriesControllerTest < Redmine::ControllerTest def test_edit_global_public_query @request.session[:user_id] = 1 - get :edit, :id => 4 + get :edit, :params => { + :id => 4 + } assert_response :success assert_select 'input[name=?][value="2"][checked=checked]', 'query[visibility]' @@ -306,7 +402,9 @@ class QueriesControllerTest < Redmine::ControllerTest def test_edit_global_private_query @request.session[:user_id] = 3 - get :edit, :id => 3 + get :edit, :params => { + :id => 3 + } assert_response :success assert_select 'input[name=?]', 'query[visibility]', 0 @@ -315,7 +413,9 @@ class QueriesControllerTest < Redmine::ControllerTest def test_edit_project_private_query @request.session[:user_id] = 3 - get :edit, :id => 2 + get :edit, :params => { + :id => 2 + } assert_response :success assert_select 'input[name=?]', 'query[visibility]', 0 @@ -324,7 +424,9 @@ class QueriesControllerTest < Redmine::ControllerTest def test_edit_project_public_query @request.session[:user_id] = 2 - get :edit, :id => 1 + get :edit, :params => { + :id => 1 + } assert_response :success assert_select 'input[name=?][value="2"][checked=checked]', 'query[visibility]' @@ -333,7 +435,9 @@ class QueriesControllerTest < Redmine::ControllerTest def test_edit_sort_criteria @request.session[:user_id] = 1 - get :edit, :id => 5 + get :edit, :params => { + :id => 5 + } assert_response :success assert_select 'select[name=?]', 'query[sort_criteria][0][]' do @@ -344,19 +448,28 @@ class QueriesControllerTest < Redmine::ControllerTest def test_edit_invalid_query @request.session[:user_id] = 2 - get :edit, :id => 99 + get :edit, :params => { + :id => 99 + } assert_response 404 end def test_udpate_global_private_query @request.session[:user_id] = 3 - put :update, - :id => 3, - :default_columns => '1', - :fields => ["status_id", "assigned_to_id"], - :operators => {"assigned_to_id" => "=", "status_id" => "o"}, - :values => { "assigned_to_id" => ["me"], "status_id" => ["1"]}, - :query => {"name" => "test_edit_global_private_query", "visibility" => "2"} + put :update, :params => { + :id => 3, + :default_columns => '1', + :fields => ["status_id", "assigned_to_id"], + :operators => { + "assigned_to_id" => "=", "status_id" => "o" + }, + :values => { + "assigned_to_id" => ["me"], "status_id" => ["1"] + }, + :query => { + "name" => "test_edit_global_private_query", "visibility" => "2" + } + } assert_redirected_to :controller => 'issues', :action => 'index', :query_id => 3 q = Query.find_by_name('test_edit_global_private_query') @@ -367,13 +480,20 @@ class QueriesControllerTest < Redmine::ControllerTest def test_update_global_public_query @request.session[:user_id] = 1 - put :update, - :id => 4, - :default_columns => '1', - :fields => ["status_id", "assigned_to_id"], - :operators => {"assigned_to_id" => "=", "status_id" => "o"}, - :values => { "assigned_to_id" => ["1"], "status_id" => ["1"]}, - :query => {"name" => "test_edit_global_public_query", "visibility" => "2"} + put :update, :params => { + :id => 4, + :default_columns => '1', + :fields => ["status_id", "assigned_to_id"], + :operators => { + "assigned_to_id" => "=", "status_id" => "o" + }, + :values => { + "assigned_to_id" => ["1"], "status_id" => ["1"] + }, + :query => { + "name" => "test_edit_global_public_query", "visibility" => "2" + } + } assert_redirected_to :controller => 'issues', :action => 'index', :query_id => 4 q = Query.find_by_name('test_edit_global_public_query') @@ -384,28 +504,40 @@ class QueriesControllerTest < Redmine::ControllerTest def test_update_with_failure @request.session[:user_id] = 1 - put :update, :id => 4, :query => {:name => ''} + put :update, :params => { + :id => 4, + :query => { + :name => '' + } + } assert_response :success assert_select_error /Name cannot be blank/ end def test_destroy @request.session[:user_id] = 2 - delete :destroy, :id => 1 + delete :destroy, :params => { + :id => 1 + } assert_redirected_to :controller => 'issues', :action => 'index', :project_id => 'ecookbook', :set_filter => 1, :query_id => nil assert_nil Query.find_by_id(1) end def test_backslash_should_be_escaped_in_filters @request.session[:user_id] = 2 - get :new, :subject => 'foo/bar' + get :new, :params => { + :subject => 'foo/bar' + } assert_response :success assert_include 'addFilter("subject", "=", ["foo\/bar"]);', response.body end def test_filter_with_project_id_should_return_filter_values @request.session[:user_id] = 2 - get :filter, :project_id => 1, :name => 'fixed_version_id' + get :filter, :params => { + :project_id => 1, + :name => 'fixed_version_id' + } assert_response :success assert_equal 'application/json', response.content_type @@ -415,7 +547,9 @@ class QueriesControllerTest < Redmine::ControllerTest def test_filter_without_project_id_should_return_filter_values @request.session[:user_id] = 2 - get :filter, :name => 'fixed_version_id' + get :filter, :params => { + :name => 'fixed_version_id' + } assert_response :success assert_equal 'application/json', response.content_type diff --git a/test/functional/reports_controller_test.rb b/test/functional/reports_controller_test.rb index 4d999d881..2b8ed911a 100644 --- a/test/functional/reports_controller_test.rb +++ b/test/functional/reports_controller_test.rb @@ -28,13 +28,18 @@ class ReportsControllerTest < Redmine::ControllerTest :versions def test_get_issue_report - get :issue_report, :id => 1 + get :issue_report, :params => { + :id => 1 + } assert_response :success end def test_get_issue_report_details %w(tracker version priority category assigned_to author subproject).each do |detail| - get :issue_report_details, :id => 1, :detail => detail + get :issue_report_details, :params => { + :id => 1, + :detail => detail + } assert_response :success end end @@ -46,7 +51,10 @@ class ReportsControllerTest < Redmine::ControllerTest Issue.generate!(:tracker_id => 1, :status_id => 5) Issue.generate!(:tracker_id => 2) - get :issue_report_details, :id => 1, :detail => 'tracker' + get :issue_report_details, :params => { + :id => 1, + :detail => 'tracker' + } assert_select 'table.list tbody :nth-child(1)' do assert_select 'td', :text => 'Bug' assert_select ':nth-child(2)', :text => '2' # status:1 @@ -58,7 +66,10 @@ class ReportsControllerTest < Redmine::ControllerTest end def test_get_issue_report_details_with_an_invalid_detail - get :issue_report_details, :id => 1, :detail => 'invalid' + get :issue_report_details, :params => { + :id => 1, + :detail => 'invalid' + } assert_response 404 end end diff --git a/test/functional/repositories_bazaar_controller_test.rb b/test/functional/repositories_bazaar_controller_test.rb index 8938c97a2..e59407703 100644 --- a/test/functional/repositories_bazaar_controller_test.rb +++ b/test/functional/repositories_bazaar_controller_test.rb @@ -42,7 +42,10 @@ class RepositoriesBazaarControllerTest < Redmine::ControllerTest def test_get_new @request.session[:user_id] = 1 @project.repository.destroy - get :new, :project_id => 'subproject1', :repository_scm => 'Bazaar' + get :new, :params => { + :project_id => 'subproject1', + :repository_scm => 'Bazaar' + } assert_response :success assert_select 'select[name=?]', 'repository_scm' do assert_select 'option[value=?][selected=selected]', 'Bazaar' @@ -50,7 +53,9 @@ class RepositoriesBazaarControllerTest < Redmine::ControllerTest end def test_browse_root - get :show, :id => PRJ_ID + get :show, :params => { + :id => PRJ_ID + } assert_response :success assert_select 'table.entries tbody' do assert_select 'tr', 2 @@ -60,7 +65,10 @@ class RepositoriesBazaarControllerTest < Redmine::ControllerTest end def test_browse_directory - get :show, :id => PRJ_ID, :path => repository_path_hash(['directory'])[:param] + get :show, :params => { + :id => PRJ_ID, + :path => repository_path_hash(['directory'])[:param] + } assert_response :success assert_select 'table.entries tbody' do assert_select 'tr', 3 @@ -71,8 +79,11 @@ class RepositoriesBazaarControllerTest < Redmine::ControllerTest end def test_browse_at_given_revision - get :show, :id => PRJ_ID, :path => repository_path_hash([])[:param], + get :show, :params => { + :id => PRJ_ID, + :path => repository_path_hash([])[:param], :rev => 3 + } assert_response :success assert_select 'table.entries tbody' do assert_select 'tr', 4 @@ -84,32 +95,40 @@ class RepositoriesBazaarControllerTest < Redmine::ControllerTest end def test_changes - get :changes, :id => PRJ_ID, + get :changes, :params => { + :id => PRJ_ID, :path => repository_path_hash(['doc-mkdir.txt'])[:param] + } assert_response :success assert_select 'h2', :text => /doc-mkdir.txt/ end def test_entry_show - get :entry, :id => PRJ_ID, + get :entry, :params => { + :id => PRJ_ID, :path => repository_path_hash(['directory', 'doc-ls.txt'])[:param] + } assert_response :success # Line 19 assert_select 'tr#L29 td.line-code', :text => /Show help message/ end def test_entry_download - get :entry, :id => PRJ_ID, + get :entry, :params => { + :id => PRJ_ID, :path => repository_path_hash(['directory', 'doc-ls.txt'])[:param], :format => 'raw' + } assert_response :success # File content assert @response.body.include?('Show help message') end def test_directory_entry - get :entry, :id => PRJ_ID, + get :entry, :params => { + :id => PRJ_ID, :path => repository_path_hash(['directory'])[:param] + } assert_response :success assert_select 'table.entries tbody' end @@ -117,7 +136,11 @@ class RepositoriesBazaarControllerTest < Redmine::ControllerTest def test_diff # Full diff of changeset 3 ['inline', 'sbs'].each do |dt| - get :diff, :id => PRJ_ID, :rev => 3, :type => dt + get :diff, :params => { + :id => PRJ_ID, + :rev => 3, + :type => dt + } assert_response :success # Line 11 removed assert_select 'th.line-num:contains(11) ~ td.diff_out', :text => /Display more information/ @@ -125,8 +148,10 @@ class RepositoriesBazaarControllerTest < Redmine::ControllerTest end def test_annotate - get :annotate, :id => PRJ_ID, + get :annotate, :params => { + :id => PRJ_ID, :path => repository_path_hash(['doc-mkdir.txt'])[:param] + } assert_response :success assert_select "th.line-num", :text => '2' do @@ -147,8 +172,11 @@ class RepositoriesBazaarControllerTest < Redmine::ControllerTest :identifier => 'author_escaping', :log_encoding => 'UTF-8') assert repository - get :annotate, :id => PRJ_ID, :repository_id => 'author_escaping', + get :annotate, :params => { + :id => PRJ_ID, + :repository_id => 'author_escaping', :path => repository_path_hash(['author-escaping-test.txt'])[:param] + } assert_response :success assert_select "th.line-num", :text => '1' do @@ -175,8 +203,11 @@ class RepositoriesBazaarControllerTest < Redmine::ControllerTest :identifier => 'author_non_ascii', :log_encoding => log_encoding) assert repository - get :annotate, :id => PRJ_ID, :repository_id => 'author_non_ascii', + get :annotate, :params => { + :id => PRJ_ID, + :repository_id => 'author_non_ascii', :path => repository_path_hash(['author-non-ascii-test.txt'])[:param] + } assert_response :success assert_select "th.line-num", :text => '1' do @@ -198,7 +229,9 @@ class RepositoriesBazaarControllerTest < Redmine::ControllerTest assert @repository.changesets.count > 0 assert_difference 'Repository.count', -1 do - delete :destroy, :id => @repository.id + delete :destroy, :params => { + :id => @repository.id + } end assert_response 302 @project.reload @@ -217,7 +250,9 @@ class RepositoriesBazaarControllerTest < Redmine::ControllerTest assert_equal 0, @repository.changesets.count assert_difference 'Repository.count', -1 do - delete :destroy, :id => @repository.id + delete :destroy, :params => { + :id => @repository.id + } end assert_response 302 @project.reload diff --git a/test/functional/repositories_controller_test.rb b/test/functional/repositories_controller_test.rb index 5fec94c37..72ed05a2c 100644 --- a/test/functional/repositories_controller_test.rb +++ b/test/functional/repositories_controller_test.rb @@ -28,7 +28,9 @@ class RepositoriesControllerTest < Redmine::ControllerTest def test_new @request.session[:user_id] = 1 - get :new, :project_id => 'subproject1' + get :new, :params => { + :project_id => 'subproject1' + } assert_response :success assert_select 'select[name=?]', 'repository_scm' do assert_select 'option[value=?][selected=selected]', 'Subversion' @@ -39,7 +41,9 @@ class RepositoriesControllerTest < Redmine::ControllerTest def test_new_should_propose_enabled_scm_only @request.session[:user_id] = 1 with_settings :enabled_scm => ['Mercurial', 'Git'] do - get :new, :project_id => 'subproject1' + get :new, :params => { + :project_id => 'subproject1' + } end assert_response :success @@ -52,7 +56,10 @@ class RepositoriesControllerTest < Redmine::ControllerTest def test_get_new_with_type @request.session[:user_id] = 1 - get :new, :project_id => 'subproject1', :repository_scm => 'Git' + get :new, :params => { + :project_id => 'subproject1', + :repository_scm => 'Git' + } assert_response :success assert_select 'select[name=?]', 'repository_scm' do @@ -63,9 +70,15 @@ class RepositoriesControllerTest < Redmine::ControllerTest def test_create @request.session[:user_id] = 1 assert_difference 'Repository.count' do - post :create, :project_id => 'subproject1', - :repository_scm => 'Subversion', - :repository => {:url => 'file:///test', :is_default => '1', :identifier => ''} + post :create, :params => { + :project_id => 'subproject1', + :repository_scm => 'Subversion', + :repository => { + :url => 'file:///test', + :is_default => '1', + :identifier => '' + } + } end assert_response 302 repository = Repository.order('id DESC').first @@ -76,9 +89,13 @@ class RepositoriesControllerTest < Redmine::ControllerTest def test_create_with_failure @request.session[:user_id] = 1 assert_no_difference 'Repository.count' do - post :create, :project_id => 'subproject1', - :repository_scm => 'Subversion', - :repository => {:url => 'invalid'} + post :create, :params => { + :project_id => 'subproject1', + :repository_scm => 'Subversion', + :repository => { + :url => 'invalid' + } + } end assert_response :success assert_select_error /URL is invalid/ @@ -89,21 +106,33 @@ class RepositoriesControllerTest < Redmine::ControllerTest def test_edit @request.session[:user_id] = 1 - get :edit, :id => 11 + get :edit, :params => { + :id => 11 + } assert_response :success assert_select 'input[name=?][value=?][disabled=disabled]', 'repository[url]', 'svn://localhost/test' end def test_update @request.session[:user_id] = 1 - put :update, :id => 11, :repository => {:password => 'test_update'} + put :update, :params => { + :id => 11, + :repository => { + :password => 'test_update' + } + } assert_response 302 assert_equal 'test_update', Repository.find(11).password end def test_update_with_failure @request.session[:user_id] = 1 - put :update, :id => 11, :repository => {:password => 'x'*260} + put :update, :params => { + :id => 11, + :repository => { + :password => 'x'*260 + } + } assert_response :success assert_select_error /Password is too long/ end @@ -111,7 +140,9 @@ class RepositoriesControllerTest < Redmine::ControllerTest def test_destroy @request.session[:user_id] = 1 assert_difference 'Repository.count', -1 do - delete :destroy, :id => 11 + delete :destroy, :params => { + :id => 11 + } end assert_response 302 assert_nil Repository.find_by_id(11) @@ -121,7 +152,9 @@ class RepositoriesControllerTest < Redmine::ControllerTest Repository::Subversion.any_instance.expects(:fetch_changesets).once with_settings :autofetch_changesets => '1' do - get :show, :id => 1 + get :show, :params => { + :id => 1 + } end end @@ -129,7 +162,9 @@ class RepositoriesControllerTest < Redmine::ControllerTest Repository::Subversion.any_instance.expects(:fetch_changesets).never with_settings :autofetch_changesets => '0' do - get :show, :id => 1 + get :show, :params => { + :id => 1 + } end end @@ -138,12 +173,16 @@ class RepositoriesControllerTest < Redmine::ControllerTest Project.find(1).close with_settings :autofetch_changesets => '1' do - get :show, :id => 1 + get :show, :params => { + :id => 1 + } end end def test_revisions - get :revisions, :id => 1 + get :revisions, :params => { + :id => 1 + } assert_response :success assert_select 'table.changesets' end @@ -151,18 +190,27 @@ class RepositoriesControllerTest < Redmine::ControllerTest def test_revisions_for_other_repository repository = Repository::Subversion.create!(:project_id => 1, :identifier => 'foo', :url => 'file:///foo') - get :revisions, :id => 1, :repository_id => 'foo' + get :revisions, :params => { + :id => 1, + :repository_id => 'foo' + } assert_response :success assert_select 'table.changesets' end def test_revisions_for_invalid_repository - get :revisions, :id => 1, :repository_id => 'foo' + get :revisions, :params => { + :id => 1, + :repository_id => 'foo' + } assert_response 404 end def test_revision - get :revision, :id => 1, :rev => 1 + get :revision, :params => { + :id => 1, + :rev => 1 + } assert_response :success assert_select 'h2', :text => 'Revision 1' end @@ -171,7 +219,10 @@ class RepositoriesControllerTest < Redmine::ControllerTest Changeset.where(:id => 100).update_all(:comments => 'Simple *text*') with_settings :commit_logs_formatting => '0' do - get :revision, :id => 1, :rev => 1 + get :revision, :params => { + :id => 1, + :rev => 1 + } assert_response :success assert_select '.changeset-comments', :text => 'Simple *text*' end @@ -181,7 +232,10 @@ class RepositoriesControllerTest < Redmine::ControllerTest Role.find(1).add_permission! :manage_related_issues @request.session[:user_id] = 2 - get :revision, :id => 1, :rev => 1 + get :revision, :params => { + :id => 1, + :rev => 1 + } assert_response :success assert_select 'form[action=?]', '/projects/ecookbook/repository/revisions/1/issues' do @@ -190,14 +244,20 @@ class RepositoriesControllerTest < Redmine::ControllerTest end def test_revision_should_not_change_the_project_menu_link - get :revision, :id => 1, :rev => 1 + get :revision, :params => { + :id => 1, + :rev => 1 + } assert_response :success assert_select '#main-menu a.repository[href=?]', '/projects/ecookbook/repository' end def test_revision_with_before_nil_and_afer_normal - get :revision, {:id => 1, :rev => 1} + get :revision, :params => { + :id => 1, + :rev => 1 + } assert_response :success assert_select 'div.contextual' do @@ -209,7 +269,13 @@ class RepositoriesControllerTest < Redmine::ControllerTest def test_add_related_issue @request.session[:user_id] = 2 assert_difference 'Changeset.find(103).issues.size' do - xhr :post, :add_related_issue, :id => 1, :rev => 4, :issue_id => 2, :format => 'js' + post :add_related_issue, :params => { + :id => 1, + :rev => 4, + :issue_id => 2, + :format => 'js' + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end @@ -221,7 +287,13 @@ class RepositoriesControllerTest < Redmine::ControllerTest def test_add_related_issue_should_accept_issue_id_with_sharp @request.session[:user_id] = 2 assert_difference 'Changeset.find(103).issues.size' do - xhr :post, :add_related_issue, :id => 1, :rev => 4, :issue_id => "#2", :format => 'js' + post :add_related_issue, :params => { + :id => 1, + :rev => 4, + :issue_id => "#2", + :format => 'js' + }, + :xhr => true end assert_equal [2], Changeset.find(103).issue_ids end @@ -229,7 +301,13 @@ class RepositoriesControllerTest < Redmine::ControllerTest def test_add_related_issue_with_invalid_issue_id @request.session[:user_id] = 2 assert_no_difference 'Changeset.find(103).issues.size' do - xhr :post, :add_related_issue, :id => 1, :rev => 4, :issue_id => 9999, :format => 'js' + post :add_related_issue, :params => { + :id => 1, + :rev => 4, + :issue_id => 9999, + :format => 'js' + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end @@ -242,7 +320,13 @@ class RepositoriesControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference 'Changeset.find(103).issues.size', -1 do - xhr :delete, :remove_related_issue, :id => 1, :rev => 4, :issue_id => 2, :format => 'js' + delete :remove_related_issue, :params => { + :id => 1, + :rev => 4, + :issue_id => 2, + :format => 'js' + }, + :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end @@ -256,13 +340,19 @@ class RepositoriesControllerTest < Redmine::ControllerTest assert_not_nil latest Date.stubs(:today).returns(latest.to_date + 10) - get :graph, :id => 1, :graph => 'commits_per_month' + get :graph, :params => { + :id => 1, + :graph => 'commits_per_month' + } assert_response :success assert_equal 'image/svg+xml', @response.content_type end def test_graph_commits_per_author - get :graph, :id => 1, :graph => 'commits_per_author' + get :graph, :params => { + :id => 1, + :graph => 'commits_per_author' + } assert_response :success assert_equal 'image/svg+xml', @response.content_type end @@ -278,7 +368,9 @@ class RepositoriesControllerTest < Redmine::ControllerTest :comments => 'Committed by foo.' ) - get :committers, :id => 10 + get :committers, :params => { + :id => 10 + } assert_response :success assert_select 'input[value=dlopper] + select option[value="3"][selected=selected]', :text => 'Dave Lopper' @@ -289,7 +381,9 @@ class RepositoriesControllerTest < Redmine::ControllerTest Changeset.delete_all @request.session[:user_id] = 2 - get :committers, :id => 10 + get :committers, :params => { + :id => 10 + } assert_response :success end @@ -304,7 +398,12 @@ class RepositoriesControllerTest < Redmine::ControllerTest :comments => 'Committed by foo.' ) assert_no_difference "Changeset.where(:user_id => 3).count" do - post :committers, :id => 10, :committers => { '0' => ['foo', '2'], '1' => ['dlopper', '3']} + post :committers, :params => { + :id => 10, + :committers => { + '0' => ['foo', '2'], '1' => ['dlopper', '3'] + } + } assert_response 302 assert_equal User.find(2), c.reload.user end diff --git a/test/functional/repositories_cvs_controller_test.rb b/test/functional/repositories_cvs_controller_test.rb index 6d48812a8..2f22d5f36 100644 --- a/test/functional/repositories_cvs_controller_test.rb +++ b/test/functional/repositories_cvs_controller_test.rb @@ -46,7 +46,10 @@ class RepositoriesCvsControllerTest < Redmine::ControllerTest def test_get_new @request.session[:user_id] = 1 @project.repository.destroy - get :new, :project_id => 'subproject1', :repository_scm => 'Cvs' + get :new, :params => { + :project_id => 'subproject1', + :repository_scm => 'Cvs' + } assert_response :success assert_select 'select[name=?]', 'repository_scm' do @@ -59,7 +62,9 @@ class RepositoriesCvsControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :show, :id => PRJ_ID + get :show, :params => { + :id => PRJ_ID + } assert_response :success assert_select 'table.entries tbody' do @@ -78,7 +83,10 @@ class RepositoriesCvsControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :show, :id => PRJ_ID, :path => repository_path_hash(['images'])[:param] + get :show, :params => { + :id => PRJ_ID, + :path => repository_path_hash(['images'])[:param] + } assert_response :success assert_select 'table.entries tbody' do @@ -94,8 +102,11 @@ class RepositoriesCvsControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :show, :id => PRJ_ID, :path => repository_path_hash(['images'])[:param], + get :show, :params => { + :id => PRJ_ID, + :path => repository_path_hash(['images'])[:param], :rev => 1 + } assert_response :success assert_select 'table.entries tbody' do @@ -110,8 +121,10 @@ class RepositoriesCvsControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :entry, :id => PRJ_ID, + get :entry, :params => { + :id => PRJ_ID, :path => repository_path_hash(['sources', 'watchers_controller.rb'])[:param] + } assert_response :success assert_select 'td.line-code', :text => /before_filter/, :count => 0 @@ -123,9 +136,11 @@ class RepositoriesCvsControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :entry, :id => PRJ_ID, + get :entry, :params => { + :id => PRJ_ID, :path => repository_path_hash(['sources', 'watchers_controller.rb'])[:param], :rev => 2 + } assert_response :success # this line was removed in r3 @@ -137,8 +152,10 @@ class RepositoriesCvsControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :entry, :id => PRJ_ID, + get :entry, :params => { + :id => PRJ_ID, :path => repository_path_hash(['sources', 'zzz.c'])[:param] + } assert_select 'p#errorExplanation', :text => /The entry or revision was not found in the repository/ end @@ -147,9 +164,11 @@ class RepositoriesCvsControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :entry, :id => PRJ_ID, + get :entry, :params => { + :id => PRJ_ID, :path => repository_path_hash(['sources', 'watchers_controller.rb'])[:param], :format => 'raw' + } assert_response :success end @@ -158,8 +177,10 @@ class RepositoriesCvsControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :entry, :id => PRJ_ID, + get :entry, :params => { + :id => PRJ_ID, :path => repository_path_hash(['sources'])[:param] + } assert_response :success assert_select 'table.entries tbody' end @@ -170,7 +191,11 @@ class RepositoriesCvsControllerTest < Redmine::ControllerTest @project.reload assert_equal NUM_REV, @repository.changesets.count ['inline', 'sbs'].each do |dt| - get :diff, :id => PRJ_ID, :rev => 3, :type => dt + get :diff, :params => { + :id => PRJ_ID, + :rev => 3, + :type => dt + } assert_response :success assert_select 'td.line-code.diff_out', :text => /before_filter :require_login/ @@ -184,7 +209,11 @@ class RepositoriesCvsControllerTest < Redmine::ControllerTest @project.reload assert_equal NUM_REV, @repository.changesets.count ['inline', 'sbs'].each do |dt| - get :diff, :id => PRJ_ID, :rev => 1, :type => dt + get :diff, :params => { + :id => PRJ_ID, + :rev => 1, + :type => dt + } assert_response :success assert_select 'td.line-code.diff_in', :text => /watched.remove_watcher/ @@ -200,8 +229,10 @@ class RepositoriesCvsControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :annotate, :id => PRJ_ID, + get :annotate, :params => { + :id => PRJ_ID, :path => repository_path_hash(['sources', 'watchers_controller.rb'])[:param] + } assert_response :success # 1.1 line @@ -226,7 +257,9 @@ class RepositoriesCvsControllerTest < Redmine::ControllerTest assert_equal NUM_REV, @repository.changesets.count assert_difference 'Repository.count', -1 do - delete :destroy, :id => @repository.id + delete :destroy, :params => { + :id => @repository.id + } end assert_response 302 @project.reload @@ -247,7 +280,9 @@ class RepositoriesCvsControllerTest < Redmine::ControllerTest assert_equal 0, @repository.changesets.count assert_difference 'Repository.count', -1 do - delete :destroy, :id => @repository.id + delete :destroy, :params => { + :id => @repository.id + } end assert_response 302 @project.reload diff --git a/test/functional/repositories_darcs_controller_test.rb b/test/functional/repositories_darcs_controller_test.rb index 4d86e1afa..0006c94ef 100644 --- a/test/functional/repositories_darcs_controller_test.rb +++ b/test/functional/repositories_darcs_controller_test.rb @@ -42,7 +42,10 @@ class RepositoriesDarcsControllerTest < Redmine::ControllerTest def test_get_new @request.session[:user_id] = 1 @project.repository.destroy - get :new, :project_id => 'subproject1', :repository_scm => 'Darcs' + get :new, :params => { + :project_id => 'subproject1', + :repository_scm => 'Darcs' + } assert_response :success assert_select 'select[name=?]', 'repository_scm' do assert_select 'option[value=?][selected=selected]', 'Darcs' @@ -54,7 +57,9 @@ class RepositoriesDarcsControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :show, :id => PRJ_ID + get :show, :params => { + :id => PRJ_ID + } assert_select 'table.entries tbody' do assert_select 'tr', 3 assert_select 'tr.dir td.filename a', :text => 'images' @@ -68,7 +73,10 @@ class RepositoriesDarcsControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :show, :id => PRJ_ID, :path => repository_path_hash(['images'])[:param] + get :show, :params => { + :id => PRJ_ID, + :path => repository_path_hash(['images'])[:param] + } assert_response :success assert_select 'table.entries tbody' do assert_select 'tr', 2 @@ -82,8 +90,11 @@ class RepositoriesDarcsControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :show, :id => PRJ_ID, :path => repository_path_hash(['images'])[:param], + get :show, :params => { + :id => PRJ_ID, + :path => repository_path_hash(['images'])[:param], :rev => 1 + } assert_response :success assert_select 'table.entries tbody' do assert_select 'tr', 1 @@ -96,8 +107,10 @@ class RepositoriesDarcsControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :changes, :id => PRJ_ID, + get :changes, :params => { + :id => PRJ_ID, :path => repository_path_hash(['images', 'edit.png'])[:param] + } assert_response :success assert_select 'h2', :text => /edit.png/ end @@ -109,7 +122,11 @@ class RepositoriesDarcsControllerTest < Redmine::ControllerTest assert_equal NUM_REV, @repository.changesets.count # Full diff of changeset 5 ['inline', 'sbs'].each do |dt| - get :diff, :id => PRJ_ID, :rev => 5, :type => dt + get :diff, :params => { + :id => PRJ_ID, + :rev => 5, + :type => dt + } assert_response :success # Line 22 removed assert_select 'th.line-num:contains(22) ~ td.diff_out', :text => /def remove/ @@ -124,7 +141,9 @@ class RepositoriesDarcsControllerTest < Redmine::ControllerTest assert_equal NUM_REV, @repository.changesets.count assert_difference 'Repository.count', -1 do - delete :destroy, :id => @repository.id + delete :destroy, :params => { + :id => @repository.id + } end assert_response 302 @project.reload @@ -144,7 +163,9 @@ class RepositoriesDarcsControllerTest < Redmine::ControllerTest assert_equal 0, @repository.changesets.count assert_difference 'Repository.count', -1 do - delete :destroy, :id => @repository.id + delete :destroy, :params => { + :id => @repository.id + } end assert_response 302 @project.reload diff --git a/test/functional/repositories_filesystem_controller_test.rb b/test/functional/repositories_filesystem_controller_test.rb index 1e25bb824..7cb6047a7 100644 --- a/test/functional/repositories_filesystem_controller_test.rb +++ b/test/functional/repositories_filesystem_controller_test.rb @@ -43,7 +43,10 @@ class RepositoriesFilesystemControllerTest < Redmine::ControllerTest def test_get_new @request.session[:user_id] = 1 @project.repository.destroy - get :new, :project_id => 'subproject1', :repository_scm => 'Filesystem' + get :new, :params => { + :project_id => 'subproject1', + :repository_scm => 'Filesystem' + } assert_response :success assert_select 'select[name=?]', 'repository_scm' do assert_select 'option[value=?][selected=selected]', 'Filesystem' @@ -53,7 +56,9 @@ class RepositoriesFilesystemControllerTest < Redmine::ControllerTest def test_browse_root @repository.fetch_changesets @repository.reload - get :show, :id => PRJ_ID + get :show, :params => { + :id => PRJ_ID + } assert_response :success assert_select 'table.entries tbody' do @@ -71,21 +76,29 @@ class RepositoriesFilesystemControllerTest < Redmine::ControllerTest end def test_show_no_extension - get :entry, :id => PRJ_ID, :path => repository_path_hash(['test'])[:param] + get :entry, :params => { + :id => PRJ_ID, + :path => repository_path_hash(['test'])[:param] + } assert_response :success assert_select 'tr#L1 td.line-code', :text => /TEST CAT/ end def test_entry_download_no_extension - get :raw, :id => PRJ_ID, :path => repository_path_hash(['test'])[:param] + get :raw, :params => { + :id => PRJ_ID, + :path => repository_path_hash(['test'])[:param] + } assert_response :success assert_equal 'application/octet-stream', @response.content_type end def test_show_non_ascii_contents with_settings :repositories_encodings => 'UTF-8,EUC-JP' do - get :entry, :id => PRJ_ID, + get :entry, :params => { + :id => PRJ_ID, :path => repository_path_hash(['japanese', 'euc-jp.txt'])[:param] + } assert_response :success assert_select 'tr#L2 td.line-code', :text => /japanese/ if @ruby19_non_utf8_pass @@ -102,8 +115,10 @@ class RepositoriesFilesystemControllerTest < Redmine::ControllerTest def test_show_utf16 enc = 'UTF-16' with_settings :repositories_encodings => enc do - get :entry, :id => PRJ_ID, + get :entry, :params => { + :id => PRJ_ID, :path => repository_path_hash(['japanese', 'utf-16.txt'])[:param] + } assert_response :success assert_select 'tr#L2 td.line-code', :text => /japanese/ end @@ -111,8 +126,10 @@ class RepositoriesFilesystemControllerTest < Redmine::ControllerTest def test_show_text_file_should_show_other_if_too_big with_settings :file_max_size_displayed => 1 do - get :entry, :id => PRJ_ID, + get :entry, :params => { + :id => PRJ_ID, :path => repository_path_hash(['japanese', 'big-file.txt'])[:param] + } assert_response :success assert_equal 'text/html', @response.content_type assert_select 'p.nodata' @@ -123,7 +140,9 @@ class RepositoriesFilesystemControllerTest < Redmine::ControllerTest @request.session[:user_id] = 1 # admin assert_difference 'Repository.count', -1 do - delete :destroy, :id => @repository.id + delete :destroy, :params => { + :id => @repository.id + } end assert_response 302 @project.reload @@ -140,7 +159,9 @@ class RepositoriesFilesystemControllerTest < Redmine::ControllerTest ) assert_difference 'Repository.count', -1 do - delete :destroy, :id => @repository.id + delete :destroy, :params => { + :id => @repository.id + } end assert_response 302 @project.reload diff --git a/test/functional/repositories_git_controller_test.rb b/test/functional/repositories_git_controller_test.rb index 093e985b8..90c3e817b 100644 --- a/test/functional/repositories_git_controller_test.rb +++ b/test/functional/repositories_git_controller_test.rb @@ -54,14 +54,17 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest def test_create_and_update @request.session[:user_id] = 1 assert_difference 'Repository.count' do - post :create, :project_id => 'subproject1', - :repository_scm => 'Git', - :repository => { - :url => '/test', - :is_default => '0', - :identifier => 'test-create', - :report_last_commit => '1', - } + post :create, :params => { + :project_id => 'subproject1', + :repository_scm => 'Git', + :repository => { + :url => '/test', + :is_default => '0', + :identifier => 'test-create', + :report_last_commit => '1', + + } + } end assert_response 302 repository = Repository.order('id DESC').first @@ -69,10 +72,13 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest assert_equal '/test', repository.url assert_equal true, repository.report_last_commit - put :update, :id => repository.id, - :repository => { - :report_last_commit => '0' - } + put :update, :params => { + :id => repository.id, + :repository => { + :report_last_commit => '0' + + } + } assert_response 302 repo2 = Repository.find(repository.id) assert_equal false, repo2.report_last_commit @@ -92,7 +98,10 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest def test_get_new @request.session[:user_id] = 1 @project.repository.destroy - get :new, :project_id => 'subproject1', :repository_scm => 'Git' + get :new, :params => { + :project_id => 'subproject1', + :repository_scm => 'Git' + } assert_response :success assert_select 'select[name=?]', 'repository_scm' do assert_select 'option[value=?][selected=selected]', 'Git' @@ -105,7 +114,9 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest @project.reload assert_equal NUM_REV, @repository.changesets.count - get :show, :id => PRJ_ID + get :show, :params => { + :id => PRJ_ID + } assert_response :success assert_select 'table.entries tbody' do @@ -131,7 +142,10 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :show, :id => PRJ_ID, :rev => 'test_branch' + get :show, :params => { + :id => PRJ_ID, + :rev => 'test_branch' + } assert_response :success assert_select 'table.entries tbody' do @@ -156,7 +170,10 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest "tag00.lightweight", "tag01.annotated", ].each do |t1| - get :show, :id => PRJ_ID, :rev => t1 + get :show, :params => { + :id => PRJ_ID, + :rev => t1 + } assert_response :success assert_select 'table.entries tbody tr' @@ -169,7 +186,10 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :show, :id => PRJ_ID, :path => repository_path_hash(['images'])[:param] + get :show, :params => { + :id => PRJ_ID, + :path => repository_path_hash(['images'])[:param] + } assert_response :success assert_select 'table.entries tbody' do @@ -184,8 +204,11 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :show, :id => PRJ_ID, :path => repository_path_hash(['images'])[:param], + get :show, :params => { + :id => PRJ_ID, + :path => repository_path_hash(['images'])[:param], :rev => '7234cb2750b63f47bff735edc50a1c0a433c2518' + } assert_response :success assert_select 'table.entries tbody' do @@ -195,15 +218,19 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest end def test_changes - get :changes, :id => PRJ_ID, + get :changes, :params => { + :id => PRJ_ID, :path => repository_path_hash(['images', 'edit.png'])[:param] + } assert_response :success assert_select 'h2', :text => /edit.png/ end def test_entry_show - get :entry, :id => PRJ_ID, + get :entry, :params => { + :id => PRJ_ID, :path => repository_path_hash(['sources', 'watchers_controller.rb'])[:param] + } assert_response :success # Line 11 assert_select 'tr#L11 td.line-code', :text => /WITHOUT ANY WARRANTY/ @@ -219,9 +246,11 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest else with_settings :repositories_encodings => 'UTF-8,ISO-8859-1' do ['57ca437c', '57ca437c0acbbcb749821fdf3726a1367056d364'].each do |r1| - get :entry, :id => PRJ_ID, - :path => repository_path_hash(['latin-1-dir', "test-#{CHAR_1_HEX}.txt"])[:param], - :rev => r1 + get :entry, :params => { + :id => PRJ_ID, + :path => repository_path_hash(['latin-1-dir', "test-#{CHAR_1_HEX}.txt"])[:param], + :rev => r1 + } assert_response :success assert_select 'tr#L1 td.line-code', :text => /test-#{CHAR_1_HEX}.txt/ end @@ -230,17 +259,21 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest end def test_entry_download - get :entry, :id => PRJ_ID, + get :entry, :params => { + :id => PRJ_ID, :path => repository_path_hash(['sources', 'watchers_controller.rb'])[:param], :format => 'raw' + } assert_response :success # File content assert @response.body.include?('WITHOUT ANY WARRANTY') end def test_directory_entry - get :entry, :id => PRJ_ID, + get :entry, :params => { + :id => PRJ_ID, :path => repository_path_hash(['sources'])[:param] + } assert_response :success assert_select 'h2 a', :text => 'sources' assert_select 'table.entries tbody' @@ -255,10 +288,11 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest assert_equal NUM_REV, @repository.changesets.count # Full diff of changeset 2f9c0091 ['inline', 'sbs'].each do |dt| - get :diff, + get :diff, :params => { :id => PRJ_ID, :rev => '2f9c0091c754a91af7a9c478e36556b4bde8dcf7', :type => dt + } assert_response :success # Line 22 removed assert_select 'th.line-num:contains(22) ~ td.diff_out', :text => /def remove/ @@ -274,11 +308,12 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest with_settings :diff_max_lines_displayed => 1000 do # Full diff of changeset 2f9c0091 ['inline', 'sbs'].each do |dt| - get :diff, + get :diff, :params => { :id => PRJ_ID, :rev => '2f9c0091c754a91af7a9c478e36556b4bde8dcf7', :path => repository_path_hash(['sources', 'watchers_controller.rb'])[:param], :type => dt + } assert_response :success # Line 22 removed assert_select 'th.line-num:contains(22) ~ td.diff_out', :text => /def remove/ @@ -297,14 +332,20 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest # Truncated diff of changeset 2f9c0091 with_cache do with_settings :default_language => 'en' do - get :diff, :id => PRJ_ID, :type => 'inline', + get :diff, :params => { + :id => PRJ_ID, + :type => 'inline', :rev => '2f9c0091c754a91af7a9c478e36556b4bde8dcf7' + } assert_response :success assert @response.body.include?("... This diff was truncated") end with_settings :default_language => 'fr' do - get :diff, :id => PRJ_ID, :type => 'inline', + get :diff, :params => { + :id => PRJ_ID, + :type => 'inline', :rev => '2f9c0091c754a91af7a9c478e36556b4bde8dcf7' + } assert_response :success assert ! @response.body.include?("... This diff was truncated") assert @response.body.include?("... Ce diff") @@ -319,11 +360,12 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest @project.reload assert_equal NUM_REV, @repository.changesets.count ['inline', 'sbs'].each do |dt| - get :diff, + get :diff, :params => { :id => PRJ_ID, :rev => '61b685fbe55ab05b5ac68402d5720c1a6ac973d1', :rev_to => '2f9c0091c754a91af7a9c478e36556b4bde8dcf7', :type => dt + } assert_response :success assert_select 'h2', :text => /2f9c0091:61b685fb/ assert_select 'form[action=?]', '/projects/subproject1/repository/revisions/61b685fbe55ab05b5ac68402d5720c1a6ac973d1/diff' @@ -341,12 +383,13 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest assert repo assert_equal false, repo.is_default assert_equal 'test-diff-path', repo.identifier - get :diff, + get :diff, :params => { :id => PRJ_ID, :repository_id => 'test-diff-path', :rev => '61b685fbe55ab05b', :rev_to => '2f9c0091c754a91a', :type => 'inline' + } assert_response :success assert_select 'form[action=?]', '/projects/subproject1/repository/test-diff-path/revisions/61b685fbe55ab05b/diff' assert_select 'input#rev_to[type=hidden][name=rev_to][value=?]', '2f9c0091c754a91a' @@ -359,7 +402,11 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest with_settings :repositories_encodings => 'UTF-8,ISO-8859-1' do ['57ca437c', '57ca437c0acbbcb749821fdf3726a1367056d364'].each do |r1| ['inline', 'sbs'].each do |dt| - get :diff, :id => PRJ_ID, :rev => r1, :type => dt + get :diff, :params => { + :id => PRJ_ID, + :rev => r1, + :type => dt + } assert_response :success assert_select 'table' do assert_select 'thead th.filename', :text => /latin-1-dir\/test-#{CHAR_1_HEX}.txt/ @@ -372,7 +419,11 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest end def test_diff_should_show_filenames - get :diff, :id => PRJ_ID, :rev => 'deff712f05a90d96edbd70facc47d944be5897e3', :type => 'inline' + get :diff, :params => { + :id => PRJ_ID, + :rev => 'deff712f05a90d96edbd70facc47d944be5897e3', + :type => 'inline' + } assert_response :success # modified file assert_select 'th.filename', :text => 'sources/watchers_controller.rb' @@ -388,24 +439,28 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest assert_nil user.pref[:diff_type] @request.session[:user_id] = 1 # admin - get :diff, + get :diff, :params => { :id => PRJ_ID, :rev => '2f9c0091c754a91af7a9c478e36556b4bde8dcf7' + } assert_response :success user.reload assert_equal "inline", user.pref[:diff_type] - get :diff, + get :diff, :params => { :id => PRJ_ID, :rev => '2f9c0091c754a91af7a9c478e36556b4bde8dcf7', :type => 'sbs' + } assert_response :success user.reload assert_equal "sbs", user.pref[:diff_type] end def test_annotate - get :annotate, :id => PRJ_ID, + get :annotate, :params => { + :id => PRJ_ID, :path => repository_path_hash(['sources', 'watchers_controller.rb'])[:param] + } assert_response :success # Line 23, changeset 2f9c0091 @@ -422,16 +477,21 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :annotate, :id => PRJ_ID, :rev => 'deff7', + get :annotate, :params => { + :id => PRJ_ID, + :rev => 'deff7', :path => repository_path_hash(['sources', 'watchers_controller.rb'])[:param] + } assert_response :success assert_select 'h2', :text => /@ deff712f/ end def test_annotate_binary_file with_settings :default_language => 'en' do - get :annotate, :id => PRJ_ID, + get :annotate, :params => { + :id => PRJ_ID, :path => repository_path_hash(['images', 'edit.png'])[:param] + } assert_response :success assert_select 'p#errorExplanation', :text => /cannot be annotated/ end @@ -439,15 +499,19 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest def test_annotate_error_when_too_big with_settings :file_max_size_displayed => 1 do - get :annotate, :id => PRJ_ID, + get :annotate, :params => { + :id => PRJ_ID, :path => repository_path_hash(['sources', 'watchers_controller.rb'])[:param], :rev => 'deff712f' + } assert_response :success assert_select 'p#errorExplanation', :text => /exceeds the maximum text file size/ - get :annotate, :id => PRJ_ID, + get :annotate, :params => { + :id => PRJ_ID, :path => repository_path_hash(['README'])[:param], :rev => '7234cb2' + } assert_response :success end end @@ -462,9 +526,11 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest else with_settings :repositories_encodings => 'UTF-8,ISO-8859-1' do ['57ca437c', '57ca437c0acbbcb749821fdf3726a1367056d364'].each do |r1| - get :annotate, :id => PRJ_ID, - :path => repository_path_hash(['latin-1-dir', "test-#{CHAR_1_HEX}.txt"])[:param], - :rev => r1 + get :annotate, :params => { + :id => PRJ_ID, + :path => repository_path_hash(['latin-1-dir', "test-#{CHAR_1_HEX}.txt"])[:param], + :rev => r1 + } assert_select "th.line-num", :text => '1' do assert_select "+ td.revision" do assert_select "a", :text => '57ca437c' @@ -481,9 +547,11 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest def test_annotate_latin_1_author ['83ca5fd546063a3c7dc2e568ba3355661a9e2b2c', '83ca5fd546063a'].each do |r1| - get :annotate, :id => PRJ_ID, + get :annotate, :params => { + :id => PRJ_ID, :path => repository_path_hash([" filename with a leading space.txt "])[:param], :rev => r1 + } assert_select "th.line-num", :text => '1' do assert_select "+ td.revision" do assert_select "a", :text => '83ca5fd5' @@ -501,7 +569,9 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :revisions, :id => PRJ_ID + get :revisions, :params => { + :id => PRJ_ID + } assert_select 'form[method=get][action=?]', '/projects/subproject1/repository/revision' end @@ -511,7 +581,10 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest @project.reload assert_equal NUM_REV, @repository.changesets.count ['61b685fbe55ab05b5ac68402d5720c1a6ac973d1', '61b685f'].each do |r| - get :revision, :id => PRJ_ID, :rev => r + get :revision, :params => { + :id => PRJ_ID, + :rev => r + } assert_response :success end end @@ -522,7 +595,10 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest @project.reload assert_equal NUM_REV, @repository.changesets.count ['', ' ', nil].each do |r| - get :revision, :id => PRJ_ID, :rev => r + get :revision, :params => { + :id => PRJ_ID, + :rev => r + } assert_response 404 assert_select_error /was not found/ end @@ -536,7 +612,9 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest assert_equal NUM_REV, @repository.changesets.count assert_difference 'Repository.count', -1 do - delete :destroy, :id => @repository.id + delete :destroy, :params => { + :id => @repository.id + } end assert_response 302 @project.reload @@ -556,7 +634,9 @@ class RepositoriesGitControllerTest < Redmine::ControllerTest assert_equal 0, @repository.changesets.count assert_difference 'Repository.count', -1 do - delete :destroy, :id => @repository.id + delete :destroy, :params => { + :id => @repository.id + } end assert_response 302 @project.reload diff --git a/test/functional/repositories_mercurial_controller_test.rb b/test/functional/repositories_mercurial_controller_test.rb index cde27baa4..e69a8e736 100644 --- a/test/functional/repositories_mercurial_controller_test.rb +++ b/test/functional/repositories_mercurial_controller_test.rb @@ -56,7 +56,10 @@ class RepositoriesMercurialControllerTest < Redmine::ControllerTest def test_get_new @request.session[:user_id] = 1 @project.repository.destroy - get :new, :project_id => 'subproject1', :repository_scm => 'Mercurial' + get :new, :params => { + :project_id => 'subproject1', + :repository_scm => 'Mercurial' + } assert_response :success assert_select 'select[name=?]', 'repository_scm' do assert_select 'option[value=?][selected=selected]', 'Mercurial' @@ -68,7 +71,9 @@ class RepositoriesMercurialControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :show, :id => PRJ_ID + get :show, :params => { + :id => PRJ_ID + } assert_response :success assert_select 'table.entries tbody' do @@ -89,7 +94,10 @@ class RepositoriesMercurialControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :show, :id => PRJ_ID, :path => repository_path_hash(['images'])[:param] + get :show, :params => { + :id => PRJ_ID, + :path => repository_path_hash(['images'])[:param] + } assert_response :success assert_select 'table.entries tbody' do @@ -109,8 +117,11 @@ class RepositoriesMercurialControllerTest < Redmine::ControllerTest @project.reload assert_equal NUM_REV, @repository.changesets.count [0, '0', '0885933ad4f6'].each do |r1| - get :show, :id => PRJ_ID, :path => repository_path_hash(['images'])[:param], + get :show, :params => { + :id => PRJ_ID, + :path => repository_path_hash(['images'])[:param], :rev => r1 + } assert_response :success assert_select 'table.entries tbody' do @@ -130,9 +141,11 @@ class RepositoriesMercurialControllerTest < Redmine::ControllerTest @project.reload assert_equal NUM_REV, @repository.changesets.count [13, '13', '3a330eb32958'].each do |r1| - get :show, :id => PRJ_ID, + get :show, :params => { + :id => PRJ_ID, :path => repository_path_hash(['sql_escape', 'percent%dir'])[:param], :rev => r1 + } assert_response :success assert_select 'table.entries tbody' do @@ -156,9 +169,11 @@ class RepositoriesMercurialControllerTest < Redmine::ControllerTest @project.reload assert_equal NUM_REV, @repository.changesets.count [21, '21', 'adf805632193'].each do |r1| - get :show, :id => PRJ_ID, + get :show, :params => { + :id => PRJ_ID, :path => repository_path_hash(['latin-1-dir'])[:param], :rev => r1 + } assert_response :success assert_select 'table.entries tbody' do @@ -182,7 +197,9 @@ class RepositoriesMercurialControllerTest < Redmine::ControllerTest def show_should_show_branch_selection_form @repository.fetch_changesets @project.reload - get :show, :id => PRJ_ID + get :show, :params => { + :id => PRJ_ID + } assert_select 'form#revision_selector[action=?]', '/projects/subproject1/repository/show' do assert_select 'select[name=branch]' do assert_select 'option[value=?]', 'test-branch-01' @@ -203,7 +220,10 @@ class RepositoriesMercurialControllerTest < Redmine::ControllerTest 'test_branch.latin-1', 'test-branch-00', ].each do |bra| - get :show, :id => PRJ_ID, :rev => bra + get :show, :params => { + :id => PRJ_ID, + :rev => bra + } assert_response :success assert_select 'table.entries tbody tr' @@ -221,7 +241,10 @@ class RepositoriesMercurialControllerTest < Redmine::ControllerTest 'tag_test.00', 'tag-init-revision' ].each do |tag| - get :show, :id => PRJ_ID, :rev => tag + get :show, :params => { + :id => PRJ_ID, + :rev => tag + } assert_response :success assert_select 'table.entries tbody tr' @@ -230,15 +253,19 @@ class RepositoriesMercurialControllerTest < Redmine::ControllerTest end def test_changes - get :changes, :id => PRJ_ID, + get :changes, :params => { + :id => PRJ_ID, :path => repository_path_hash(['images', 'edit.png'])[:param] + } assert_response :success assert_select 'h2', :text => /edit.png/ end def test_entry_show - get :entry, :id => PRJ_ID, + get :entry, :params => { + :id => PRJ_ID, :path => repository_path_hash(['sources', 'watchers_controller.rb'])[:param] + } assert_response :success # Line 10 assert_select 'tr#L10 td.line-code', :text => /WITHOUT ANY WARRANTY/ @@ -246,9 +273,11 @@ class RepositoriesMercurialControllerTest < Redmine::ControllerTest def test_entry_show_latin_1_path [21, '21', 'adf805632193'].each do |r1| - get :entry, :id => PRJ_ID, - :path => repository_path_hash(['latin-1-dir', "test-#{@char_1}-2.txt"])[:param], - :rev => r1 + get :entry, :params => { + :id => PRJ_ID, + :path => repository_path_hash(['latin-1-dir', "test-#{@char_1}-2.txt"])[:param], + :rev => r1 + } assert_response :success assert_select 'tr#L1 td.line-code', :text => /Mercurial is a distributed version control system/ end @@ -257,9 +286,11 @@ class RepositoriesMercurialControllerTest < Redmine::ControllerTest def test_entry_show_latin_1_contents with_settings :repositories_encodings => 'UTF-8,ISO-8859-1' do [27, '27', '7bbf4c738e71'].each do |r1| - get :entry, :id => PRJ_ID, - :path => repository_path_hash(['latin-1-dir', "test-#{@char_1}.txt"])[:param], - :rev => r1 + get :entry, :params => { + :id => PRJ_ID, + :path => repository_path_hash(['latin-1-dir', "test-#{@char_1}.txt"])[:param], + :rev => r1 + } assert_response :success assert_select 'tr#L1 td.line-code', :text => /test-#{@char_1}.txt/ end @@ -267,9 +298,11 @@ class RepositoriesMercurialControllerTest < Redmine::ControllerTest end def test_entry_download - get :entry, :id => PRJ_ID, + get :entry, :params => { + :id => PRJ_ID, :path => repository_path_hash(['sources', 'watchers_controller.rb'])[:param], :format => 'raw' + } assert_response :success # File content assert @response.body.include?('WITHOUT ANY WARRANTY') @@ -280,8 +313,10 @@ class RepositoriesMercurialControllerTest < Redmine::ControllerTest end def test_directory_entry - get :entry, :id => PRJ_ID, + get :entry, :params => { + :id => PRJ_ID, :path => repository_path_hash(['sources'])[:param] + } assert_response :success assert_select 'h2 a', :text => 'sources' assert_select 'table.entries tbody' @@ -295,7 +330,11 @@ class RepositoriesMercurialControllerTest < Redmine::ControllerTest [4, '4', 'def6d2f1254a'].each do |r1| # Full diff of changeset 4 ['inline', 'sbs'].each do |dt| - get :diff, :id => PRJ_ID, :rev => r1, :type => dt + get :diff, :params => { + :id => PRJ_ID, + :rev => r1, + :type => dt + } assert_response :success if @diff_c_support # Line 22 removed @@ -314,11 +353,12 @@ class RepositoriesMercurialControllerTest < Redmine::ControllerTest [2, '400bb8672109', '400', 400].each do |r1| [4, 'def6d2f1254a'].each do |r2| ['inline', 'sbs'].each do |dt| - get :diff, + get :diff, :params => { :id => PRJ_ID, :rev => r1, :rev_to => r2, :type => dt + } assert_response :success assert_select 'h2', :text => /4:def6d2f1254a 2:400bb8672109/ end @@ -330,7 +370,11 @@ class RepositoriesMercurialControllerTest < Redmine::ControllerTest with_settings :repositories_encodings => 'UTF-8,ISO-8859-1' do [21, 'adf805632193'].each do |r1| ['inline', 'sbs'].each do |dt| - get :diff, :id => PRJ_ID, :rev => r1, :type => dt + get :diff, :params => { + :id => PRJ_ID, + :rev => r1, + :type => dt + } assert_response :success assert_select 'table' do assert_select 'thead th.filename', :text => /latin-1-dir\/test-#{@char_1}-2.txt/ @@ -342,20 +386,30 @@ class RepositoriesMercurialControllerTest < Redmine::ControllerTest end def test_diff_should_show_modified_filenames - get :diff, :id => PRJ_ID, :rev => '400bb8672109', :type => 'inline' + get :diff, :params => { + :id => PRJ_ID, + :rev => '400bb8672109', + :type => 'inline' + } assert_response :success assert_select 'th.filename', :text => 'sources/watchers_controller.rb' end def test_diff_should_show_deleted_filenames - get :diff, :id => PRJ_ID, :rev => 'b3a615152df8', :type => 'inline' + get :diff, :params => { + :id => PRJ_ID, + :rev => 'b3a615152df8', + :type => 'inline' + } assert_response :success assert_select 'th.filename', :text => 'sources/welcome_controller.rb' end def test_annotate - get :annotate, :id => PRJ_ID, + get :annotate, :params => { + :id => PRJ_ID, :path => repository_path_hash(['sources', 'watchers_controller.rb'])[:param] + } assert_response :success # Line 22, revision 4:def6d2f1254a @@ -372,8 +426,10 @@ class RepositoriesMercurialControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :annotate, :id => PRJ_ID, + get :annotate, :params => { + :id => PRJ_ID, :path => repository_path_hash(['sources', 'welcome_controller.rb'])[:param] + } assert_response 404 assert_select_error /was not found/ end @@ -384,8 +440,11 @@ class RepositoriesMercurialControllerTest < Redmine::ControllerTest @project.reload assert_equal NUM_REV, @repository.changesets.count [2, '400bb8672109', '400', 400].each do |r1| - get :annotate, :id => PRJ_ID, :rev => r1, + get :annotate, :params => { + :id => PRJ_ID, + :rev => r1, :path => repository_path_hash(['sources', 'watchers_controller.rb'])[:param] + } assert_response :success assert_select 'h2', :text => /@ 2:400bb8672109/ end @@ -393,9 +452,11 @@ class RepositoriesMercurialControllerTest < Redmine::ControllerTest def test_annotate_latin_1_path [21, '21', 'adf805632193'].each do |r1| - get :annotate, :id => PRJ_ID, - :path => repository_path_hash(['latin-1-dir', "test-#{@char_1}-2.txt"])[:param], - :rev => r1 + get :annotate, :params => { + :id => PRJ_ID, + :path => repository_path_hash(['latin-1-dir', "test-#{@char_1}-2.txt"])[:param], + :rev => r1 + } assert_response :success assert_select "th.line-num", :text => '1' do assert_select "+ td.revision" do @@ -412,9 +473,11 @@ class RepositoriesMercurialControllerTest < Redmine::ControllerTest def test_annotate_latin_1_contents with_settings :repositories_encodings => 'UTF-8,ISO-8859-1' do [27, '7bbf4c738e71'].each do |r1| - get :annotate, :id => PRJ_ID, - :path => repository_path_hash(['latin-1-dir', "test-#{@char_1}.txt"])[:param], - :rev => r1 + get :annotate, :params => { + :id => PRJ_ID, + :path => repository_path_hash(['latin-1-dir', "test-#{@char_1}.txt"])[:param], + :rev => r1 + } assert_select 'tr#L1 td.line-code', :text => /test-#{@char_1}.txt/ end end @@ -427,7 +490,10 @@ class RepositoriesMercurialControllerTest < Redmine::ControllerTest assert_equal NUM_REV, @repository.changesets.count ['1', '9d5b5b', '9d5b5b004199'].each do |r| with_settings :default_language => "en" do - get :revision, :id => PRJ_ID, :rev => r + get :revision, :params => { + :id => PRJ_ID, + :rev => r + } assert_response :success assert_select 'title', :text => 'Revision 1:9d5b5b004199 - Added 2 files and modified one. - eCookbook Subproject 1 - Redmine' @@ -441,7 +507,10 @@ class RepositoriesMercurialControllerTest < Redmine::ControllerTest @project.reload assert_equal NUM_REV, @repository.changesets.count ['', ' ', nil].each do |r| - get :revision, :id => PRJ_ID, :rev => r + get :revision, :params => { + :id => PRJ_ID, + :rev => r + } assert_response 404 assert_select_error /was not found/ end @@ -454,7 +523,9 @@ class RepositoriesMercurialControllerTest < Redmine::ControllerTest assert_equal NUM_REV, @repository.changesets.count assert_difference 'Repository.count', -1 do - delete :destroy, :id => @repository.id + delete :destroy, :params => { + :id => @repository.id + } end assert_response 302 @project.reload @@ -473,7 +544,9 @@ class RepositoriesMercurialControllerTest < Redmine::ControllerTest assert_equal 0, @repository.changesets.count assert_difference 'Repository.count', -1 do - delete :destroy, :id => @repository.id + delete :destroy, :params => { + :id => @repository.id + } end assert_response 302 @project.reload diff --git a/test/functional/repositories_subversion_controller_test.rb b/test/functional/repositories_subversion_controller_test.rb index 92dc2c2f7..4829d720c 100644 --- a/test/functional/repositories_subversion_controller_test.rb +++ b/test/functional/repositories_subversion_controller_test.rb @@ -41,7 +41,10 @@ class RepositoriesSubversionControllerTest < Redmine::ControllerTest def test_new @request.session[:user_id] = 1 @project.repository.destroy - get :new, :project_id => 'subproject1', :repository_scm => 'Subversion' + get :new, :params => { + :project_id => 'subproject1', + :repository_scm => 'Subversion' + } assert_response :success assert_select 'select[name=?]', 'repository_scm' do assert_select 'option[value=?][selected=selected]', 'Subversion' @@ -53,7 +56,9 @@ class RepositoriesSubversionControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :show, :id => PRJ_ID + get :show, :params => { + :id => PRJ_ID + } assert_response :success assert_select 'table.entries tbody' do @@ -78,7 +83,10 @@ class RepositoriesSubversionControllerTest < Redmine::ControllerTest :url => self.class.subversion_repository_url, :is_default => false, :identifier => 'svn') - get :show, :id => PRJ_ID, :repository_id => 'svn' + get :show, :params => { + :id => PRJ_ID, + :repository_id => 'svn' + } assert_response :success assert_select 'tr.dir a[href="/projects/subproject1/repository/svn/show/subversion_test"]' @@ -91,7 +99,10 @@ class RepositoriesSubversionControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :show, :id => PRJ_ID, :path => repository_path_hash(['subversion_test'])[:param] + get :show, :params => { + :id => PRJ_ID, + :path => repository_path_hash(['subversion_test'])[:param] + } assert_response :success assert_select 'table.entries tbody' do @@ -111,8 +122,11 @@ class RepositoriesSubversionControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :show, :id => PRJ_ID, :path => repository_path_hash(['subversion_test'])[:param], + get :show, :params => { + :id => PRJ_ID, + :path => repository_path_hash(['subversion_test'])[:param], :rev => 4 + } assert_response :success assert_select 'table.entries tbody' do @@ -130,8 +144,10 @@ class RepositoriesSubversionControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :changes, :id => PRJ_ID, + get :changes, :params => { + :id => PRJ_ID, :path => repository_path_hash(['subversion_test', 'folder', 'helloworld.rb'])[:param] + } assert_response :success assert_select 'table.changesets tbody' do @@ -155,8 +171,10 @@ class RepositoriesSubversionControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :changes, :id => PRJ_ID, + get :changes, :params => { + :id => PRJ_ID, :path => repository_path_hash(['subversion_test', 'folder'])[:param] + } assert_response :success assert_select 'table.changesets tbody' do @@ -175,8 +193,10 @@ class RepositoriesSubversionControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :entry, :id => PRJ_ID, + get :entry, :params => { + :id => PRJ_ID, :path => repository_path_hash(['subversion_test', 'helloworld.c'])[:param] + } assert_response :success assert_select 'h2 a', :text => 'subversion_test' assert_select 'h2 a', :text => 'helloworld.c' @@ -189,8 +209,10 @@ class RepositoriesSubversionControllerTest < Redmine::ControllerTest assert_equal NUM_REV, @repository.changesets.count # no files in the test repo is larger than 1KB... with_settings :file_max_size_displayed => 0 do - get :entry, :id => PRJ_ID, + get :entry, :params => { + :id => PRJ_ID, :path => repository_path_hash(['subversion_test', 'helloworld.c'])[:param] + } assert_response :success assert_equal 'text/html', @response.content_type assert_select 'p.nodata' @@ -198,8 +220,10 @@ class RepositoriesSubversionControllerTest < Redmine::ControllerTest end def test_entry_should_display_images - get :entry, :id => PRJ_ID, + get :entry, :params => { + :id => PRJ_ID, :path => repository_path_hash(['subversion_test', 'folder', 'subfolder', 'rubylogo.gif'])[:param] + } assert_response :success assert_select 'img[src=?]', '/projects/subproject1/repository/raw/subversion_test/folder/subfolder/rubylogo.gif' end @@ -209,9 +233,11 @@ class RepositoriesSubversionControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :entry, :id => PRJ_ID, + get :entry, :params => { + :id => PRJ_ID, :path => repository_path_hash(['subversion_test', 'helloworld.rb'])[:param], :rev => 2 + } assert_response :success # this line was removed in r3 and file was moved in r6 assert_select 'td.line-code', :text => /Here's the code/ @@ -222,8 +248,10 @@ class RepositoriesSubversionControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :entry, :id => PRJ_ID, + get :entry, :params => { + :id => PRJ_ID, :path => repository_path_hash(['subversion_test', 'zzz.c'])[:param] + } assert_select 'p#errorExplanation', :text => /The entry or revision was not found in the repository/ end @@ -232,8 +260,10 @@ class RepositoriesSubversionControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :raw, :id => PRJ_ID, + get :raw, :params => { + :id => PRJ_ID, :path => repository_path_hash(['subversion_test', 'helloworld.c'])[:param] + } assert_response :success assert_equal 'attachment; filename="helloworld.c"', @response.headers['Content-Disposition'] end @@ -243,8 +273,10 @@ class RepositoriesSubversionControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :entry, :id => PRJ_ID, + get :entry, :params => { + :id => PRJ_ID, :path => repository_path_hash(['subversion_test', 'folder'])[:param] + } assert_response :success assert_select 'h2 a', :text => 'subversion_test' assert_select 'h2 a', :text => 'folder' @@ -252,7 +284,10 @@ class RepositoriesSubversionControllerTest < Redmine::ControllerTest # TODO: this test needs fixtures. def test_revision - get :revision, :id => 1, :rev => 2 + get :revision, :params => { + :id => 1, + :rev => 2 + } assert_response :success assert_select 'ul' do @@ -270,13 +305,20 @@ class RepositoriesSubversionControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :revision, :id => PRJ_ID, :rev => 'something_weird' + get :revision, :params => { + :id => PRJ_ID, + :rev => 'something_weird' + } assert_response 404 assert_select_error /was not found/ end def test_invalid_revision_diff - get :diff, :id => PRJ_ID, :rev => '1', :rev_to => 'something_weird' + get :diff, :params => { + :id => PRJ_ID, + :rev => '1', + :rev_to => 'something_weird' + } assert_response 404 assert_select_error /was not found/ end @@ -287,7 +329,10 @@ class RepositoriesSubversionControllerTest < Redmine::ControllerTest @project.reload assert_equal NUM_REV, @repository.changesets.count ['', ' ', nil].each do |r| - get :revision, :id => PRJ_ID, :rev => r + get :revision, :params => { + :id => PRJ_ID, + :rev => r + } assert_response 404 assert_select_error /was not found/ end @@ -299,7 +344,10 @@ class RepositoriesSubversionControllerTest < Redmine::ControllerTest # Changes repository url to a subdirectory r.update_attribute :url, (r.url + '/test/some') - get :revision, :id => 1, :rev => 2 + get :revision, :params => { + :id => 1, + :rev => 2 + } assert_response :success assert_select 'ul' do @@ -318,7 +366,11 @@ class RepositoriesSubversionControllerTest < Redmine::ControllerTest @project.reload assert_equal NUM_REV, @repository.changesets.count ['inline', 'sbs'].each do |dt| - get :diff, :id => PRJ_ID, :rev => 3, :type => dt + get :diff, :params => { + :id => PRJ_ID, + :rev => 3, + :type => dt + } assert_response :success assert_select 'h2', :text => /Revision 3/ assert_select 'th.filename', :text => 'subversion_test/textfile.txt' @@ -331,7 +383,11 @@ class RepositoriesSubversionControllerTest < Redmine::ControllerTest @project.reload assert_equal NUM_REV, @repository.changesets.count - get :diff, :id => PRJ_ID, :rev => 5, :format => 'diff' + get :diff, :params => { + :id => PRJ_ID, + :rev => 5, + :format => 'diff' + } assert_response :success assert_equal 'text/x-patch', @response.content_type assert_equal 'Index: subversion_test/folder/greeter.rb', @response.body.split(/\r?\n/).first @@ -343,9 +399,13 @@ class RepositoriesSubversionControllerTest < Redmine::ControllerTest @project.reload assert_equal NUM_REV, @repository.changesets.count ['inline', 'sbs'].each do |dt| - get :diff, :id => PRJ_ID, :rev => 6, :rev_to => 2, + get :diff, :params => { + :id => PRJ_ID, + :rev => 6, + :rev_to => 2, :path => repository_path_hash(['subversion_test', 'folder'])[:param], :type => dt + } assert_response :success assert_select 'h2', :text => /2:6/ @@ -361,8 +421,10 @@ class RepositoriesSubversionControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :annotate, :id => PRJ_ID, + get :annotate, :params => { + :id => PRJ_ID, :path => repository_path_hash(['subversion_test', 'helloworld.c'])[:param] + } assert_response :success assert_select 'tr' do @@ -384,8 +446,11 @@ class RepositoriesSubversionControllerTest < Redmine::ControllerTest @repository.fetch_changesets @project.reload assert_equal NUM_REV, @repository.changesets.count - get :annotate, :id => PRJ_ID, :rev => 8, + get :annotate, :params => { + :id => PRJ_ID, + :rev => 8, :path => repository_path_hash(['subversion_test', 'helloworld.c'])[:param] + } assert_response :success assert_select 'h2', :text => /@ 8/ end @@ -397,7 +462,9 @@ class RepositoriesSubversionControllerTest < Redmine::ControllerTest assert_equal NUM_REV, @repository.changesets.count assert_difference 'Repository.count', -1 do - delete :destroy, :id => @repository.id + delete :destroy, :params => { + :id => @repository.id + } end assert_response 302 @project.reload @@ -414,7 +481,9 @@ class RepositoriesSubversionControllerTest < Redmine::ControllerTest assert_equal 0, @repository.changesets.count assert_difference 'Repository.count', -1 do - delete :destroy, :id => @repository.id + delete :destroy, :params => { + :id => @repository.id + } end assert_response 302 @project.reload diff --git a/test/functional/sessions_controller_test.rb b/test/functional/sessions_controller_test.rb index f362947b5..bcc182ccc 100644 --- a/test/functional/sessions_controller_test.rb +++ b/test/functional/sessions_controller_test.rb @@ -35,7 +35,10 @@ class SessionsControllerTest < Redmine::ControllerTest token = Token.create!(:user_id => 2, :action => 'session', :created_on => 10.hours.ago, :updated_on => 10.hours.ago) created = token.reload.created_on - get :index, :session => {:user_id => 2, :tk => token.value} + get :index, :session => { + :user_id => 2, + :tk => token.value + } assert_response :success token.reload assert_equal created.to_i, token.created_on.to_i @@ -48,13 +51,18 @@ class SessionsControllerTest < Redmine::ControllerTest token = Token.create!(:user_id => 2, :action => 'session', :created_on => created, :updated_on => created) with_settings :session_lifetime => '0', :session_timeout => '0' do - get :index, :session => {:user_id => 2, :tk => token.value} + get :index, :session => { + :user_id => 2, + :tk => token.value + } assert_response :success end end def test_user_session_without_token_should_be_reset - get :index, :session => {:user_id => 2} + get :index, :session => { + :user_id => 2 + } assert_redirected_to 'http://test.host/login?back_url=http%3A%2F%2Ftest.host%2F' end @@ -63,7 +71,10 @@ class SessionsControllerTest < Redmine::ControllerTest token = Token.create!(:user_id => 2, :action => 'session', :created_on => created, :updated_on => created) with_settings :session_timeout => '720' do - get :index, :session => {:user_id => 2, :tk => token.value} + get :index, :session => { + :user_id => 2, + :tk => token.value + } assert_redirected_to 'http://test.host/login?back_url=http%3A%2F%2Ftest.host%2F' end end @@ -73,7 +84,10 @@ class SessionsControllerTest < Redmine::ControllerTest token = Token.create!(:user_id => 2, :action => 'session', :created_on => created, :updated_on => created) with_settings :session_timeout => '720' do - get :index, :session => {:user_id => 2, :tk => token.value} + get :index, :session => { + :user_id => 2, + :tk => token.value + } assert_response :success end end @@ -83,7 +97,10 @@ class SessionsControllerTest < Redmine::ControllerTest token = Token.create!(:user_id => 2, :action => 'session', :created_on => created, :updated_on => created) with_settings :session_timeout => '60' do - get :index, :session => {:user_id => 2, :tk => token.value} + get :index, :session => { + :user_id => 2, + :tk => token.value + } assert_redirected_to 'http://test.host/login?back_url=http%3A%2F%2Ftest.host%2F' end end @@ -93,7 +110,10 @@ class SessionsControllerTest < Redmine::ControllerTest token = Token.create!(:user_id => 2, :action => 'session', :created_on => created, :updated_on => created) with_settings :session_timeout => '60' do - get :index, :session => {:user_id => 2, :tk => token.value} + get :index, :session => { + :user_id => 2, + :tk => token.value + } assert_response :success end end @@ -106,7 +126,10 @@ class SessionsControllerTest < Redmine::ControllerTest autologin_token = Token.create!(:user_id => 2, :action => 'autologin', :created_on => 1.day.ago) @request.cookies['autologin'] = autologin_token.value - get :index, :session => {:user_id => 2, :tk => token.value} + get :index, :session => { + :user_id => 2, + :tk => token.value + } assert_equal 2, session[:user_id] assert_response :success assert_not_equal token.value, session[:tk] @@ -122,7 +145,10 @@ class SessionsControllerTest < Redmine::ControllerTest token = Token.create!(:user_id => 2, :action => 'session', :created_on => created, :updated_on => created) with_settings :session_timeout => '60' do - get :index, :session => {:user_id => user.id, :tk => token.value} + get :index, :session => { + :user_id => user.id, + :tk => token.value + } assert_redirected_to 'http://test.host/login?back_url=http%3A%2F%2Ftest.host%2F' assert_include "Veuillez vous reconnecter", flash[:error] assert_equal :fr, current_language diff --git a/test/functional/versions_controller_test.rb b/test/functional/versions_controller_test.rb index 87c6517df..2698516bf 100644 --- a/test/functional/versions_controller_test.rb +++ b/test/functional/versions_controller_test.rb @@ -136,7 +136,7 @@ class VersionsControllerTest < Redmine::ControllerTest def test_new_from_issue_form @request.session[:user_id] = 2 - xhr :get, :new, :params => {:project_id => '1'} + get :new, :params => {:project_id => '1'}, :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end @@ -155,7 +155,7 @@ class VersionsControllerTest < Redmine::ControllerTest def test_create_from_issue_form @request.session[:user_id] = 2 assert_difference 'Version.count' do - xhr :post, :create, :params => {:project_id => '1', :version => {:name => 'test_add_version_from_issue_form'}} + post :create, :params => {:project_id => '1', :version => {:name => 'test_add_version_from_issue_form'}}, :xhr => true end version = Version.find_by_name('test_add_version_from_issue_form') assert_not_nil version @@ -169,7 +169,7 @@ class VersionsControllerTest < Redmine::ControllerTest def test_create_from_issue_form_with_failure @request.session[:user_id] = 2 assert_no_difference 'Version.count' do - xhr :post, :create, :params => {:project_id => '1', :version => {:name => ''}} + post :create, :params => {:project_id => '1', :version => {:name => ''}}, :xhr => true end assert_response :success assert_equal 'text/javascript', response.content_type @@ -247,12 +247,12 @@ class VersionsControllerTest < Redmine::ControllerTest end def test_issue_status_by - xhr :get, :status_by, :params => {:id => 2} + get :status_by, :params => {:id => 2}, :xhr => true assert_response :success end def test_issue_status_by_status - xhr :get, :status_by, :params => {:id => 2, :status_by => 'status'} + get :status_by, :params => {:id => 2, :status_by => 'status'}, :xhr => true assert_response :success assert_include 'Assigned', response.body assert_include 'Closed', response.body diff --git a/test/functional/watchers_controller_test.rb b/test/functional/watchers_controller_test.rb index 3cec7a075..10ef85b39 100644 --- a/test/functional/watchers_controller_test.rb +++ b/test/functional/watchers_controller_test.rb @@ -38,7 +38,7 @@ class WatchersControllerTest < Redmine::ControllerTest def test_watch_a_single_object @request.session[:user_id] = 3 assert_difference('Watcher.count') do - xhr :post, :watch, :params => {:object_type => 'issue', :object_id => '1'} + post :watch, :params => {:object_type => 'issue', :object_id => '1'}, :xhr => true assert_response :success assert_include '$(".issue-1-watcher")', response.body end @@ -48,7 +48,7 @@ class WatchersControllerTest < Redmine::ControllerTest def test_watch_a_collection_with_a_single_object @request.session[:user_id] = 3 assert_difference('Watcher.count') do - xhr :post, :watch, :params => {:object_type => 'issue', :object_id => ['1']} + post :watch, :params => {:object_type => 'issue', :object_id => ['1']}, :xhr => true assert_response :success assert_include '$(".issue-1-watcher")', response.body end @@ -58,7 +58,7 @@ class WatchersControllerTest < Redmine::ControllerTest def test_watch_a_collection_with_multiple_objects @request.session[:user_id] = 3 assert_difference('Watcher.count', 2) do - xhr :post, :watch, :params => {:object_type => 'issue', :object_id => ['1', '3']} + post :watch, :params => {:object_type => 'issue', :object_id => ['1', '3']}, :xhr => true assert_response :success assert_include '$(".issue-bulk-watcher")', response.body end @@ -71,7 +71,7 @@ class WatchersControllerTest < Redmine::ControllerTest assert_not_nil m = Project.find(1).enabled_module('news') assert_difference 'Watcher.count' do - xhr :post, :watch, :params => {:object_type => 'enabled_module', :object_id => m.id.to_s} + post :watch, :params => {:object_type => 'enabled_module', :object_id => m.id.to_s}, :xhr => true assert_response :success end assert m.reload.watched_by?(User.find(7)) @@ -82,7 +82,7 @@ class WatchersControllerTest < Redmine::ControllerTest assert_not_nil m = Project.find(2).enabled_module('news') assert_no_difference 'Watcher.count' do - xhr :post, :watch, :params => {:object_type => 'enabled_module', :object_id => m.id.to_s} + post :watch, :params => {:object_type => 'enabled_module', :object_id => m.id.to_s}, :xhr => true assert_response 403 end end @@ -91,7 +91,7 @@ class WatchersControllerTest < Redmine::ControllerTest Role.find(2).remove_permission! :view_issues @request.session[:user_id] = 3 assert_no_difference('Watcher.count') do - xhr :post, :watch, :params => {:object_type => 'issue', :object_id => '1'} + post :watch, :params => {:object_type => 'issue', :object_id => '1'}, :xhr => true assert_response 403 end end @@ -99,7 +99,7 @@ class WatchersControllerTest < Redmine::ControllerTest def test_watch_invalid_class_should_respond_with_404 @request.session[:user_id] = 3 assert_no_difference('Watcher.count') do - xhr :post, :watch, :params => {:object_type => 'foo', :object_id => '1'} + post :watch, :params => {:object_type => 'foo', :object_id => '1'}, :xhr => true assert_response 404 end end @@ -107,7 +107,7 @@ class WatchersControllerTest < Redmine::ControllerTest def test_watch_invalid_object_should_respond_with_404 @request.session[:user_id] = 3 assert_no_difference('Watcher.count') do - xhr :post, :watch, :params => {:object_type => 'issue', :object_id => '999'} + post :watch, :params => {:object_type => 'issue', :object_id => '999'}, :xhr => true assert_response 404 end end @@ -125,7 +125,7 @@ class WatchersControllerTest < Redmine::ControllerTest def test_unwatch @request.session[:user_id] = 3 assert_difference('Watcher.count', -1) do - xhr :delete, :unwatch, :params => {:object_type => 'issue', :object_id => '2'} + delete :unwatch, :params => {:object_type => 'issue', :object_id => '2'}, :xhr => true assert_response :success assert_include '$(".issue-2-watcher")', response.body end @@ -138,7 +138,7 @@ class WatchersControllerTest < Redmine::ControllerTest Watcher.create!(:user_id => 3, :watchable => Issue.find(3)) assert_difference('Watcher.count', -2) do - xhr :delete, :unwatch, :params => {:object_type => 'issue', :object_id => ['1', '3']} + delete :unwatch, :params => {:object_type => 'issue', :object_id => ['1', '3']}, :xhr => true assert_response :success assert_include '$(".issue-bulk-watcher")', response.body end @@ -148,28 +148,28 @@ class WatchersControllerTest < Redmine::ControllerTest def test_new @request.session[:user_id] = 2 - xhr :get, :new, :params => {:object_type => 'issue', :object_id => '2'} + get :new, :params => {:object_type => 'issue', :object_id => '2'}, :xhr => true assert_response :success assert_match /ajax-modal/, response.body end def test_new_with_multiple_objects @request.session[:user_id] = 2 - xhr :get, :new, :params => {:object_type => 'issue', :object_id => ['1', '2']} + get :new, :params => {:object_type => 'issue', :object_id => ['1', '2']}, :xhr => true assert_response :success assert_match /ajax-modal/, response.body end def test_new_for_new_record_with_project_id @request.session[:user_id] = 2 - xhr :get, :new, :params => {:project_id => 1} + get :new, :params => {:project_id => 1}, :xhr => true assert_response :success assert_match /ajax-modal/, response.body end def test_new_for_new_record_with_project_identifier @request.session[:user_id] = 2 - xhr :get, :new, :params => {:project_id => 'ecookbook'} + get :new, :params => {:project_id => 'ecookbook'}, :xhr => true assert_response :success assert_match /ajax-modal/, response.body end @@ -190,10 +190,10 @@ class WatchersControllerTest < Redmine::ControllerTest def test_create @request.session[:user_id] = 2 assert_difference('Watcher.count') do - xhr :post, :create, :params => { + post :create, :params => { :object_type => 'issue', :object_id => '2', :watcher => {:user_id => '4'} - } + }, :xhr => true assert_response :success assert_match /watchers/, response.body assert_match /ajax-modal/, response.body @@ -204,10 +204,10 @@ class WatchersControllerTest < Redmine::ControllerTest def test_create_with_mutiple_users @request.session[:user_id] = 2 assert_difference('Watcher.count', 2) do - xhr :post, :create, :params => { + post :create, :params => { :object_type => 'issue', :object_id => '2', :watcher => {:user_ids => ['4', '7']} - } + }, :xhr => true assert_response :success assert_match /watchers/, response.body assert_match /ajax-modal/, response.body @@ -219,10 +219,10 @@ class WatchersControllerTest < Redmine::ControllerTest def test_create_with_mutiple_objects @request.session[:user_id] = 2 assert_difference('Watcher.count', 4) do - xhr :post, :create, :params => { + post :create, :params => { :object_type => 'issue', :object_id => ['1', '2'], :watcher => {:user_ids => ['4', '7']} - } + }, :xhr => true assert_response :success assert_match /watchers/, response.body assert_match /ajax-modal/, response.body @@ -235,7 +235,7 @@ class WatchersControllerTest < Redmine::ControllerTest def test_autocomplete_on_watchable_creation @request.session[:user_id] = 2 - xhr :get, :autocomplete_for_user, :params => {:q => 'mi', :project_id => 'ecookbook'} + get :autocomplete_for_user, :params => {:q => 'mi', :project_id => 'ecookbook'}, :xhr => true assert_response :success assert_select 'input', :count => 4 assert_select 'input[name=?][value="1"]', 'watcher[user_ids][]' @@ -250,17 +250,17 @@ class WatchersControllerTest < Redmine::ControllerTest user = User.generate!(:firstname => 'issue15622') membership = user.membership(project) assert_nil membership - xhr :get, :autocomplete_for_user, :params => {:q => 'issue15622', :project_id => 'ecookbook'} + get :autocomplete_for_user, :params => {:q => 'issue15622', :project_id => 'ecookbook'}, :xhr => true assert_response :success assert_select 'input', :count => 1 end def test_autocomplete_on_watchable_update @request.session[:user_id] = 2 - xhr :get, :autocomplete_for_user, :params => { + get :autocomplete_for_user, :params => { :object_type => 'issue', :object_id => '2', :project_id => 'ecookbook', :q => 'mi' - } + }, :xhr => true assert_response :success assert_select 'input', :count => 3 assert_select 'input[name=?][value="2"]', 'watcher[user_ids][]' @@ -275,18 +275,18 @@ class WatchersControllerTest < Redmine::ControllerTest membership = user.membership(project) assert_nil membership - xhr :get, :autocomplete_for_user, :params => { + get :autocomplete_for_user, :params => { :object_type => 'issue', :object_id => '2', :project_id => 'ecookbook', :q => 'issue15622' - } + }, :xhr => true assert_response :success assert_select 'input', :count => 1 assert_difference('Watcher.count', 1) do - xhr :post, :create, :params => { + post :create, :params => { :object_type => 'issue', :object_id => '2', :watcher => {:user_ids => ["#{user.id}"]} - } + }, :xhr => true assert_response :success assert_match /watchers/, response.body assert_match /ajax-modal/, response.body @@ -302,7 +302,7 @@ class WatchersControllerTest < Redmine::ControllerTest User.add_to_project(visible, Project.find(1)) @request.session[:user_id] = 2 - xhr :get, :autocomplete_for_user, :params => {:q => 'autocomp', :project_id => 'ecookbook'} + get :autocomplete_for_user, :params => {:q => 'autocomp', :project_id => 'ecookbook'}, :xhr => true assert_response :success assert_include visible.name, response.body @@ -312,9 +312,9 @@ class WatchersControllerTest < Redmine::ControllerTest def test_append @request.session[:user_id] = 2 assert_no_difference 'Watcher.count' do - xhr :post, :append, :params => { + post :append, :params => { :watcher => {:user_ids => ['4', '7']}, :project_id => 'ecookbook' - } + }, :xhr => true assert_response :success assert_include 'watchers_inputs', response.body assert_include 'issue[watcher_user_ids][]', response.body @@ -323,7 +323,7 @@ class WatchersControllerTest < Redmine::ControllerTest def test_append_without_user_should_render_nothing @request.session[:user_id] = 2 - xhr :post, :append, :params => {:project_id => 'ecookbook'} + post :append, :params => {:project_id => 'ecookbook'}, :xhr => true assert_response :success assert response.body.blank? end @@ -343,9 +343,9 @@ class WatchersControllerTest < Redmine::ControllerTest def test_destroy @request.session[:user_id] = 2 assert_difference('Watcher.count', -1) do - xhr :delete, :destroy, :params => { + delete :destroy, :params => { :object_type => 'issue', :object_id => '2', :user_id => '3' - } + }, :xhr => true assert_response :success assert_match /watchers/, response.body end @@ -359,9 +359,9 @@ class WatchersControllerTest < Redmine::ControllerTest @request.session[:user_id] = 2 assert_difference('Watcher.count', -1) do - xhr :delete, :destroy, :params => { + delete :destroy, :params => { :object_type => 'issue', :object_id => '2', :user_id => '3' - } + }, :xhr => true assert_response :success assert_match /watchers/, response.body end diff --git a/test/functional/wiki_controller_test.rb b/test/functional/wiki_controller_test.rb index 1cc0a3b7d..8931b4ec7 100644 --- a/test/functional/wiki_controller_test.rb +++ b/test/functional/wiki_controller_test.rb @@ -188,7 +188,7 @@ class WikiControllerTest < Redmine::ControllerTest def test_get_new_xhr @request.session[:user_id] = 2 - xhr :get, :new, :params => {:project_id => 'ecookbook'} + get :new, :params => {:project_id => 'ecookbook'}, :xhr => true assert_response :success assert_include 'Unallowed characters', response.body end @@ -203,7 +203,7 @@ class WikiControllerTest < Redmine::ControllerTest def test_post_new_xhr_with_valid_title_should_redirect_to_edit @request.session[:user_id] = 2 - xhr :post, :new, :params => {:project_id => 'ecookbook', :title => 'New Page'} + post :new, :params => {:project_id => 'ecookbook', :title => 'New Page'}, :xhr => true assert_response :success assert_equal 'window.location = "/projects/ecookbook/wiki/New_Page"', response.body end @@ -228,7 +228,7 @@ class WikiControllerTest < Redmine::ControllerTest def test_post_new_xhr_with_invalid_title_should_display_errors @request.session[:user_id] = 2 - xhr :post, :new, :params => {:project_id => 'ecookbook', :title => 'Another page'} + post :new, :params => {:project_id => 'ecookbook', :title => 'Another page'}, :xhr => true assert_response :success assert_include 'Title has already been taken', response.body end @@ -581,7 +581,7 @@ class WikiControllerTest < Redmine::ControllerTest def test_preview @request.session[:user_id] = 2 - xhr :post, :preview, :params => { + post :preview, :params => { :project_id => 1, :id => 'CookBook_documentation', :content => { @@ -589,14 +589,14 @@ class WikiControllerTest < Redmine::ControllerTest :text => 'this is a *previewed text*', :version => 3 } - } + }, :xhr => true assert_response :success assert_select 'strong', :text => /previewed text/ end def test_preview_new_page @request.session[:user_id] = 2 - xhr :post, :preview, :params => { + post :preview, :params => { :project_id => 1, :id => 'New page', :content => { @@ -604,7 +604,7 @@ class WikiControllerTest < Redmine::ControllerTest :comments => '', :version => 0 } - } + }, :xhr => true assert_response :success assert_select 'h1', :text => /New page/ end diff --git a/test/functional/wikis_controller_test.rb b/test/functional/wikis_controller_test.rb index 7a37ca265..ed68269ce 100644 --- a/test/functional/wikis_controller_test.rb +++ b/test/functional/wikis_controller_test.rb @@ -29,7 +29,7 @@ class WikisControllerTest < Redmine::ControllerTest assert_nil Project.find(3).wiki assert_difference 'Wiki.count' do - xhr :post, :edit, :params => {:id => 3, :wiki => { :start_page => 'Start page' }} + post :edit, :params => {:id => 3, :wiki => { :start_page => 'Start page' }}, :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end @@ -43,7 +43,7 @@ class WikisControllerTest < Redmine::ControllerTest @request.session[:user_id] = 1 assert_no_difference 'Wiki.count' do - xhr :post, :edit, :params => {:id => 3, :wiki => { :start_page => '' }} + post :edit, :params => {:id => 3, :wiki => { :start_page => '' }}, :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end @@ -56,7 +56,7 @@ class WikisControllerTest < Redmine::ControllerTest @request.session[:user_id] = 1 assert_no_difference 'Wiki.count' do - xhr :post, :edit, :params => {:id => 1, :wiki => { :start_page => 'Other start page' }} + post :edit, :params => {:id => 1, :wiki => { :start_page => 'Other start page' }}, :xhr => true assert_response :success assert_equal 'text/javascript', response.content_type end diff --git a/test/test_helper.rb b/test/test_helper.rb index 4cee54472..19a60c838 100644 --- a/test/test_helper.rb +++ b/test/test_helper.rb @@ -320,10 +320,12 @@ module Redmine assert_equal expected_filters.size, filter_init.scan("addFilter").size, "filters counts don't match" end - def process(method, path, parameters={}, session={}, flash={}) - if parameters.key?(:params) || parameters.key?(:session) - raise ArgumentError if session.present? - super method, path, parameters[:params], parameters[:session], parameters.except(:params, :session) + def process(action, http_method = 'GET', *args) + parameters, session, flash = *args + if args.size == 1 && parameters[:xhr] == true + xhr http_method.downcase.to_sym, action, parameters.except(:xhr) + elsif parameters && (parameters.key?(:params) || parameters.key?(:session) || parameters.key?(:flash)) + super action, http_method, parameters[:params], parameters[:session], parameters[:flash] else super end |