Skip to content

Commit

Permalink
Fix after_commit on: :destroy not being triggered
Browse files Browse the repository at this point in the history
  • Loading branch information
npezza93 committed May 5, 2017
1 parent c1232a3 commit 682ca2a
Show file tree
Hide file tree
Showing 3 changed files with 58 additions and 3 deletions.
6 changes: 3 additions & 3 deletions .travis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -11,16 +11,16 @@ env:
matrix:
- RAILS='~> 4.2.7.1'
- RAILS='~> 5.0.0.1'
- RAILS='~> 5.1.0.rc1'
- RAILS='~> 5.1.0'

matrix:
exclude:
- env: RAILS='~> 5.1.0.rc1'
- env: RAILS='~> 5.1.0'
rvm: 2.2.6
allow_failures:
- env: RAILS='~> 4.2.7.1'
rvm: jruby-9.1.6.0
- env: RAILS='~> 5.0.0.1'
rvm: jruby-9.1.6.0
- env: RAILS='~> 5.1.0.rc1'
- env: RAILS='~> 5.1.0'
rvm: jruby-9.1.6.0
26 changes: 26 additions & 0 deletions lib/paranoia.rb
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,7 @@ def destroy
association.decrement_counters
end
@_disable_counter_cache = false
@_trigger_destroy_callback = true
result
end
end
Expand Down Expand Up @@ -193,6 +194,31 @@ def timestamp_attributes_with_current_time
timestamp_attributes_for_update_in_model.each_with_object({}) { |attr,hash| hash[attr] = current_time_from_proper_timezone }
end

def transaction_include_any_action?(actions)
actions.any? do |action|
case action
when :create
transaction_record_state(:new_record)
when :destroy
if ActiveRecord::VERSION::STRING < "5.1.0"
transaction_include_destroy?
else
defined?(@_trigger_destroy_callback) && @_trigger_destroy_callback
end
when :update
update_trigger = !(transaction_record_state(:new_record) || transaction_include_destroy?)
if ActiveRecord::VERSION::STRING >= "5.1.0"
update_trigger &&= (defined?(@_trigger_update_callback) && @_trigger_update_callback)
end
update_trigger
end
end
end

def transaction_include_destroy?
destroyed? || try(:paranoia_destroyed?)
end

# restore associated records that have been soft deleted when
# we called #destroy
def restore_associated_records(recovery_window_range = nil)
Expand Down
29 changes: 29 additions & 0 deletions test/paranoia_test.rb
Original file line number Diff line number Diff line change
Expand Up @@ -111,6 +111,16 @@ def test_destroy_behavior_for_plain_models
assert_equal 0, model.class.unscoped.count
end

def test_after_commit_on_destroy_callbacks
model = AfterCommitDestroyModel.new
model.save
model.reset_after_commit_callback_called # clear called callback flags
refute model.after_commit_callback_called
model.destroy

assert model.after_commit_callback_called
end

# Anti-regression test for #81, which would've introduced a bug to break this test.
def test_destroy_behavior_for_plain_models_callbacks
model = CallbackModel.new
Expand Down Expand Up @@ -1359,3 +1369,22 @@ class ParanoidBelongsTo < ActiveRecord::Base
belongs_to :paranoid_has_one
end
end

class AfterCommitDestroyModel < ActiveRecord::Base
self.table_name = "callback_models"

attr_reader :after_commit_callback_called

acts_as_paranoid
after_commit :callback_triggered, on: :destroy

def reset_after_commit_callback_called
@after_commit_callback_called = false
end

private

def callback_triggered
@after_commit_callback_called = true
end
end

0 comments on commit 682ca2a

Please sign in to comment.