refactor: mutualize email_expert logic
This commit is contained in:
parent
71b0592b0a
commit
5cd780251b
5 changed files with 42 additions and 31 deletions
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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?
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in a new issue