2015-11-04 17:27:01 +01:00
|
|
|
describe Administrateur, type: :model do
|
2018-05-31 18:07:19 +02:00
|
|
|
let(:administration) { create(:administration) }
|
|
|
|
|
2015-11-10 10:23:15 +01:00
|
|
|
describe 'assocations' do
|
2019-08-06 11:02:54 +02:00
|
|
|
it { is_expected.to have_and_belong_to_many(:instructeurs) }
|
2015-11-10 10:23:15 +01:00
|
|
|
it { is_expected.to have_many(:procedures) }
|
|
|
|
end
|
|
|
|
|
2018-08-24 16:45:43 +02:00
|
|
|
describe "#renew_api_token" do
|
2018-09-26 17:22:36 +02:00
|
|
|
let!(:administrateur) { create(:administrateur) }
|
|
|
|
let!(:token) { administrateur.renew_api_token }
|
2018-08-24 16:45:43 +02:00
|
|
|
|
2018-09-26 17:22:36 +02:00
|
|
|
it { expect(BCrypt::Password.new(administrateur.encrypted_token)).to eq(token) }
|
2018-08-24 16:45:43 +02:00
|
|
|
|
|
|
|
context 'when it s called twice' do
|
2018-09-26 17:22:36 +02:00
|
|
|
let!(:new_token) { administrateur.renew_api_token }
|
2018-08-24 16:45:43 +02:00
|
|
|
|
2018-09-26 17:22:36 +02:00
|
|
|
it { expect(new_token).not_to eq(token) }
|
2018-08-24 16:45:43 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-01-08 16:08:47 +01:00
|
|
|
describe "#can_be_deleted?" do
|
|
|
|
subject { administrateur.can_be_deleted? }
|
|
|
|
|
|
|
|
context "when the administrateur's procedures have other administrateurs" do
|
|
|
|
let!(:administrateur) { create(:administrateur) }
|
|
|
|
let!(:autre_administrateur) { create(:administrateur) }
|
|
|
|
let!(:procedure) { create(:procedure, administrateurs: [administrateur, autre_administrateur]) }
|
|
|
|
|
|
|
|
it { is_expected.to be true }
|
|
|
|
end
|
|
|
|
|
2020-02-03 17:46:24 +01:00
|
|
|
context "when the administrateur has a procedure where they is the only admin" do
|
2020-02-03 16:33:47 +01:00
|
|
|
let!(:administrateur) { create(:administrateur) }
|
|
|
|
let!(:procedure) { create(:procedure, administrateurs: [administrateur]) }
|
|
|
|
|
|
|
|
it { is_expected.to be false }
|
|
|
|
end
|
|
|
|
|
2020-01-08 16:08:47 +01:00
|
|
|
context "when the administrateur has no procedure" do
|
|
|
|
let!(:administrateur) { create(:administrateur) }
|
|
|
|
|
|
|
|
it { is_expected.to be true }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-01-30 10:48:28 +01:00
|
|
|
describe '#delete_and_transfer_services' do
|
|
|
|
let!(:administrateur) { create(:administrateur) }
|
|
|
|
let!(:autre_administrateur) { create(:administrateur) }
|
|
|
|
let!(:procedure) { create(:procedure, :with_service, administrateurs: [administrateur, autre_administrateur]) }
|
|
|
|
let(:service) { procedure.service }
|
|
|
|
|
|
|
|
it "delete and transfer services to other admin" do
|
|
|
|
service.update(administrateur: administrateur)
|
|
|
|
administrateur.delete_and_transfer_services
|
|
|
|
|
|
|
|
expect(Administrateur.find_by(id: administrateur.id)).to be_nil
|
|
|
|
expect(service.reload.administrateur).to eq(autre_administrateur)
|
|
|
|
end
|
2020-03-16 17:07:39 +01:00
|
|
|
|
|
|
|
it "delete service if not associated to procedures" do
|
|
|
|
service_without_procedure = create(:service, administrateur: administrateur)
|
|
|
|
administrateur.delete_and_transfer_services
|
|
|
|
|
|
|
|
expect(Service.find_by(id: service_without_procedure.id)).to be_nil
|
|
|
|
expect(Administrateur.find_by(id: administrateur.id)).to be_nil
|
2020-04-10 17:41:51 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
it "does not delete service if associated to an archived procedure" do
|
|
|
|
service.update(administrateur: administrateur)
|
|
|
|
procedure.discard!
|
|
|
|
administrateur.delete_and_transfer_services
|
|
|
|
|
|
|
|
expect(Service.find_by(id: procedure.service.id)).not_to be_nil
|
|
|
|
expect(Administrateur.find_by(id: administrateur.id)).to be_nil
|
2020-03-16 17:07:39 +01:00
|
|
|
end
|
2020-01-30 10:48:28 +01:00
|
|
|
end
|
2021-10-18 13:10:35 +02:00
|
|
|
|
|
|
|
describe '#merge' do
|
|
|
|
let(:new_admin) { create(:administrateur) }
|
|
|
|
let(:old_admin) { create(:administrateur) }
|
|
|
|
|
|
|
|
subject { new_admin.merge(old_admin) }
|
|
|
|
|
|
|
|
context 'when the old admin does not exist' do
|
|
|
|
let(:old_admin) { nil }
|
|
|
|
|
|
|
|
it { expect { subject }.not_to raise_error }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the old admin has a procedure' do
|
|
|
|
let(:procedure) { create(:procedure) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
old_admin.procedures << procedure
|
|
|
|
subject
|
|
|
|
[new_admin, old_admin].map(&:reload)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'transfers the procedure' do
|
|
|
|
expect(new_admin.procedures).to match_array(procedure)
|
|
|
|
expect(old_admin.procedures).to be_empty
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when both admins share a procedure' do
|
|
|
|
let(:procedure) { create(:procedure) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
new_admin.procedures << procedure
|
|
|
|
old_admin.procedures << procedure
|
|
|
|
subject
|
|
|
|
[new_admin, old_admin].map(&:reload)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'removes the procedure from the old one' do
|
|
|
|
expect(old_admin.procedures).to be_empty
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the old admin has a service' do
|
|
|
|
let(:service) { create(:service, administrateur: old_admin) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
service
|
|
|
|
subject
|
|
|
|
[new_admin, old_admin].map(&:reload)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'transfers the service' do
|
|
|
|
expect(new_admin.services).to match_array(service)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the old admin has an instructeur' do
|
|
|
|
let(:instructeur) { create(:instructeur) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
old_admin.instructeurs << instructeur
|
|
|
|
subject
|
|
|
|
[new_admin, old_admin].map(&:reload)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'transfers the instructeur' do
|
|
|
|
expect(new_admin.instructeurs).to match_array(instructeur)
|
|
|
|
expect(old_admin.instructeurs).to be_empty
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when both admins share an instructeur' do
|
|
|
|
let(:instructeur) { create(:instructeur) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
old_admin.instructeurs << instructeur
|
|
|
|
new_admin.instructeurs << instructeur
|
|
|
|
subject
|
|
|
|
[new_admin, old_admin].map(&:reload)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'transfers the instructeur' do
|
|
|
|
expect(new_admin.instructeurs).to match_array(instructeur)
|
|
|
|
expect(old_admin.instructeurs).to be_empty
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2015-10-23 16:19:55 +02:00
|
|
|
end
|