2019-07-07 11:18:12 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe ApplicationWorker do
|
2020-04-08 14:13:33 +05:30
|
|
|
let_it_be(:worker) do
|
2018-03-17 18:26:18 +05:30
|
|
|
Class.new do
|
|
|
|
def self.name
|
|
|
|
'Gitlab::Foo::Bar::DummyWorker'
|
|
|
|
end
|
|
|
|
|
|
|
|
include ApplicationWorker
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-04-08 14:13:33 +05:30
|
|
|
let(:instance) { worker.new }
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
describe 'Sidekiq options' do
|
|
|
|
it 'sets the queue name based on the class name' do
|
|
|
|
expect(worker.sidekiq_options['queue']).to eq('foo_bar_dummy')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-04-08 14:13:33 +05:30
|
|
|
describe '#structured_payload' do
|
|
|
|
let(:payload) { {} }
|
|
|
|
|
|
|
|
subject(:result) { instance.structured_payload(payload) }
|
|
|
|
|
|
|
|
it 'adds worker related payload' do
|
|
|
|
instance.jid = 'a jid'
|
|
|
|
|
|
|
|
expect(result).to include(
|
|
|
|
'class' => worker.class,
|
|
|
|
'job_status' => 'running',
|
|
|
|
'queue' => worker.queue,
|
|
|
|
'jid' => instance.jid
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'adds labkit context' do
|
|
|
|
user = build_stubbed(:user, username: 'jane-doe')
|
|
|
|
|
|
|
|
instance.with_context(user: user) do
|
|
|
|
expect(result).to include('meta.user' => user.username)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'adds custom payload converting stringified keys' do
|
|
|
|
payload[:message] = 'some message'
|
|
|
|
|
|
|
|
expect(result).to include('message' => payload[:message])
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'does not override predefined context keys with custom payload' do
|
|
|
|
payload['class'] = 'custom value'
|
|
|
|
|
|
|
|
expect(result).to include('class' => worker.class)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
describe '.queue_namespace' do
|
|
|
|
it 'sets the queue name based on the class name' do
|
|
|
|
worker.queue_namespace :some_namespace
|
|
|
|
|
|
|
|
expect(worker.queue).to eq('some_namespace:foo_bar_dummy')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '.queue' do
|
|
|
|
it 'returns the queue name' do
|
|
|
|
worker.sidekiq_options queue: :some_queue
|
|
|
|
|
|
|
|
expect(worker.queue).to eq('some_queue')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '.bulk_perform_async' do
|
|
|
|
it 'enqueues jobs in bulk' do
|
|
|
|
Sidekiq::Testing.fake! do
|
|
|
|
worker.bulk_perform_async([['Foo', [1]], ['Foo', [2]]])
|
|
|
|
|
|
|
|
expect(worker.jobs.count).to eq 2
|
|
|
|
expect(worker.jobs).to all(include('enqueued_at'))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '.bulk_perform_in' do
|
|
|
|
context 'when delay is valid' do
|
|
|
|
it 'correctly schedules jobs' do
|
|
|
|
Sidekiq::Testing.fake! do
|
|
|
|
worker.bulk_perform_in(1.minute, [['Foo', [1]], ['Foo', [2]]])
|
|
|
|
|
|
|
|
expect(worker.jobs.count).to eq 2
|
|
|
|
expect(worker.jobs).to all(include('at'))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when delay is invalid' do
|
|
|
|
it 'raises an ArgumentError exception' do
|
|
|
|
expect { worker.bulk_perform_in(-60, [['Foo']]) }
|
|
|
|
.to raise_error(ArgumentError)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|