File: project_destroy_worker_spec.rb

package info (click to toggle)
gitlab 17.6.5-19
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 629,368 kB
  • sloc: ruby: 1,915,304; javascript: 557,307; sql: 60,639; xml: 6,509; sh: 4,567; makefile: 1,239; python: 406
file content (76 lines) | stat: -rw-r--r-- 2,139 bytes parent folder | download
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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe ProjectDestroyWorker, feature_category: :source_code_management do
  let!(:project) { create(:project, :repository, pending_delete: true) }
  let!(:repository) { project.repository.raw }

  let(:user) { project.first_owner }
  let(:params) { {} }

  subject(:worker) { described_class.new }

  it_behaves_like 'an idempotent worker' do
    let(:job_args) { [project.id, user.id, {}] }

    it 'does not change projects when run twice' do
      expect { worker.perform(project.id, user.id, {}) }.to change { Project.count }.by(-1)
      expect { worker.perform(project.id, user.id, {}) }.not_to change { Project.count }
    end
  end

  describe '#perform' do
    shared_examples 'deletes the project' do
      specify do
        worker.perform(project.id, user.id, params)

        expect(Project.all).not_to include(project)
        expect(repository).not_to exist
      end
    end

    it_behaves_like 'deletes the project'

    context 'when an admin deletes the project' do
      let_it_be(:user) { create(:admin) }

      context 'with admin_mode setting enabled' do
        context 'with admin mode session', :enable_admin_mode do
          it_behaves_like 'deletes the project'
        end

        context 'without admin mode session' do
          it 'does not delete the project' do
            worker.perform(project.id, user.id, params)

            expect(Project.all).to include(project)
            expect(repository).to exist
          end
        end
      end

      context 'with admin_mode setting disabled' do
        before do
          stub_application_setting(admin_mode: false)
        end

        context 'without admin mode session' do
          it_behaves_like 'deletes the project'
        end
      end
    end

    it 'does not raise error when project could not be found' do
      expect do
        worker.perform(-1, user.id, {})
      end.not_to raise_error
    end

    it 'does not raise error when user could not be found' do
      expect do
        worker.perform(project.id, -1, {})
      end.not_to raise_error
    end
  end
end