1
0
Fork 0
mirror of https://github.com/mperham/sidekiq.git synced 2022-11-09 13:52:34 -05:00
mperham--sidekiq/test/test_worker.rb
Kelly Sutton 4a0432622f
Implement Sidekiq::Worker.perform_bulk (#5042)
* Sketch out some failing tests to capture the behavior

Co-authored-by: jeffcarbs <jeff.carbonella@gmail.com>

* Implement Sidekiq::Client.perform_bulk

Co-authored-by: jeffcarbs <jeff.carbonella@gmail.com>

* Allow .perform_bulk to operate on different batch sizes

Co-authored-by: jeffcarbs <jeff.carbonella@gmail.com>

* Write a failing test to capture the Sidekiq::Worker::Setter.perform_bulk behavior

Co-authored-by: jeffcarbs <jeff.carbonella@gmail.com>

* Implement Sidekiq::Worker::Setter.perform_bulk

Co-authored-by: jeffcarbs <jeff.carbonella@gmail.com>

* Write a small comment for to document the method

Co-authored-by: jeffcarbs <jeff.carbonella@gmail.com>

* Add a Changes.md entry

Co-authored-by: jeffcarbs <jeff.carbonella@gmail.com>
2021-11-02 09:54:44 -07:00

95 lines
2.4 KiB
Ruby

require_relative 'helper'
describe Sidekiq::Worker do
describe '#set' do
class SetWorker
include Sidekiq::Worker
queue_as :foo
sidekiq_options 'retry' => 12
end
def setup
Sidekiq.redis {|c| c.flushdb }
end
it "provides basic ActiveJob compatibilility" do
q = Sidekiq::ScheduledSet.new
assert_equal 0, q.size
jid = SetWorker.set(wait_until: 1.hour.from_now).perform_async(123)
assert jid
assert_equal 1, q.size
jid = SetWorker.set(wait: 1.hour).perform_async(123)
assert jid
assert_equal 2, q.size
q = Sidekiq::Queue.new("foo")
assert_equal 0, q.size
SetWorker.perform_async
assert_equal 1, q.size
SetWorker.set(queue: 'xyz').perform_async
assert_equal 1, Sidekiq::Queue.new("xyz").size
end
it 'can be memoized' do
q = Sidekiq::Queue.new('bar')
assert_equal 0, q.size
set = SetWorker.set(queue: :bar, foo: 'qaaz')
set.perform_async(1)
set.perform_async(1)
set.perform_async(1)
set.perform_async(1)
assert_equal 4, q.size
assert_equal 4, q.map{|j| j['jid'] }.uniq.size
set.perform_in(10, 1)
end
it 'allows option overrides' do
q = Sidekiq::Queue.new('bar')
assert_equal 0, q.size
assert SetWorker.set(queue: :bar).perform_async(1)
job = q.first
assert_equal 'bar', job['queue']
assert_equal 12, job['retry']
end
it 'handles symbols and strings' do
q = Sidekiq::Queue.new('bar')
assert_equal 0, q.size
assert SetWorker.set('queue' => 'bar', :retry => 11).perform_async(1)
job = q.first
assert_equal 'bar', job['queue']
assert_equal 11, job['retry']
q.clear
assert SetWorker.perform_async(1)
assert_equal 0, q.size
q = Sidekiq::Queue.new('foo')
job = q.first
assert_equal 'foo', job['queue']
assert_equal 12, job['retry']
end
it 'allows multiple calls' do
SetWorker.set(queue: :foo).set(bar: 'xyz').perform_async
q = Sidekiq::Queue.new('foo')
job = q.first
assert_equal 'foo', job['queue']
assert_equal 'xyz', job['bar']
end
it 'works with .perform_bulk' do
q = Sidekiq::Queue.new('bar')
assert_equal 0, q.size
set = SetWorker.set('queue' => 'bar')
jids = set.perform_bulk((1..1_001).to_a.map { |x| Array(x) })
assert_equal 1_001, q.size
assert_equal 1_001, jids.size
end
end
end