diff options
author | Arthur Neves <arthurnn@gmail.com> | 2015-03-13 15:28:56 -0400 |
---|---|---|
committer | Arthur Neves <arthurnn@gmail.com> | 2015-03-14 12:20:36 -0400 |
commit | 0d76ab9c6f01e6390ba8878a296ff9d3ac6b9aa8 (patch) | |
tree | 642b1be901bc5fa66c1034532b526e08ce26d2bf /activerecord/test/cases | |
parent | 675f299c8eec586ccc5d8faa6a66e22b387acee2 (diff) | |
download | rails-0d76ab9c6f01e6390ba8878a296ff9d3ac6b9aa8.tar.gz rails-0d76ab9c6f01e6390ba8878a296ff9d3ac6b9aa8.tar.bz2 rails-0d76ab9c6f01e6390ba8878a296ff9d3ac6b9aa8.zip |
Fix before_commit when updating a record on the callback
Diffstat (limited to 'activerecord/test/cases')
-rw-r--r-- | activerecord/test/cases/transaction_callbacks_test.rb | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/activerecord/test/cases/transaction_callbacks_test.rb b/activerecord/test/cases/transaction_callbacks_test.rb index e868022fed..2475248eff 100644 --- a/activerecord/test/cases/transaction_callbacks_test.rb +++ b/activerecord/test/cases/transaction_callbacks_test.rb @@ -376,6 +376,9 @@ class CallbacksOnMultipleActionsTest < ActiveRecord::TestCase after_commit(on: [:create, :update]) { |record| record.history << :create_and_update } after_commit(on: [:update, :destroy]) { |record| record.history << :update_and_destroy } + before_commit(if: :save_before_commit_history) { |record| record.history << :before_commit } + before_commit(if: :update_title) { |record| record.update(title: "before commit title") } + def clear_history @history = [] end @@ -383,6 +386,8 @@ class CallbacksOnMultipleActionsTest < ActiveRecord::TestCase def history @history ||= [] end + + attr_accessor :save_before_commit_history, :update_title end def test_after_commit_on_multiple_actions @@ -399,6 +404,23 @@ class CallbacksOnMultipleActionsTest < ActiveRecord::TestCase topic.destroy assert_equal [:update_and_destroy, :create_and_destroy], topic.history end + + def test_before_commit_actions + topic = TopicWithCallbacksOnMultipleActions.new + topic.save_before_commit_history = true + topic.save + + assert_equal [:before_commit, :create_and_update, :create_and_destroy], topic.history + end + + def test_before_commit_update_in_same_transaction + topic = TopicWithCallbacksOnMultipleActions.new + topic.update_title = true + topic.save + + assert_equal "before commit title", topic.title + assert_equal "before commit title", topic.reload.title + end end |