aboutsummaryrefslogtreecommitdiffstats
path: root/activemodel/test
diff options
context:
space:
mode:
authorRafael Mendonça França <rafaelmfranca@gmail.com>2014-07-15 16:00:50 -0300
committerRafael Mendonça França <rafaelmfranca@gmail.com>2014-07-15 16:04:31 -0300
commit66d0a0153578ce760d822580c5b8c0b726042ac2 (patch)
tree9307990257adef0f8908d8ef150677ef87bf2947 /activemodel/test
parent101cf688987ec39c05859061677f99b43facc2a2 (diff)
downloadrails-66d0a0153578ce760d822580c5b8c0b726042ac2.tar.gz
rails-66d0a0153578ce760d822580c5b8c0b726042ac2.tar.bz2
rails-66d0a0153578ce760d822580c5b8c0b726042ac2.zip
Deprecate ActiveModel::Dirty#reset_changes in favor of #clear_changes_information
This method name is causing confusion with the `reset_#{attribute}` methods. While `reset_name` set the value of the name attribute for the previous value the `reset_changes` only discard the changes and previous changes.
Diffstat (limited to 'activemodel/test')
-rw-r--r--activemodel/test/cases/dirty_test.rb21
1 files changed, 21 insertions, 0 deletions
diff --git a/activemodel/test/cases/dirty_test.rb b/activemodel/test/cases/dirty_test.rb
index 562fadbb85..09f26c319d 100644
--- a/activemodel/test/cases/dirty_test.rb
+++ b/activemodel/test/cases/dirty_test.rb
@@ -43,6 +43,10 @@ class DirtyTest < ActiveModel::TestCase
end
def reload
+ clear_changes_information
+ end
+
+ def deprecated_reload
reset_changes
end
@@ -181,6 +185,23 @@ class DirtyTest < ActiveModel::TestCase
assert_equal ActiveSupport::HashWithIndifferentAccess.new, @model.changed_attributes
end
+ test "reset_changes is deprecated" do
+ @model.name = 'Dmitry'
+ @model.name_changed?
+ @model.save
+ @model.name = 'Bob'
+
+ assert_equal [nil, 'Dmitry'], @model.previous_changes['name']
+ assert_equal 'Dmitry', @model.changed_attributes['name']
+
+ assert_deprecated do
+ @model.deprecated_reload
+ end
+
+ assert_equal ActiveSupport::HashWithIndifferentAccess.new, @model.previous_changes
+ assert_equal ActiveSupport::HashWithIndifferentAccess.new, @model.changed_attributes
+ end
+
test "undo_changes should restore all previous data" do
@model.name = 'Dmitry'
@model.color = 'Red'