attachments_controller_test.rb
385 lines
| 12.1 KiB
| text/x-ruby
|
RubyLexer
|
r4484 | # encoding: utf-8 | ||
# | ||||
# Redmine - project management software | ||||
|
r10939 | # Copyright (C) 2006-2013 Jean-Philippe Lang | ||
|
r1506 | # | ||
# 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. | ||||
|
r5564 | # | ||
|
r1506 | # 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. | ||||
|
r5564 | # | ||
|
r1506 | # 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__) | ||
|
r1506 | |||
|
r2773 | class AttachmentsControllerTest < ActionController::TestCase | ||
|
r7697 | fixtures :users, :projects, :roles, :members, :member_roles, | ||
:enabled_modules, :issues, :trackers, :attachments, | ||||
|
r2600 | :versions, :wiki_pages, :wikis, :documents | ||
|
r5564 | |||
|
r1506 | def setup | ||
User.current = nil | ||||
|
r8128 | set_fixtures_attachments_directory | ||
end | ||||
def teardown | ||||
set_tmp_attachments_directory | ||||
|
r1506 | end | ||
|
r5564 | |||
|
r1506 | def test_show_diff | ||
|
r7741 | ['inline', 'sbs'].each do |dt| | ||
|
r7742 | # 060719210727_changeset_utf8.diff | ||
|
r7741 | get :show, :id => 14, :type => dt | ||
assert_response :success | ||||
assert_template 'diff' | ||||
assert_equal 'text/html', @response.content_type | ||||
assert_tag 'th', | ||||
:attributes => {:class => /filename/}, | ||||
:content => /issues_controller.rb\t\(révision 1484\)/ | ||||
assert_tag 'td', | ||||
:attributes => {:class => /line-code/}, | ||||
:content => /Demande créée avec succès/ | ||||
end | ||||
|
r7791 | set_tmp_attachments_directory | ||
|
r4484 | end | ||
|
r5564 | |||
|
r10950 | def test_show_diff_replace_cannot_convert_content | ||
|
r7746 | with_settings :repositories_encodings => 'UTF-8' do | ||
['inline', 'sbs'].each do |dt| | ||||
# 060719210727_changeset_iso8859-1.diff | ||||
|
r7765 | get :show, :id => 5, :type => dt | ||
|
r7746 | assert_response :success | ||
assert_template 'diff' | ||||
assert_equal 'text/html', @response.content_type | ||||
assert_tag 'th', | ||||
:attributes => {:class => "filename"}, | ||||
:content => /issues_controller.rb\t\(r\?vision 1484\)/ | ||||
assert_tag 'td', | ||||
:attributes => {:class => /line-code/}, | ||||
:content => /Demande cr\?\?e avec succ\?s/ | ||||
end | ||||
|
r7741 | end | ||
|
r7791 | set_tmp_attachments_directory | ||
|
r1506 | end | ||
|
r5564 | |||
|
r7747 | def test_show_diff_latin_1 | ||
with_settings :repositories_encodings => 'UTF-8,ISO-8859-1' do | ||||
|
r7753 | ['inline', 'sbs'].each do |dt| | ||
# 060719210727_changeset_iso8859-1.diff | ||||
|
r7765 | get :show, :id => 5, :type => dt | ||
|
r7753 | assert_response :success | ||
assert_template 'diff' | ||||
assert_equal 'text/html', @response.content_type | ||||
assert_tag 'th', | ||||
:attributes => {:class => "filename"}, | ||||
:content => /issues_controller.rb\t\(révision 1484\)/ | ||||
assert_tag 'td', | ||||
:attributes => {:class => /line-code/}, | ||||
:content => /Demande créée avec succès/ | ||||
end | ||||
|
r7747 | end | ||
|
r7791 | set_tmp_attachments_directory | ||
|
r7747 | end | ||
|
r8641 | def test_save_diff_type | ||
|
r10292 | user1 = User.find(1) | ||
user1.pref[:diff_type] = nil | ||||
user1.preference.save | ||||
|
r8641 | user = User.find(1) | ||
|
r10292 | assert_nil user.pref[:diff_type] | ||
@request.session[:user_id] = 1 # admin | ||||
|
r8641 | get :show, :id => 5 | ||
assert_response :success | ||||
assert_template 'diff' | ||||
user.reload | ||||
assert_equal "inline", user.pref[:diff_type] | ||||
get :show, :id => 5, :type => 'sbs' | ||||
assert_response :success | ||||
assert_template 'diff' | ||||
user.reload | ||||
assert_equal "sbs", user.pref[:diff_type] | ||||
end | ||||
|
r10246 | def test_diff_show_filename_in_mercurial_export | ||
set_tmp_attachments_directory | ||||
a = Attachment.new(:container => Issue.find(1), | ||||
:file => uploaded_test_file("hg-export.diff", "text/plain"), | ||||
:author => User.find(1)) | ||||
assert a.save | ||||
assert_equal 'hg-export.diff', a.filename | ||||
get :show, :id => a.id, :type => 'inline' | ||||
assert_response :success | ||||
assert_template 'diff' | ||||
assert_equal 'text/html', @response.content_type | ||||
assert_select 'th.filename', :text => 'test1.txt' | ||||
end | ||||
|
r1506 | def test_show_text_file | ||
get :show, :id => 4 | ||||
assert_response :success | ||||
assert_template 'file' | ||||
|
r2440 | assert_equal 'text/html', @response.content_type | ||
|
r7791 | set_tmp_attachments_directory | ||
|
r2440 | end | ||
|
r5564 | |||
|
r7703 | def test_show_text_file_utf_8 | ||
|
r7728 | set_tmp_attachments_directory | ||
|
r7703 | a = Attachment.new(:container => Issue.find(1), | ||
:file => uploaded_test_file("japanese-utf-8.txt", "text/plain"), | ||||
:author => User.find(1)) | ||||
assert a.save | ||||
assert_equal 'japanese-utf-8.txt', a.filename | ||||
str_japanese = "\xe6\x97\xa5\xe6\x9c\xac\xe8\xaa\x9e" | ||||
str_japanese.force_encoding('UTF-8') if str_japanese.respond_to?(:force_encoding) | ||||
get :show, :id => a.id | ||||
assert_response :success | ||||
assert_template 'file' | ||||
assert_equal 'text/html', @response.content_type | ||||
assert_tag :tag => 'th', | ||||
:content => '1', | ||||
:attributes => { :class => 'line-num' }, | ||||
:sibling => { :tag => 'td', :content => /#{str_japanese}/ } | ||||
end | ||||
|
r10950 | def test_show_text_file_replace_cannot_convert_content | ||
|
r7728 | set_tmp_attachments_directory | ||
|
r7746 | with_settings :repositories_encodings => 'UTF-8' do | ||
a = Attachment.new(:container => Issue.find(1), | ||||
:file => uploaded_test_file("iso8859-1.txt", "text/plain"), | ||||
:author => User.find(1)) | ||||
assert a.save | ||||
assert_equal 'iso8859-1.txt', a.filename | ||||
get :show, :id => a.id | ||||
assert_response :success | ||||
assert_template 'file' | ||||
assert_equal 'text/html', @response.content_type | ||||
assert_tag :tag => 'th', | ||||
:content => '7', | ||||
:attributes => { :class => 'line-num' }, | ||||
:sibling => { :tag => 'td', :content => /Demande cr\?\?e avec succ\?s/ } | ||||
|
r7791 | end | ||
|
r7704 | end | ||
|
r7748 | def test_show_text_file_latin_1 | ||
set_tmp_attachments_directory | ||||
with_settings :repositories_encodings => 'UTF-8,ISO-8859-1' do | ||||
a = Attachment.new(:container => Issue.find(1), | ||||
:file => uploaded_test_file("iso8859-1.txt", "text/plain"), | ||||
:author => User.find(1)) | ||||
assert a.save | ||||
assert_equal 'iso8859-1.txt', a.filename | ||||
get :show, :id => a.id | ||||
assert_response :success | ||||
assert_template 'file' | ||||
assert_equal 'text/html', @response.content_type | ||||
assert_tag :tag => 'th', | ||||
:content => '7', | ||||
:attributes => { :class => 'line-num' }, | ||||
:sibling => { :tag => 'td', :content => /Demande créée avec succès/ } | ||||
end | ||||
end | ||||
|
r2440 | def test_show_text_file_should_send_if_too_big | ||
|
r2441 | Setting.file_max_size_displayed = 512 | ||
|
r2440 | Attachment.find(4).update_attribute :filesize, 754.kilobyte | ||
|
r5564 | |||
|
r2440 | get :show, :id => 4 | ||
assert_response :success | ||||
assert_equal 'application/x-ruby', @response.content_type | ||||
|
r7791 | set_tmp_attachments_directory | ||
|
r1506 | end | ||
|
r5564 | |||
|
r1506 | def test_show_other | ||
get :show, :id => 6 | ||||
assert_response :success | ||||
assert_equal 'application/octet-stream', @response.content_type | ||||
|
r7791 | set_tmp_attachments_directory | ||
|
r1506 | end | ||
|
r5564 | |||
|
r5346 | def test_show_file_from_private_issue_without_permission | ||
get :show, :id => 15 | ||||
assert_redirected_to '/login?back_url=http%3A%2F%2Ftest.host%2Fattachments%2F15' | ||||
|
r7791 | set_tmp_attachments_directory | ||
|
r5346 | end | ||
|
r5564 | |||
|
r5346 | def test_show_file_from_private_issue_with_permission | ||
@request.session[:user_id] = 2 | ||||
get :show, :id => 15 | ||||
assert_response :success | ||||
assert_tag 'h2', :content => /private.diff/ | ||||
|
r7791 | set_tmp_attachments_directory | ||
|
r5346 | end | ||
|
r5564 | |||
|
r10748 | def test_show_file_without_container_should_be_allowed_to_author | ||
|
r8794 | set_tmp_attachments_directory | ||
|
r8771 | attachment = Attachment.create!(:file => uploaded_test_file("testfile.txt", "text/plain"), :author_id => 2) | ||
@request.session[:user_id] = 2 | ||||
get :show, :id => attachment.id | ||||
|
r10748 | assert_response 200 | ||
end | ||||
|
r10757 | def test_show_file_without_container_should_be_denied_to_other_users | ||
|
r10748 | set_tmp_attachments_directory | ||
attachment = Attachment.create!(:file => uploaded_test_file("testfile.txt", "text/plain"), :author_id => 2) | ||||
@request.session[:user_id] = 3 | ||||
get :show, :id => attachment.id | ||||
|
r8771 | assert_response 403 | ||
end | ||||
|
r8828 | def test_show_invalid_should_respond_with_404 | ||
get :show, :id => 999 | ||||
assert_response 404 | ||||
end | ||||
|
r1506 | def test_download_text_file | ||
get :download, :id => 4 | ||||
assert_response :success | ||||
assert_equal 'application/x-ruby', @response.content_type | ||||
|
r7791 | set_tmp_attachments_directory | ||
|
r1506 | end | ||
|
r5564 | |||
|
r7864 | def test_download_version_file_with_issue_tracking_disabled | ||
Project.find(1).disable_module! :issue_tracking | ||||
get :download, :id => 9 | ||||
assert_response :success | ||||
end | ||||
|
r3144 | def test_download_should_assign_content_type_if_blank | ||
Attachment.find(4).update_attribute(:content_type, '') | ||||
|
r5564 | |||
|
r3144 | get :download, :id => 4 | ||
assert_response :success | ||||
assert_equal 'text/x-ruby', @response.content_type | ||||
|
r7791 | set_tmp_attachments_directory | ||
|
r3144 | end | ||
|
r5564 | |||
|
r2600 | def test_download_missing_file | ||
get :download, :id => 2 | ||||
assert_response 404 | ||||
|
r7791 | set_tmp_attachments_directory | ||
|
r2600 | end | ||
|
r5564 | |||
|
r9750 | def test_download_should_be_denied_without_permission | ||
|
r1668 | get :download, :id => 7 | ||
|
r2233 | assert_redirected_to '/login?back_url=http%3A%2F%2Ftest.host%2Fattachments%2Fdownload%2F7' | ||
|
r7791 | set_tmp_attachments_directory | ||
|
r1668 | end | ||
|
r5564 | |||
|
r9750 | if convert_installed? | ||
def test_thumbnail | ||||
Attachment.clear_thumbnails | ||||
@request.session[:user_id] = 2 | ||||
|
r9830 | |||
get :thumbnail, :id => 16 | ||||
assert_response :success | ||||
assert_equal 'image/png', response.content_type | ||||
|
r9750 | end | ||
|
r9830 | def test_thumbnail_should_not_exceed_maximum_size | ||
Redmine::Thumbnail.expects(:generate).with {|source, target, size| size == 800} | ||||
|
r9750 | @request.session[:user_id] = 2 | ||
|
r9830 | get :thumbnail, :id => 16, :size => 2000 | ||
|
r9750 | end | ||
|
r9830 | def test_thumbnail_should_round_size | ||
Redmine::Thumbnail.expects(:generate).with {|source, target, size| size == 250} | ||||
|
r9750 | @request.session[:user_id] = 2 | ||
|
r9830 | get :thumbnail, :id => 16, :size => 260 | ||
end | ||||
def test_thumbnail_should_return_404_for_non_image_attachment | ||||
@request.session[:user_id] = 2 | ||||
get :thumbnail, :id => 15 | ||||
assert_response 404 | ||||
|
r9750 | end | ||
def test_thumbnail_should_return_404_if_thumbnail_generation_failed | ||||
Attachment.any_instance.stubs(:thumbnail).returns(nil) | ||||
@request.session[:user_id] = 2 | ||||
|
r9830 | |||
get :thumbnail, :id => 16 | ||||
assert_response 404 | ||||
|
r9750 | end | ||
def test_thumbnail_should_be_denied_without_permission | ||||
|
r9830 | get :thumbnail, :id => 16 | ||
assert_redirected_to '/login?back_url=http%3A%2F%2Ftest.host%2Fattachments%2Fthumbnail%2F16' | ||||
|
r9750 | end | ||
else | ||||
puts '(ImageMagick convert not available)' | ||||
end | ||||
|
r2114 | def test_destroy_issue_attachment | ||
|
r7863 | set_tmp_attachments_directory | ||
|
r2114 | issue = Issue.find(3) | ||
@request.session[:user_id] = 2 | ||||
|
r5564 | |||
|
r2114 | assert_difference 'issue.attachments.count', -1 do | ||
|
r8953 | assert_difference 'Journal.count' do | ||
delete :destroy, :id => 1 | ||||
assert_redirected_to '/projects/ecookbook' | ||||
end | ||||
|
r2114 | end | ||
assert_nil Attachment.find_by_id(1) | ||||
|
r8953 | j = Journal.first(:order => 'id DESC') | ||
assert_equal issue, j.journalized | ||||
|
r2114 | assert_equal 'attachment', j.details.first.property | ||
assert_equal '1', j.details.first.prop_key | ||||
assert_equal 'error281.txt', j.details.first.old_value | ||||
|
r8953 | assert_equal User.find(2), j.user | ||
|
r2114 | end | ||
|
r5564 | |||
|
r2114 | def test_destroy_wiki_page_attachment | ||
|
r7863 | set_tmp_attachments_directory | ||
|
r2114 | @request.session[:user_id] = 2 | ||
assert_difference 'Attachment.count', -1 do | ||||
|
r7828 | delete :destroy, :id => 3 | ||
|
r2115 | assert_response 302 | ||
end | ||||
end | ||||
|
r5564 | |||
|
r2115 | def test_destroy_project_attachment | ||
|
r7863 | set_tmp_attachments_directory | ||
|
r2115 | @request.session[:user_id] = 2 | ||
assert_difference 'Attachment.count', -1 do | ||||
|
r7828 | delete :destroy, :id => 8 | ||
|
r2115 | assert_response 302 | ||
end | ||||
end | ||||
|
r5564 | |||
|
r2115 | def test_destroy_version_attachment | ||
|
r7863 | set_tmp_attachments_directory | ||
|
r2115 | @request.session[:user_id] = 2 | ||
assert_difference 'Attachment.count', -1 do | ||||
|
r7828 | delete :destroy, :id => 9 | ||
|
r2115 | assert_response 302 | ||
|
r2114 | end | ||
end | ||||
|
r5564 | |||
|
r2114 | def test_destroy_without_permission | ||
|
r7863 | set_tmp_attachments_directory | ||
|
r7828 | assert_no_difference 'Attachment.count' do | ||
delete :destroy, :id => 3 | ||||
end | ||||
assert_response 302 | ||||
|
r2114 | assert Attachment.find_by_id(3) | ||
end | ||||
|
r1506 | end | ||