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) }
|
|
|
|
|
2021-10-25 15:50:48 +02:00
|
|
|
describe 'associations' do
|
2023-10-24 17:45:20 +02:00
|
|
|
it { is_expected.to have_many(:commentaire_groupe_gestionnaires) }
|
2024-02-07 17:19:50 +01:00
|
|
|
it { is_expected.to have_many(:archives) }
|
|
|
|
it { is_expected.to have_many(:exports) }
|
2019-08-06 11:02:54 +02:00
|
|
|
it { is_expected.to have_and_belong_to_many(:instructeurs) }
|
2023-09-04 12:07:04 +02:00
|
|
|
it { is_expected.to belong_to(:groupe_gestionnaire).optional }
|
2015-11-10 10:23:15 +01:00
|
|
|
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
|
2024-06-01 22:50:48 +02:00
|
|
|
let!(:administrateur) { administrateurs(:default_admin) }
|
2020-01-08 16:08:47 +01:00
|
|
|
let!(:autre_administrateur) { create(:administrateur) }
|
|
|
|
let!(:procedure) { create(:procedure, administrateurs: [administrateur, autre_administrateur]) }
|
|
|
|
|
|
|
|
it { is_expected.to be true }
|
|
|
|
end
|
|
|
|
|
2023-10-05 11:23:46 +02:00
|
|
|
context "when the administrateur has a procedure with dossiers where they is the only admin" do
|
2024-06-01 22:50:48 +02:00
|
|
|
let!(:administrateur) { administrateurs(:default_admin) }
|
2023-10-05 11:23:46 +02:00
|
|
|
let!(:procedure) { create(:procedure_with_dossiers, administrateurs: [administrateur]) }
|
2020-02-03 16:33:47 +01:00
|
|
|
|
|
|
|
it { is_expected.to be false }
|
|
|
|
end
|
|
|
|
|
2023-10-05 11:23:46 +02:00
|
|
|
context "when the administrateur has a procedure with dossiers and with other admins" do
|
2024-06-01 22:50:48 +02:00
|
|
|
let!(:administrateur) { administrateurs(:default_admin) }
|
2023-10-05 11:23:46 +02:00
|
|
|
let!(:administrateur2) { create(:administrateur) }
|
|
|
|
let!(:procedure) { create(:procedure_with_dossiers, administrateurs: [administrateur, administrateur2]) }
|
|
|
|
|
|
|
|
it { is_expected.to be true }
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the administrateur has a procedure without dossiers" do
|
2024-06-01 22:50:48 +02:00
|
|
|
let!(:administrateur) { administrateurs(:default_admin) }
|
2023-10-05 11:23:46 +02:00
|
|
|
let!(:procedure) { create(:procedure, administrateurs: [administrateur]) }
|
|
|
|
|
|
|
|
it { is_expected.to be true }
|
|
|
|
end
|
|
|
|
|
2020-01-08 16:08:47 +01:00
|
|
|
context "when the administrateur has no procedure" do
|
2024-06-01 22:50:48 +02:00
|
|
|
let!(:administrateur) { administrateurs(:default_admin) }
|
2020-01-08 16:08:47 +01:00
|
|
|
|
|
|
|
it { is_expected.to be true }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2021-10-18 13:10:35 +02:00
|
|
|
describe '#merge' do
|
2024-06-01 22:50:48 +02:00
|
|
|
let(:new_admin) { administrateurs(:default_admin) }
|
2021-10-18 13:10:35 +02:00
|
|
|
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) }
|
2022-11-07 14:11:05 +01:00
|
|
|
let(:discarded_procedure) { create(:procedure, :discarded) }
|
2021-10-18 13:10:35 +02:00
|
|
|
|
|
|
|
before do
|
2022-11-07 14:11:05 +01:00
|
|
|
old_admin.procedures << procedure << discarded_procedure
|
2021-10-18 13:10:35 +02:00
|
|
|
subject
|
|
|
|
[new_admin, old_admin].map(&:reload)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'transfers the procedure' do
|
2022-11-07 14:11:05 +01:00
|
|
|
expect(new_admin.procedures.with_discarded).to match_array([procedure, discarded_procedure])
|
|
|
|
expect(old_admin.procedures.with_discarded).to be_empty
|
2021-10-18 13:10:35 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when both admins share a procedure' do
|
2024-06-01 22:50:48 +02:00
|
|
|
let(:procedure) { create(:procedure, administrateurs: [old_admin, new_admin]) }
|
2021-10-18 13:10:35 +02:00
|
|
|
|
|
|
|
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
|
|
|
|
|
2022-10-19 16:53:38 +02:00
|
|
|
context 'when both admins have a service with the same name' do
|
2023-04-04 15:57:51 +02:00
|
|
|
let!(:service_1) { create(:service, nom: 'S', administrateur: old_admin) }
|
|
|
|
let!(:service_2) { create(:service, nom: 'S', administrateur: new_admin) }
|
|
|
|
let!(:procedure_1) { create(:procedure, service: service_1) }
|
2022-10-19 16:53:38 +02:00
|
|
|
|
2023-04-04 15:57:51 +02:00
|
|
|
it 'removes the service from the old one' do
|
2022-10-19 16:53:38 +02:00
|
|
|
subject
|
|
|
|
[new_admin, old_admin, service_2].map(&:reload)
|
|
|
|
|
|
|
|
expect(old_admin.services).to be_empty
|
|
|
|
expect(service_2.procedures).to include(procedure_1)
|
|
|
|
end
|
2023-04-04 15:57:51 +02:00
|
|
|
|
|
|
|
context 'and a discarded procedure use this service' do
|
|
|
|
let!(:procedure_1) { create(:procedure, :discarded, service: service_1) }
|
|
|
|
let!(:procedure_2) { create(:procedure, :discarded, service: service_1) }
|
|
|
|
|
|
|
|
it 'transfers old service to targeted_administrateur' do
|
|
|
|
expect { subject }.not_to raise_error
|
|
|
|
end
|
|
|
|
end
|
2022-10-19 16:53:38 +02:00
|
|
|
end
|
|
|
|
|
2021-10-18 13:10:35 +02:00
|
|
|
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
|
|
|
|
|
2023-07-17 15:40:38 +02:00
|
|
|
context 'when the old admin has an v3 api token' do
|
2023-06-28 13:37:33 +02:00
|
|
|
let(:old_admin) { create(:administrateur, :with_api_token) }
|
|
|
|
|
|
|
|
it 'transferts the api token' do
|
2023-07-17 15:40:38 +02:00
|
|
|
token = old_admin.api_tokens.first
|
2023-06-28 13:37:33 +02:00
|
|
|
subject
|
|
|
|
expect(new_admin.api_tokens.count).to eq 1
|
2023-07-17 15:40:38 +02:00
|
|
|
expect(new_admin.api_tokens.first).to eq token
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the old admin has an old api token' do
|
|
|
|
let(:old_admin) { create(:administrateur, :with_api_token) }
|
|
|
|
|
|
|
|
it 'does not transfer the api token' do
|
|
|
|
old_admin.api_tokens.first.update(version: 2)
|
|
|
|
subject
|
|
|
|
expect(new_admin.api_tokens.count).to eq 0
|
2023-06-28 13:37:33 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2021-10-18 13:10:35 +02:00
|
|
|
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
|
2022-05-02 14:32:12 +02:00
|
|
|
|
|
|
|
describe 'unused' do
|
|
|
|
subject { Administrateur.unused }
|
|
|
|
|
2024-06-01 22:50:48 +02:00
|
|
|
let(:new_admin) { administrateurs(:default_admin) }
|
2023-08-01 12:30:23 +02:00
|
|
|
let(:unused_admin) { create(:administrateur, :with_api_token) }
|
2022-05-02 14:32:12 +02:00
|
|
|
|
|
|
|
before do
|
|
|
|
new_admin.user.update(last_sign_in_at: (6.months - 1.day).ago)
|
|
|
|
unused_admin.user.update(last_sign_in_at: (6.months + 1.day).ago)
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to match([unused_admin]) }
|
|
|
|
|
|
|
|
context 'with a hidden procedure' do
|
|
|
|
let(:procedure) { create(:procedure, hidden_at: 1.month.ago) }
|
|
|
|
|
|
|
|
before { unused_admin.procedures << procedure }
|
|
|
|
|
|
|
|
it { is_expected.to be_empty }
|
|
|
|
end
|
|
|
|
|
2023-08-01 12:30:23 +02:00
|
|
|
context 'with a with_api_token on api v1' do
|
|
|
|
before { unused_admin.api_tokens.first.touch(:last_v1_authenticated_at) }
|
|
|
|
|
|
|
|
it { is_expected.to be_empty }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with a with_api_token on api v2' do
|
|
|
|
before { unused_admin.api_tokens.first.touch(:last_v2_authenticated_at) }
|
|
|
|
|
|
|
|
it { is_expected.to be_empty }
|
|
|
|
end
|
|
|
|
|
2022-05-02 14:32:12 +02:00
|
|
|
context 'with a service' do
|
|
|
|
let(:service) { create(:service) }
|
|
|
|
|
|
|
|
before { unused_admin.services << service }
|
|
|
|
|
|
|
|
it { is_expected.to be_empty }
|
|
|
|
end
|
2023-07-24 17:55:33 +02:00
|
|
|
|
|
|
|
context 'with a custom longer threshold period' do
|
|
|
|
before { stub_const("Administrateur::UNUSED_ADMIN_THRESHOLD", 7.months) }
|
|
|
|
|
|
|
|
it { is_expected.to be_empty }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with a custom shorter threshold period' do
|
|
|
|
before { stub_const("Administrateur::UNUSED_ADMIN_THRESHOLD", 5.months) }
|
|
|
|
|
2023-07-25 12:49:13 +02:00
|
|
|
it { is_expected.to match_array([new_admin, unused_admin]) }
|
2023-07-24 17:55:33 +02:00
|
|
|
end
|
2022-05-02 14:32:12 +02:00
|
|
|
end
|
2022-10-24 16:03:49 +02:00
|
|
|
|
|
|
|
describe 'zones' do
|
2024-06-01 22:50:48 +02:00
|
|
|
let(:admin) { administrateurs(:default_admin) }
|
2022-10-24 16:03:49 +02:00
|
|
|
let(:zone1) { create(:zone) }
|
|
|
|
let(:zone2) { create(:zone) }
|
|
|
|
let!(:procedure) { create(:procedure, administrateurs: [admin], zones: [zone1, zone2]) }
|
|
|
|
|
|
|
|
it 'return zones of procedures that the admin is associated' do
|
|
|
|
expect(admin.zones).to eq [zone1, zone2]
|
|
|
|
end
|
|
|
|
end
|
2023-11-06 14:55:31 +01:00
|
|
|
|
|
|
|
describe "#unread_commentaires?" do
|
|
|
|
context "commentaire_seen_at is nil" do
|
|
|
|
let(:gestionnaire) { create(:gestionnaire) }
|
2024-06-01 22:50:48 +02:00
|
|
|
let(:administrateur) { administrateurs(:default_admin) }
|
2023-11-06 14:55:31 +01:00
|
|
|
let(:groupe_gestionnaire) { create(:groupe_gestionnaire, gestionnaires: [gestionnaire]) }
|
|
|
|
let!(:commentaire_groupe_gestionnaire) { create(:commentaire_groupe_gestionnaire, groupe_gestionnaire: groupe_gestionnaire, sender: administrateur, gestionnaire: gestionnaire, created_at: 12.hours.ago) }
|
|
|
|
|
|
|
|
it do
|
|
|
|
expect(administrateur.unread_commentaires?).to eq true
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "commentaire_seen_at before last commentaire" do
|
|
|
|
let(:gestionnaire) { create(:gestionnaire) }
|
|
|
|
let(:administrateur) { create(:administrateur, commentaire_seen_at: 1.day.ago) }
|
|
|
|
let(:groupe_gestionnaire) { create(:groupe_gestionnaire, gestionnaires: [gestionnaire]) }
|
|
|
|
let!(:commentaire_groupe_gestionnaire) { create(:commentaire_groupe_gestionnaire, groupe_gestionnaire: groupe_gestionnaire, sender: administrateur, gestionnaire: gestionnaire, created_at: 12.hours.ago) }
|
|
|
|
|
|
|
|
it do
|
|
|
|
expect(administrateur.unread_commentaires?).to eq true
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "commentaire_seen_at after last commentaire" do
|
|
|
|
let(:gestionnaire) { create(:gestionnaire) }
|
|
|
|
let(:administrateur) { create(:administrateur, commentaire_seen_at: 1.hour.ago) }
|
|
|
|
let(:groupe_gestionnaire) { create(:groupe_gestionnaire, gestionnaires: [gestionnaire]) }
|
|
|
|
let!(:commentaire_groupe_gestionnaire) { create(:commentaire_groupe_gestionnaire, groupe_gestionnaire: groupe_gestionnaire, sender: administrateur, gestionnaire: gestionnaire, created_at: 12.hours.ago) }
|
|
|
|
|
|
|
|
it do
|
|
|
|
expect(administrateur.unread_commentaires?).to eq false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "#mark_commentaire_as_seen" do
|
|
|
|
let(:now) { Time.zone.now.beginning_of_minute }
|
|
|
|
let(:gestionnaire) { create(:gestionnaire) }
|
2024-06-01 22:50:48 +02:00
|
|
|
let(:administrateur) { administrateurs(:default_admin) }
|
2023-11-06 14:55:31 +01:00
|
|
|
let(:groupe_gestionnaire) { create(:groupe_gestionnaire, gestionnaires: [gestionnaire]) }
|
|
|
|
let!(:commentaire_groupe_gestionnaire) { create(:commentaire_groupe_gestionnaire, groupe_gestionnaire: groupe_gestionnaire, sender: administrateur, created_at: 12.hours.ago) }
|
|
|
|
|
|
|
|
before do
|
2023-12-10 18:25:58 +01:00
|
|
|
travel_to(now) do
|
2023-11-06 14:55:31 +01:00
|
|
|
administrateur.mark_commentaire_as_seen
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it { expect(administrateur.commentaire_seen_at).to eq now }
|
|
|
|
end
|
2015-10-23 16:19:55 +02:00
|
|
|
end
|