aboutsummaryrefslogtreecommitdiffstats
path: root/activestorage/test/models/attachments_test.rb
diff options
context:
space:
mode:
authorGeorge Claghorn <george@basecamp.com>2018-03-04 18:54:12 -0500
committerGeorge Claghorn <george@basecamp.com>2018-03-04 18:54:31 -0500
commit7e658588fa15e799614268f1f733946bf2ef26cd (patch)
tree9e49401430d6392b0fbba99d77c20cb867b4983b /activestorage/test/models/attachments_test.rb
parent968c499aca5ca71dc909ba7a632c5dbc4f58b101 (diff)
downloadrails-7e658588fa15e799614268f1f733946bf2ef26cd.tar.gz
rails-7e658588fa15e799614268f1f733946bf2ef26cd.tar.bz2
rails-7e658588fa15e799614268f1f733946bf2ef26cd.zip
Handle another case where a blob might be erroneously purged
Diffstat (limited to 'activestorage/test/models/attachments_test.rb')
-rw-r--r--activestorage/test/models/attachments_test.rb12
1 files changed, 12 insertions, 0 deletions
diff --git a/activestorage/test/models/attachments_test.rb b/activestorage/test/models/attachments_test.rb
index 4c6b3e6000..25e0352eca 100644
--- a/activestorage/test/models/attachments_test.rb
+++ b/activestorage/test/models/attachments_test.rb
@@ -68,6 +68,18 @@ class ActiveStorage::AttachmentsTest < ActiveSupport::TestCase
end
end
+ test "replaced attached blob with itself by signed ID" do
+ @user.avatar.attach create_blob(filename: "funky.jpg")
+
+ assert_no_changes -> { @user.reload.avatar.blob } do
+ assert_no_changes -> { @user.reload.avatar.attachment } do
+ assert_no_enqueued_jobs do
+ @user.avatar.attach @user.avatar.blob.signed_id
+ end
+ end
+ end
+ end
+
test "attach blob to new record" do
user = User.new(name: "Jason")