diff options
author | Larry Reid <lcreid@jadesystems.ca> | 2018-07-16 10:44:55 -0700 |
---|---|---|
committer | Larry Reid <lcreid@jadesystems.ca> | 2018-07-23 14:53:27 -0700 |
commit | 332e7601a98ebff6a7494a556c7fe97c5691f085 (patch) | |
tree | dd60a40250979168ca972db33a189774dc5e75e5 /activerecord/test/models | |
parent | bd139a59405044c27bf367cde671e4bdbf7ccb57 (diff) | |
download | rails-332e7601a98ebff6a7494a556c7fe97c5691f085.tar.gz rails-332e7601a98ebff6a7494a556c7fe97c5691f085.tar.bz2 rails-332e7601a98ebff6a7494a556c7fe97c5691f085.zip |
Fix circular `autosave: true`
Use a variable local to the `save_collection_association` method in
`activerecord/lib/active_record/autosave_association.rb`, instead of an
instance variable.
Prior to this PR, when there was a circular series of `autosave: true`
associations, the callback for a `has_many` association was run while
another instance of the same callback on the same association hadn't
finished running. When control returned to the first instance of the
callback, the instance variable had changed, and subsequent associated
records weren't saved correctly. Specifically, the ID field for the
`belongs_to` corresponding to the `has_many` was `nil`.
Remove unnecessary test and comments.
Fixes #28080.
Diffstat (limited to 'activerecord/test/models')
-rw-r--r-- | activerecord/test/models/section.rb | 6 | ||||
-rw-r--r-- | activerecord/test/models/seminar.rb | 6 | ||||
-rw-r--r-- | activerecord/test/models/session.rb | 6 |
3 files changed, 18 insertions, 0 deletions
diff --git a/activerecord/test/models/section.rb b/activerecord/test/models/section.rb new file mode 100644 index 0000000000..f8b4cc7936 --- /dev/null +++ b/activerecord/test/models/section.rb @@ -0,0 +1,6 @@ +# frozen_string_literal: true + +class Section < ActiveRecord::Base + belongs_to :session, inverse_of: :sections, autosave: true + belongs_to :seminar, inverse_of: :sections, autosave: true +end diff --git a/activerecord/test/models/seminar.rb b/activerecord/test/models/seminar.rb new file mode 100644 index 0000000000..c18aa86433 --- /dev/null +++ b/activerecord/test/models/seminar.rb @@ -0,0 +1,6 @@ +# frozen_string_literal: true + +class Seminar < ActiveRecord::Base + has_many :sections, inverse_of: :seminar, autosave: true, dependent: :destroy + has_many :sessions, through: :sections +end diff --git a/activerecord/test/models/session.rb b/activerecord/test/models/session.rb new file mode 100644 index 0000000000..db66b5297e --- /dev/null +++ b/activerecord/test/models/session.rb @@ -0,0 +1,6 @@ +# frozen_string_literal: true + +class Session < ActiveRecord::Base + has_many :sections, inverse_of: :session, autosave: true, dependent: :destroy + has_many :seminars, through: :sections +end |