diff options
author | George Claghorn <george@basecamp.com> | 2017-07-27 17:05:38 -0400 |
---|---|---|
committer | George Claghorn <george@basecamp.com> | 2017-07-27 17:05:38 -0400 |
commit | 64bbcaf2446a116f1abed69b781522cebbb572da (patch) | |
tree | 544c82b2a571fcf163f1c7123472cac970b1510a /test/controllers | |
parent | a9091eaa67bd2ebbb4876549ff33a33600276040 (diff) | |
download | rails-64bbcaf2446a116f1abed69b781522cebbb572da.tar.gz rails-64bbcaf2446a116f1abed69b781522cebbb572da.tar.bz2 rails-64bbcaf2446a116f1abed69b781522cebbb572da.zip |
Use blob service URL methods
Diffstat (limited to 'test/controllers')
-rw-r--r-- | test/controllers/disk_controller_test.rb | 48 |
1 files changed, 14 insertions, 34 deletions
diff --git a/test/controllers/disk_controller_test.rb b/test/controllers/disk_controller_test.rb index 83087eff68..f498d5e22e 100644 --- a/test/controllers/disk_controller_test.rb +++ b/test/controllers/disk_controller_test.rb @@ -4,73 +4,53 @@ require "database/setup" class ActiveStorage::DiskControllerTest < ActionDispatch::IntegrationTest test "showing blob inline" do blob = create_blob - key = ActiveStorage.verifier.generate(blob.key, expires_in: 5.minutes, purpose: :blob_key) - get rails_disk_service_url(key, blob.filename, content_type: blob.content_type) + get blob.service_url assert_equal "inline; filename=\"#{blob.filename.base}\"", @response.headers["Content-Disposition"] assert_equal "text/plain", @response.headers["Content-Type"] end test "showing blob as attachment" do blob = create_blob - key = ActiveStorage.verifier.generate(blob.key, expires_in: 5.minutes, purpose: :blob_key) - get rails_disk_service_url(key, blob.filename, content_type: blob.content_type, disposition: :attachment) + get blob.service_url(disposition: :attachment) assert_equal "attachment; filename=\"#{blob.filename.base}\"", @response.headers["Content-Disposition"] assert_equal "text/plain", @response.headers["Content-Type"] end test "directly uploading blob with integrity" do - data = "Something else entirely!" - blob = create_blob_before_direct_upload byte_size: data.size, checksum: Digest::MD5.base64digest(data) - token = encode_verified_token_for blob + data = "Something else entirely!" + blob = create_blob_before_direct_upload byte_size: data.size, checksum: Digest::MD5.base64digest(data) - put update_rails_disk_service_url(token), params: data, headers: { "Content-Type" => "text/plain" } + put blob.service_url_for_direct_upload, params: data, headers: { "Content-Type" => "text/plain" } assert_response :no_content assert_equal data, blob.download end test "directly uploading blob without integrity" do - data = "Something else entirely!" - blob = create_blob_before_direct_upload byte_size: data.size, checksum: Digest::MD5.base64digest("bad data") - token = encode_verified_token_for blob + data = "Something else entirely!" + blob = create_blob_before_direct_upload byte_size: data.size, checksum: Digest::MD5.base64digest("bad data") - put update_rails_disk_service_url(token), params: data + put blob.service_url_for_direct_upload, params: data assert_response :unprocessable_entity assert_not blob.service.exist?(blob.key) end test "directly uploading blob with mismatched content type" do - data = "Something else entirely!" - blob = create_blob_before_direct_upload byte_size: data.size, checksum: Digest::MD5.base64digest(data) - token = encode_verified_token_for blob + data = "Something else entirely!" + blob = create_blob_before_direct_upload byte_size: data.size, checksum: Digest::MD5.base64digest(data) - put update_rails_disk_service_url(token), params: data, headers: { "Content-Type" => "application/octet-stream" } + put blob.service_url_for_direct_upload, params: data, headers: { "Content-Type" => "application/octet-stream" } assert_response :unprocessable_entity assert_not blob.service.exist?(blob.key) end test "directly uploading blob with mismatched content length" do - data = "Something else entirely!" - blob = create_blob_before_direct_upload byte_size: data.size - 1, checksum: Digest::MD5.base64digest(data) - token = encode_verified_token_for blob + data = "Something else entirely!" + blob = create_blob_before_direct_upload byte_size: data.size - 1, checksum: Digest::MD5.base64digest(data) - put update_rails_disk_service_url(token), params: data, headers: { "Content-Type" => "text/plain" } + put blob.service_url_for_direct_upload, params: data, headers: { "Content-Type" => "text/plain" } assert_response :unprocessable_entity assert_not blob.service.exist?(blob.key) end - - private - def encode_verified_token_for(blob) - ActiveStorage.verifier.generate( - { - key: blob.key, - content_length: blob.byte_size, - content_type: blob.content_type, - checksum: blob.checksum - }, - expires_in: 5.minutes, - purpose: :blob_token - ) - end end |