summaryrefslogtreecommitdiff
path: root/spec/workers/repository_remove_remote_worker_spec.rb
blob: f22d7c1d07339fecd4937ea29916d76ed3867c66 (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
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
require 'rails_helper'

describe RepositoryRemoveRemoteWorker do
  subject(:worker) { described_class.new }

  describe '#perform' do
    let(:remote_name) { 'joe'}
    let!(:project) { create(:project, :repository) }

    context 'when it cannot obtain lease' do
      it 'logs error' do
        allow_any_instance_of(Gitlab::ExclusiveLease).to receive(:try_obtain) { nil }

        expect_any_instance_of(Repository).not_to receive(:remove_remote)
        expect(worker).to receive(:log_error).with('Cannot obtain an exclusive lease. There must be another instance already in execution.')

        worker.perform(project.id, remote_name)
      end
    end

    context 'when it gets the lease' do
      before do
        allow_any_instance_of(Gitlab::ExclusiveLease).to receive(:try_obtain).and_return(true)
      end

      context 'when project does not exist' do
        it 'returns nil' do
          expect(worker.perform(-1, 'remote_name')).to be_nil
        end
      end

      context 'when project exists' do
        it 'removes remote from repository' do
          masterrev = project.repository.find_branch('master').dereferenced_target

          create_remote_branch(remote_name, 'remote_branch', masterrev)

          expect_any_instance_of(Repository).to receive(:remove_remote).with(remote_name).and_call_original

          worker.perform(project.id, remote_name)
        end
      end
    end
  end

  def create_remote_branch(remote_name, branch_name, target)
    rugged = project.repository.rugged
    rugged.references.create("refs/remotes/#{remote_name}/#{branch_name}", target.id)
  end
end