diff options
author | Bogdan Gusiev <agresso@gmail.com> | 2013-12-04 16:16:11 +0200 |
---|---|---|
committer | Bogdan Gusiev <agresso@gmail.com> | 2013-12-04 16:16:11 +0200 |
commit | 998ba0e7084345a045d49a64ee9cf9d2d2441780 (patch) | |
tree | da21b1253cccc132c2cd45cb9657fff3c24c21ee /activerecord/test/cases | |
parent | b6f189e2f0bcc8f36f52c83e8ac2255d5e578a42 (diff) | |
download | rails-998ba0e7084345a045d49a64ee9cf9d2d2441780.tar.gz rails-998ba0e7084345a045d49a64ee9cf9d2d2441780.tar.bz2 rails-998ba0e7084345a045d49a64ee9cf9d2d2441780.zip |
Fix bugs with changed attributes tracking when transaction gets rollback
Diffstat (limited to 'activerecord/test/cases')
-rw-r--r-- | activerecord/test/cases/transactions_test.rb | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/activerecord/test/cases/transactions_test.rb b/activerecord/test/cases/transactions_test.rb index 89dab16975..4edb200b1d 100644 --- a/activerecord/test/cases/transactions_test.rb +++ b/activerecord/test/cases/transactions_test.rb @@ -268,6 +268,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 |