diff options
author | Dave Yeu <daveyeu@gmail.com> | 2012-04-29 22:38:32 -0400 |
---|---|---|
committer | Dave Yeu <daveyeu@gmail.com> | 2012-08-11 21:54:00 -0400 |
commit | a4801a792a1e47d7f156c6646f662232c46eefa2 (patch) | |
tree | 2b8a504e0c4ce822a3432f56b318113a1e7599aa /activerecord/lib | |
parent | a513cc1862cc61fd9605352a58c5e36cc40cb574 (diff) | |
download | rails-a4801a792a1e47d7f156c6646f662232c46eefa2.tar.gz rails-a4801a792a1e47d7f156c6646f662232c46eefa2.tar.bz2 rails-a4801a792a1e47d7f156c6646f662232c46eefa2.zip |
Restore state on create when ActiveRecord::RecordInvalid is raised
This fixes issue #3217.
Diffstat (limited to 'activerecord/lib')
-rw-r--r-- | activerecord/lib/active_record/transactions.rb | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/activerecord/lib/active_record/transactions.rb b/activerecord/lib/active_record/transactions.rb index 9cb9b4627b..5c3399e2aa 100644 --- a/activerecord/lib/active_record/transactions.rb +++ b/activerecord/lib/active_record/transactions.rb @@ -327,7 +327,7 @@ module ActiveRecord def restore_transaction_record_state(force = false) #:nodoc: if defined?(@_start_transaction_state) @_start_transaction_state[:level] = (@_start_transaction_state[:level] || 0) - 1 - if @_start_transaction_state[:level] < 1 + if @_start_transaction_state[:level] < 1 || force restore_state = remove_instance_variable(:@_start_transaction_state) was_frozen = @attributes.frozen? @attributes = @attributes.dup if was_frozen |