issues_controller_transaction_test.rb
265 lines
| 9.0 KiB
| text/x-ruby
|
RubyLexer
|
r3555 | # Redmine - project management software | ||
|
r9453 | # Copyright (C) 2006-2012 Jean-Philippe Lang | ||
|
r3555 | # | ||
# This program is free software; you can redistribute it and/or | ||||
# modify it under the terms of the GNU General Public License | ||||
# as published by the Free Software Foundation; either version 2 | ||||
# of the License, or (at your option) any later version. | ||||
|
r6799 | # | ||
|
r3555 | # This program is distributed in the hope that it will be useful, | ||
# but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||||
# GNU General Public License for more details. | ||||
|
r6799 | # | ||
|
r3555 | # You should have received a copy of the GNU General Public License | ||
# along with this program; if not, write to the Free Software | ||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | ||||
|
r4395 | require File.expand_path('../../test_helper', __FILE__) | ||
|
r3555 | require 'issues_controller' | ||
class IssuesControllerTransactionTest < ActionController::TestCase | ||||
fixtures :projects, | ||||
:users, | ||||
:roles, | ||||
:members, | ||||
:member_roles, | ||||
:issues, | ||||
:issue_statuses, | ||||
:versions, | ||||
:trackers, | ||||
:projects_trackers, | ||||
:issue_categories, | ||||
:enabled_modules, | ||||
:enumerations, | ||||
:attachments, | ||||
:workflows, | ||||
:custom_fields, | ||||
:custom_values, | ||||
:custom_fields_projects, | ||||
:custom_fields_trackers, | ||||
:time_entries, | ||||
:journals, | ||||
:journal_details, | ||||
:queries | ||||
self.use_transactional_fixtures = false | ||||
|
r6799 | |||
|
r3555 | def setup | ||
@controller = IssuesController.new | ||||
@request = ActionController::TestRequest.new | ||||
@response = ActionController::TestResponse.new | ||||
User.current = nil | ||||
end | ||||
|
r6799 | |||
|
r8654 | def test_update_stale_issue_should_not_update_the_issue | ||
|
r3555 | issue = Issue.find(2) | ||
@request.session[:user_id] = 2 | ||||
assert_no_difference 'Journal.count' do | ||||
assert_no_difference 'TimeEntry.count' do | ||||
|
r8771 | put :update, | ||
:id => issue.id, | ||||
:issue => { | ||||
:fixed_version_id => 4, | ||||
|
r10336 | :notes => 'My notes', | ||
|
r8771 | :lock_version => (issue.lock_version - 1) | ||
}, | ||||
:time_entry => { :hours => '2.5', :comments => '', :activity_id => TimeEntryActivity.first.id } | ||||
end | ||||
end | ||||
assert_response :success | ||||
assert_template 'edit' | ||||
|
r9742 | |||
assert_select 'div.conflict' | ||||
assert_select 'input[name=?][value=?]', 'conflict_resolution', 'overwrite' | ||||
assert_select 'input[name=?][value=?]', 'conflict_resolution', 'add_notes' | ||||
assert_select 'label' do | ||||
assert_select 'input[name=?][value=?]', 'conflict_resolution', 'cancel' | ||||
assert_select 'a[href=/issues/2]' | ||||
end | ||||
|
r8771 | end | ||
def test_update_stale_issue_should_save_attachments | ||||
set_tmp_attachments_directory | ||||
issue = Issue.find(2) | ||||
@request.session[:user_id] = 2 | ||||
assert_no_difference 'Journal.count' do | ||||
assert_no_difference 'TimeEntry.count' do | ||||
assert_difference 'Attachment.count' do | ||||
|
r3555 | put :update, | ||
:id => issue.id, | ||||
:issue => { | ||||
:fixed_version_id => 4, | ||||
|
r10336 | :notes => 'My notes', | ||
|
r3555 | :lock_version => (issue.lock_version - 1) | ||
}, | ||||
:attachments => {'1' => {'file' => uploaded_test_file('testfile.txt', 'text/plain')}}, | ||||
|
r3587 | :time_entry => { :hours => '2.5', :comments => '', :activity_id => TimeEntryActivity.first.id } | ||
|
r3555 | end | ||
end | ||||
end | ||||
|
r6799 | |||
|
r3555 | assert_response :success | ||
assert_template 'edit' | ||||
|
r8771 | attachment = Attachment.first(:order => 'id DESC') | ||
assert_tag 'input', :attributes => {:name => 'attachments[p0][token]', :value => attachment.token} | ||||
assert_tag 'span', :content => /testfile.txt/ | ||||
|
r8654 | end | ||
def test_update_stale_issue_without_notes_should_not_show_add_notes_option | ||||
issue = Issue.find(2) | ||||
@request.session[:user_id] = 2 | ||||
put :update, :id => issue.id, | ||||
:issue => { | ||||
:fixed_version_id => 4, | ||||
|
r10336 | :notes => '', | ||
|
r8654 | :lock_version => (issue.lock_version - 1) | ||
|
r10336 | } | ||
|
r8654 | |||
assert_tag 'div', :attributes => {:class => 'conflict'} | ||||
assert_tag 'input', :attributes => {:name => 'conflict_resolution', :value => 'overwrite'} | ||||
assert_no_tag 'input', :attributes => {:name => 'conflict_resolution', :value => 'add_notes'} | ||||
assert_tag 'input', :attributes => {:name => 'conflict_resolution', :value => 'cancel'} | ||||
end | ||||
def test_update_stale_issue_should_show_conflicting_journals | ||||
@request.session[:user_id] = 2 | ||||
put :update, :id => 1, | ||||
:issue => { | ||||
:fixed_version_id => 4, | ||||
|
r10336 | :notes => '', | ||
|
r8654 | :lock_version => 2 | ||
}, | ||||
:last_journal_id => 1 | ||||
assert_not_nil assigns(:conflict_journals) | ||||
assert_equal 1, assigns(:conflict_journals).size | ||||
assert_equal 2, assigns(:conflict_journals).first.id | ||||
assert_tag 'div', :attributes => {:class => 'conflict'}, | ||||
:descendant => {:content => /Some notes with Redmine links/} | ||||
end | ||||
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, | ||||
|
r10336 | :notes => '', | ||
|
r8654 | :lock_version => 2 | ||
}, | ||||
:last_journal_id => '' | ||||
assert_not_nil assigns(:conflict_journals) | ||||
assert_equal 2, assigns(:conflict_journals).size | ||||
assert_tag 'div', :attributes => {:class => 'conflict'}, | ||||
:descendant => {:content => /Some notes with Redmine links/} | ||||
assert_tag 'div', :attributes => {:class => 'conflict'}, | ||||
:descendant => {:content => /Journal notes/} | ||||
end | ||||
|
r10336 | def test_update_stale_issue_should_show_private_journals_with_permission_only | ||
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 => '' | ||||
assert_include journal, assigns(:conflict_journals) | ||||
Role.find(1).remove_permission! :view_private_notes | ||||
put :update, :id => 1, :issue => {:fixed_version_id => 4, :lock_version => 2}, :last_journal_id => '' | ||||
assert_not_include journal, assigns(:conflict_journals) | ||||
end | ||||
|
r8654 | def test_update_stale_issue_with_overwrite_conflict_resolution_should_update | ||
@request.session[:user_id] = 2 | ||||
assert_difference 'Journal.count' do | ||||
put :update, :id => 1, | ||||
:issue => { | ||||
:fixed_version_id => 4, | ||||
|
r10336 | :notes => 'overwrite_conflict_resolution', | ||
|
r8654 | :lock_version => 2 | ||
}, | ||||
:conflict_resolution => 'overwrite' | ||||
end | ||||
assert_response 302 | ||||
issue = Issue.find(1) | ||||
assert_equal 4, issue.fixed_version_id | ||||
journal = Journal.first(:order => 'id DESC') | ||||
assert_equal 'overwrite_conflict_resolution', journal.notes | ||||
assert journal.details.any? | ||||
end | ||||
def test_update_stale_issue_with_add_notes_conflict_resolution_should_update | ||||
@request.session[:user_id] = 2 | ||||
assert_difference 'Journal.count' do | ||||
put :update, :id => 1, | ||||
:issue => { | ||||
:fixed_version_id => 4, | ||||
|
r10336 | :notes => 'add_notes_conflict_resolution', | ||
|
r8654 | :lock_version => 2 | ||
}, | ||||
:conflict_resolution => 'add_notes' | ||||
end | ||||
assert_response 302 | ||||
issue = Issue.find(1) | ||||
assert_nil issue.fixed_version_id | ||||
journal = Journal.first(:order => 'id DESC') | ||||
assert_equal 'add_notes_conflict_resolution', journal.notes | ||||
assert journal.details.empty? | ||||
end | ||||
def test_update_stale_issue_with_cancel_conflict_resolution_should_redirect_without_updating | ||||
@request.session[:user_id] = 2 | ||||
assert_no_difference 'Journal.count' do | ||||
put :update, :id => 1, | ||||
:issue => { | ||||
:fixed_version_id => 4, | ||||
|
r10336 | :notes => 'add_notes_conflict_resolution', | ||
|
r8654 | :lock_version => 2 | ||
}, | ||||
:conflict_resolution => 'cancel' | ||||
end | ||||
assert_redirected_to '/issues/1' | ||||
issue = Issue.find(1) | ||||
assert_nil issue.fixed_version_id | ||||
|
r3555 | end | ||
|
r7958 | |||
|
r10415 | def test_put_update_with_spent_time_and_failure_should_not_add_spent_time | ||
@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 } | ||||
assert_response :success | ||||
end | ||||
assert_select 'input[name=?][value=?]', 'time_entry[hours]', '2.5' | ||||
assert_select 'input[name=?][value=?]', 'time_entry[comments]', 'should not be added' | ||||
assert_select 'select[name=?]', 'time_entry[activity_id]' do | ||||
assert_select 'option[value=?][selected=selected]', TimeEntryActivity.first.id | ||||
end | ||||
end | ||||
|
r7958 | def test_index_should_rescue_invalid_sql_query | ||
Query.any_instance.stubs(:statement).returns("INVALID STATEMENT") | ||||
get :index | ||||
assert_response 500 | ||||
assert_tag 'p', :content => /An error occurred/ | ||||
assert_nil session[:query] | ||||
assert_nil session[:issues_index_sort] | ||||
end | ||||
|
r3555 | end | ||