aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/test/cases/adapters/mysql2/transaction_test.rb
diff options
context:
space:
mode:
authorErol Fornoles <erol.fornoles@gmail.com>2016-05-22 14:11:06 +0800
committerErol Fornoles <erol.fornoles@gmail.com>2016-05-24 19:04:38 +0800
commitf5c0c7ffa09c3e29a6ba361d927f6c45f49d6425 (patch)
tree268f424de894fb899ab4b428b9757c4fbc0c90d6 /activerecord/test/cases/adapters/mysql2/transaction_test.rb
parent61483b18bcbfaa054113a67f40515c7bf3e892b2 (diff)
downloadrails-f5c0c7ffa09c3e29a6ba361d927f6c45f49d6425.tar.gz
rails-f5c0c7ffa09c3e29a6ba361d927f6c45f49d6425.tar.bz2
rails-f5c0c7ffa09c3e29a6ba361d927f6c45f49d6425.zip
Introduce new ActiveRecord transaction error classes
Diffstat (limited to 'activerecord/test/cases/adapters/mysql2/transaction_test.rb')
-rw-r--r--activerecord/test/cases/adapters/mysql2/transaction_test.rb33
1 files changed, 13 insertions, 20 deletions
diff --git a/activerecord/test/cases/adapters/mysql2/transaction_test.rb b/activerecord/test/cases/adapters/mysql2/transaction_test.rb
index 0e37c70e5c..1a88b9cbca 100644
--- a/activerecord/test/cases/adapters/mysql2/transaction_test.rb
+++ b/activerecord/test/cases/adapters/mysql2/transaction_test.rb
@@ -27,32 +27,25 @@ module ActiveRecord
@connection.drop_table 'samples', if_exists: true
end
- test "raises error when a serialization failure occurs" do
- assert_raises(ActiveRecord::TransactionSerializationError) do
- thread = Thread.new do
- Sample.transaction isolation: :serializable do
- Sample.delete_all
-
- 10.times do |i|
- sleep 0.1
+ test "raises DeadlockDetected when a deadlock is encountered" do
+ assert_raises(ActiveRecord::DeadlockDetected) do
+ s1 = Sample.create value: 1
+ s2 = Sample.create value: 2
- Sample.create value: i
- end
+ thread = Thread.new do
+ Sample.transaction do
+ s1.lock!
+ sleep 1
+ s2.update_attributes value: 1
end
end
- sleep 0.1
-
- Sample.transaction isolation: :serializable do
- Sample.delete_all
-
- 10.times do |i|
- sleep 0.1
-
- Sample.create value: i
- end
+ sleep 0.5
+ Sample.transaction do
+ s2.lock!
sleep 1
+ s1.update_attributes value: 2
end
thread.join