module ActiveJob::Core 
        Active Job Core
Provides general behavior that will be included into every Active Job object that inherits from ActiveJob::Base.
Attributes
| [RW] | arguments | 
            Job arguments  | 
          
| [RW] | enqueue_error | 
            Track any exceptions raised by the backend so callers can inspect the errors.  | 
          
| [RW] | enqueued_at | 
            Track when a job was enqueued  | 
          
| [RW] | exception_executions | 
            Hash that contains the number of times this job handled errors for each specific retry_on declaration. Keys are the string representation of the exceptions listed in the retry_on declaration, while its associated value holds the number of executions where the corresponding retry_on declaration handled one of its listed exceptions.  | 
          
| [RW] | executions | 
            Number of times this job has been executed (which increments on every retry, like after an exception).  | 
          
| [RW] | job_id | 
            Job Identifier  | 
          
| [RW] | locale | 
            I18n.locale to be used during the job.  | 
          
| [W] | priority | 
            Priority that the job will have (lower is more priority).  | 
          
| [RW] | provider_job_id | 
            ID optionally provided by adapter  | 
          
| [W] | queue_name | 
            Queue in which the job will reside.  | 
          
| [RW] | scheduled_at | 
            Time when the job should be performed  | 
          
| [W] | serialized_arguments | 
            |
| [RW] | timezone | 
            Timezone to be used during the job.  | 
          
Public class methods
Creates a new job instance. Takes the arguments that will be passed to the perform method.
Source code GitHub
# File activejob/lib/active_job/core.rb, line 103
def initialize(*arguments)
  @arguments  = arguments
  @job_id     = SecureRandom.uuid
  @queue_name = self.class.queue_name
  @scheduled_at = nil
  @priority   = self.class.priority
  @executions = 0
  @exception_executions = {}
  @timezone   = Time.zone&.name
end
            Public instance methods
Attaches the stored job data to the current instance. Receives a hash returned from serialize
Examples
class DeliverWebhookJob < ActiveJob::Base
  attr_writer :attempt_number
  def attempt_number
    @attempt_number ||= 0
  end
  def serialize
    super.merge('attempt_number' => attempt_number + 1)
  end
  def deserialize(job_data)
    super
    self.attempt_number = job_data['attempt_number']
  end
  rescue_from(Timeout::Error) do |exception|
    raise exception if attempt_number > 5
    retry_job(wait: 10)
  end
end
Source code GitHub
# File activejob/lib/active_job/core.rb, line 160
def deserialize(job_data)
  self.job_id               = job_data["job_id"]
  self.provider_job_id      = job_data["provider_job_id"]
  self.queue_name           = job_data["queue_name"]
  self.priority             = job_data["priority"]
  self.serialized_arguments = job_data["arguments"]
  self.executions           = job_data["executions"]
  self.exception_executions = job_data["exception_executions"]
  self.locale               = job_data["locale"] || I18n.locale.to_s
  self.timezone             = job_data["timezone"] || Time.zone&.name
  self.enqueued_at          = Time.iso8601(job_data["enqueued_at"]) if job_data["enqueued_at"]
  self.scheduled_at         = Time.iso8601(job_data["scheduled_at"]) if job_data["scheduled_at"]
end
            Returns a hash with the job data that can safely be passed to the queuing adapter.
Source code GitHub
# File activejob/lib/active_job/core.rb, line 117
def serialize
  {
    "job_class"  => self.class.name,
    "job_id"     => job_id,
    "provider_job_id" => provider_job_id,
    "queue_name" => queue_name,
    "priority"   => priority,
    "arguments"  => serialize_arguments_if_needed(arguments),
    "executions" => executions,
    "exception_executions" => exception_executions,
    "locale"     => I18n.locale.to_s,
    "timezone"   => timezone,
    "enqueued_at" => Time.now.utc.iso8601(9),
    "scheduled_at" => scheduled_at ? scheduled_at.utc.iso8601(9) : nil,
  }
end
            Source code GitHub
# File activejob/lib/active_job/core.rb, line 58
def successfully_enqueued?
  @successfully_enqueued
end