# frozen_string_literal: true require 'spec_helper' require_migration! RSpec.describe RescheduleDeleteOrphanedDeployments, :sidekiq, schema: 20210617161348 do let!(:namespace) { table(:namespaces).create!(name: 'user', path: 'user') } let!(:project) { table(:projects).create!(namespace_id: namespace.id) } let!(:environment) { table(:environments).create!(name: 'production', slug: 'production', project_id: project.id) } let(:background_migration_jobs) { table(:background_migration_jobs) } before do create_deployment!(environment.id, project.id) create_deployment!(environment.id, project.id) create_deployment!(environment.id, project.id) create_deployment!(non_existing_record_id, project.id) create_deployment!(non_existing_record_id, project.id) create_deployment!(non_existing_record_id, project.id) create_deployment!(non_existing_record_id, project.id) stub_const("#{described_class}::BATCH_SIZE", 1) end it 'steal existing background migration jobs' do expect(Gitlab::BackgroundMigration).to receive(:steal).with('DeleteOrphanedDeployments') migrate! end it 'cleans up background migration jobs tracking records' do old_successful_job = background_migration_jobs.create!( class_name: 'DeleteOrphanedDeployments', status: Gitlab::Database::BackgroundMigrationJob.statuses[:succeeded], arguments: [table(:deployments).minimum(:id), table(:deployments).minimum(:id)] ) old_pending_job = background_migration_jobs.create!( class_name: 'DeleteOrphanedDeployments', status: Gitlab::Database::BackgroundMigrationJob.statuses[:pending], arguments: [table(:deployments).maximum(:id), table(:deployments).maximum(:id)] ) migrate! expect { old_successful_job.reload }.to raise_error(ActiveRecord::RecordNotFound) expect { old_pending_job.reload }.to raise_error(ActiveRecord::RecordNotFound) end it 'schedules DeleteOrphanedDeployments background jobs' do Sidekiq::Testing.fake! do freeze_time do migrate! expect(BackgroundMigrationWorker.jobs.size).to eq(7) table(:deployments).find_each do |deployment| expect(described_class::MIGRATION).to be_scheduled_migration(deployment.id, deployment.id) end end end end def create_deployment!(environment_id, project_id) table(:deployments).create!( environment_id: environment_id, project_id: project_id, ref: 'master', tag: false, sha: 'x', status: 1, iid: table(:deployments).count + 1) end end