2022-03-03 12:50:03 -08:00
|
|
|
require_relative "helper"
|
2019-03-04 11:16:58 -08:00
|
|
|
|
|
|
|
describe Sidekiq::Worker do
|
2022-03-03 12:50:03 -08:00
|
|
|
describe "#set" do
|
2019-03-04 11:16:58 -08:00
|
|
|
class SetWorker
|
|
|
|
include Sidekiq::Worker
|
2021-09-28 11:24:17 -07:00
|
|
|
queue_as :foo
|
2022-03-03 12:50:03 -08:00
|
|
|
sidekiq_options "retry" => 12
|
2022-02-22 08:08:03 -08:00
|
|
|
def perform
|
|
|
|
end
|
2019-03-04 11:16:58 -08:00
|
|
|
end
|
|
|
|
|
|
|
|
def setup
|
2022-03-03 12:50:03 -08:00
|
|
|
Sidekiq.redis { |c| c.flushdb }
|
2019-03-04 11:16:58 -08:00
|
|
|
end
|
|
|
|
|
2021-09-28 11:24:17 -07:00
|
|
|
it "provides basic ActiveJob compatibilility" do
|
|
|
|
q = Sidekiq::ScheduledSet.new
|
|
|
|
assert_equal 0, q.size
|
2021-10-05 14:03:53 -07:00
|
|
|
jid = SetWorker.set(wait_until: 1.hour.from_now).perform_async(123)
|
2021-09-28 11:24:17 -07:00
|
|
|
assert jid
|
|
|
|
assert_equal 1, q.size
|
2021-10-05 14:03:53 -07:00
|
|
|
jid = SetWorker.set(wait: 1.hour).perform_async(123)
|
|
|
|
assert jid
|
|
|
|
assert_equal 2, q.size
|
2021-09-28 11:24:17 -07:00
|
|
|
|
|
|
|
q = Sidekiq::Queue.new("foo")
|
|
|
|
assert_equal 0, q.size
|
|
|
|
SetWorker.perform_async
|
2022-02-22 08:08:03 -08:00
|
|
|
SetWorker.perform_inline
|
|
|
|
SetWorker.perform_sync
|
2021-09-28 11:24:17 -07:00
|
|
|
assert_equal 1, q.size
|
|
|
|
|
2022-03-03 12:50:03 -08:00
|
|
|
SetWorker.set(queue: "xyz").perform_async
|
2021-09-28 11:24:17 -07:00
|
|
|
assert_equal 1, Sidekiq::Queue.new("xyz").size
|
|
|
|
end
|
|
|
|
|
2022-03-03 12:50:03 -08:00
|
|
|
it "can be memoized" do
|
|
|
|
q = Sidekiq::Queue.new("bar")
|
2019-03-04 11:16:58 -08:00
|
|
|
assert_equal 0, q.size
|
2022-03-03 12:50:03 -08:00
|
|
|
set = SetWorker.set(queue: :bar, foo: "qaaz")
|
2019-03-04 11:16:58 -08:00
|
|
|
set.perform_async(1)
|
|
|
|
set.perform_async(1)
|
|
|
|
set.perform_async(1)
|
|
|
|
set.perform_async(1)
|
|
|
|
assert_equal 4, q.size
|
2022-03-03 12:50:03 -08:00
|
|
|
assert_equal 4, q.map { |j| j["jid"] }.uniq.size
|
2019-03-04 11:16:58 -08:00
|
|
|
set.perform_in(10, 1)
|
|
|
|
end
|
|
|
|
|
2022-03-03 12:50:03 -08:00
|
|
|
it "allows option overrides" do
|
|
|
|
q = Sidekiq::Queue.new("bar")
|
2019-03-04 11:16:58 -08:00
|
|
|
assert_equal 0, q.size
|
|
|
|
assert SetWorker.set(queue: :bar).perform_async(1)
|
|
|
|
job = q.first
|
2022-03-03 12:50:03 -08:00
|
|
|
assert_equal "bar", job["queue"]
|
|
|
|
assert_equal 12, job["retry"]
|
2019-03-04 11:16:58 -08:00
|
|
|
end
|
|
|
|
|
2022-03-03 12:50:03 -08:00
|
|
|
it "handles symbols and strings" do
|
|
|
|
q = Sidekiq::Queue.new("bar")
|
2019-03-04 11:16:58 -08:00
|
|
|
assert_equal 0, q.size
|
2022-03-03 12:50:03 -08:00
|
|
|
assert SetWorker.set("queue" => "bar", :retry => 11).perform_async(1)
|
2019-03-04 11:16:58 -08:00
|
|
|
job = q.first
|
2022-03-03 12:50:03 -08:00
|
|
|
assert_equal "bar", job["queue"]
|
|
|
|
assert_equal 11, job["retry"]
|
2019-03-04 11:16:58 -08:00
|
|
|
|
|
|
|
q.clear
|
|
|
|
assert SetWorker.perform_async(1)
|
|
|
|
assert_equal 0, q.size
|
|
|
|
|
2022-03-03 12:50:03 -08:00
|
|
|
q = Sidekiq::Queue.new("foo")
|
2019-03-04 11:16:58 -08:00
|
|
|
job = q.first
|
2022-03-03 12:50:03 -08:00
|
|
|
assert_equal "foo", job["queue"]
|
|
|
|
assert_equal 12, job["retry"]
|
2019-03-04 11:16:58 -08:00
|
|
|
end
|
|
|
|
|
2022-03-03 12:50:03 -08:00
|
|
|
it "allows multiple calls" do
|
|
|
|
SetWorker.set(queue: :foo).set(bar: "xyz").perform_async
|
2019-03-04 11:16:58 -08:00
|
|
|
|
2022-03-03 12:50:03 -08:00
|
|
|
q = Sidekiq::Queue.new("foo")
|
2019-03-04 11:16:58 -08:00
|
|
|
job = q.first
|
2022-03-03 12:50:03 -08:00
|
|
|
assert_equal "foo", job["queue"]
|
|
|
|
assert_equal "xyz", job["bar"]
|
2019-03-04 11:16:58 -08:00
|
|
|
end
|
2021-11-02 09:54:44 -07:00
|
|
|
|
2022-03-03 12:50:03 -08:00
|
|
|
it "works with .perform_bulk" do
|
|
|
|
q = Sidekiq::Queue.new("bar")
|
2021-11-02 09:54:44 -07:00
|
|
|
assert_equal 0, q.size
|
|
|
|
|
2022-03-03 12:50:03 -08:00
|
|
|
set = SetWorker.set(queue: "bar")
|
2021-11-02 09:54:44 -07:00
|
|
|
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
|
2021-11-16 09:54:35 -07:00
|
|
|
|
2022-03-03 12:50:03 -08:00
|
|
|
describe ".perform_bulk and lazy enumerators" do
|
|
|
|
it "evaluates lazy enumerators" do
|
|
|
|
q = Sidekiq::Queue.new("bar")
|
2021-11-16 09:54:35 -07:00
|
|
|
assert_equal 0, q.size
|
|
|
|
|
2022-03-03 12:50:03 -08:00
|
|
|
set = SetWorker.set("queue" => "bar")
|
2021-11-16 09:54:35 -07:00
|
|
|
lazy_args = (1..1_001).to_a.map { |x| Array(x) }.lazy
|
|
|
|
jids = set.perform_bulk(lazy_args)
|
|
|
|
|
|
|
|
assert_equal 1_001, q.size
|
|
|
|
assert_equal 1_001, jids.size
|
|
|
|
end
|
|
|
|
end
|
2019-03-04 11:16:58 -08:00
|
|
|
end
|
2021-11-15 15:57:48 +05:30
|
|
|
|
2022-03-03 12:50:03 -08:00
|
|
|
describe "#perform_inline" do
|
2021-11-15 15:57:48 +05:30
|
|
|
$my_recorder = []
|
|
|
|
|
|
|
|
class MyCustomWorker
|
|
|
|
include Sidekiq::Worker
|
|
|
|
|
|
|
|
def perform(recorder)
|
2022-03-03 12:50:03 -08:00
|
|
|
$my_recorder << ["work_performed"]
|
2021-11-15 15:57:48 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
class MyCustomMiddleware
|
|
|
|
def initialize(name, recorder)
|
|
|
|
@name = name
|
|
|
|
@recorder = recorder
|
|
|
|
end
|
2021-12-07 14:02:59 -08:00
|
|
|
|
2021-11-15 15:57:48 +05:30
|
|
|
def call(*args)
|
|
|
|
@recorder << "#{@name}-before"
|
|
|
|
response = yield
|
|
|
|
@recorder << "#{@name}-after"
|
2022-03-03 12:50:03 -08:00
|
|
|
response
|
2021-11-15 15:57:48 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2022-03-03 12:50:03 -08:00
|
|
|
it "executes middleware & runs job inline" do
|
2021-11-15 15:57:48 +05:30
|
|
|
server_chain = Sidekiq::Middleware::Chain.new
|
|
|
|
server_chain.add MyCustomMiddleware, "1-server", $my_recorder
|
|
|
|
client_chain = Sidekiq::Middleware::Chain.new
|
|
|
|
client_chain.add MyCustomMiddleware, "1-client", $my_recorder
|
|
|
|
Sidekiq.stub(:server_middleware, server_chain) do
|
|
|
|
Sidekiq.stub(:client_middleware, client_chain) do
|
|
|
|
MyCustomWorker.perform_inline($my_recorder)
|
2022-03-03 12:50:03 -08:00
|
|
|
assert_equal $my_recorder.flatten, %w[1-client-before 1-client-after 1-server-before work_performed 1-server-after]
|
2021-11-15 15:57:48 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2019-03-04 11:16:58 -08:00
|
|
|
end
|