aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord
diff options
context:
space:
mode:
authorEmilio Tagua <miloops@gmail.com>2010-09-15 11:22:24 -0300
committerEmilio Tagua <miloops@gmail.com>2010-11-19 19:07:43 -0300
commitf3adddb966f3c93de4992b42cf554e3ef2a3acf1 (patch)
tree83d31288faa055e1dfc9a7474a9c7d52c9374e66 /activerecord
parente83f5a0ae97889dddfd0956081b0f4582594cda9 (diff)
downloadrails-f3adddb966f3c93de4992b42cf554e3ef2a3acf1.tar.gz
rails-f3adddb966f3c93de4992b42cf554e3ef2a3acf1.tar.bz2
rails-f3adddb966f3c93de4992b42cf554e3ef2a3acf1.zip
Remove objects from identity map if save! failed, otherwise finding again the same record will have invalid attributes.
Diffstat (limited to 'activerecord')
-rw-r--r--activerecord/lib/active_record/attribute_methods/dirty.rb3
-rw-r--r--activerecord/test/cases/identity_map_test.rb13
2 files changed, 16 insertions, 0 deletions
diff --git a/activerecord/lib/active_record/attribute_methods/dirty.rb b/activerecord/lib/active_record/attribute_methods/dirty.rb
index 91d16ca97a..40ab37b5d2 100644
--- a/activerecord/lib/active_record/attribute_methods/dirty.rb
+++ b/activerecord/lib/active_record/attribute_methods/dirty.rb
@@ -33,6 +33,9 @@ module ActiveRecord
@previously_changed = changes
@changed_attributes.clear
end
+ rescue
+ IdentityMap.remove(self) if IdentityMap.enabled?
+ raise
end
# <tt>reload</tt> the record and clears changed attributes.
diff --git a/activerecord/test/cases/identity_map_test.rb b/activerecord/test/cases/identity_map_test.rb
index d4be698082..1683bd28c3 100644
--- a/activerecord/test/cases/identity_map_test.rb
+++ b/activerecord/test/cases/identity_map_test.rb
@@ -261,4 +261,17 @@ class IdentityMapTest < ActiveRecord::TestCase
assert_not_equal developer.salary, same_developer.salary
end
+ def test_reload_object_if_forced_save_failed
+ developer = Developer.first
+ developer.salary = 0
+
+ assert_raise(ActiveRecord::RecordInvalid) { developer.save! }
+
+ same_developer = Developer.first
+
+ assert_not_same developer, same_developer
+ assert_not_equal 0, same_developer.salary
+ assert_not_equal developer.salary, same_developer.salary
+ end
+
end