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 60
    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 45
    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