aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/test
diff options
context:
space:
mode:
authorChristian Bäuerlein <fabrik42@gmail.com>2011-10-14 16:28:02 +0200
committerChristian Bäuerlein <fabrik42@gmail.com>2011-10-14 16:28:02 +0200
commit410fa4cf7c710ff062c59c1c90357729c418be65 (patch)
treea7fa601845f6de15ae53f9e23049559959432ead /activerecord/test
parent401d00d296c0c4dafd0e1103051f6adf0ae56fc5 (diff)
downloadrails-410fa4cf7c710ff062c59c1c90357729c418be65.tar.gz
rails-410fa4cf7c710ff062c59c1c90357729c418be65.tar.bz2
rails-410fa4cf7c710ff062c59c1c90357729c418be65.zip
Includes stale record in StaleObjectError
Diffstat (limited to 'activerecord/test')
-rw-r--r--activerecord/test/cases/locking_test.rb19
1 files changed, 18 insertions, 1 deletions
diff --git a/activerecord/test/cases/locking_test.rb b/activerecord/test/cases/locking_test.rb
index 61baa55027..e9bd7f07b6 100644
--- a/activerecord/test/cases/locking_test.rb
+++ b/activerecord/test/cases/locking_test.rb
@@ -125,6 +125,24 @@ class OptimisticLockingTest < ActiveRecord::TestCase
assert_raise(ActiveRecord::StaleObjectError) { p2.save! }
end
+ def test_lock_exception_record
+ p1 = Person.new(:first_name => 'mira')
+ assert_equal 0, p1.lock_version
+
+ p1.first_name = 'mira2'
+ p1.save!
+ p2 = Person.find(p1.id)
+ assert_equal 0, p1.lock_version
+ assert_equal 0, p2.lock_version
+
+ p1.first_name = 'mira3'
+ p1.save!
+
+ p2.first_name = 'sue'
+ error = assert_raise(ActiveRecord::StaleObjectError) { p2.save! }
+ assert_equal(error.record.object_id, p2.object_id)
+ end
+
def test_lock_new_with_nil
p1 = Person.new(:first_name => 'anika')
p1.save!
@@ -141,7 +159,6 @@ class OptimisticLockingTest < ActiveRecord::TestCase
assert_equal 1, p1.lock_version
end
-
def test_lock_column_name_existing
t1 = LegacyThing.find(1)
t2 = LegacyThing.find(1)