Merge pull request #11072 from demarches-simplifiees/fix-11071

ETQ Dev, si un expert invite un autre Expert sur un dossier lié à un autre dossier, je ne veux pas avoir de données incohérentes en base
This commit is contained in:
Mathieu Magnin 2024-11-26 10:03:14 +00:00 committed by GitHub
commit d79a80c711
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
4 changed files with 148 additions and 2 deletions

View file

@ -0,0 +1,83 @@
# frozen_string_literal: true
module Maintenance
RSpec.describe FixAvisExpertsProcedureMismatchTask do
describe "#collection" do
subject(:collection) { described_class.new.collection }
let!(:mismatched_avis) do
expert = create(:expert)
procedure1 = create(:procedure)
procedure2 = create(:procedure)
dossier = create(:dossier, procedure: procedure2)
wrong_experts_procedure = create(:experts_procedure, expert: expert, procedure: procedure1)
create(:avis,
dossier: dossier,
expert: expert,
experts_procedure: wrong_experts_procedure)
end
let!(:correct_avis) do
expert = create(:expert)
procedure = create(:procedure)
dossier = create(:dossier, procedure: procedure)
experts_procedure = create(:experts_procedure, expert: expert, procedure: procedure)
create(:avis,
dossier: dossier,
expert: expert,
experts_procedure: experts_procedure)
end
it "only returns avis with mismatched procedure ids" do
expect(collection).to include(mismatched_avis)
expect(collection).not_to include(correct_avis)
end
end
describe "#process" do
subject(:process) { described_class.process(avis) }
let(:expert) { create(:expert) }
let(:procedure1) { create(:procedure) }
let(:procedure2) { create(:procedure) }
let(:dossier) { create(:dossier, procedure: procedure2) }
let!(:wrong_experts_procedure) do
create(:experts_procedure, expert: expert, procedure: procedure1)
end
let(:avis) do
create(:avis,
dossier: dossier,
expert: expert,
experts_procedure: wrong_experts_procedure)
end
it "fixes the experts_procedure association" do
expect(avis.experts_procedure.procedure_id).to eq(procedure1.id)
expect(avis.dossier.procedure.id).to eq(procedure2.id)
process
avis.reload
expect(avis.experts_procedure.procedure_id).to eq(procedure2.id)
expect(avis.dossier.procedure.id).to eq(procedure2.id)
end
context "when the correct experts_procedure already exists" do
let!(:correct_experts_procedure) do
create(:experts_procedure, expert: expert, procedure: procedure2)
end
it "uses the existing experts_procedure" do
process
avis.reload
expect(avis.experts_procedure).to eq(correct_experts_procedure)
end
end
end
end
end