Module: ActiveJob::Execution
- Extended by:
- ActiveSupport::Concern
- Includes:
- ActiveSupport::Rescuable
- Included in:
- Base
- Defined in:
- lib/active_job/execution.rb
Overview
Active Job Execution
Provides methods to execute jobs immediately, and wraps job execution so that exceptions configured with rescue_from are handled.
Defined Under Namespace
Modules: ClassMethods
Instance Method Summary collapse
- #perform ⇒ Object
-
#perform_now ⇒ Object
Performs the job immediately.
Instance Method Details
#perform ⇒ Object
61 62 63 |
# File 'lib/active_job/execution.rb', line 61 def perform(*) fail NotImplementedError end |
#perform_now ⇒ Object
Performs the job immediately. The job is not sent to the queuing adapter but directly executed by blocking the execution of others until it’s finished. perform_now
returns the value of your job’s perform
method.
class MyJob < ActiveJob::Base
def perform
"Hello World!"
end
end
puts MyJob.new(*args).perform_now # => "Hello World!"
46 47 48 49 50 51 52 53 54 55 56 57 58 59 |
# File 'lib/active_job/execution.rb', line 46 def perform_now # Guard against jobs that were persisted before we started counting executions by zeroing out nil counters self.executions = (executions || 0) + 1 deserialize_arguments_if_needed _perform_job rescue Exception => exception handled = rescue_with_handler(exception) return handled if handled run_after_discard_procs(exception) raise end |