diff options
author | Jean-Philippe Lang <jp_lang@yahoo.fr> | 2014-12-22 13:41:51 +0000 |
---|---|---|
committer | Jean-Philippe Lang <jp_lang@yahoo.fr> | 2014-12-22 13:41:51 +0000 |
commit | 9b082712a09146b4237cf3427dce6293ba748643 (patch) | |
tree | fc3080139f07ff6d9881ea469420d6871ed8b636 /test | |
parent | 6c6ea394af66e2dcf41ce5c16526d93da1c29507 (diff) | |
download | redmine-9b082712a09146b4237cf3427dce6293ba748643.tar.gz redmine-9b082712a09146b4237cf3427dce6293ba748643.zip |
Adds tests for creating an issue with multiple uploads.
git-svn-id: http://svn.redmine.org/redmine/trunk@13791 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'test')
-rw-r--r-- | test/integration/api_test/issues_test.rb | 57 | ||||
-rw-r--r-- | test/test_helper.rb | 39 |
2 files changed, 96 insertions, 0 deletions
diff --git a/test/integration/api_test/issues_test.rb b/test/integration/api_test/issues_test.rb index 161beee67..439e1d400 100644 --- a/test/integration/api_test/issues_test.rb +++ b/test/integration/api_test/issues_test.rb @@ -561,6 +561,63 @@ class Redmine::ApiTest::IssuesTest < Redmine::ApiTest::Base assert_response :success end + def test_create_issue_with_multiple_uploaded_files_as_xml + token1 = xml_upload('File content 1', credentials('jsmith')) + token2 = xml_upload('File content 2', credentials('jsmith')) + + payload = <<-XML +<?xml version="1.0" encoding="UTF-8" ?> +<issue> + <project_id>1</project_id> + <tracker_id>1</tracker_id> + <subject>Issue with multiple attachments</subject> + <uploads type="array"> + <upload> + <token>#{token1}</token> + <filename>test1.txt</filename> + </upload> + <upload> + <token>#{token2}</token> + <filename>test1.txt</filename> + </upload> + </uploads> +</issue> +XML + + assert_difference 'Issue.count' do + post '/issues.xml', payload, {"CONTENT_TYPE" => 'application/xml'}.merge(credentials('jsmith')) + assert_response :created + end + issue = Issue.order('id DESC').first + assert_equal 2, issue.attachments.count + end + + def test_create_issue_with_multiple_uploaded_files_as_json + token1 = json_upload('File content 1', credentials('jsmith')) + token2 = json_upload('File content 2', credentials('jsmith')) + + payload = <<-JSON +{ + "issue": { + "project_id": "1", + "tracker_id": "1", + "subject": "Issue with multiple attachments", + "uploads": [ + {"token": "#{token1}", "filename": "test1.txt"}, + {"token": "#{token2}", "filename": "test2.txt"} + ] + } +} +JSON + + assert_difference 'Issue.count' do + post '/issues.json', payload, {"CONTENT_TYPE" => 'application/json'}.merge(credentials('jsmith')) + assert_response :created + end + issue = Issue.order('id DESC').first + assert_equal 2, issue.attachments.count + end + def test_update_issue_with_uploaded_file set_tmp_attachments_directory # upload the file diff --git a/test/test_helper.rb b/test/test_helper.rb index 44ea86f5b..22b96a809 100644 --- a/test/test_helper.rb +++ b/test/test_helper.rb @@ -271,6 +271,45 @@ module Redmine def teardown Setting.rest_api_enabled = '0' end + + # Uploads content using the XML API and returns the attachment token + def xml_upload(content, credentials) + upload('xml', content, credentials) + end + + # Uploads content using the JSON API and returns the attachment token + def json_upload(content, credentials) + upload('json', content, credentials) + end + + def upload(format, content, credentials) + set_tmp_attachments_directory + assert_difference 'Attachment.count' do + post "/uploads.#{format}", content, {"CONTENT_TYPE" => 'application/octet-stream'}.merge(credentials) + assert_response :created + end + data = response_data + assert_kind_of Hash, data['upload'] + token = data['upload']['token'] + assert_not_nil token + token + end + + # Parses the response body based on its content type + def response_data + unless response.content_type.to_s =~ /^application\/(.+)/ + raise "Unexpected response type: #{response.content_type}" + end + format = $1 + case format + when 'xml' + Hash.from_xml(response.body) + when 'json' + ActiveSupport::JSON.decode(response.body) + else + raise "Unknown response format: #{format}" + end + end end class Routing < Redmine::RoutingTest |