Module: ActiveJob::Execution

Extended by:
ActiveSupport::Concern
Includes:
ActiveSupport::Rescuable
Included in:
Base
Defined in:
activejob/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

Methods included from ActiveSupport::Concern

append_features, class_methods, extended, included, prepend_features, prepended

Methods included from ActiveSupport::Rescuable

#handler_for_rescue, #rescue_with_handler

Instance Method Details

#performObject



61
62
63
# File 'activejob/lib/active_job/execution.rb', line 61

def perform(*)
  fail NotImplementedError
end

#perform_nowObject

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 'activejob/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