Merge pull request #7757 from betagouv/7738-fix-delete-administrateur

fix: remove instructeur when admin is removed
This commit is contained in:
Colin Darie 2022-09-13 10:28:57 +02:00 committed by GitHub
commit f55bf4c451
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 31 additions and 3 deletions

View file

@ -73,6 +73,14 @@ module Manager
if administrateur.present?
procedure.administrateurs.delete(administrateur)
end
instructeur = Instructeur.by_email(current_super_admin.email)
if instructeur.present?
procedure.groupe_instructeurs.map do |groupe_instructeur|
groupe_instructeur.assign_tos.where(instructeur: instructeur).destroy_all
end
end
redirect_to manager_procedure_path(procedure)
end

View file

@ -72,11 +72,31 @@ describe Manager::ProceduresController, type: :controller do
describe '#delete_administrateur' do
let(:procedure) { create(:procedure, :with_service, administrateurs: [administrateur, autre_administrateur]) }
let(:administrateur) { create(:administrateur, email: super_admin.email) }
subject(:delete_request) { put :delete_administrateur, params: { id: procedure.id } }
it "removes the current administrateur from the procedure" do
delete_request
expect(procedure.administrateurs).to eq([autre_administrateur])
end
context 'when the current administrateur has been added as instructeur too' do
let(:instructeur) { create(:instructeur) }
let(:administrateur) { create(:administrateur, email: super_admin.email, instructeur: instructeur) }
before do
put :delete_administrateur, params: { id: procedure.id }
procedure.groupe_instructeurs.map do |groupe_instructeur|
instructeur.assign_to.create!(groupe_instructeur: groupe_instructeur, manager: true)
end
end
it { expect(procedure.administrateurs).to eq([autre_administrateur]) }
it "removes the instructeur from the procedure" do
delete_request
instructeur.groupe_instructeurs.each do |groupe_instructeur|
expect(groupe_instructeur.instructeurs).not_to include(instructeur)
end
end
end
end
end