aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/test/cases
diff options
context:
space:
mode:
authorCurtis Hawthorne <curtis@curtis.hawthorne.name>2009-03-09 14:56:09 +0000
committerPratik Naik <pratiknaik@gmail.com>2009-03-09 14:56:09 +0000
commit0d922885fb54c19f04680482f024452859218910 (patch)
treee8ec3cbf4434c9f6a8b26ff27e890a5c1cb7097a /activerecord/test/cases
parent1e6c50e21bdb8c99116a7dc6921ef3eb4ed9531a (diff)
downloadrails-0d922885fb54c19f04680482f024452859218910.tar.gz
rails-0d922885fb54c19f04680482f024452859218910.tar.bz2
rails-0d922885fb54c19f04680482f024452859218910.zip
Ensure Model#destroy respects optimistic locking [#1966 state:resolved]
Signed-off-by: Pratik Naik <pratiknaik@gmail.com>
Diffstat (limited to 'activerecord/test/cases')
-rw-r--r--activerecord/test/cases/locking_test.rb18
1 files changed, 18 insertions, 0 deletions
diff --git a/activerecord/test/cases/locking_test.rb b/activerecord/test/cases/locking_test.rb
index 8d2059d63f..e177235591 100644
--- a/activerecord/test/cases/locking_test.rb
+++ b/activerecord/test/cases/locking_test.rb
@@ -38,6 +38,24 @@ class OptimisticLockingTest < ActiveRecord::TestCase
assert_raise(ActiveRecord::StaleObjectError) { p2.save! }
end
+ def test_lock_destroy
+ p1 = Person.find(1)
+ p2 = Person.find(1)
+ assert_equal 0, p1.lock_version
+ assert_equal 0, p2.lock_version
+
+ p1.first_name = 'stu'
+ p1.save!
+ assert_equal 1, p1.lock_version
+ assert_equal 0, p2.lock_version
+
+ assert_raises(ActiveRecord::StaleObjectError) { p2.destroy }
+
+ assert p1.destroy
+ assert_equal true, p1.frozen?
+ assert_raises(ActiveRecord::RecordNotFound) { Person.find(1) }
+ end
+
def test_lock_repeating
p1 = Person.find(1)
p2 = Person.find(1)