demarches-normaliennes/spec/jobs/cron/discarded_dossiers_deletion_job_spec.rb
2024-08-22 09:26:48 +02:00

94 lines
3.1 KiB
Ruby

# frozen_string_literal: true
RSpec.describe Cron::DiscardedDossiersDeletionJob, type: :job do
describe '#perform' do
let(:instructeur) { create(:instructeur) }
let(:dossier) { create(:dossier, :with_individual, state) }
let(:dossier_2) { create(:dossier, :with_individual, state) }
before do
# hack to add passer_en_instruction and supprimer to dossier.dossier_operation_logs
dossier.send(:log_dossier_operation, instructeur, :passer_en_instruction, dossier)
dossier.send(:log_dossier_operation, instructeur, :supprimer, dossier)
dossier.update_columns(hidden_by_user_at: hidden_at, hidden_by_administration_at: hidden_at)
dossier.update_column(:hidden_by_reason, "user_request")
dossier_2.update_columns(hidden_by_expired_at: hidden_at)
dossier_2.update_column(:hidden_by_reason, "expired")
end
subject do
Cron::DiscardedDossiersDeletionJob.perform_now
end
def operations_left
DossierOperationLog.where(dossier_id: dossier.id).pluck(:operation)
end
RSpec.shared_examples "does not delete" do
before { subject }
it 'does not delete it' do
expect { dossier.reload }.not_to raise_error
expect { dossier_2.reload }.not_to raise_error
end
it 'does not delete its operations logs' do
expect(operations_left).to match_array(["passer_en_instruction", "supprimer"])
end
end
RSpec.shared_examples "does delete" do
before { subject }
it 'does delete it' do
expect { dossier.reload }.to raise_error(ActiveRecord::RecordNotFound)
expect { dossier_2.reload }.to raise_error(ActiveRecord::RecordNotFound)
end
it 'deletes its operations logs except supprimer' do
expect(operations_left).to eq(["supprimer"])
end
end
[:en_construction, :en_instruction, :accepte, :refuse, :sans_suite].each do |state|
context "with a dossier #{state}" do
let(:state) { state }
context 'not hidden' do
let(:hidden_at) { nil }
include_examples "does not delete"
end
context 'hidden not so long ago' do
let(:hidden_at) { 1.week.ago + 1.hour }
include_examples "does not delete"
end
end
end
[:en_construction, :accepte, :refuse, :sans_suite].each do |state|
context "with a dossier #{state}" do
let(:state) { state }
context 'hidden long ago' do
let(:hidden_at) { 1.week.ago - 1.hour }
include_examples "does delete"
end
end
end
context "error on error" do
let(:state) { :en_construction }
let(:hidden_at) { 1.month.ago }
let(:failing_dossier) { create(:dossier, :en_construction, hidden_by_user_at: 5.weeks.ago, hidden_by_reason: "user_request") }
before do
failing_dossier.update_column(:hidden_by_reason, nil) # recurrent error previously causing job to crash
expect(Sentry).to receive(:capture_exception).with(instance_of(KeyError), extra: { dossier: failing_dossier.id })
end
include_examples "does delete"
end
end
end