forked from sidekiq/sidekiq
/
test_fetch.rb
104 lines (93 loc) · 2.64 KB
/
test_fetch.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
require_relative 'helper'
require 'sidekiq/fetch'
class TestFetcher < Sidekiq::Test
describe 'fetcher' do
before do
Sidekiq.redis = { :url => REDIS_URL, :namespace => 'fuzzy' }
Sidekiq.redis do |conn|
conn.flushdb
conn.rpush('queue:basic', 'msg')
end
end
after do
Sidekiq.redis = REDIS
end
it 'retrieves' do
fetch = Sidekiq::BasicFetch.new(:queues => ['basic', 'bar'])
uow = fetch.retrieve_work
refute_nil uow
assert_equal 'basic', uow.queue_name
assert_equal 'msg', uow.message
q = Sidekiq::Queue.new('basic')
assert_equal 0, q.size
uow.requeue
assert_equal 1, q.size
assert_nil uow.acknowledge
end
it 'retrieves with strict setting' do
fetch = Sidekiq::BasicFetch.new(:queues => ['basic', 'bar', 'bar'], :strict => true)
cmd = fetch.queues_cmd
assert_equal cmd, ['queue:basic', 'queue:bar', 1]
end
it 'bulk requeues' do
q1 = Sidekiq::Queue.new('foo')
q2 = Sidekiq::Queue.new('bar')
assert_equal 0, q1.size
assert_equal 0, q2.size
uow = Sidekiq::BasicFetch::UnitOfWork
Sidekiq::BasicFetch.bulk_requeue([uow.new('fuzzy:queue:foo', 'bob'), uow.new('fuzzy:queue:foo', 'bar'), uow.new('fuzzy:queue:bar', 'widget')], {:queues => []})
assert_equal 2, q1.size
assert_equal 1, q2.size
end
describe 'fetching' do
before do
Sidekiq::Fetcher.reset
end
it 'instantiates' do
begin
Sidekiq.options[:fetch] = NullFetch
mgr = Minitest::Mock.new
fetch = Sidekiq::Fetcher.new(mgr, {})
fetch.fetch
Sidekiq::Fetcher.done!
ensure
Sidekiq.options[:fetch] = Sidekiq::BasicFetch
end
end
class NullFetch
def initialize(opts)
end
def retrieve_work
end
def self.bulk_requeue(*args)
end
end
it 'handles redis network errors' do
begin
Sidekiq.logger.level = Logger::FATAL
Sidekiq.options[:fetch] = ErrorFetch
mgr = Minitest::Mock.new
fetch = Sidekiq::Fetcher.new(mgr, {})
def fetch.pause
end
refute fetch.down
fetch.fetch
Sidekiq::Fetcher.done!
assert fetch.down
ensure
Sidekiq.options[:fetch] = Sidekiq::BasicFetch
Sidekiq.logger.level = Logger::ERROR
end
end
class ErrorFetch
def initialize(opts)
end
def retrieve_work
raise IOError, "ker-BOOM"
end
def self.bulk_requeue(*args)
end
end
end
end
end