diff options
author | Sean Griffin <sean@seantheprogrammer.com> | 2016-12-06 15:30:52 -0500 |
---|---|---|
committer | GitHub <noreply@github.com> | 2016-12-06 15:30:52 -0500 |
commit | 09b2e29fc602cedce6dc856ffeb5f8521c089aa5 (patch) | |
tree | cccf2d4f5586d94bec3d9bf70483b72661ae7be8 | |
parent | 91ae6e86da8174f5c4073bfce7fa6239464a4f02 (diff) | |
parent | e7f4c45bdc178c41face92e4be9ec027a07daeda (diff) | |
download | rails-09b2e29fc602cedce6dc856ffeb5f8521c089aa5.tar.gz rails-09b2e29fc602cedce6dc856ffeb5f8521c089aa5.tar.bz2 rails-09b2e29fc602cedce6dc856ffeb5f8521c089aa5.zip |
Merge pull request #27251 from ebeigarts/fix-autosave
Fix association scope inside autosaved association callbacks
-rw-r--r-- | activerecord/lib/active_record/autosave_association.rb | 6 | ||||
-rw-r--r-- | activerecord/test/cases/autosave_association_test.rb | 24 |
2 files changed, 27 insertions, 3 deletions
diff --git a/activerecord/lib/active_record/autosave_association.rb b/activerecord/lib/active_record/autosave_association.rb index b343332bae..9d0b501862 100644 --- a/activerecord/lib/active_record/autosave_association.rb +++ b/activerecord/lib/active_record/autosave_association.rb @@ -383,6 +383,9 @@ module ActiveRecord if association = association_instance_get(reflection.name) autosave = reflection.options[:autosave] + # reconstruct the scope now that we know the owner's id + association.reset_scope if association.respond_to?(:reset_scope) + if records = associated_records_to_validate_or_save(association, @new_record_before_save, autosave) if autosave records_to_destroy = records.select(&:marked_for_destruction?) @@ -408,9 +411,6 @@ module ActiveRecord raise ActiveRecord::Rollback unless saved end end - - # reconstruct the scope now that we know the owner's id - association.reset_scope if association.respond_to?(:reset_scope) end end diff --git a/activerecord/test/cases/autosave_association_test.rb b/activerecord/test/cases/autosave_association_test.rb index a3f82ed49d..77ee3ca2d7 100644 --- a/activerecord/test/cases/autosave_association_test.rb +++ b/activerecord/test/cases/autosave_association_test.rb @@ -1699,3 +1699,27 @@ class TestAutosaveAssociationWithTouch < ActiveRecord::TestCase assert_nothing_raised { invoice.line_items.create(amount: 10) } end end + +class TestAutosaveAssociationOnAHasManyAssociationWithInverse < ActiveRecord::TestCase + class Post < ActiveRecord::Base + has_many :comments, inverse_of: :post + end + + class Comment < ActiveRecord::Base + belongs_to :post, inverse_of: :comments + + attr_accessor :post_comments_count + after_save do + self.post_comments_count = post.comments.count + end + end + + def test_after_save_callback_with_autosave + post = Post.new(title: "Test", body: "...") + comment = post.comments.build(body: "...") + post.save! + + assert_equal 1, post.comments.count + assert_equal 1, comment.post_comments_count + end +end |