refactor: mutualize email_expert logic

This commit is contained in:
simon lehericey 2024-04-16 11:12:32 +02:00
parent 71b0592b0a
commit 5cd780251b
No known key found for this signature in database
GPG key ID: CDE670D827C7B3C5
5 changed files with 42 additions and 31 deletions

View file

@ -83,11 +83,7 @@ module Experts
def avis_new def avis_new
@new_avis = Avis.new @new_avis = Avis.new
if @dossier.procedure.experts_require_administrateur_invitation? @experts_emails = Expert.autocomplete_mails(@dossier.procedure)
@experts_emails = @dossier.procedure.experts_procedures.where(revoked_at: nil).map { _1.expert.email }.sort
else
@experts_emails = @dossier.procedure.experts.map(&:email).sort
end
end end
def create_avis def create_avis

View file

@ -64,21 +64,13 @@ module Instructeurs
def avis def avis
@avis_seen_at = current_instructeur.follows.find_by(dossier: dossier)&.avis_seen_at @avis_seen_at = current_instructeur.follows.find_by(dossier: dossier)&.avis_seen_at
@avis = Avis.new @avis = Avis.new
if @dossier.procedure.experts_require_administrateur_invitation? @experts_emails = Expert.autocomplete_mails(@dossier.procedure)
@experts_emails = dossier.procedure.experts_procedures.where(revoked_at: nil).map(&:expert).map(&:email).sort
else
@experts_emails = @dossier.procedure.experts.map(&:email).sort
end
end end
def avis_new def avis_new
@avis_seen_at = current_instructeur.follows.find_by(dossier: dossier)&.avis_seen_at @avis_seen_at = current_instructeur.follows.find_by(dossier: dossier)&.avis_seen_at
@avis = Avis.new @avis = Avis.new
if @dossier.procedure.experts_require_administrateur_invitation? @experts_emails = Expert.autocomplete_mails(@dossier.procedure)
@experts_emails = dossier.procedure.experts_procedures.where(revoked_at: nil).map(&:expert).map(&:email).sort
else
@experts_emails = @dossier.procedure.experts.map(&:email).sort
end
end end
def personnes_impliquees def personnes_impliquees

View file

@ -29,6 +29,14 @@ class Expert < ApplicationRecord
end end
end end
def self.autocomplete_mails(procedure)
if procedure.experts_require_administrateur_invitation?
procedure.experts_procedures.where(revoked_at: nil).map(&:expert).map(&:email).sort
else
procedure.experts.map(&:email).sort
end
end
def merge(old_expert) def merge(old_expert)
return if old_expert.nil? return if old_expert.nil?

View file

@ -355,26 +355,12 @@ describe Experts::AvisController, type: :controller do
end end
describe '#avis_new' do describe '#avis_new' do
let!(:revoked_expert) { create(:experts_procedure, revoked_at: 2.days.ago, procedure: procedure, expert: create(:expert)).expert }
before do before do
allow(Expert).to receive(:autocomplete_mails).and_return([])
get :avis_new, params: { procedure_id: procedure.id, id: avis_without_answer.id } get :avis_new, params: { procedure_id: procedure.id, id: avis_without_answer.id }
end end
context 'when procedure experts need administrateur invitation' do
let!(:procedure) { create(:procedure, experts_require_administrateur_invitation: true) }
it 'limit invited email list to not revoked experts' do it { expect(Expert).to have_received(:autocomplete_mails).with(procedure) }
expect(assigns(:experts_emails)).to include(experts_procedure.expert.user.email)
expect(assigns(:experts_emails)).not_to include(revoked_expert.user.email)
end
end
context 'when procedure experts can be anyone' do
let!(:procedure) { create(:procedure, experts_require_administrateur_invitation: false) }
it 'prefill autocomplete with all experts in the procedure' do
expect(assigns(:experts_emails)).to include(experts_procedure.expert.user.email)
expect(assigns(:experts_emails)).to include(revoked_expert.user.email)
end
end
end end
describe '#create_avis' do describe '#create_avis' do

View file

@ -94,4 +94,33 @@ RSpec.describe Expert, type: :model do
end end
end end
end end
describe '.autocomplete_mails' do
subject { Expert.autocomplete_mails(procedure) }
let(:procedure) { create(:procedure, experts_require_administrateur_invitation: true) }
let(:expert) { create(:expert) }
let(:revoked_expert) { create(:expert) }
before do
procedure.experts << expert << revoked_expert
ExpertsProcedure.find_by(expert: revoked_expert, procedure: procedure)
.update!(revoked_at: 1.day.ago)
end
context 'when procedure experts need administrateur invitation' do
it 'returns only not revoked experts' do
expect(subject).to eq([expert.user.email])
end
end
context 'when procedure experts can be anyone' do
let(:procedure) { create(:procedure, experts_require_administrateur_invitation: false) }
it 'prefill autocomplete with all experts in the procedure' do
expect(subject).to eq([expert.user.email, revoked_expert.user.email])
end
end
end
end end