aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/test/cases
diff options
context:
space:
mode:
authorRafael Mendonça França <rafaelmfranca@gmail.com>2014-05-07 17:33:48 -0300
committerRafael Mendonça França <rafaelmfranca@gmail.com>2014-05-07 17:33:48 -0300
commit8d8d4f1560264cd1c74364d67fa0501f6dd2c4fa (patch)
treeb135372a1b4094343476205c57a9b6b756c41ca3 /activerecord/test/cases
parent37c1e47da09fba4ee76143da05bbd4faabbaa53e (diff)
parent998ba0e7084345a045d49a64ee9cf9d2d2441780 (diff)
downloadrails-8d8d4f1560264cd1c74364d67fa0501f6dd2c4fa.tar.gz
rails-8d8d4f1560264cd1c74364d67fa0501f6dd2c4fa.tar.bz2
rails-8d8d4f1560264cd1c74364d67fa0501f6dd2c4fa.zip
Merge pull request #13166 from bogdan/transaction-magic
[Regression 3.2 -> 4.0] Fix bugs with changed attributes tracking when transaction gets rollback
Diffstat (limited to 'activerecord/test/cases')
-rw-r--r--activerecord/test/cases/transactions_test.rb56
1 files changed, 56 insertions, 0 deletions
diff --git a/activerecord/test/cases/transactions_test.rb b/activerecord/test/cases/transactions_test.rb
index e6ed85394b..bb5548a60f 100644
--- a/activerecord/test/cases/transactions_test.rb
+++ b/activerecord/test/cases/transactions_test.rb
@@ -274,6 +274,62 @@ class TransactionTest < ActiveRecord::TestCase
end
end
+ def test_dirty_state_rollback
+ assert !@first.approved?
+ Topic.transaction do
+ @first.approved = true
+ @first.save!
+ raise ActiveRecord::Rollback
+ end
+ assert @first.approved
+ assert @first.changes["approved"]
+ @first.save!
+ assert @first.reload.approved
+ end
+
+ def test_dirty_state_rollback2
+ assert !@first.approved?
+ @first.approved = true
+ Topic.transaction do
+ @first.save!
+ raise ActiveRecord::Rollback
+ end
+ assert @first.changes["approved"]
+ assert @first.approved
+ @first.save!
+ assert @first.reload.approved
+ end
+
+ def test_dirty_state_rollback3
+ assert !@first.approved?
+ @first.approved = true
+ @first.save!
+ Topic.transaction do
+ @first.approved = false
+ @first.save!
+ raise ActiveRecord::Rollback
+ end
+ assert !@first.approved
+ assert @first.changes["approved"]
+ @first.save!
+ assert !@first.reload.approved
+ end
+
+ def test_dirty_state_rollback4
+ assert !@first.approved?
+ Topic.transaction do
+ @first.approved = true
+ @first.save!
+ @first.approved = false
+ @first.save!
+ raise ActiveRecord::Rollback
+ end
+ assert !@first.approved
+ assert !@first.changes["approved"]
+ @first.save!
+ assert !@first.reload.approved
+ end
+
def test_force_savepoint_in_nested_transaction
Topic.transaction do
@first.approved = true