123456789_123456789_123456789_123456789_123456789_

Class: ActiveJob::QueueAdapters::TestAdapter

Relationships & Source Files
Super Chains via Extension / Inclusion / Inheritance
Class Chain:
Instance Chain:
Inherits: ActiveJob::QueueAdapters::AbstractAdapter
Defined in: activejob/lib/active_job/queue_adapters/test_adapter.rb

Overview

Test adapter for Active Job

The test adapter should be used only in testing. Along with ::ActiveJob::TestCase and ::ActiveJob::TestHelper it makes a great tool to test your Rails application.

To use the test adapter set queue_adapter config to :test.

Rails.application.config.active_job.queue_adapter = :test

Class Method Summary

Instance Attribute Summary

AbstractAdapter - Inherited

#enqueue_after_transaction_commit?

Defines whether enqueuing should happen implicitly to after commit when called from inside a transaction.

Instance Method Summary

Constructor Details

.new(enqueue_after_transaction_commit: true) ⇒ TestAdapter

[ GitHub ]

  
# File 'activejob/lib/active_job/queue_adapters/test_adapter.rb', line 18

def initialize(enqueue_after_transaction_commit: true)
  @enqueue_after_transaction_commit = enqueue_after_transaction_commit
end

Instance Attribute Details

#at (rw)

[ GitHub ]

  
# File 'activejob/lib/active_job/queue_adapters/test_adapter.rb', line 15

attr_accessor(:perform_enqueued_jobs, :perform_enqueued_at_jobs, :filter, :reject, :queue, :at, :enqueue_after_transaction_commit)

#enqueue_after_transaction_commit (rw)

[ GitHub ]

  
# File 'activejob/lib/active_job/queue_adapters/test_adapter.rb', line 15

attr_accessor(:perform_enqueued_jobs, :perform_enqueued_at_jobs, :filter, :reject, :queue, :at, :enqueue_after_transaction_commit)

#enqueue_after_transaction_commit?Boolean (rw)

This method is for internal use only.
[ GitHub ]

  
# File 'activejob/lib/active_job/queue_adapters/test_adapter.rb', line 22

def enqueue_after_transaction_commit? # :nodoc:
  @enqueue_after_transaction_commit
end

#enqueued_jobs (rw)

Provides a store of all the enqueued jobs with the TestAdapter so you can check them.

[ GitHub ]

  
# File 'activejob/lib/active_job/queue_adapters/test_adapter.rb', line 27

def enqueued_jobs
  @enqueued_jobs ||= []
end

#enqueued_jobs=(value) (rw)

[ GitHub ]

  
# File 'activejob/lib/active_job/queue_adapters/test_adapter.rb', line 16

attr_writer(:enqueued_jobs, :performed_jobs)

#filter (rw)

[ GitHub ]

  
# File 'activejob/lib/active_job/queue_adapters/test_adapter.rb', line 15

attr_accessor(:perform_enqueued_jobs, :perform_enqueued_at_jobs, :filter, :reject, :queue, :at, :enqueue_after_transaction_commit)

#perform_enqueued_at_jobs (rw)

[ GitHub ]

  
# File 'activejob/lib/active_job/queue_adapters/test_adapter.rb', line 15

attr_accessor(:perform_enqueued_jobs, :perform_enqueued_at_jobs, :filter, :reject, :queue, :at, :enqueue_after_transaction_commit)

#perform_enqueued_jobs (rw)

[ GitHub ]

  
# File 'activejob/lib/active_job/queue_adapters/test_adapter.rb', line 15

attr_accessor(:perform_enqueued_jobs, :perform_enqueued_at_jobs, :filter, :reject, :queue, :at, :enqueue_after_transaction_commit)

#performed_jobs (rw)

Provides a store of all the performed jobs with the TestAdapter so you can check them.

[ GitHub ]

  
# File 'activejob/lib/active_job/queue_adapters/test_adapter.rb', line 32

