aboutsummaryrefslogtreecommitdiffstats
path: root/activemodel/test
diff options
context:
space:
mode:
authorAttila Domokos <adomokos@gmail.com>2013-01-14 15:03:42 -0500
committerAttila Domokos <adomokos@gmail.com>2013-01-15 10:24:57 -0500
commit63333e600fd8cc22002547d08e6de6f577fd40d2 (patch)
tree39a9fb7ca9b42fca28ca4099056be45c11374835 /activemodel/test
parentbf095770e561c51cebeb5a556afc03a21d9e603c (diff)
downloadrails-63333e600fd8cc22002547d08e6de6f577fd40d2.tar.gz
rails-63333e600fd8cc22002547d08e6de6f577fd40d2.tar.bz2
rails-63333e600fd8cc22002547d08e6de6f577fd40d2.zip
Cleaning up ActiveModel::Dirty tests
* Clarifying what the #changed method returns * Adding tests to describe what the #changed_attributes returns * Updating test name based on pull request comment * Moving the test lower in the file per pull request comment
Diffstat (limited to 'activemodel/test')
-rw-r--r--activemodel/test/cases/dirty_test.rb13
1 files changed, 12 insertions, 1 deletions
diff --git a/activemodel/test/cases/dirty_test.rb b/activemodel/test/cases/dirty_test.rb
index 0b9f9537e2..ba45089cca 100644
--- a/activemodel/test/cases/dirty_test.rb
+++ b/activemodel/test/cases/dirty_test.rb
@@ -46,7 +46,7 @@ class DirtyTest < ActiveModel::TestCase
assert @model.name_changed?
end
- test "list of changed attributes" do
+ test "list of changed attribute keys" do
assert_equal [], @model.changed
@model.name = "Paul"
assert_equal ['name'], @model.changed
@@ -106,6 +106,17 @@ class DirtyTest < ActiveModel::TestCase
assert_equal [nil, "Jericho Cane"], @model.previous_changes['name']
end
+ test "previous value is preserved when changed after save" do
+ assert_equal({}, @model.changed_attributes)
+ @model.name = "Paul"
+ assert_equal({ "name" => nil }, @model.changed_attributes)
+
+ @model.save
+
+ @model.name = "John"
+ assert_equal({ "name" => "Paul" }, @model.changed_attributes)
+ end
+
test "changing the same attribute multiple times retains the correct original value" do
@model.name = "Otto"
@model.save