aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRafael Mendonça França <rafaelmfranca@gmail.com>2018-06-11 14:41:33 -0400
committerRafael Mendonça França <rafaelmfranca@gmail.com>2018-06-11 15:03:32 -0400
commit832b7a7ca330a38235d9bdecb18fa9dbf4ed156f (patch)
tree40db7275a422c942317c30ddffdd58a31bda84ce
parentb05bcb8fef706ef45e2f273040083b1bbd180c6e (diff)
downloadrails-832b7a7ca330a38235d9bdecb18fa9dbf4ed156f.tar.gz
rails-832b7a7ca330a38235d9bdecb18fa9dbf4ed156f.tar.bz2
rails-832b7a7ca330a38235d9bdecb18fa9dbf4ed156f.zip
Don't use `target=`
It mark the association as loaded and this can cause the object to be in an stale state.
-rw-r--r--activerecord/lib/active_record/associations/collection_association.rb2
-rw-r--r--activerecord/test/cases/associations/has_many_through_associations_test.rb2
2 files changed, 2 insertions, 2 deletions
diff --git a/activerecord/lib/active_record/associations/collection_association.rb b/activerecord/lib/active_record/associations/collection_association.rb
index 9a90cd2cc7..840d900bbc 100644
--- a/activerecord/lib/active_record/associations/collection_association.rb
+++ b/activerecord/lib/active_record/associations/collection_association.rb
@@ -400,7 +400,7 @@ module ActiveRecord
records.each { |record| callback(:before_remove, record) }
delete_records(existing_records, method) if existing_records.any?
- self.target -= records
+ @target -= records
records.each { |record| callback(:after_remove, record) }
end
diff --git a/activerecord/test/cases/associations/has_many_through_associations_test.rb b/activerecord/test/cases/associations/has_many_through_associations_test.rb
index 259e4eb4b7..d5573b6d02 100644
--- a/activerecord/test/cases/associations/has_many_through_associations_test.rb
+++ b/activerecord/test/cases/associations/has_many_through_associations_test.rb
@@ -357,7 +357,7 @@ class HasManyThroughAssociationsTest < ActiveRecord::TestCase
posts(:welcome).people.delete(people(:michael))
end
- assert_queries(0) do
+ assert_queries(1) do
assert_empty posts(:welcome).people
end