aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib/active_record/errors.rb
diff options
context:
space:
mode:
authorRafael Mendonça França <rafaelmfranca@gmail.com>2016-08-03 07:05:22 -0300
committerRafael Mendonça França <rafaelmfranca@gmail.com>2016-08-03 07:05:22 -0300
commitfac9938b917f3417a19775d1c6905123fc402256 (patch)
treed8efc9958372769cde477dc70f613c044cdb11fc /activerecord/lib/active_record/errors.rb
parent8ada07b2b8d63c3379facb5d81485b5fdeafaceb (diff)
parentf5c0c7ffa09c3e29a6ba361d927f6c45f49d6425 (diff)
downloadrails-fac9938b917f3417a19775d1c6905123fc402256.tar.gz
rails-fac9938b917f3417a19775d1c6905123fc402256.tar.bz2
rails-fac9938b917f3417a19775d1c6905123fc402256.zip
Merge pull request #25107 from Erol/introduce-new-ar-transaction-error-classes
Introduce new ActiveRecord transaction error classes Closes #26018
Diffstat (limited to 'activerecord/lib/active_record/errors.rb')
-rw-r--r--activerecord/lib/active_record/errors.rb14
1 files changed, 12 insertions, 2 deletions
diff --git a/activerecord/lib/active_record/errors.rb b/activerecord/lib/active_record/errors.rb
index 26146dbce7..3f75ce4099 100644
--- a/activerecord/lib/active_record/errors.rb
+++ b/activerecord/lib/active_record/errors.rb
@@ -285,14 +285,24 @@ module ActiveRecord
class TransactionIsolationError < ActiveRecordError
end
- # TransactionSerializationError will be raised when a transaction is rolled
+ # TransactionRollbackError will be raised when a transaction is rolled
# back by the database due to a serialization failure or a deadlock.
#
# See the following:
#
# * http://www.postgresql.org/docs/current/static/transaction-iso.html
# * https://dev.mysql.com/doc/refman/5.7/en/error-messages-server.html#error_er_lock_deadlock
- class TransactionSerializationError < StatementInvalid
+ class TransactionRollbackError < StatementInvalid
+ end
+
+ # SerializationFailure will be raised when a transaction is rolled
+ # back by the database due to a serialization failure.
+ class SerializationFailure < TransactionRollbackError
+ end
+
+ # DeadlockDetected will be raised when a transaction is rolled
+ # back by the database when a deadlock is encountered.
+ class DeadlockDetected < TransactionRollbackError
end
# IrreversibleOrderError is raised when a relation's order is too complex for