1
0
Fork 0
mirror of https://github.com/mperham/sidekiq.git synced 2022-11-09 13:52:34 -05:00
mperham--sidekiq/lib/sidekiq/testing.rb

54 lines
1.6 KiB
Ruby

module Sidekiq
module Worker
##
# The Sidekiq testing infrastructure overrides perform_async
# so that it does not actually touch the network. Instead it
# stores the asynchronous jobs in a per-class array so that
# their presence/absence can be asserted by your tests.
#
# This is similar to ActionMailer's :test delivery_method and its
# ActionMailer::Base.deliveries array.
#
# Example:
#
# require 'sidekiq/testing'
#
# assert_equal 0, HardWorker.jobs.size
# HardWorker.perform_async(:something)
# assert_equal 1, HardWorker.jobs.size
# assert_equal :something, HardWorker.jobs[0]['args'][0]
#
# assert_equal 0, Sidekiq::Extensions::DelayedMailer.jobs.size
# MyMailer.delayed.send_welcome_email('foo@example.com')
# assert_equal 1, Sidekiq::Extensions::DelayedMailer.jobs.size
#
module ClassMethods
alias_method :perform_async_old, :perform_async
def perform_async(*args)
jobs << { 'class' => self.name, 'args' => args }
true
end
alias_method :perform_in_old, :perform_in
alias_method :perform_at_old, :perform_at
def perform_in(interval, *args)
int = interval.to_f
ts = (int < 1_000_000_000 ? Time.now.to_f + int : int)
jobs << { 'class' => self.name, 'args' => args, 'at' => ts }
true
end
alias_method :perform_at, :perform_in
def jobs
@pushed ||= []
end
def drain
while job = jobs.shift do
new.perform(*job['args'])
end
end
end
end
end