2012-02-10 00:46:44 -05:00
|
|
|
require 'helper'
|
2012-03-10 16:07:19 -05:00
|
|
|
require 'sidekiq'
|
2012-02-10 00:46:44 -05:00
|
|
|
require 'sidekiq/worker'
|
2012-03-10 14:56:34 -05:00
|
|
|
require 'active_record'
|
|
|
|
require 'action_mailer'
|
2012-04-28 00:21:23 -04:00
|
|
|
require 'sidekiq/rails'
|
2012-03-10 14:56:34 -05:00
|
|
|
require 'sidekiq/extensions/action_mailer'
|
|
|
|
require 'sidekiq/extensions/active_record'
|
2012-02-10 00:46:44 -05:00
|
|
|
|
2012-03-10 16:07:19 -05:00
|
|
|
Sidekiq.hook_rails!
|
|
|
|
|
2012-02-10 00:46:44 -05:00
|
|
|
class TestTesting < MiniTest::Unit::TestCase
|
|
|
|
describe 'sidekiq testing' do
|
2012-05-02 13:45:05 -04:00
|
|
|
class PerformError < RuntimeError; end
|
|
|
|
|
2012-02-10 00:46:44 -05:00
|
|
|
class DirectWorker
|
|
|
|
include Sidekiq::Worker
|
|
|
|
def perform(a, b)
|
|
|
|
a + b
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-05-01 17:20:35 -04:00
|
|
|
class EnqueuedWorker
|
|
|
|
include Sidekiq::Worker
|
|
|
|
def perform(a, b)
|
|
|
|
a + b
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-05-02 13:45:05 -04:00
|
|
|
class StoredWorker
|
|
|
|
include Sidekiq::Worker
|
|
|
|
def perform(error)
|
|
|
|
raise PerformError if error
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-03-10 14:56:34 -05:00
|
|
|
class FooMailer < ActionMailer::Base
|
|
|
|
def bar(str)
|
|
|
|
str
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
class FooModel < ActiveRecord::Base
|
|
|
|
def bar(str)
|
|
|
|
str
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
before do
|
2012-05-01 17:20:35 -04:00
|
|
|
load 'sidekiq/testing.rb'
|
2012-03-10 14:56:34 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
after do
|
|
|
|
# Undo override
|
|
|
|
Sidekiq::Worker::ClassMethods.class_eval do
|
2012-06-28 03:46:18 -04:00
|
|
|
remove_method :client_push
|
|
|
|
alias_method :client_push, :client_push_old
|
|
|
|
remove_method :client_push_old
|
2012-02-10 00:46:44 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-05-01 17:20:35 -04:00
|
|
|
it 'stubs the async call' do
|
2012-03-10 14:56:34 -05:00
|
|
|
assert_equal 0, DirectWorker.jobs.size
|
|
|
|
assert DirectWorker.perform_async(1, 2)
|
|
|
|
assert_equal 1, DirectWorker.jobs.size
|
2012-06-03 14:03:22 -04:00
|
|
|
assert DirectWorker.perform_in(10, 1, 2)
|
|
|
|
assert_equal 2, DirectWorker.jobs.size
|
|
|
|
assert DirectWorker.perform_at(10, 1, 2)
|
|
|
|
assert_equal 3, DirectWorker.jobs.size
|
|
|
|
assert_in_delta 10.seconds.from_now.to_f, DirectWorker.jobs.last['at'], 0.01
|
2012-05-01 17:20:35 -04:00
|
|
|
end
|
2012-03-10 14:56:34 -05:00
|
|
|
|
2012-05-01 17:20:35 -04:00
|
|
|
it 'stubs the delay call on mailers' do
|
2012-03-10 14:56:34 -05:00
|
|
|
assert_equal 0, Sidekiq::Extensions::DelayedMailer.jobs.size
|
|
|
|
FooMailer.delay.bar('hello!')
|
|
|
|
assert_equal 1, Sidekiq::Extensions::DelayedMailer.jobs.size
|
2012-05-01 17:20:35 -04:00
|
|
|
end
|
2012-03-10 14:56:34 -05:00
|
|
|
|
2012-05-01 17:20:35 -04:00
|
|
|
it 'stubs the delay call on models' do
|
2012-03-10 14:56:34 -05:00
|
|
|
assert_equal 0, Sidekiq::Extensions::DelayedModel.jobs.size
|
|
|
|
FooModel.delay.bar('hello!')
|
|
|
|
assert_equal 1, Sidekiq::Extensions::DelayedModel.jobs.size
|
|
|
|
end
|
|
|
|
|
2012-05-01 17:20:35 -04:00
|
|
|
it 'stubs the enqueue call' do
|
|
|
|
assert_equal 0, EnqueuedWorker.jobs.size
|
|
|
|
assert Sidekiq::Client.enqueue(EnqueuedWorker, 1, 2)
|
|
|
|
assert_equal 1, EnqueuedWorker.jobs.size
|
|
|
|
end
|
2012-05-02 13:45:05 -04:00
|
|
|
|
|
|
|
it 'executes all stored jobs' do
|
|
|
|
assert StoredWorker.perform_async(false)
|
|
|
|
assert StoredWorker.perform_async(true)
|
|
|
|
|
|
|
|
assert_equal 2, StoredWorker.jobs.size
|
|
|
|
assert_raises PerformError do
|
2012-05-02 13:59:31 -04:00
|
|
|
StoredWorker.drain
|
2012-05-02 13:45:05 -04:00
|
|
|
end
|
|
|
|
assert_equal 0, StoredWorker.jobs.size
|
|
|
|
end
|
2012-02-10 00:46:44 -05:00
|
|
|
end
|
|
|
|
end
|