[#10951] Create a cron job to warn user that old brouillon is deleted

This commit is contained in:
Mathieu Magnin 2024-11-19 16:55:23 +01:00
parent 38e9ca4979
commit 5ab0899a49
No known key found for this signature in database
GPG key ID: 8DCAFC82D7BA654E
6 changed files with 84 additions and 1 deletions

View file

@ -0,0 +1,15 @@
# frozen_string_literal: true
class Cron::PurgeOldBrouillonDossiersJob < Cron::CronJob
self.schedule_expression = "every day at 08:30"
def perform
Dossier
.state_brouillon
.where(updated_at: ..(3.months + 2.weeks).ago)
.find_each do |dossier|
dossier.hide_and_keep_track!(:automatic, :not_modified_for_a_long_time)
DossierMailer.notify_old_brouillon_after_deletion(dossier).deliver_later
end
end
end

View file

@ -567,7 +567,7 @@ class Dossier < ApplicationRecord
end end
def can_be_deleted_by_automatic?(reason) def can_be_deleted_by_automatic?(reason)
reason == :expired && !en_instruction? reason == :expired && !en_instruction? || reason == :not_modified_for_a_long_time && brouillon?
end end
def can_terminer_automatiquement_by_sva_svr? def can_terminer_automatiquement_by_sva_svr?

View file

@ -0,0 +1,9 @@
- content_for(:title, "#{@subject}")
%p= t(:hello, scope: [:views, :shared, :greetings])
%p= t('.body', dossier_id: @dossier.id, libelle_demarche: @dossier.procedure.libelle)
%p= t('.new_dossier_html', link: commencer_url(@dossier.procedure))
= render partial: "layouts/mailers/signature"

View file

@ -0,0 +1,8 @@
en:
dossier_mailer:
notify_old_brouillon_after_deletion:
subject: 'Your draft application n°%{dossier_id} has been deleted due to inactivity'
body: |
Your application n° %{dossier_id} for "%{libelle_demarche}" has been automatically deleted as it had not been modified for more than 3 months.
new_dossier_html: |
If you wish to submit a new application for this procedure, you can <a href="%{link}">click here</a>.

View file

@ -0,0 +1,8 @@
fr:
dossier_mailer:
notify_old_brouillon_after_deletion:
subject: "Votre dossier n°%{dossier_id} en brouillon a été supprimé pour cause d'inactivité"
body: |
Votre dossier n° %{dossier_id} pour la démarche "%{libelle_demarche}" n'ayant pas été modifié depuis plus de 3 mois a été supprimé automatiquement.
new_dossier_html: |
Si vous souhaitez déposer un nouveau dossier pour cette démarche, vous pouvez <a href="%{link}">cliquer ici</a>.

View file

@ -0,0 +1,43 @@
# frozen_string_literal: true
RSpec.describe Cron::PurgeOldBrouillonDossiersJob, type: :job do
let(:procedure) { create(:procedure) }
let!(:recent_brouillon) { travel_to(3.months.ago) { create(:dossier, :brouillon, procedure: procedure) } }
let!(:old_brouillon) { travel_to(5.months.ago) { create(:dossier, :brouillon, procedure: procedure) } }
let!(:very_old_brouillon) { travel_to(6.months.ago) { create(:dossier, :brouillon, procedure: procedure) } }
let!(:old_en_construction) { travel_to(5.months.ago) { create(:dossier, :en_construction, procedure: procedure) } }
subject(:perform_job) { described_class.perform_now }
describe '#perform' do
before do
allow(DossierMailer).to receive(:notify_old_brouillon_after_deletion).and_return(double(deliver_later: true))
end
it 'hides only old brouillon dossiers' do
expect { perform_job }.to change { Dossier.visible_by_user.count }.by(-2)
expect(Dossier.visible_by_user.pluck(:id)).to match_array([recent_brouillon.id, old_en_construction.id])
end
it 'sends notification emails for each hidden dossier' do
perform_job
expect(DossierMailer).to have_received(:notify_old_brouillon_after_deletion).with(old_brouillon).once
expect(DossierMailer).to have_received(:notify_old_brouillon_after_deletion).with(very_old_brouillon).once
expect(DossierMailer).not_to have_received(:notify_old_brouillon_after_deletion).with(recent_brouillon)
expect(DossierMailer).not_to have_received(:notify_old_brouillon_after_deletion).with(old_en_construction)
end
it 'sets the correct hidden_by attributes' do
perform_job
[old_brouillon, very_old_brouillon].each do |dossier|
dossier.reload
expect(dossier.hidden_by_expired_at).to be_present
expect(dossier.hidden_by_reason).to eq("not_modified_for_a_long_time")
end
end
end
end