aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib/active_record/attribute_methods
diff options
context:
space:
mode:
authorRyuta Kamizono <kamipo@gmail.com>2019-05-13 22:42:24 +0900
committerRyuta Kamizono <kamipo@gmail.com>2019-05-13 23:30:05 +0900
commitdcb825902d79d0f6baba956f7c6ec5767611353e (patch)
treeed378d749fa4a075f5e380b1b05a82ffe4697fb8 /activerecord/lib/active_record/attribute_methods
parent9854efd5ac6a05555cc73b21c98c37252eaef0a6 (diff)
downloadrails-dcb825902d79d0f6baba956f7c6ec5767611353e.tar.gz
rails-dcb825902d79d0f6baba956f7c6ec5767611353e.tar.bz2
rails-dcb825902d79d0f6baba956f7c6ec5767611353e.zip
Don't track implicit `touch` mutation
This partly reverts the effect of d1107f4d. d1107f4d makes `touch` tracks the mutation whether the `touch` is occurred by explicit or not. Existing apps expects that the previous changes tracks only the changes which is explicit action by users. I'd revert the implicit `touch` mutation tracking since I'd not like to break existing apps. Fixes #36219.
Diffstat (limited to 'activerecord/lib/active_record/attribute_methods')
-rw-r--r--activerecord/lib/active_record/attribute_methods/dirty.rb7
1 files changed, 6 insertions, 1 deletions
diff --git a/activerecord/lib/active_record/attribute_methods/dirty.rb b/activerecord/lib/active_record/attribute_methods/dirty.rb
index a43ebdf60d..45341765c1 100644
--- a/activerecord/lib/active_record/attribute_methods/dirty.rb
+++ b/activerecord/lib/active_record/attribute_methods/dirty.rb
@@ -177,6 +177,11 @@ module ActiveRecord
affected_rows = super
+ if @_skip_dirty_tracking ||= false
+ clear_attribute_changes(@_touch_attr_names)
+ return affected_rows
+ end
+
changes = {}
@attributes.keys.each do |attr_name|
next if @_touch_attr_names.include?(attr_name)
@@ -193,7 +198,7 @@ module ActiveRecord
affected_rows
ensure
- @_touch_attr_names = nil
+ @_touch_attr_names, @_skip_dirty_tracking = nil, nil
end
def _update_record(attribute_names = attribute_names_for_partial_writes)