77db302aa0
This commit adds `ActiveJob.deprecator` and replaces all usages of `ActiveSupport::Deprecation.warn` in `activejob/lib` with `ActiveJob.deprecator`. Additionally, this commit adds `ActiveJob.deprecator` to `Rails.application.deprecators` so that it can be configured via settings such as `config.active_support.report_deprecations`. This commit also removes a defunct `ActiveSupport::Deprecation.silence` call that was added in 9eb4b4ed01f893c2fc7ff3ee4f99301dec7ea3c2 but not removed when the deprecation was completed in 10bd5e59c3291bb2034869e97cca30634a559afb.
76 lines
2.1 KiB
Ruby
76 lines
2.1 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require "helper"
|
|
require "jobs/callback_job"
|
|
require "jobs/abort_before_enqueue_job"
|
|
|
|
require "active_support/core_ext/object/inclusion"
|
|
|
|
class CallbacksTest < ActiveSupport::TestCase
|
|
test "perform callbacks" do
|
|
performed_callback_job = CallbackJob.new("A-JOB-ID")
|
|
performed_callback_job.perform_now
|
|
assert "CallbackJob ran before_perform".in? performed_callback_job.history
|
|
assert "CallbackJob ran after_perform".in? performed_callback_job.history
|
|
assert "CallbackJob ran around_perform_start".in? performed_callback_job.history
|
|
assert "CallbackJob ran around_perform_stop".in? performed_callback_job.history
|
|
end
|
|
|
|
test "perform return value" do
|
|
job = Class.new(ActiveJob::Base) do
|
|
def perform
|
|
123
|
|
end
|
|
end
|
|
|
|
assert_equal(123, job.perform_now)
|
|
end
|
|
|
|
test "perform around_callbacks return value" do
|
|
value = nil
|
|
|
|
Class.new(ActiveJob::Base) do
|
|
around_perform do |_, block|
|
|
value = block.call
|
|
end
|
|
|
|
def perform
|
|
123
|
|
end
|
|
end.perform_now
|
|
|
|
assert_equal(123, value)
|
|
end
|
|
|
|
test "enqueue callbacks" do
|
|
enqueued_callback_job = CallbackJob.perform_later
|
|
assert "CallbackJob ran before_enqueue".in? enqueued_callback_job.history
|
|
assert "CallbackJob ran after_enqueue".in? enqueued_callback_job.history
|
|
assert "CallbackJob ran around_enqueue_start".in? enqueued_callback_job.history
|
|
assert "CallbackJob ran around_enqueue_stop".in? enqueued_callback_job.history
|
|
end
|
|
|
|
test "#enqueue returns false when before_enqueue aborts callback chain" do
|
|
assert_equal false, AbortBeforeEnqueueJob.new.enqueue
|
|
end
|
|
|
|
test "#enqueue does not run after_enqueue callbacks when previous callbacks aborted" do
|
|
job = AbortBeforeEnqueueJob.new
|
|
job.enqueue
|
|
|
|
assert_nil(job.flag)
|
|
end
|
|
|
|
test "#perform does not run after_perform callbacks when swhen previous callbacks aborted" do
|
|
job = AbortBeforeEnqueueJob.new
|
|
job.perform_now
|
|
|
|
assert_nil(job.flag)
|
|
end
|
|
|
|
test "#enqueue returns self when the job was enqueued" do
|
|
job = CallbackJob.new
|
|
assert_equal job, job.enqueue
|
|
end
|
|
end
|