2018-07-07 23:25:33 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require "test_helper"
|
|
|
|
require "database/setup"
|
|
|
|
|
|
|
|
class ActiveStorage::ManyAttachedTest < ActiveSupport::TestCase
|
|
|
|
include ActiveJob::TestHelper
|
|
|
|
|
|
|
|
setup do
|
|
|
|
@user = User.create!(name: "Josh")
|
|
|
|
end
|
|
|
|
|
2019-10-11 17:47:42 -04:00
|
|
|
teardown do
|
|
|
|
ActiveStorage::Blob.all.each(&:delete)
|
|
|
|
end
|
2018-07-07 23:25:33 -04:00
|
|
|
|
|
|
|
test "attaching existing blobs to an existing record" do
|
|
|
|
@user.highlights.attach create_blob(filename: "funky.jpg"), create_blob(filename: "town.jpg")
|
|
|
|
assert_equal "funky.jpg", @user.highlights.first.filename.to_s
|
|
|
|
assert_equal "town.jpg", @user.highlights.second.filename.to_s
|
2019-02-20 23:37:10 -05:00
|
|
|
|
|
|
|
assert_not_empty @user.highlights_attachments
|
|
|
|
assert_equal @user.highlights_blobs.count, 2
|
2018-07-07 23:25:33 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
test "attaching existing blobs from signed IDs to an existing record" do
|
|
|
|
@user.highlights.attach create_blob(filename: "funky.jpg").signed_id, create_blob(filename: "town.jpg").signed_id
|
|
|
|
assert_equal "funky.jpg", @user.highlights.first.filename.to_s
|
|
|
|
assert_equal "town.jpg", @user.highlights.second.filename.to_s
|
|
|
|
end
|
|
|
|
|
|
|
|
test "attaching new blobs from Hashes to an existing record" do
|
|
|
|
@user.highlights.attach(
|
|
|
|
{ io: StringIO.new("STUFF"), filename: "funky.jpg", content_type: "image/jpg" },
|
|
|
|
{ io: StringIO.new("THINGS"), filename: "town.jpg", content_type: "image/jpeg" })
|
|
|
|
|
|
|
|
assert_equal "funky.jpg", @user.highlights.first.filename.to_s
|
|
|
|
assert_equal "town.jpg", @user.highlights.second.filename.to_s
|
|
|
|
end
|
|
|
|
|
|
|
|
test "attaching new blobs from uploaded files to an existing record" do
|
|
|
|
@user.highlights.attach fixture_file_upload("racecar.jpg"), fixture_file_upload("video.mp4")
|
|
|
|
assert_equal "racecar.jpg", @user.highlights.first.filename.to_s
|
|
|
|
assert_equal "video.mp4", @user.highlights.second.filename.to_s
|
|
|
|
end
|
|
|
|
|
2018-07-13 13:29:33 -04:00
|
|
|
test "attaching existing blobs to an existing, changed record" do
|
|
|
|
@user.name = "Tina"
|
|
|
|
assert @user.changed?
|
|
|
|
|
|
|
|
@user.highlights.attach create_blob(filename: "funky.jpg"), create_blob(filename: "town.jpg")
|
|
|
|
assert_equal "funky.jpg", @user.highlights.first.filename.to_s
|
|
|
|
assert_equal "town.jpg", @user.highlights.second.filename.to_s
|
|
|
|
assert_not @user.highlights.first.persisted?
|
|
|
|
assert_not @user.highlights.second.persisted?
|
|
|
|
assert @user.will_save_change_to_name?
|
|
|
|
|
|
|
|
@user.save!
|
|
|
|
assert_equal "funky.jpg", @user.highlights.reload.first.filename.to_s
|
|
|
|
assert_equal "town.jpg", @user.highlights.second.filename.to_s
|
|
|
|
end
|
|
|
|
|
|
|
|
test "attaching existing blobs from signed IDs to an existing, changed record" do
|
|
|
|
@user.name = "Tina"
|
|
|
|
assert @user.changed?
|
|
|
|
|
|
|
|
@user.highlights.attach create_blob(filename: "funky.jpg").signed_id, create_blob(filename: "town.jpg").signed_id
|
|
|
|
assert_equal "funky.jpg", @user.highlights.first.filename.to_s
|
|
|
|
assert_equal "town.jpg", @user.highlights.second.filename.to_s
|
|
|
|
assert_not @user.highlights.first.persisted?
|
|
|
|
assert_not @user.highlights.second.persisted?
|
|
|
|
assert @user.will_save_change_to_name?
|
|
|
|
|
|
|
|
@user.save!
|
|
|
|
assert_equal "funky.jpg", @user.highlights.reload.first.filename.to_s
|
|
|
|
assert_equal "town.jpg", @user.highlights.second.filename.to_s
|
|
|
|
end
|
|
|
|
|
|
|
|
test "attaching new blobs from Hashes to an existing, changed record" do
|
|
|
|
@user.name = "Tina"
|
|
|
|
assert @user.changed?
|
|
|
|
|
|
|
|
@user.highlights.attach(
|
|
|
|
{ io: StringIO.new("STUFF"), filename: "funky.jpg", content_type: "image/jpg" },
|
|
|
|
{ io: StringIO.new("THINGS"), filename: "town.jpg", content_type: "image/jpeg" })
|
|
|
|
|
|
|
|
assert_equal "funky.jpg", @user.highlights.first.filename.to_s
|
|
|
|
assert_equal "town.jpg", @user.highlights.second.filename.to_s
|
|
|
|
assert_not @user.highlights.first.persisted?
|
|
|
|
assert_not @user.highlights.second.persisted?
|
|
|
|
assert @user.will_save_change_to_name?
|
|
|
|
|
|
|
|
@user.save!
|
|
|
|
assert_equal "funky.jpg", @user.highlights.reload.first.filename.to_s
|
|
|
|
assert_equal "town.jpg", @user.highlights.second.filename.to_s
|
|
|
|
end
|
|
|
|
|
|
|
|
test "attaching new blobs from uploaded files to an existing, changed record" do
|
|
|
|
@user.name = "Tina"
|
|
|
|
assert @user.changed?
|
|
|
|
|
|
|
|
@user.highlights.attach fixture_file_upload("racecar.jpg"), fixture_file_upload("video.mp4")
|
|
|
|
assert_equal "racecar.jpg", @user.highlights.first.filename.to_s
|
|
|
|
assert_equal "video.mp4", @user.highlights.second.filename.to_s
|
|
|
|
assert_not @user.highlights.first.persisted?
|
|
|
|
assert_not @user.highlights.second.persisted?
|
|
|
|
assert @user.will_save_change_to_name?
|
|
|
|
|
|
|
|
@user.save!
|
|
|
|
assert_equal "racecar.jpg", @user.highlights.reload.first.filename.to_s
|
|
|
|
assert_equal "video.mp4", @user.highlights.second.filename.to_s
|
|
|
|
end
|
|
|
|
|
2019-08-15 16:36:34 -04:00
|
|
|
test "attaching new blobs from uploaded files to an existing, changed record one at a time" do
|
|
|
|
@user.name = "Tina"
|
|
|
|
assert @user.changed?
|
|
|
|
|
|
|
|
@user.highlights.attach fixture_file_upload("racecar.jpg")
|
|
|
|
@user.highlights.attach fixture_file_upload("video.mp4")
|
|
|
|
assert_equal "racecar.jpg", @user.highlights.first.filename.to_s
|
|
|
|
assert_equal "video.mp4", @user.highlights.second.filename.to_s
|
|
|
|
assert_not @user.highlights.first.persisted?
|
|
|
|
assert_not @user.highlights.second.persisted?
|
|
|
|
assert @user.will_save_change_to_name?
|
|
|
|
assert_not ActiveStorage::Blob.service.exist?(@user.highlights.first.key)
|
|
|
|
assert_not ActiveStorage::Blob.service.exist?(@user.highlights.second.key)
|
|
|
|
|
|
|
|
@user.save!
|
|
|
|
assert_equal "racecar.jpg", @user.highlights.reload.first.filename.to_s
|
|
|
|
assert_equal "video.mp4", @user.highlights.second.filename.to_s
|
|
|
|
assert ActiveStorage::Blob.service.exist?(@user.highlights.first.key)
|
|
|
|
assert ActiveStorage::Blob.service.exist?(@user.highlights.second.key)
|
|
|
|
end
|
|
|
|
|
2018-07-16 15:59:17 -04:00
|
|
|
test "attaching existing blobs to an existing record one at a time" do
|
2018-07-16 15:57:43 -04:00
|
|
|
@user.highlights.attach create_blob(filename: "funky.jpg")
|
|
|
|
@user.highlights.attach create_blob(filename: "town.jpg")
|
|
|
|
assert_equal "funky.jpg", @user.highlights.first.filename.to_s
|
|
|
|
assert_equal "town.jpg", @user.highlights.second.filename.to_s
|
|
|
|
|
|
|
|
@user.reload
|
|
|
|
assert_equal "funky.jpg", @user.highlights.first.filename.to_s
|
|
|
|
assert_equal "town.jpg", @user.highlights.second.filename.to_s
|
|
|
|
end
|
|
|
|
|
2018-07-07 23:25:33 -04:00
|
|
|
test "updating an existing record to attach existing blobs" do
|
|
|
|
@user.update! highlights: [ create_file_blob(filename: "racecar.jpg"), create_file_blob(filename: "video.mp4") ]
|
|
|
|
assert_equal "racecar.jpg", @user.highlights.first.filename.to_s
|
|
|
|
assert_equal "video.mp4", @user.highlights.second.filename.to_s
|
|
|
|
end
|
|
|
|
|
|
|
|
test "updating an existing record to attach existing blobs from signed IDs" do
|
|
|
|
@user.update! highlights: [ create_blob(filename: "funky.jpg").signed_id, create_blob(filename: "town.jpg").signed_id ]
|
|
|
|
assert_equal "funky.jpg", @user.highlights.first.filename.to_s
|
|
|
|
assert_equal "town.jpg", @user.highlights.second.filename.to_s
|
|
|
|
end
|
|
|
|
|
|
|
|
test "successfully updating an existing record to attach new blobs from uploaded files" do
|
|
|
|
@user.highlights = [ fixture_file_upload("racecar.jpg"), fixture_file_upload("video.mp4") ]
|
|
|
|
assert_equal "racecar.jpg", @user.highlights.first.filename.to_s
|
|
|
|
assert_equal "video.mp4", @user.highlights.second.filename.to_s
|
|
|
|
assert_not ActiveStorage::Blob.service.exist?(@user.highlights.first.key)
|
|
|
|
assert_not ActiveStorage::Blob.service.exist?(@user.highlights.second.key)
|
|
|
|
|
|
|
|
@user.save!
|
|
|
|
assert ActiveStorage::Blob.service.exist?(@user.highlights.first.key)
|
|
|
|
assert ActiveStorage::Blob.service.exist?(@user.highlights.second.key)
|
|
|
|
end
|
|
|
|
|
|
|
|
test "unsuccessfully updating an existing record to attach new blobs from uploaded files" do
|
|
|
|
assert_not @user.update(name: "", highlights: [ fixture_file_upload("racecar.jpg"), fixture_file_upload("video.mp4") ])
|
|
|
|
assert_equal "racecar.jpg", @user.highlights.first.filename.to_s
|
|
|
|
assert_equal "video.mp4", @user.highlights.second.filename.to_s
|
|
|
|
assert_not ActiveStorage::Blob.service.exist?(@user.highlights.first.key)
|
|
|
|
assert_not ActiveStorage::Blob.service.exist?(@user.highlights.second.key)
|
|
|
|
end
|
|
|
|
|
2018-07-17 09:33:28 -04:00
|
|
|
test "replacing existing, dependent attachments on an existing record via assign and attach" do
|
|
|
|
[ create_blob(filename: "funky.jpg"), create_blob(filename: "town.jpg") ].tap do |old_blobs|
|
|
|
|
@user.highlights.attach old_blobs
|
|
|
|
|
|
|
|
@user.highlights = []
|
|
|
|
assert_not @user.highlights.attached?
|
|
|
|
|
|
|
|
perform_enqueued_jobs do
|
|
|
|
@user.highlights.attach create_blob(filename: "whenever.jpg"), create_blob(filename: "wherever.jpg")
|
|
|
|
end
|
|
|
|
|
|
|
|
assert_equal "whenever.jpg", @user.highlights.first.filename.to_s
|
|
|
|
assert_equal "wherever.jpg", @user.highlights.second.filename.to_s
|
|
|
|
assert_not ActiveStorage::Blob.exists?(old_blobs.first.id)
|
|
|
|
assert_not ActiveStorage::Blob.exists?(old_blobs.second.id)
|
|
|
|
assert_not ActiveStorage::Blob.service.exist?(old_blobs.first.key)
|
|
|
|
assert_not ActiveStorage::Blob.service.exist?(old_blobs.second.key)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
test "replacing existing, independent attachments on an existing record via assign and attach" do
|
2018-07-17 16:23:53 -04:00
|
|
|
@user.vlogs.attach create_blob(filename: "funky.mp4"), create_blob(filename: "town.mp4")
|
2018-07-17 09:33:28 -04:00
|
|
|
|
2018-07-17 16:23:53 -04:00
|
|
|
@user.vlogs = []
|
|
|
|
assert_not @user.vlogs.attached?
|
2018-07-17 09:33:28 -04:00
|
|
|
|
2018-07-17 16:23:53 -04:00
|
|
|
assert_no_enqueued_jobs only: ActiveStorage::PurgeJob do
|
|
|
|
@user.vlogs.attach create_blob(filename: "whenever.mp4"), create_blob(filename: "wherever.mp4")
|
2018-07-17 09:33:28 -04:00
|
|
|
end
|
2018-07-17 16:23:53 -04:00
|
|
|
|
|
|
|
assert_equal "whenever.mp4", @user.vlogs.first.filename.to_s
|
|
|
|
assert_equal "wherever.mp4", @user.vlogs.second.filename.to_s
|
2018-07-17 09:33:28 -04:00
|
|
|
end
|
|
|
|
|
2018-07-07 23:25:33 -04:00
|
|
|
test "successfully updating an existing record to replace existing, dependent attachments" do
|
|
|
|
[ create_blob(filename: "funky.jpg"), create_blob(filename: "town.jpg") ].tap do |old_blobs|
|
|
|
|
@user.highlights.attach old_blobs
|
|
|
|
|
|
|
|
perform_enqueued_jobs do
|
|
|
|
@user.update! highlights: [ create_blob(filename: "whenever.jpg"), create_blob(filename: "wherever.jpg") ]
|
|
|
|
end
|
|
|
|
|
|
|
|
assert_equal "whenever.jpg", @user.highlights.first.filename.to_s
|
|
|
|
assert_equal "wherever.jpg", @user.highlights.second.filename.to_s
|
|
|
|
assert_not ActiveStorage::Blob.exists?(old_blobs.first.id)
|
|
|
|
assert_not ActiveStorage::Blob.exists?(old_blobs.second.id)
|
|
|
|
assert_not ActiveStorage::Blob.service.exist?(old_blobs.first.key)
|
|
|
|
assert_not ActiveStorage::Blob.service.exist?(old_blobs.second.key)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
test "successfully updating an existing record to replace existing, independent attachments" do
|
|
|
|
@user.vlogs.attach create_blob(filename: "funky.mp4"), create_blob(filename: "town.mp4")
|
|
|
|
|
|
|
|
assert_no_enqueued_jobs only: ActiveStorage::PurgeJob do
|
|
|
|
@user.update! vlogs: [ create_blob(filename: "whenever.mp4"), create_blob(filename: "wherever.mp4") ]
|
|
|
|
end
|
|
|
|
|
|
|
|
assert_equal "whenever.mp4", @user.vlogs.first.filename.to_s
|
|
|
|
assert_equal "wherever.mp4", @user.vlogs.second.filename.to_s
|
|
|
|
end
|
|
|
|
|
|
|
|
test "unsuccessfully updating an existing record to replace existing attachments" do
|
|
|
|
@user.highlights.attach create_blob(filename: "funky.jpg"), create_blob(filename: "town.jpg")
|
|
|
|
|
|
|
|
assert_no_enqueued_jobs do
|
|
|
|
assert_not @user.update(name: "", highlights: [ fixture_file_upload("racecar.jpg"), fixture_file_upload("video.mp4") ])
|
|
|
|
end
|
|
|
|
|
|
|
|
assert_equal "racecar.jpg", @user.highlights.first.filename.to_s
|
|
|
|
assert_equal "video.mp4", @user.highlights.second.filename.to_s
|
|
|
|
assert_not ActiveStorage::Blob.service.exist?(@user.highlights.first.key)
|
|
|
|
assert_not ActiveStorage::Blob.service.exist?(@user.highlights.second.key)
|
|
|
|
end
|
|
|
|
|
|
|
|
test "updating an existing record to attach one new blob and one previously-attached blob" do
|
|
|
|
[ create_blob(filename: "funky.jpg"), create_blob(filename: "town.jpg") ].tap do |blobs|
|
|
|
|
@user.highlights.attach blobs.first
|
|
|
|
|
|
|
|
perform_enqueued_jobs do
|
|
|
|
assert_no_changes -> { @user.highlights_attachments.first.id } do
|
|
|
|
@user.update! highlights: blobs
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
assert_equal "funky.jpg", @user.highlights.first.filename.to_s
|
|
|
|
assert_equal "town.jpg", @user.highlights.second.filename.to_s
|
|
|
|
assert ActiveStorage::Blob.service.exist?(@user.highlights.first.key)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-07-16 08:59:23 -04:00
|
|
|
test "updating an existing record to remove dependent attachments" do
|
|
|
|
[ create_blob(filename: "funky.jpg"), create_blob(filename: "town.jpg") ].tap do |blobs|
|
|
|
|
@user.highlights.attach blobs
|
|
|
|
|
|
|
|
assert_enqueued_with job: ActiveStorage::PurgeJob, args: [ blobs.first ] do
|
|
|
|
assert_enqueued_with job: ActiveStorage::PurgeJob, args: [ blobs.second ] do
|
|
|
|
@user.update! highlights: []
|
|
|
|
end
|
2018-07-07 23:25:33 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
assert_not @user.highlights.attached?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-07-16 08:59:23 -04:00
|
|
|
test "updating an existing record to remove independent attachments" do
|
2018-07-07 23:25:33 -04:00
|
|
|
[ create_blob(filename: "funky.mp4"), create_blob(filename: "town.mp4") ].tap do |blobs|
|
|
|
|
@user.vlogs.attach blobs
|
|
|
|
|
|
|
|
assert_no_enqueued_jobs only: ActiveStorage::PurgeJob do
|
|
|
|
@user.update! vlogs: []
|
|
|
|
end
|
|
|
|
|
|
|
|
assert_not @user.vlogs.attached?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-07-20 06:33:11 -04:00
|
|
|
test "updating an existing record with attachments when appending on assign" do
|
|
|
|
append_on_assign do
|
|
|
|
@user.highlights.attach create_blob(filename: "funky.jpg"), create_blob(filename: "town.jpg")
|
|
|
|
|
|
|
|
assert_difference -> { @user.reload.highlights.count }, +2 do
|
|
|
|
@user.update! highlights: [ create_blob(filename: "whenever.jpg"), create_blob(filename: "wherever.jpg") ]
|
|
|
|
end
|
|
|
|
|
|
|
|
assert_no_difference -> { @user.reload.highlights.count } do
|
|
|
|
@user.update! highlights: [ ]
|
|
|
|
end
|
|
|
|
|
|
|
|
assert_no_difference -> { @user.reload.highlights.count } do
|
|
|
|
@user.update! highlights: nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-07-07 23:25:33 -04:00
|
|
|
test "attaching existing blobs to a new record" do
|
|
|
|
User.new(name: "Jason").tap do |user|
|
|
|
|
user.highlights.attach create_blob(filename: "funky.jpg"), create_blob(filename: "town.jpg")
|
|
|
|
assert user.new_record?
|
|
|
|
assert_equal "funky.jpg", user.highlights.first.filename.to_s
|
|
|
|
assert_equal "town.jpg", user.highlights.second.filename.to_s
|
|
|
|
|
|
|
|
user.save!
|
|
|
|
assert_equal "funky.jpg", user.highlights.first.filename.to_s
|
|
|
|
assert_equal "town.jpg", user.highlights.second.filename.to_s
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
test "attaching an existing blob from a signed ID to a new record" do
|
|
|
|
User.new(name: "Jason").tap do |user|
|
2020-05-22 23:52:38 -04:00
|
|
|
user.highlights.attach create_blob(filename: "funky.jpg").signed_id
|
2018-07-07 23:25:33 -04:00
|
|
|
assert user.new_record?
|
2020-05-22 23:52:38 -04:00
|
|
|
assert_equal "funky.jpg", user.highlights.first.filename.to_s
|
2018-07-07 23:25:33 -04:00
|
|
|
|
|
|
|
user.save!
|
2020-05-22 23:52:38 -04:00
|
|
|
assert_equal "funky.jpg", user.reload.highlights.first.filename.to_s
|
2018-07-07 23:25:33 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-07-13 13:29:33 -04:00
|
|
|
test "attaching new blobs from Hashes to a new record" do
|
2018-07-07 23:25:33 -04:00
|
|
|
User.new(name: "Jason").tap do |user|
|
|
|
|
user.highlights.attach(
|
|
|
|
{ io: StringIO.new("STUFF"), filename: "funky.jpg", content_type: "image/jpg" },
|
|
|
|
{ io: StringIO.new("THINGS"), filename: "town.jpg", content_type: "image/jpg" })
|
|
|
|
|
|
|
|
assert user.new_record?
|
|
|
|
assert user.highlights.first.new_record?
|
|
|
|
assert user.highlights.second.new_record?
|
2018-07-13 13:29:33 -04:00
|
|
|
assert user.highlights.first.blob.new_record?
|
|
|
|
assert user.highlights.second.blob.new_record?
|
2018-07-07 23:25:33 -04:00
|
|
|
assert_equal "funky.jpg", user.highlights.first.filename.to_s
|
|
|
|
assert_equal "town.jpg", user.highlights.second.filename.to_s
|
2018-07-13 13:29:33 -04:00
|
|
|
assert_not ActiveStorage::Blob.service.exist?(user.highlights.first.key)
|
|
|
|
assert_not ActiveStorage::Blob.service.exist?(user.highlights.second.key)
|
2018-07-07 23:25:33 -04:00
|
|
|
|
|
|
|
user.save!
|
2018-07-13 13:29:33 -04:00
|
|
|
assert user.highlights.first.persisted?
|
|
|
|
assert user.highlights.second.persisted?
|
|
|
|
assert user.highlights.first.blob.persisted?
|
|
|
|
assert user.highlights.second.blob.persisted?
|
2018-07-07 23:25:33 -04:00
|
|
|
assert_equal "funky.jpg", user.reload.highlights.first.filename.to_s
|
|
|
|
assert_equal "town.jpg", user.highlights.second.filename.to_s
|
2018-07-13 13:29:33 -04:00
|
|
|
assert ActiveStorage::Blob.service.exist?(user.highlights.first.key)
|
|
|
|
assert ActiveStorage::Blob.service.exist?(user.highlights.second.key)
|
2018-07-07 23:25:33 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
test "attaching new blobs from uploaded files to a new record" do
|
|
|
|
User.new(name: "Jason").tap do |user|
|
|
|
|
user.highlights.attach fixture_file_upload("racecar.jpg"), fixture_file_upload("video.mp4")
|
|
|
|
assert user.new_record?
|
|
|
|
assert user.highlights.first.new_record?
|
|
|
|
assert user.highlights.second.new_record?
|
2018-07-13 13:29:33 -04:00
|
|
|
assert user.highlights.first.blob.new_record?
|
|
|
|
assert user.highlights.second.blob.new_record?
|
2018-07-07 23:25:33 -04:00
|
|
|
assert_equal "racecar.jpg", user.highlights.first.filename.to_s
|
|
|
|
assert_equal "video.mp4", user.highlights.second.filename.to_s
|
2018-07-13 13:29:33 -04:00
|
|
|
assert_not ActiveStorage::Blob.service.exist?(user.highlights.first.key)
|
|
|
|
assert_not ActiveStorage::Blob.service.exist?(user.highlights.second.key)
|
2018-07-07 23:25:33 -04:00
|
|
|
|
|
|
|
user.save!
|
2018-07-13 13:29:33 -04:00
|
|
|
assert user.highlights.first.persisted?
|
|
|
|
assert user.highlights.second.persisted?
|
|
|
|
assert user.highlights.first.blob.persisted?
|
|
|
|
assert user.highlights.second.blob.persisted?
|
2018-07-07 23:25:33 -04:00
|
|
|
assert_equal "racecar.jpg", user.reload.highlights.first.filename.to_s
|
|
|
|
assert_equal "video.mp4", user.highlights.second.filename.to_s
|
2018-07-13 13:29:33 -04:00
|
|
|
assert ActiveStorage::Blob.service.exist?(user.highlights.first.key)
|
|
|
|
assert ActiveStorage::Blob.service.exist?(user.highlights.second.key)
|
2018-07-07 23:25:33 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
test "creating a record with existing blobs attached" do
|
|
|
|
user = User.create!(name: "Jason", highlights: [ create_blob(filename: "funky.jpg"), create_blob(filename: "town.jpg") ])
|
|
|
|
assert_equal "funky.jpg", user.reload.highlights.first.filename.to_s
|
|
|
|
assert_equal "town.jpg", user.reload.highlights.second.filename.to_s
|
|
|
|
end
|
|
|
|
|
|
|
|
test "creating a record with an existing blob from signed IDs attached" do
|
|
|
|
user = User.create!(name: "Jason", highlights: [
|
|
|
|
create_blob(filename: "funky.jpg").signed_id, create_blob(filename: "town.jpg").signed_id ])
|
|
|
|
assert_equal "funky.jpg", user.reload.highlights.first.filename.to_s
|
|
|
|
assert_equal "town.jpg", user.reload.highlights.second.filename.to_s
|
|
|
|
end
|
|
|
|
|
|
|
|
test "creating a record with new blobs from uploaded files attached" do
|
|
|
|
User.new(name: "Jason", highlights: [ fixture_file_upload("racecar.jpg"), fixture_file_upload("video.mp4") ]).tap do |user|
|
|
|
|
assert user.new_record?
|
|
|
|
assert user.highlights.first.new_record?
|
|
|
|
assert user.highlights.second.new_record?
|
|
|
|
assert user.highlights.first.blob.new_record?
|
|
|
|
assert user.highlights.second.blob.new_record?
|
|
|
|
assert_equal "racecar.jpg", user.highlights.first.filename.to_s
|
|
|
|
assert_equal "video.mp4", user.highlights.second.filename.to_s
|
|
|
|
assert_not ActiveStorage::Blob.service.exist?(user.highlights.first.key)
|
|
|
|
assert_not ActiveStorage::Blob.service.exist?(user.highlights.second.key)
|
|
|
|
|
|
|
|
user.save!
|
|
|
|
assert_equal "racecar.jpg", user.highlights.first.filename.to_s
|
|
|
|
assert_equal "video.mp4", user.highlights.second.filename.to_s
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
test "creating a record with an unexpected object attached" do
|
2018-07-08 11:35:27 -04:00
|
|
|
error = assert_raises(ArgumentError) { User.create!(name: "Jason", highlights: :foo) }
|
2018-07-07 23:25:33 -04:00
|
|
|
assert_equal "Could not find or build blob: expected attachable, got :foo", error.message
|
|
|
|
end
|
|
|
|
|
2018-07-13 12:17:33 -04:00
|
|
|
test "detaching" do
|
|
|
|
[ create_blob(filename: "funky.jpg"), create_blob(filename: "town.jpg") ].tap do |blobs|
|
|
|
|
@user.highlights.attach blobs
|
|
|
|
assert @user.highlights.attached?
|
|
|
|
|
|
|
|
perform_enqueued_jobs do
|
|
|
|
@user.highlights.detach
|
|
|
|
end
|
|
|
|
|
|
|
|
assert_not @user.highlights.attached?
|
|
|
|
assert ActiveStorage::Blob.exists?(blobs.first.id)
|
|
|
|
assert ActiveStorage::Blob.exists?(blobs.second.id)
|
|
|
|
assert ActiveStorage::Blob.service.exist?(blobs.first.key)
|
|
|
|
assert ActiveStorage::Blob.service.exist?(blobs.second.key)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-07-07 23:25:33 -04:00
|
|
|
test "purging" do
|
|
|
|
[ create_blob(filename: "funky.jpg"), create_blob(filename: "town.jpg") ].tap do |blobs|
|
|
|
|
@user.highlights.attach blobs
|
|
|
|
assert @user.highlights.attached?
|
|
|
|
|
2020-07-20 20:44:32 -04:00
|
|
|
assert_changes -> { @user.updated_at } do
|
|
|
|
@user.highlights.purge
|
|
|
|
end
|
2018-07-07 23:25:33 -04:00
|
|
|
assert_not @user.highlights.attached?
|
|
|
|
assert_not ActiveStorage::Blob.exists?(blobs.first.id)
|
|
|
|
assert_not ActiveStorage::Blob.exists?(blobs.second.id)
|
|
|
|
assert_not ActiveStorage::Blob.service.exist?(blobs.first.key)
|
|
|
|
assert_not ActiveStorage::Blob.service.exist?(blobs.second.key)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-07-26 09:24:31 -04:00
|
|
|
test "purging attachment with shared blobs" do
|
|
|
|
[
|
|
|
|
create_blob(filename: "funky.jpg"),
|
|
|
|
create_blob(filename: "town.jpg"),
|
|
|
|
create_blob(filename: "worm.jpg")
|
|
|
|
].tap do |blobs|
|
|
|
|
@user.highlights.attach blobs
|
|
|
|
assert @user.highlights.attached?
|
|
|
|
|
|
|
|
another_user = User.create!(name: "John")
|
|
|
|
shared_blobs = [blobs.second, blobs.third]
|
|
|
|
another_user.highlights.attach shared_blobs
|
|
|
|
assert another_user.highlights.attached?
|
|
|
|
|
|
|
|
@user.highlights.purge
|
|
|
|
assert_not @user.highlights.attached?
|
|
|
|
|
|
|
|
assert_not ActiveStorage::Blob.exists?(blobs.first.id)
|
|
|
|
assert ActiveStorage::Blob.exists?(blobs.second.id)
|
|
|
|
assert ActiveStorage::Blob.exists?(blobs.third.id)
|
|
|
|
|
|
|
|
assert_not ActiveStorage::Blob.service.exist?(blobs.first.key)
|
|
|
|
assert ActiveStorage::Blob.service.exist?(blobs.second.key)
|
|
|
|
assert ActiveStorage::Blob.service.exist?(blobs.third.key)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-07-07 23:25:33 -04:00
|
|
|
test "purging later" do
|
|
|
|
[ create_blob(filename: "funky.jpg"), create_blob(filename: "town.jpg") ].tap do |blobs|
|
|
|
|
@user.highlights.attach blobs
|
|
|
|
assert @user.highlights.attached?
|
|
|
|
|
|
|
|
perform_enqueued_jobs do
|
2020-07-20 20:44:32 -04:00
|
|
|
assert_changes -> { @user.updated_at } do
|
|
|
|
@user.highlights.purge_later
|
|
|
|
end
|
2018-07-07 23:25:33 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
assert_not @user.highlights.attached?
|
|
|
|
assert_not ActiveStorage::Blob.exists?(blobs.first.id)
|
|
|
|
assert_not ActiveStorage::Blob.exists?(blobs.second.id)
|
|
|
|
assert_not ActiveStorage::Blob.service.exist?(blobs.first.key)
|
|
|
|
assert_not ActiveStorage::Blob.service.exist?(blobs.second.key)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-07-26 09:24:31 -04:00
|
|
|
test "purging attachment later with shared blobs" do
|
|
|
|
[
|
|
|
|
create_blob(filename: "funky.jpg"),
|
|
|
|
create_blob(filename: "town.jpg"),
|
|
|
|
create_blob(filename: "worm.jpg")
|
|
|
|
].tap do |blobs|
|
|
|
|
@user.highlights.attach blobs
|
|
|
|
assert @user.highlights.attached?
|
|
|
|
|
|
|
|
another_user = User.create!(name: "John")
|
|
|
|
shared_blobs = [blobs.second, blobs.third]
|
|
|
|
another_user.highlights.attach shared_blobs
|
|
|
|
assert another_user.highlights.attached?
|
|
|
|
|
|
|
|
perform_enqueued_jobs do
|
|
|
|
@user.highlights.purge_later
|
|
|
|
end
|
|
|
|
|
|
|
|
assert_not @user.highlights.attached?
|
|
|
|
assert_not ActiveStorage::Blob.exists?(blobs.first.id)
|
|
|
|
assert ActiveStorage::Blob.exists?(blobs.second.id)
|
|
|
|
assert ActiveStorage::Blob.exists?(blobs.third.id)
|
|
|
|
|
|
|
|
assert_not ActiveStorage::Blob.service.exist?(blobs.first.key)
|
|
|
|
assert ActiveStorage::Blob.service.exist?(blobs.second.key)
|
|
|
|
assert ActiveStorage::Blob.service.exist?(blobs.third.key)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-07-07 23:25:33 -04:00
|
|
|
test "purging dependent attachment later on destroy" do
|
|
|
|
[ create_blob(filename: "funky.jpg"), create_blob(filename: "town.jpg") ].tap do |blobs|
|
|
|
|
@user.highlights.attach blobs
|
|
|
|
|
|
|
|
perform_enqueued_jobs do
|
|
|
|
@user.destroy!
|
|
|
|
end
|
|
|
|
|
|
|
|
assert_not ActiveStorage::Blob.exists?(blobs.first.id)
|
|
|
|
assert_not ActiveStorage::Blob.exists?(blobs.second.id)
|
|
|
|
assert_not ActiveStorage::Blob.service.exist?(blobs.first.key)
|
|
|
|
assert_not ActiveStorage::Blob.service.exist?(blobs.second.key)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
test "not purging independent attachment on destroy" do
|
|
|
|
[ create_blob(filename: "funky.mp4"), create_blob(filename: "town.mp4") ].tap do |blobs|
|
|
|
|
@user.vlogs.attach blobs
|
|
|
|
|
|
|
|
assert_no_enqueued_jobs do
|
|
|
|
@user.destroy!
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-05-25 22:03:32 -04:00
|
|
|
test "duped record does not share attachments" do
|
|
|
|
@user.highlights.attach [ create_blob(filename: "funky.jpg") ]
|
|
|
|
|
|
|
|
assert_not_equal @user.highlights.first, @user.dup.highlights.first
|
|
|
|
end
|
|
|
|
|
|
|
|
test "duped record does not share attachment changes" do
|
|
|
|
@user.highlights.attach [ create_blob(filename: "funky.jpg") ]
|
|
|
|
assert_not_predicate @user, :changed_for_autosave?
|
|
|
|
|
|
|
|
@user.dup.highlights.attach [ create_blob(filename: "town.mp4") ]
|
|
|
|
assert_not_predicate @user, :changed_for_autosave?
|
|
|
|
end
|
|
|
|
|
2018-07-13 14:48:45 -04:00
|
|
|
test "clearing change on reload" do
|
|
|
|
@user.highlights = [ create_blob(filename: "funky.jpg"), create_blob(filename: "town.jpg") ]
|
|
|
|
assert @user.highlights.attached?
|
|
|
|
|
|
|
|
@user.reload
|
|
|
|
assert_not @user.highlights.attached?
|
|
|
|
end
|
|
|
|
|
2018-07-07 23:25:33 -04:00
|
|
|
test "overriding attached reader" do
|
|
|
|
@user.highlights.attach create_blob(filename: "funky.jpg"), create_blob(filename: "town.jpg")
|
|
|
|
|
|
|
|
assert_equal "funky.jpg", @user.highlights.first.filename.to_s
|
|
|
|
assert_equal "town.jpg", @user.highlights.second.filename.to_s
|
|
|
|
|
|
|
|
begin
|
|
|
|
User.class_eval do
|
|
|
|
def highlights
|
|
|
|
super.reverse
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
assert_equal "town.jpg", @user.highlights.first.filename.to_s
|
|
|
|
assert_equal "funky.jpg", @user.highlights.second.filename.to_s
|
|
|
|
ensure
|
2018-12-20 11:39:18 -05:00
|
|
|
User.remove_method :highlights
|
2018-07-07 23:25:33 -04:00
|
|
|
end
|
|
|
|
end
|
2019-07-20 06:33:11 -04:00
|
|
|
|
2019-01-14 14:56:35 -05:00
|
|
|
test "attaching a new blob from a Hash with a custom service" do
|
|
|
|
with_service("mirror") do
|
|
|
|
@user.highlights.attach io: StringIO.new("STUFF"), filename: "town.jpg", content_type: "image/jpg"
|
|
|
|
@user.vlogs.attach io: StringIO.new("STUFF"), filename: "town.jpg", content_type: "image/jpg"
|
|
|
|
|
|
|
|
assert_instance_of ActiveStorage::Service::MirrorService, @user.highlights.first.service
|
|
|
|
assert_instance_of ActiveStorage::Service::DiskService, @user.vlogs.first.service
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-10-02 02:49:23 -04:00
|
|
|
test "attaching a new blob from an uploaded file with a custom service" do
|
2019-01-14 14:56:35 -05:00
|
|
|
with_service("mirror") do
|
|
|
|
@user.highlights.attach fixture_file_upload("racecar.jpg")
|
|
|
|
@user.vlogs.attach fixture_file_upload("racecar.jpg")
|
|
|
|
|
|
|
|
assert_instance_of ActiveStorage::Service::MirrorService, @user.highlights.first.service
|
|
|
|
assert_instance_of ActiveStorage::Service::DiskService, @user.vlogs.first.service
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
test "raises error when misconfigured service is passed" do
|
|
|
|
error = assert_raises ArgumentError do
|
|
|
|
User.class_eval do
|
|
|
|
has_many_attached :featured_photos, service: :unknown
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
assert_match(/Cannot configure service :unknown for User#featured_photos/, error.message)
|
|
|
|
end
|
|
|
|
|
2019-07-20 06:33:11 -04:00
|
|
|
private
|
|
|
|
def append_on_assign
|
|
|
|
ActiveStorage.replace_on_assign_to_many, previous = false, ActiveStorage.replace_on_assign_to_many
|
|
|
|
yield
|
|
|
|
ensure
|
|
|
|
ActiveStorage.replace_on_assign_to_many = previous
|
|
|
|
end
|
2018-07-07 23:25:33 -04:00
|
|
|
end
|