Merge pull request #10853 from demarches-simplifiees/fix-adding-admin-or-instructor-from-manager

Correctif : ETQ super admin je peux m'ajouter à une démarche si je suis déjà soit administrateur soit instructeur
This commit is contained in:
Eric Leroy-Terquem 2024-09-24 07:14:58 +00:00 committed by GitHub
commit 063a2fc13e
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
3 changed files with 71 additions and 7 deletions

View file

@ -68,18 +68,35 @@ module Manager
def add_administrateur_and_instructeur
administrateur = Administrateur.by_email(current_super_admin.email)
instructeur = Instructeur.by_email(current_super_admin.email)
if administrateur && instructeur
ActiveRecord::Base.transaction do
notices, alerts = [], []
if administrateur
if !AdministrateursProcedure.exists?(procedure: procedure, administrateur: administrateur)
AdministrateursProcedure.create!(procedure: procedure, administrateur: administrateur, manager: true)
end
notices.push "Ladministrateur #{administrateur.email} a été ajouté à la démarche."
else
alerts.push "Ladministrateur #{administrateur.email} est introuvable."
end
if instructeur
procedure.groupe_instructeurs.map do |groupe_instructeur|
if !instructeur.assign_to.exists?(groupe_instructeur: groupe_instructeur)
instructeur.assign_to.create(groupe_instructeur: groupe_instructeur, manager: true)
end
end
flash[:notice] = "Ladministrateur \"#{administrateur.email}\" a été ajouté à la démarche. L'instructeur \"#{instructeur.email}\" a été ajouté aux #{procedure.groupe_instructeurs.count} groupes d'instructeurs"
if procedure.groupe_instructeurs.many?
notices.push "L'instructeur #{instructeur.email} a été ajouté aux #{procedure.groupe_instructeurs.count} groupes d'instructeurs."
else
flash[:alert] = "Ladministrateur \"#{administrateur.email}\" est introuvable."
notices.push "L'instructeur #{instructeur.email} a été ajouté à la démarche."
end
else
alerts.push "L'instructeur #{instructeur.email} est introuvable."
end
flash[:notice] = notices.join(" ") if notices.present?
flash[:alert] = alerts.join(" ") if alerts.present?
redirect_to manager_procedure_path(procedure)
end

View file

@ -77,7 +77,7 @@ as well as a link to its edit page.
<button>Ajouter un administrateur (pour toujours)</button>
<p>J'utilise cette option ETQ support quand un usager a besoin de devenir administrateur sur une démarche</p>
<% end %>
<% if procedure.administrateurs.any? { |admin| admin.email == current_super_admin.email } %>
<% if procedure.administrateurs.any? { |admin| admin.email == current_super_admin.email } && procedure.instructeurs.any? { |instructeur| instructeur.email == current_super_admin.email } %>
<p style="margin-top: 20px;">Vous êtes administrateur de cette démarche. Aller à la démarche
<%= link_to("ETQ admin", admin_procedure_path(procedure), **external_link_attributes) %>
ou

View file

@ -124,4 +124,51 @@ describe Manager::ProceduresController, type: :controller do
end
end
end
describe '#add_administrateur_and_instructeur' do
let(:procedure) { create(:procedure, administrateurs: [autre_administrateur]) }
subject { post :add_administrateur_and_instructeur, params: { id: procedure.id } }
context "when the current super admin is not an administrateur and not an instructeur of the procedure" do
before { administrateur }
it "adds the current super admin as administrateur and instructeur to the procedure" do
subject
expect(procedure.administrateurs).to include(administrateur)
expect(procedure.instructeurs).to include(administrateur.instructeur)
expect(flash[:alert]).to be_nil
expect(flash[:notice]).to eq("Ladministrateur #{administrateur.email} a été ajouté à la démarche. L'instructeur #{administrateur.instructeur.email} a été ajouté à la démarche.")
end
end
context "when the current super admin is an instructor of the procedure but not an administrator" do
let!(:administrateur) { create(:administrateur, email: super_admin.email, instructeur: instructeur) }
let(:instructeur) { create(:instructeur) }
before do
procedure.groupe_instructeurs.map do |groupe_instructeur|
groupe_instructeur.add_instructeurs(emails: [instructeur.email])
end
end
it "adds the current super admin as administrateur to the procedure" do
subject
expect(procedure.administrateurs).to include(administrateur)
expect(procedure.instructeurs).to include(administrateur.instructeur)
expect(flash[:alert]).to be_nil
expect(flash[:notice]).to eq("Ladministrateur #{administrateur.email} a été ajouté à la démarche. L'instructeur #{instructeur.email} a été ajouté à la démarche.")
end
end
context "when the current super admin is an administrator of the procedure but not an instructor" do
let(:procedure) { create(:procedure, administrateurs: [administrateur, autre_administrateur]) }
it "adds the current super admin as instructor to the procedure" do
subject
expect(procedure.administrateurs).to include(administrateur)
expect(procedure.instructeurs).to include(administrateur.instructeur)
expect(flash[:alert]).to be_nil
expect(flash[:notice]).to eq("Ladministrateur #{administrateur.email} a été ajouté à la démarche. L'instructeur #{administrateur.instructeur.email} a été ajouté à la démarche.")
end
end
end
end