diff options
author | brainopia <brainopia@evilmartians.com> | 2015-03-04 15:24:03 +0300 |
---|---|---|
committer | brainopia <brainopia@evilmartians.com> | 2015-03-04 15:24:03 +0300 |
commit | caae79a385ce112245262a17414bcd96bea013c2 (patch) | |
tree | 3797e0efee56b7e360eca163effdd31183252b73 /activerecord | |
parent | 8313797810eefb7e00d0b5a8e91ac02907fa5e8f (diff) | |
download | rails-caae79a385ce112245262a17414bcd96bea013c2.tar.gz rails-caae79a385ce112245262a17414bcd96bea013c2.tar.bz2 rails-caae79a385ce112245262a17414bcd96bea013c2.zip |
Fix transaction state for unsynced records when entering transaction
Diffstat (limited to 'activerecord')
-rw-r--r-- | activerecord/lib/active_record/transactions.rb | 1 | ||||
-rw-r--r-- | activerecord/test/cases/transactions_test.rb | 9 |
2 files changed, 10 insertions, 0 deletions
diff --git a/activerecord/lib/active_record/transactions.rb b/activerecord/lib/active_record/transactions.rb index ce4b2dfa8e..514dd1f2f3 100644 --- a/activerecord/lib/active_record/transactions.rb +++ b/activerecord/lib/active_record/transactions.rb @@ -356,6 +356,7 @@ module ActiveRecord if has_transactional_callbacks? self.class.connection.add_transaction_record(self) else + sync_with_transaction_state set_transaction_state(self.class.connection.transaction_state) end remember_transaction_record_state diff --git a/activerecord/test/cases/transactions_test.rb b/activerecord/test/cases/transactions_test.rb index 922d01601e..4be3ea445c 100644 --- a/activerecord/test/cases/transactions_test.rb +++ b/activerecord/test/cases/transactions_test.rb @@ -593,6 +593,15 @@ class TransactionTest < ActiveRecord::TestCase assert topic.frozen?, 'frozen' end + def test_rollback_for_freshly_persisted_records + topic = Topic.create + Topic.transaction do + topic.destroy + raise ActiveRecord::Rollback + end + assert topic.persisted?, 'persisted' + end + def test_sqlite_add_column_in_transaction return true unless current_adapter?(:SQLite3Adapter) |