attachments_test.rb
150 lines
| 5.3 KiB
| text/x-ruby
|
RubyLexer
|
r6175 | # Redmine - project management software | ||
|
r9453 | # Copyright (C) 2006-2012 Jean-Philippe Lang | ||
|
r6175 | # | ||
# 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. | ||||
|
r6546 | # | ||
|
r6175 | # 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. | ||||
|
r6546 | # | ||
|
r6175 | # 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. | ||||
require File.expand_path('../../../test_helper', __FILE__) | ||||
class ApiTest::AttachmentsTest < ActionController::IntegrationTest | ||||
|
r7386 | fixtures :projects, :trackers, :issue_statuses, :issues, | ||
:enumerations, :users, :issue_categories, | ||||
:projects_trackers, | ||||
:roles, | ||||
:member_roles, | ||||
:members, | ||||
:enabled_modules, | ||||
:workflows, | ||||
:attachments | ||||
|
r6175 | |||
def setup | ||||
Setting.rest_api_enabled = '1' | ||||
|
r8128 | set_fixtures_attachments_directory | ||
end | ||||
def teardown | ||||
set_tmp_attachments_directory | ||||
|
r6175 | end | ||
|
r6546 | |||
|
r10223 | test "GET /attachments/:id.xml should return the attachment" do | ||
get '/attachments/7.xml', {}, credentials('jsmith') | ||||
assert_response :success | ||||
assert_equal 'application/xml', @response.content_type | ||||
assert_tag :tag => 'attachment', | ||||
:child => { | ||||
:tag => 'id', | ||||
:content => '7', | ||||
:sibling => { | ||||
:tag => 'filename', | ||||
:content => 'archive.zip', | ||||
:sibling => { | ||||
:tag => 'content_url', | ||||
:content => 'http://www.example.com/attachments/download/7/archive.zip' | ||||
|
r6175 | } | ||
|
r10223 | } | ||
} | ||||
end | ||||
|
r6546 | |||
|
r10223 | test "GET /attachments/:id.xml should deny access without credentials" do | ||
get '/attachments/7.xml' | ||||
assert_response 401 | ||||
set_tmp_attachments_directory | ||||
|
r6175 | end | ||
|
r6546 | |||
|
r10223 | test "GET /attachments/download/:id/:filename should return the attachment content" do | ||
get '/attachments/download/7/archive.zip', {}, credentials('jsmith') | ||||
assert_response :success | ||||
assert_equal 'application/octet-stream', @response.content_type | ||||
set_tmp_attachments_directory | ||||
end | ||||
|
r6546 | |||
|
r10223 | test "GET /attachments/download/:id/:filename should deny access without credentials" do | ||
get '/attachments/download/7/archive.zip' | ||||
assert_response 302 | ||||
set_tmp_attachments_directory | ||||
|
r6175 | end | ||
|
r8808 | |||
|
r10223 | test "POST /uploads.xml should return the token" do | ||
set_tmp_attachments_directory | ||||
assert_difference 'Attachment.count' do | ||||
post '/uploads.xml', 'File content', {"CONTENT_TYPE" => 'application/octet-stream'}.merge(credentials('jsmith')) | ||||
assert_response :created | ||||
assert_equal 'application/xml', response.content_type | ||||
end | ||||
|
r8808 | |||
|
r10223 | xml = Hash.from_xml(response.body) | ||
assert_kind_of Hash, xml['upload'] | ||||
token = xml['upload']['token'] | ||||
assert_not_nil token | ||||
|
r8808 | |||
|
r10223 | attachment = Attachment.first(:order => 'id DESC') | ||
assert_equal token, attachment.token | ||||
assert_nil attachment.container | ||||
assert_equal 2, attachment.author_id | ||||
assert_equal 'File content'.size, attachment.filesize | ||||
assert attachment.content_type.blank? | ||||
assert attachment.filename.present? | ||||
assert_match /\d+_[0-9a-z]+/, attachment.diskfile | ||||
assert File.exist?(attachment.diskfile) | ||||
assert_equal 'File content', File.read(attachment.diskfile) | ||||
end | ||||
|
r8808 | |||
|
r10224 | test "POST /uploads.json should return the token" do | ||
set_tmp_attachments_directory | ||||
assert_difference 'Attachment.count' do | ||||
post '/uploads.json', 'File content', {"CONTENT_TYPE" => 'application/octet-stream'}.merge(credentials('jsmith')) | ||||
assert_response :created | ||||
assert_equal 'application/json', response.content_type | ||||
end | ||||
json = ActiveSupport::JSON.decode(response.body) | ||||
assert_kind_of Hash, json['upload'] | ||||
token = json['upload']['token'] | ||||
assert_not_nil token | ||||
attachment = Attachment.first(:order => 'id DESC') | ||||
assert_equal token, attachment.token | ||||
end | ||||
|
r10467 | test "POST /uploads.xml should accept :filename param as the attachment filename" do | ||
set_tmp_attachments_directory | ||||
assert_difference 'Attachment.count' do | ||||
post '/uploads.xml?filename=test.txt', 'File content', {"CONTENT_TYPE" => 'application/octet-stream'}.merge(credentials('jsmith')) | ||||
assert_response :created | ||||
end | ||||
attachment = Attachment.order('id DESC').first | ||||
assert_equal 'test.txt', attachment.filename | ||||
assert_match /_test\.txt$/, attachment.diskfile | ||||
end | ||||
|
r10223 | test "POST /uploads.xml should not accept other content types" do | ||
set_tmp_attachments_directory | ||||
assert_no_difference 'Attachment.count' do | ||||
post '/uploads.xml', 'PNG DATA', {"CONTENT_TYPE" => 'image/png'}.merge(credentials('jsmith')) | ||||
assert_response 406 | ||||
|
r8808 | end | ||
|
r10223 | end | ||
|
r8817 | |||
|
r10223 | test "POST /uploads.xml should return errors if file is too big" do | ||
set_tmp_attachments_directory | ||||
with_settings :attachment_max_size => 1 do | ||||
assert_no_difference 'Attachment.count' do | ||||
post '/uploads.xml', ('x' * 2048), {"CONTENT_TYPE" => 'application/octet-stream'}.merge(credentials('jsmith')) | ||||
assert_response 422 | ||||
assert_tag 'error', :content => /exceeds the maximum allowed file size/ | ||||
|
r8817 | end | ||
end | ||||
|
r8808 | end | ||
|
r6175 | end | ||