def performed_jobs
  @performed_jobs ||= []
end

#performed_jobs=(value) (rw)

[ GitHub ]

  
# File 'activejob/lib/active_job/queue_adapters/test_adapter.rb', line 16

attr_writer(:enqueued_jobs, :performed_jobs)

#queue (rw)

[ GitHub ]

  
# File 'activejob/lib/active_job/queue_adapters/test_adapter.rb', line 15

attr_accessor(:perform_enqueued_jobs, :perform_enqueued_at_jobs, :filter, :reject, :queue, :at, :enqueue_after_transaction_commit)

#reject (rw)

[ GitHub ]

  
# File 'activejob/lib/active_job/queue_adapters/test_adapter.rb', line 15

attr_accessor(:perform_enqueued_jobs, :perform_enqueued_at_jobs, :filter, :reject, :queue, :at, :enqueue_after_transaction_commit)

Instance Method Details

#enqueue(job)

This method is for internal use only.
[ GitHub ]

  
# File 'activejob/lib/active_job/queue_adapters/test_adapter.rb', line 36

def enqueue(job) # :nodoc:
  job_data = job_to_hash(job)
  perform_or_enqueue(perform_enqueued_jobs && !filtered?(job), job, job_data)
end

#enqueue_at(job, timestamp)

This method is for internal use only.
[ GitHub ]

  
# File 'activejob/lib/active_job/queue_adapters/test_adapter.rb', line 41

def enqueue_at(job, timestamp) # :nodoc:
  job_data = job_to_hash(job, at: timestamp)
  perform_or_enqueue(perform_enqueued_at_jobs && !filtered?(job), job, job_data)
end

#filter_as_proc(filter) (private)

[ GitHub ]

  
# File 'activejob/lib/active_job/queue_adapters/test_adapter.rb', line 87

def filter_as_proc(filter)
  return filter if filter.is_a?(Proc)

  ->(job) { Array(filter).include?(job.class) }
end

#filtered?(job) ⇒ Boolean (private)

[ GitHub ]

  
# File 'activejob/lib/active_job/queue_adapters/test_adapter.rb', line 65

def filtered?(job)
  filtered_queue?(job) || filtered_job_class?(job) || filtered_time?(job)
end

#filtered_job_class?(job) ⇒ Boolean (private)

[ GitHub ]

  
# File 'activejob/lib/active_job/queue_adapters/test_adapter.rb', line 79

def filtered_job_class?(job)
  if filter
    !filter_as_proc(filter).call(job)
  elsif reject
    filter_as_proc(reject).call(job)
  end
end

#filtered_queue?(job) ⇒ Boolean (private)

[ GitHub ]

  
# File 'activejob/lib/active_job/queue_adapters/test_adapter.rb', line 73

def filtered_queue?(job)
  if queue
    job.queue_name != queue.to_s
  end
end

#filtered_time?(job) ⇒ Boolean (private)

[ GitHub ]

  
# File 'activejob/lib/active_job/queue_adapters/test_adapter.rb', line 69

def filtered_time?(job)
  job.scheduled_at > at if at && job.scheduled_at
end

#job_to_hash(job, extras = {}) (private)

[ GitHub ]

  
# File 'activejob/lib/active_job/queue_adapters/test_adapter.rb', line 47

def job_to_hash(job, extras = {})
  job.serialize.tap do |job_data|
    job_data[:job] = job.class
    job_data[:args] = job_data.fetch("arguments")
    job_data[:queue] = job_data.fetch("queue_name")
    job_data[:priority] = job_data.fetch("priority")
  end.merge(extras)
end

#perform_or_enqueue(perform, job, job_data) (private)

[ GitHub ]

  
# File 'activejob/lib/active_job/queue_adapters/test_adapter.rb', line 56

def perform_or_enqueue(perform, job, job_data)
  if perform
    performed_jobs << job_data
    Base.execute(job.serialize)
  else
    enqueued_jobs << job_data
  end
end