Active Job Execution

Provides methods to execute jobs immediately, and wraps job execution so that exceptions configured with rescue_from are handled.

Namespace

Module

Methods

Included Modules

Instance Public methods

perform(*)

๐Ÿ“ Source code
# File activejob/lib/active_job/execution.rb, line 61
    def perform(*)
      fail NotImplementedError
    end
๐Ÿ”Ž See on GitHub

perform_now()

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!"
๐Ÿ“ Source code
# 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
๐Ÿ”Ž See on GitHub