diff options
author | Felipe Artur <felipefac@gmail.com> | 2018-08-21 16:29:50 -0300 |
---|---|---|
committer | Felipe Artur <felipefac@gmail.com> | 2018-09-10 18:01:25 -0300 |
commit | 918475314650100e1fe22d9da26aa962499b9ebc (patch) | |
tree | 59576193169981cdd2de52e517193f63431457e1 /spec/workers/project_service_worker_spec.rb | |
parent | fab15563963029c9f067d11d3d43fe3e6fac09a1 (diff) | |
download | gitlab-ce-918475314650100e1fe22d9da26aa962499b9ebc.tar.gz |
Log project services errors when executing async
Diffstat (limited to 'spec/workers/project_service_worker_spec.rb')
-rw-r--r-- | spec/workers/project_service_worker_spec.rb | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/spec/workers/project_service_worker_spec.rb b/spec/workers/project_service_worker_spec.rb new file mode 100644 index 00000000000..56934f122e4 --- /dev/null +++ b/spec/workers/project_service_worker_spec.rb @@ -0,0 +1,25 @@ +# frozen_string_literal: true +require 'spec_helper' + +describe ProjectServiceWorker, '#perform' do + let(:worker) { described_class.new } + let(:service) { JiraService.new } + + before do + allow(Service).to receive(:find).and_return(service) + end + + it 'executes service with given data' do + data = { test: 'test' } + expect(service).to receive(:execute).with(data) + + worker.perform(1, data) + end + + it 'logs error messages' do + allow(service).to receive(:execute).and_raise(StandardError, 'invalid URL') + expect(Sidekiq.logger).to receive(:error).with({ class: described_class.name, service_class: service.class.name, message: "invalid URL" }) + + worker.perform(1, {}) + end +end |