summaryrefslogtreecommitdiff
path: root/spec/workers/project_service_worker_spec.rb
blob: 56934f122e445c738579ec69ae346e04fc29aecc (plain)
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
# 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