Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'spec/workers/environments/auto_delete_cron_worker_spec.rb')
-rw-r--r--spec/workers/environments/auto_delete_cron_worker_spec.rb105
1 files changed, 105 insertions, 0 deletions
diff --git a/spec/workers/environments/auto_delete_cron_worker_spec.rb b/spec/workers/environments/auto_delete_cron_worker_spec.rb
new file mode 100644
index 00000000000..b18f3da5d10
--- /dev/null
+++ b/spec/workers/environments/auto_delete_cron_worker_spec.rb
@@ -0,0 +1,105 @@
+# frozen_string_literal: true
+
+require 'spec_helper'
+
+RSpec.describe Environments::AutoDeleteCronWorker do
+ include CreateEnvironmentsHelpers
+
+ let(:worker) { described_class.new }
+
+ describe '#perform' do
+ subject { worker.perform }
+
+ let_it_be(:project) { create(:project, :repository) }
+
+ let!(:environment) { create(:environment, :auto_deletable, project: project) }
+
+ it 'deletes the environment' do
+ expect { subject }.to change { Environment.count }.by(-1)
+ end
+
+ context 'when environment is not stopped' do
+ let!(:environment) { create(:environment, :available, auto_delete_at: 1.day.ago, project: project) }
+
+ it 'does not delete the environment' do
+ expect { subject }.not_to change { Environment.count }
+ end
+ end
+
+ context 'when auto_delete_at is null' do
+ let!(:environment) { create(:environment, :stopped, auto_delete_at: nil, project: project) }
+
+ it 'does not delete the environment' do
+ expect { subject }.not_to change { Environment.count }
+ end
+ end
+
+ context 'with multiple deletable environments' do
+ let!(:other_environment) { create(:environment, :auto_deletable, project: project) }
+
+ it 'deletes all deletable environments' do
+ expect { subject }.to change { Environment.count }.by(-2)
+ end
+
+ context 'when loop reached loop limit' do
+ before do
+ stub_const("#{described_class}::LOOP_LIMIT", 1)
+ stub_const("#{described_class}::BATCH_SIZE", 1)
+ end
+
+ it 'deletes only one deletable environment' do
+ expect { subject }.to change { Environment.count }.by(-1)
+ end
+ end
+
+ context 'when batch size is less than the number of environments' do
+ before do
+ stub_const("#{described_class}::BATCH_SIZE", 1)
+ end
+
+ it 'deletes all deletable environments' do
+ expect { subject }.to change { Environment.count }.by(-2)
+ end
+ end
+ end
+
+ context 'with multiple deployments' do
+ it 'deletes the deployment records and refs' do
+ deployment_1 = create(:deployment, environment: environment, project: project)
+ deployment_2 = create(:deployment, environment: environment, project: project)
+ deployment_1.create_ref
+ deployment_2.create_ref
+
+ expect(project.repository.commit(deployment_1.ref_path)).to be_present
+ expect(project.repository.commit(deployment_2.ref_path)).to be_present
+
+ expect { subject }.to change { Deployment.count }.by(-2)
+
+ expect(project.repository.commit(deployment_1.ref_path)).not_to be_present
+ expect(project.repository.commit(deployment_2.ref_path)).not_to be_present
+ end
+ end
+
+ context 'when loop reached timeout' do
+ before do
+ stub_const("#{described_class}::LOOP_TIMEOUT", 0.seconds)
+ stub_const("#{described_class}::LOOP_LIMIT", 100_000)
+ allow_next_instance_of(described_class) do |worker|
+ allow(worker).to receive(:destroy_in_batch) { true }
+ end
+ end
+
+ it 'does not delete the environment' do
+ expect { subject }.not_to change { Environment.count }
+ end
+ end
+
+ context 'with idempotent flag' do
+ include_examples 'an idempotent worker' do
+ it 'deletes the environment' do
+ expect { subject }.to change { Environment.count }.by(-1)
+ end
+ end
+ end
+ end
+end