2016-11-14 18:36:09 +01:00
|
|
|
require 'spec_helper'
|
2015-09-22 10:15:12 +02:00
|
|
|
|
|
|
|
describe Gestionnaire, type: :model do
|
2016-07-18 18:24:29 +02:00
|
|
|
let(:admin) { create :administrateur }
|
2017-07-18 15:26:33 +02:00
|
|
|
let!(:procedure) { create :procedure, :published, administrateur: admin }
|
|
|
|
let!(:procedure_2) { create :procedure, :published, administrateur: admin }
|
|
|
|
let!(:procedure_3) { create :procedure, :published, administrateur: admin }
|
2018-02-26 17:25:28 +01:00
|
|
|
let(:gestionnaire) { create :gestionnaire, administrateurs: [admin] }
|
2017-01-05 12:44:15 +01:00
|
|
|
let!(:procedure_assign) { create :assign_to, gestionnaire: gestionnaire, procedure: procedure }
|
2016-07-18 18:24:29 +02:00
|
|
|
|
|
|
|
before do
|
|
|
|
create :assign_to, gestionnaire: gestionnaire, procedure: procedure_2
|
|
|
|
end
|
|
|
|
|
2017-07-17 11:28:14 +02:00
|
|
|
describe 'follow' do
|
|
|
|
let(:dossier) { create :dossier }
|
|
|
|
let(:already_followed_dossier) { create :dossier }
|
|
|
|
|
|
|
|
before { gestionnaire.followed_dossiers << already_followed_dossier }
|
|
|
|
|
|
|
|
context 'when a gestionnaire follow a dossier for the first time' do
|
|
|
|
before { gestionnaire.follow(dossier) }
|
|
|
|
|
|
|
|
it { expect(gestionnaire.follow?(dossier)).to be true }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when a gestionnaire follows a dossier already followed' do
|
|
|
|
before { gestionnaire.follow(already_followed_dossier) }
|
|
|
|
|
|
|
|
it { expect(gestionnaire.follow?(already_followed_dossier)).to be true }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-10-05 14:10:49 +02:00
|
|
|
describe '#unfollow' do
|
|
|
|
let(:already_followed_dossier) { create(:dossier) }
|
|
|
|
before { gestionnaire.followed_dossiers << already_followed_dossier }
|
|
|
|
|
|
|
|
context 'when a gestionnaire unfollow a dossier already followed' do
|
|
|
|
before do
|
|
|
|
gestionnaire.unfollow(already_followed_dossier)
|
|
|
|
already_followed_dossier.reload
|
|
|
|
end
|
|
|
|
|
|
|
|
it { expect(gestionnaire.follow?(already_followed_dossier)).to be false }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-07-18 18:24:29 +02:00
|
|
|
describe '#follow?' do
|
|
|
|
let!(:dossier) { create :dossier, procedure: procedure }
|
|
|
|
|
2017-07-17 13:13:20 +02:00
|
|
|
subject { gestionnaire.follow?(dossier) }
|
2016-07-18 18:24:29 +02:00
|
|
|
|
|
|
|
context 'when gestionnaire follow a dossier' do
|
|
|
|
before do
|
|
|
|
create :follow, dossier_id: dossier.id, gestionnaire_id: gestionnaire.id
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to be_truthy }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when gestionnaire not follow a dossier' do
|
|
|
|
it { is_expected.to be_falsey }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-02-20 11:24:32 +01:00
|
|
|
describe "#assign_to_procedure" do
|
|
|
|
subject { gestionnaire.assign_to_procedure(procedure_to_assign) }
|
|
|
|
|
|
|
|
context "with a procedure not already assigned" do
|
|
|
|
let(:procedure_to_assign) { procedure_3 }
|
|
|
|
|
|
|
|
it { is_expected.to be_truthy }
|
|
|
|
it { expect{ subject }.to change(gestionnaire.procedures, :count) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context "with an already assigned procedure" do
|
|
|
|
let(:procedure_to_assign) { procedure }
|
|
|
|
|
|
|
|
it { is_expected.to be_falsey }
|
|
|
|
it { expect{ subject }.not_to change(gestionnaire.procedures, :count) }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "#remove_from_procedure" do
|
|
|
|
subject { gestionnaire.remove_from_procedure(procedure_to_remove) }
|
|
|
|
|
|
|
|
context "with an assigned procedure" do
|
|
|
|
let(:procedure_to_remove) { procedure }
|
|
|
|
let!(:procedure_presentation) { procedure_assign.procedure_presentation }
|
|
|
|
|
|
|
|
it { is_expected.to be_truthy }
|
|
|
|
|
|
|
|
describe "consequences" do
|
|
|
|
before do
|
|
|
|
procedure_assign.build_procedure_presentation
|
|
|
|
procedure_assign.save
|
|
|
|
subject
|
|
|
|
end
|
|
|
|
|
|
|
|
it "removes the assign_to and procedure_presentation" do
|
|
|
|
expect(AssignTo.where(id: procedure_assign).count).to eq(0)
|
|
|
|
expect(ProcedurePresentation.where(assign_to_id: procedure_assign.id).count).to eq(0)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "with an already unassigned procedure" do
|
|
|
|
let(:procedure_to_remove) { procedure_3 }
|
|
|
|
|
|
|
|
it { is_expected.to be_falsey }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-10-18 15:49:04 +02:00
|
|
|
context 'unified login' do
|
|
|
|
it 'syncs credentials to associated user' do
|
|
|
|
gestionnaire = create(:gestionnaire)
|
|
|
|
user = create(:user, email: gestionnaire.email)
|
2016-10-11 10:31:32 +02:00
|
|
|
|
2018-03-02 16:27:03 +01:00
|
|
|
gestionnaire.update(email: 'whoami@plop.com', password: 'super secret')
|
2016-10-18 15:49:04 +02:00
|
|
|
|
|
|
|
user.reload
|
|
|
|
expect(user.email).to eq('whoami@plop.com')
|
|
|
|
expect(user.valid_password?('super secret')).to be(true)
|
|
|
|
end
|
2016-12-07 17:24:01 +01:00
|
|
|
|
|
|
|
it 'syncs credentials to associated administrateur' do
|
|
|
|
gestionnaire = create(:gestionnaire)
|
|
|
|
admin = create(:administrateur, email: gestionnaire.email)
|
|
|
|
|
2018-03-02 16:27:03 +01:00
|
|
|
gestionnaire.update(email: 'whoami@plop.com', password: 'super secret')
|
2016-12-07 17:24:01 +01:00
|
|
|
|
|
|
|
admin.reload
|
|
|
|
expect(admin.email).to eq('whoami@plop.com')
|
|
|
|
expect(admin.valid_password?('super secret')).to be(true)
|
|
|
|
end
|
2016-10-11 10:31:32 +02:00
|
|
|
end
|
2016-12-26 17:25:59 +01:00
|
|
|
|
2017-05-12 16:47:18 +02:00
|
|
|
describe 'last_week_overview' do
|
|
|
|
let!(:gestionnaire2) { create(:gestionnaire) }
|
|
|
|
subject { gestionnaire2.last_week_overview }
|
|
|
|
let(:friday) { DateTime.new(2017, 5, 12) }
|
|
|
|
let(:monday) { DateTime.now.beginning_of_week }
|
|
|
|
|
2017-11-29 16:07:39 +01:00
|
|
|
before { Timecop.freeze(friday) }
|
2017-10-05 16:10:00 +02:00
|
|
|
after { Timecop.return }
|
|
|
|
|
2017-05-12 16:47:18 +02:00
|
|
|
context 'when no procedure published was active last week' do
|
2018-05-16 17:21:12 +02:00
|
|
|
let!(:procedure) { create(:procedure, :published, gestionnaires: [gestionnaire2], libelle: 'procedure') }
|
2017-05-12 16:47:18 +02:00
|
|
|
context 'when the gestionnaire has no notifications' do
|
|
|
|
it { is_expected.to eq(nil) }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when a procedure published was active' do
|
2018-05-16 17:21:12 +02:00
|
|
|
let!(:procedure) { create(:procedure, :published, gestionnaires: [gestionnaire2], libelle: 'procedure') }
|
2017-05-12 16:47:18 +02:00
|
|
|
let(:procedure_overview) { double('procedure_overview', 'had_some_activities?'.to_sym => true) }
|
|
|
|
|
|
|
|
before :each do
|
|
|
|
expect_any_instance_of(Procedure).to receive(:procedure_overview).and_return(procedure_overview)
|
|
|
|
end
|
|
|
|
|
2017-07-19 12:23:53 +02:00
|
|
|
it { expect(gestionnaire2.last_week_overview[:procedure_overviews]).to match([procedure_overview]) }
|
2017-05-12 16:47:18 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
context 'when a procedure not published was active with no notifications' do
|
2018-05-16 17:21:12 +02:00
|
|
|
let!(:procedure) { create(:procedure, gestionnaires: [gestionnaire2], libelle: 'procedure') }
|
2017-05-12 16:47:18 +02:00
|
|
|
let(:procedure_overview) { double('procedure_overview', 'had_some_activities?'.to_sym => true) }
|
|
|
|
|
|
|
|
before :each do
|
|
|
|
allow_any_instance_of(Procedure).to receive(:procedure_overview).and_return(procedure_overview)
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to eq(nil) }
|
|
|
|
end
|
|
|
|
end
|
2017-05-16 15:20:38 +02:00
|
|
|
|
2018-03-20 16:00:30 +01:00
|
|
|
describe '#can_view_dossier?' do
|
2017-05-16 15:20:38 +02:00
|
|
|
subject{ gestionnaire.can_view_dossier?(dossier.id) }
|
|
|
|
|
|
|
|
context 'when gestionnaire is assigned on dossier' do
|
2018-08-28 14:10:55 +02:00
|
|
|
let!(:dossier){ create(:dossier, procedure: procedure, state: Dossier.states.fetch(:en_instruction)) }
|
2017-05-16 15:20:38 +02:00
|
|
|
|
|
|
|
it { expect(subject).to be true }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when gestionnaire is invited on dossier' do
|
|
|
|
let(:dossier){ create(:dossier) }
|
|
|
|
let!(:avis){ create(:avis, dossier: dossier, gestionnaire: gestionnaire) }
|
|
|
|
|
|
|
|
it { expect(subject).to be true }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when gestionnaire is neither assigned nor invited on dossier' do
|
|
|
|
let(:dossier){ create(:dossier) }
|
|
|
|
|
|
|
|
it { expect(subject).to be false }
|
|
|
|
end
|
|
|
|
end
|
2017-08-30 11:12:58 +02:00
|
|
|
|
2017-10-02 17:03:38 +02:00
|
|
|
describe "procedure_presentation_for_procedure_id" do
|
|
|
|
let!(:pp) { ProcedurePresentation.create(assign_to: procedure_assign) }
|
|
|
|
|
2018-01-15 21:54:40 +01:00
|
|
|
it { expect(gestionnaire.procedure_presentation_for_procedure_id(procedure.id)).to eq(pp) }
|
|
|
|
it { expect(gestionnaire.procedure_presentation_for_procedure_id(procedure_2.id).persisted?).to be_falsey }
|
2017-10-02 17:03:38 +02:00
|
|
|
end
|
2017-10-05 16:10:00 +02:00
|
|
|
|
|
|
|
describe '#notifications_for_dossier' do
|
2018-08-28 14:10:55 +02:00
|
|
|
let!(:dossier) { create(:dossier, :followed, state: Dossier.states.fetch(:en_construction)) }
|
2017-10-05 16:10:00 +02:00
|
|
|
let(:gestionnaire) { dossier.follows.first.gestionnaire }
|
|
|
|
|
|
|
|
subject { gestionnaire.notifications_for_dossier(dossier) }
|
|
|
|
|
|
|
|
context 'when the gestionnaire has just followed the dossier' do
|
|
|
|
it { is_expected.to match({ demande: false, annotations_privees: false, avis: false, messagerie: false }) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when there is a modification on public champs' do
|
|
|
|
before { dossier.champs.first.update_attribute('value', 'toto') }
|
|
|
|
|
|
|
|
it { is_expected.to match({ demande: true, annotations_privees: false, avis: false, messagerie: false }) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when there is a modification on a piece jusitificative' do
|
|
|
|
before { dossier.pieces_justificatives << create(:piece_justificative, :contrat) }
|
|
|
|
|
|
|
|
it { is_expected.to match({ demande: true, annotations_privees: false, avis: false, messagerie: false }) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when there is a modification on private champs' do
|
|
|
|
before { dossier.champs_private.first.update_attribute('value', 'toto') }
|
|
|
|
|
|
|
|
it { is_expected.to match({ demande: false, annotations_privees: true, avis: false, messagerie: false }) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when there is a modification on avis' do
|
|
|
|
before { create(:avis, dossier: dossier) }
|
|
|
|
|
|
|
|
it { is_expected.to match({ demande: false, annotations_privees: false, avis: true, messagerie: false }) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'messagerie' do
|
|
|
|
context 'when there is a new commentaire' do
|
|
|
|
before { create(:commentaire, dossier: dossier, email: 'a@b.com') }
|
|
|
|
|
|
|
|
it { is_expected.to match({ demande: false, annotations_privees: false, avis: false, messagerie: true }) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when there is a new commentaire issued by tps' do
|
2018-05-31 15:43:57 +02:00
|
|
|
before { create(:commentaire, dossier: dossier, email: CONTACT_EMAIL) }
|
2017-10-05 16:10:00 +02:00
|
|
|
|
|
|
|
it { is_expected.to match({ demande: false, annotations_privees: false, avis: false, messagerie: false }) }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#notification_for_procedure' do
|
2018-08-28 14:10:55 +02:00
|
|
|
let!(:dossier) { create(:dossier, :followed, state: Dossier.states.fetch(:en_construction)) }
|
2017-10-05 16:10:00 +02:00
|
|
|
let(:gestionnaire) { dossier.follows.first.gestionnaire }
|
|
|
|
let(:procedure) { dossier.procedure }
|
|
|
|
let!(:gestionnaire_2) { create(:gestionnaire, procedures: [procedure]) }
|
|
|
|
|
2018-08-28 14:10:55 +02:00
|
|
|
let!(:dossier_on_procedure_2) { create(:dossier, :followed, state: Dossier.states.fetch(:en_construction)) }
|
2017-10-05 16:10:00 +02:00
|
|
|
let!(:gestionnaire_on_procedure_2) { dossier_on_procedure_2.follows.first.gestionnaire }
|
|
|
|
|
|
|
|
before do
|
|
|
|
gestionnaire_2.followed_dossiers << dossier
|
|
|
|
end
|
|
|
|
|
|
|
|
subject { gestionnaire.notifications_for_procedure(procedure) }
|
|
|
|
|
|
|
|
context 'when the gestionnaire has just followed the dossier' do
|
|
|
|
it { is_expected.to match([]) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when there is a modification on public champs' do
|
|
|
|
before { dossier.champs.first.update_attribute('value', 'toto') }
|
|
|
|
|
|
|
|
it { is_expected.to match([dossier.id]) }
|
|
|
|
it { expect(gestionnaire_2.notifications_for_procedure(procedure)).to match([dossier.id]) }
|
|
|
|
it { expect(gestionnaire_on_procedure_2.notifications_for_procedure(procedure)).to match([]) }
|
|
|
|
|
|
|
|
context 'and there is a modification on private champs' do
|
|
|
|
before { dossier.champs_private.first.update_attribute('value', 'toto') }
|
|
|
|
|
|
|
|
it { is_expected.to match([dossier.id]) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when gestionnaire update it s public champs last seen' do
|
|
|
|
let(:follow) { gestionnaire.follows.find_by(dossier: dossier) }
|
|
|
|
|
|
|
|
before { follow.update_attribute('demande_seen_at', DateTime.now) }
|
|
|
|
|
|
|
|
it { is_expected.to match([]) }
|
|
|
|
it { expect(gestionnaire_2.notifications_for_procedure(procedure)).to match([dossier.id]) }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when there is a modification on a piece justificative' do
|
|
|
|
before { dossier.pieces_justificatives << create(:piece_justificative, :contrat) }
|
|
|
|
|
|
|
|
it { is_expected.to match([dossier.id]) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when there is a modification on public champs on a followed dossier from another procedure' do
|
|
|
|
before { dossier_on_procedure_2.champs.first.update_attribute('value', 'toto') }
|
|
|
|
|
|
|
|
it { is_expected.to match([]) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when there is a modification on private champs' do
|
|
|
|
before { dossier.champs_private.first.update_attribute('value', 'toto') }
|
|
|
|
|
|
|
|
it { is_expected.to match([dossier.id]) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when there is a modification on avis' do
|
|
|
|
before { create(:avis, dossier: dossier) }
|
|
|
|
|
|
|
|
it { is_expected.to match([dossier.id]) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'the messagerie' do
|
|
|
|
context 'when there is a new commentaire' do
|
|
|
|
before { create(:commentaire, dossier: dossier, email: 'a@b.com') }
|
|
|
|
|
|
|
|
it { is_expected.to match([dossier.id]) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when there is a new commentaire issued by tps' do
|
2018-05-31 15:43:57 +02:00
|
|
|
before { create(:commentaire, dossier: dossier, email: CONTACT_EMAIL) }
|
2017-10-05 16:10:00 +02:00
|
|
|
|
|
|
|
it { is_expected.to match([]) }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#notifications_per_procedure' do
|
2018-08-28 14:10:55 +02:00
|
|
|
let!(:dossier) { create(:dossier, :followed, state: Dossier.states.fetch(:en_construction)) }
|
2017-10-05 16:10:00 +02:00
|
|
|
let(:gestionnaire) { dossier.follows.first.gestionnaire }
|
|
|
|
let(:procedure) { dossier.procedure }
|
|
|
|
|
|
|
|
subject { gestionnaire.notifications_per_procedure }
|
|
|
|
|
|
|
|
context 'when there is a modification on public champs' do
|
|
|
|
before { dossier.champs.first.update_attribute('value', 'toto') }
|
|
|
|
|
|
|
|
it { is_expected.to match({ procedure.id => 1 }) }
|
|
|
|
end
|
|
|
|
end
|
2017-10-24 11:41:22 +02:00
|
|
|
|
|
|
|
describe '#mark_tab_as_seen' do
|
2018-08-28 14:10:55 +02:00
|
|
|
let!(:dossier) { create(:dossier, :followed, state: Dossier.states.fetch(:en_construction)) }
|
2017-10-24 11:41:22 +02:00
|
|
|
let(:gestionnaire) { dossier.follows.first.gestionnaire }
|
|
|
|
let(:freeze_date) { DateTime.parse('12/12/2012') }
|
|
|
|
|
|
|
|
context 'when demande is acknowledged' do
|
|
|
|
let(:follow) { gestionnaire.follows.find_by(dossier: dossier) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
Timecop.freeze(freeze_date)
|
|
|
|
gestionnaire.mark_tab_as_seen(dossier, :demande)
|
|
|
|
end
|
2017-11-29 16:07:39 +01:00
|
|
|
after { Timecop.return }
|
2017-10-24 11:41:22 +02:00
|
|
|
|
|
|
|
it { expect(follow.demande_seen_at).to eq(freeze_date) }
|
|
|
|
end
|
|
|
|
end
|
2015-09-22 10:15:12 +02:00
|
|
|
end
|