summaryrefslogtreecommitdiff
path: root/spec/workers
diff options
context:
space:
mode:
authorFelipe Artur <felipefac@gmail.com>2018-08-21 16:29:50 -0300
committerFelipe Artur <felipefac@gmail.com>2018-09-10 18:01:25 -0300
commit918475314650100e1fe22d9da26aa962499b9ebc (patch)
tree59576193169981cdd2de52e517193f63431457e1 /spec/workers
parentfab15563963029c9f067d11d3d43fe3e6fac09a1 (diff)
downloadgitlab-ce-918475314650100e1fe22d9da26aa962499b9ebc.tar.gz
Log project services errors when executing async
Diffstat (limited to 'spec/workers')
-rw-r--r--spec/workers/project_service_worker_spec.rb25
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