diff options
author | Brian Thomas Storti <btstorti@gmail.com> | 2013-11-23 09:24:52 -0200 |
---|---|---|
committer | Brian Thomas Storti <btstorti@gmail.com> | 2013-11-25 19:30:07 -0200 |
commit | 5aab0c053832ded70a3a4b58cb97f8f8bba796ba (patch) | |
tree | 6f10893ea925ca124b7c57c6fb0cdb0073759f03 /activerecord/test/models | |
parent | 19dd2166103cc1d39d7346714c46f32191958981 (diff) | |
download | rails-5aab0c053832ded70a3a4b58cb97f8f8bba796ba.tar.gz rails-5aab0c053832ded70a3a4b58cb97f8f8bba796ba.tar.bz2 rails-5aab0c053832ded70a3a4b58cb97f8f8bba796ba.zip |
Raise `RecordNotDestroyed` when children can't be replaced
Fixes #12812
Raise `ActiveRecord::RecordNotDestroyed` when a child marked with
`dependent: destroy` can't be destroyed.
The following code:
```ruby
class Post < ActiveRecord::Base
has_many :comments, dependent: :destroy
end
class Comment < ActiveRecord::Base
before_destroy do
return false
end
end
post = Post.create!(comments: [Comment.create!])
post.comments = [Comment.create!]
````
would result in a `post` with two `comments`.
With this commit, the same code would raise a `RecordNotDestroyed`
exception, keeping the `post` with the same `comment`.
Diffstat (limited to 'activerecord/test/models')
-rw-r--r-- | activerecord/test/models/bulb.rb | 6 | ||||
-rw-r--r-- | activerecord/test/models/car.rb | 1 |
2 files changed, 7 insertions, 0 deletions
diff --git a/activerecord/test/models/bulb.rb b/activerecord/test/models/bulb.rb index 4361188e21..831a0d5387 100644 --- a/activerecord/test/models/bulb.rb +++ b/activerecord/test/models/bulb.rb @@ -43,3 +43,9 @@ class FunkyBulb < Bulb raise "before_destroy was called" end end + +class FailedBulb < Bulb + before_destroy do + false + end +end diff --git a/activerecord/test/models/car.rb b/activerecord/test/models/car.rb index 8f3b70a7c6..c4a15a79e2 100644 --- a/activerecord/test/models/car.rb +++ b/activerecord/test/models/car.rb @@ -2,6 +2,7 @@ class Car < ActiveRecord::Base has_many :bulbs has_many :all_bulbs, -> { unscope where: :name }, class_name: "Bulb" has_many :funky_bulbs, class_name: 'FunkyBulb', dependent: :destroy + has_many :failed_bulbs, class_name: 'FailedBulb', dependent: :destroy has_many :foo_bulbs, -> { where(:name => 'foo') }, :class_name => "Bulb" has_one :bulb |