diff options
| author | Peter Zhu <peter@peterzhu.ca> | 2019-07-19 10:41:38 -0400 | 
|---|---|---|
| committer | Peter Zhu <peter@peterzhu.ca> | 2019-07-24 14:56:20 -0400 | 
| commit | 094fa9277d840fe2061f37b9704f81fecdbbe965 (patch) | |
| tree | 7d44d205d9581eb56ca3b216ba8df739be2b1e23 | |
| parent | e4747a4965ad7f081f6c66cadcadffe0545e4025 (diff) | |
| download | rails-094fa9277d840fe2061f37b9704f81fecdbbe965.tar.gz rails-094fa9277d840fe2061f37b9704f81fecdbbe965.tar.bz2 rails-094fa9277d840fe2061f37b9704f81fecdbbe965.zip | |
Add content_type to upload in Azure
| -rw-r--r-- | activestorage/lib/active_storage/service/azure_storage_service.rb | 4 | ||||
| -rw-r--r-- | activestorage/test/service/azure_storage_service_test.rb | 14 | 
2 files changed, 16 insertions, 2 deletions
| diff --git a/activestorage/lib/active_storage/service/azure_storage_service.rb b/activestorage/lib/active_storage/service/azure_storage_service.rb index 993cc0e5f7..8d77e9b20f 100644 --- a/activestorage/lib/active_storage/service/azure_storage_service.rb +++ b/activestorage/lib/active_storage/service/azure_storage_service.rb @@ -17,10 +17,10 @@ module ActiveStorage        @container = container      end -    def upload(key, io, checksum: nil, **) +    def upload(key, io, checksum: nil, content_type: nil, **)        instrument :upload, key: key, checksum: checksum do          handle_errors do -          blobs.create_block_blob(container, key, IO.try_convert(io) || io, content_md5: checksum) +          blobs.create_block_blob(container, key, IO.try_convert(io) || io, content_md5: checksum, content_type: content_type)          end        end      end diff --git a/activestorage/test/service/azure_storage_service_test.rb b/activestorage/test/service/azure_storage_service_test.rb index 2b07902d07..fc7b86ccb0 100644 --- a/activestorage/test/service/azure_storage_service_test.rb +++ b/activestorage/test/service/azure_storage_service_test.rb @@ -9,6 +9,20 @@ if SERVICE_CONFIGURATIONS[:azure]      include ActiveStorage::Service::SharedServiceTests +    test "upload with content_type" do +      key      = SecureRandom.base58(24) +      data     = "Foobar" + +      @service.upload(key, StringIO.new(data), checksum: Digest::MD5.base64digest(data), filename: ActiveStorage::Filename.new("test.txt"), content_type: "text/plain") + +      url = @service.url(key, expires_in: 2.minutes, disposition: :attachment, content_type: nil, filename: ActiveStorage::Filename.new("test.html")) +      response = Net::HTTP.get_response(URI(url)) +      assert_equal "text/plain", response.content_type +      assert_match(/attachment;.*test\.html/, response["Content-Disposition"]) +    ensure +      @service.delete key +    end +      test "signed URL generation" do        url = @service.url(@key, expires_in: 5.minutes,          disposition: :inline, filename: ActiveStorage::Filename.new("avatar.png"), content_type: "image/png") | 
