2020-03-13 15:44:24 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
RSpec.describe MergeRequestMergeabilityCheckWorker do
|
2020-03-13 15:44:24 +05:30
|
|
|
subject { described_class.new }
|
|
|
|
|
|
|
|
describe '#perform' do
|
|
|
|
context 'when merge request does not exist' do
|
|
|
|
it 'does not execute MergeabilityCheckService' do
|
|
|
|
expect(MergeRequests::MergeabilityCheckService).not_to receive(:new)
|
|
|
|
|
2021-10-27 15:23:28 +05:30
|
|
|
expect(Sidekiq.logger).to receive(:error).once
|
|
|
|
.with(
|
|
|
|
merge_request_id: 1,
|
|
|
|
worker: "MergeRequestMergeabilityCheckWorker",
|
|
|
|
message: 'Failed to find merge request')
|
|
|
|
|
2020-03-13 15:44:24 +05:30
|
|
|
subject.perform(1)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when merge request exists' do
|
|
|
|
let(:merge_request) { create(:merge_request) }
|
|
|
|
|
|
|
|
it 'executes MergeabilityCheckService' do
|
|
|
|
expect_next_instance_of(MergeRequests::MergeabilityCheckService, merge_request) do |service|
|
|
|
|
expect(service).to receive(:execute).and_return(double(error?: false))
|
|
|
|
end
|
|
|
|
|
|
|
|
subject.perform(merge_request.id)
|
|
|
|
end
|
2021-10-27 15:23:28 +05:30
|
|
|
|
|
|
|
it 'structurally logs a failed mergeability check' do
|
|
|
|
expect_next_instance_of(MergeRequests::MergeabilityCheckService, merge_request) do |service|
|
|
|
|
expect(service).to receive(:execute).and_return(double(error?: true, message: "solar flares"))
|
|
|
|
end
|
|
|
|
|
|
|
|
expect(Sidekiq.logger).to receive(:error).once
|
|
|
|
.with(
|
|
|
|
merge_request_id: merge_request.id,
|
|
|
|
worker: "MergeRequestMergeabilityCheckWorker",
|
|
|
|
message: 'Failed to check mergeability of merge request: solar flares')
|
|
|
|
|
|
|
|
subject.perform(merge_request.id)
|
|
|
|
end
|
2020-03-13 15:44:24 +05:30
|
|
|
end
|
2020-05-24 23:13:21 +05:30
|
|
|
|
|
|
|
it_behaves_like 'an idempotent worker' do
|
|
|
|
let(:merge_request) { create(:merge_request) }
|
|
|
|
let(:job_args) { [merge_request.id] }
|
|
|
|
|
|
|
|
it 'is mergeable' do
|
|
|
|
subject
|
|
|
|
|
|
|
|
expect(merge_request).to be_mergeable
|
|
|
|
end
|
|
|
|
end
|
2020-03-13 15:44:24 +05:30
|
|
|
end
|
|
|
|
end
|