summaryrefslogtreecommitdiff
path: root/spec/services/clusters/destroy_service_spec.rb
blob: 2bc0099ff047c54b3e11969a95730b6a04eb8abe (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
51
52
53
54
55
56
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe Clusters::DestroyService, feature_category: :kubernetes_management do
  describe '#execute' do
    subject { described_class.new(cluster.user, params).execute(cluster) }

    let!(:cluster) { create(:cluster, :project, :provided_by_user) }

    context 'when correct params' do
      shared_examples 'only removes cluster' do
        it 'does not start cleanup' do
          expect(cluster).not_to receive(:start_cleanup)
          subject
        end

        it 'destroys the cluster' do
          subject
          expect { cluster.reload }.to raise_error ActiveRecord::RecordNotFound
        end
      end

      context 'when params are empty' do
        let(:params) { {} }

        it_behaves_like 'only removes cluster'
      end

      context 'when cleanup param is false' do
        let(:params) { { cleanup: 'false' } }

        it_behaves_like 'only removes cluster'
      end

      context 'when cleanup param is true' do
        let(:params) { { cleanup: 'true' } }

        before do
          allow(Clusters::Cleanup::ProjectNamespaceWorker).to receive(:perform_async)
        end

        it 'does not destroy cluster' do
          subject
          expect(Clusters::Cluster.where(id: cluster.id).exists?).not_to be_falsey
        end

        it 'transition cluster#cleanup_status from cleanup_not_started to cleanup_removing_project_namespaces' do
          expect { subject }.to change { cluster.cleanup_status_name }
            .from(:cleanup_not_started)
            .to(:cleanup_removing_project_namespaces)
        end
      end
    end
  end
end