2019-12-03 18:36:50 +01:00
|
|
|
RSpec.describe Export, type: :model do
|
|
|
|
describe 'validations' do
|
|
|
|
let(:groupe_instructeur) { create(:groupe_instructeur) }
|
|
|
|
|
|
|
|
context 'when everything is ok' do
|
2021-03-31 18:19:28 +02:00
|
|
|
let(:export) { build(:export, groupe_instructeurs: [groupe_instructeur]) }
|
2019-12-03 18:36:50 +01:00
|
|
|
|
|
|
|
it { expect(export.save).to be true }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when groupe instructeurs are missing' do
|
|
|
|
let(:export) { build(:export, groupe_instructeurs: []) }
|
|
|
|
|
|
|
|
it { expect(export.save).to be false }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when format is missing' do
|
2021-03-31 18:19:28 +02:00
|
|
|
let(:export) { build(:export, format: nil, groupe_instructeurs: [groupe_instructeur]) }
|
2019-12-03 18:36:50 +01:00
|
|
|
|
|
|
|
it { expect(export.save).to be false }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '.stale' do
|
|
|
|
let!(:export) { create(:export) }
|
|
|
|
let(:stale_date) { Time.zone.now() - (Export::MAX_DUREE_CONSERVATION_EXPORT + 1.minute) }
|
2022-07-26 14:13:23 +02:00
|
|
|
let!(:stale_export_generated) { create(:export, :generated, updated_at: stale_date) }
|
|
|
|
let!(:stale_export_failed) { create(:export, :failed, updated_at: stale_date) }
|
|
|
|
let!(:stale_export_pending) { create(:export, :pending, updated_at: stale_date) }
|
2019-12-03 18:36:50 +01:00
|
|
|
|
2022-07-26 14:13:23 +02:00
|
|
|
it { expect(Export.stale(Export::MAX_DUREE_CONSERVATION_EXPORT)).to match_array([stale_export_generated, stale_export_failed]) }
|
2019-12-03 18:36:50 +01:00
|
|
|
end
|
|
|
|
|
2022-07-27 10:23:21 +02:00
|
|
|
describe '.stuck' do
|
|
|
|
let!(:export) { create(:export) }
|
|
|
|
let(:stuck_date) { Time.zone.now() - (Export::MAX_DUREE_GENERATION + 1.minute) }
|
|
|
|
let!(:stale_export_generated) { create(:export, :generated, updated_at: stuck_date) }
|
|
|
|
let!(:stale_export_failed) { create(:export, :failed, updated_at: stuck_date) }
|
|
|
|
let!(:stale_export_pending) { create(:export, :pending, updated_at: stuck_date) }
|
|
|
|
|
|
|
|
it { expect(Export.stuck(Export::MAX_DUREE_GENERATION)).to match_array([stale_export_pending]) }
|
|
|
|
end
|
|
|
|
|
2019-12-03 18:36:50 +01:00
|
|
|
describe '.destroy' do
|
|
|
|
let!(:groupe_instructeur) { create(:groupe_instructeur) }
|
|
|
|
let!(:export) { create(:export, groupe_instructeurs: [groupe_instructeur]) }
|
|
|
|
|
|
|
|
before { export.destroy! }
|
|
|
|
|
|
|
|
it { expect(Export.count).to eq(0) }
|
|
|
|
it { expect(groupe_instructeur.reload).to be_present }
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '.find_by groupe_instructeurs' do
|
|
|
|
let!(:procedure) { create(:procedure) }
|
2022-10-31 14:10:35 +01:00
|
|
|
let!(:gi_1) { create(:groupe_instructeur, procedure: procedure, instructeurs: [create(:instructeur)]) }
|
|
|
|
let!(:gi_2) { create(:groupe_instructeur, procedure: procedure, instructeurs: [create(:instructeur)]) }
|
|
|
|
let!(:gi_3) { create(:groupe_instructeur, procedure: procedure, instructeurs: [create(:instructeur)]) }
|
|
|
|
|
|
|
|
context 'without procedure_presentation' do
|
|
|
|
context 'when an export is made for one groupe instructeur' do
|
|
|
|
let!(:export) { create(:export, groupe_instructeurs: [gi_1, gi_2]) }
|
2019-12-03 18:36:50 +01:00
|
|
|
|
2023-09-13 12:59:38 +02:00
|
|
|
it { expect(Export.by_key([gi_1.id], nil)).to be_empty }
|
|
|
|
it { expect(Export.by_key([gi_2.id, gi_1.id], nil)).to eq([export]) }
|
|
|
|
it { expect(Export.by_key([gi_1.id, gi_2.id, gi_3.id], nil)).to be_empty }
|
2022-10-31 14:10:35 +01:00
|
|
|
end
|
|
|
|
end
|
2019-12-03 18:36:50 +01:00
|
|
|
|
2022-10-31 14:10:35 +01:00
|
|
|
context 'with procedure_presentation and without' do
|
|
|
|
let!(:export_global) { create(:export, statut: Export.statuts.fetch(:tous), groupe_instructeurs: [gi_1, gi_2], procedure_presentation: nil) }
|
|
|
|
let!(:export_with_filter) { create(:export, statut: Export.statuts.fetch(:suivis), groupe_instructeurs: [gi_1, gi_2], procedure_presentation: create(:procedure_presentation, procedure: procedure, assign_to: gi_1.instructeurs.first.assign_to.first)) }
|
|
|
|
let!(:procedure_presentation) { create(:procedure_presentation, procedure: gi_1.procedure) }
|
|
|
|
|
|
|
|
it 'find global exports as well as filtered one' do
|
2023-09-13 12:59:38 +02:00
|
|
|
expect(Export.by_key([gi_2.id, gi_1.id], export_with_filter.procedure_presentation))
|
|
|
|
.to contain_exactly(export_with_filter, export_global)
|
2022-10-31 14:10:35 +01:00
|
|
|
end
|
2019-12-03 18:36:50 +01:00
|
|
|
end
|
|
|
|
end
|
2022-05-10 14:38:04 +02:00
|
|
|
|
2022-10-21 16:53:11 +02:00
|
|
|
describe '.find_or_create_export' do
|
|
|
|
let!(:procedure) { create(:procedure) }
|
|
|
|
let!(:gi_1) { create(:groupe_instructeur, procedure: procedure, instructeurs: [create(:instructeur)]) }
|
|
|
|
let!(:pp) { gi_1.instructeurs.first.procedure_presentation_and_errors_for_procedure_id(procedure.id).first }
|
|
|
|
before { pp.add_filter('tous', 'self/created_at', '10/12/2021') }
|
|
|
|
|
|
|
|
context 'with procedure_presentation having different filters' do
|
|
|
|
it 'works once' do
|
|
|
|
expect { Export.find_or_create_export(:zip, [gi_1], time_span_type: Export.time_span_types.fetch(:everything), statut: Export.statuts.fetch(:tous), procedure_presentation: pp) }
|
|
|
|
.to change { Export.count }.by(1)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'works once, changes procedure_presentation, recreate a new' do
|
|
|
|
expect { Export.find_or_create_export(:zip, [gi_1], time_span_type: Export.time_span_types.fetch(:everything), statut: Export.statuts.fetch(:tous), procedure_presentation: pp) }
|
|
|
|
.to change { Export.count }.by(1)
|
|
|
|
pp.add_filter('tous', 'self/updated_at', '10/12/2021')
|
|
|
|
expect { Export.find_or_create_export(:zip, [gi_1], time_span_type: Export.time_span_types.fetch(:everything), statut: Export.statuts.fetch(:tous), procedure_presentation: pp) }
|
|
|
|
.to change { Export.count }.by(1)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2022-05-10 14:38:04 +02:00
|
|
|
describe '.dossiers_for_export' do
|
2022-10-10 10:55:31 +02:00
|
|
|
let!(:procedure) { create(:procedure, :published, :with_instructeur) }
|
2022-05-10 14:38:04 +02:00
|
|
|
|
|
|
|
let!(:dossier_brouillon) { create(:dossier, :brouillon, procedure: procedure) }
|
|
|
|
let!(:dossier_en_construction) { create(:dossier, :en_construction, procedure: procedure) }
|
|
|
|
let!(:dossier_en_instruction) { create(:dossier, :en_instruction, procedure: procedure) }
|
|
|
|
let!(:dossier_accepte) { create(:dossier, :accepte, procedure: procedure) }
|
|
|
|
|
2022-10-10 10:55:31 +02:00
|
|
|
let(:export) do
|
|
|
|
create(:export,
|
|
|
|
groupe_instructeurs: [procedure.groupe_instructeurs.first],
|
|
|
|
procedure_presentation: procedure_presentation,
|
|
|
|
statut: statut)
|
|
|
|
end
|
2022-05-10 14:38:04 +02:00
|
|
|
|
|
|
|
context 'without procedure_presentation or since' do
|
2022-10-10 10:55:31 +02:00
|
|
|
let(:procedure_presentation) { nil }
|
|
|
|
let(:statut) { nil }
|
2022-05-10 14:38:04 +02:00
|
|
|
it 'does not includes brouillons' do
|
|
|
|
expect(export.send(:dossiers_for_export)).to include(dossier_en_construction)
|
|
|
|
expect(export.send(:dossiers_for_export)).to include(dossier_en_instruction)
|
|
|
|
expect(export.send(:dossiers_for_export)).to include(dossier_accepte)
|
|
|
|
expect(export.send(:dossiers_for_export)).not_to include(dossier_brouillon)
|
|
|
|
end
|
|
|
|
end
|
2022-10-10 10:55:31 +02:00
|
|
|
|
|
|
|
context 'with procedure_presentation and statut supprimes_recemment' do
|
|
|
|
let(:statut) { 'supprimes_recemment' }
|
|
|
|
let(:procedure_presentation) do
|
|
|
|
create(:procedure_presentation,
|
|
|
|
procedure: procedure,
|
|
|
|
assign_to: procedure.groupe_instructeurs.first.assign_tos.first)
|
|
|
|
end
|
|
|
|
let!(:dossier_recemment_supprime) { create(:dossier, :accepte, procedure: procedure, hidden_by_administration_at: 2.days.ago) }
|
|
|
|
|
|
|
|
it 'includes supprimes_recemment' do
|
|
|
|
expect(export.send(:dossiers_for_export)).to include(dossier_recemment_supprime)
|
|
|
|
end
|
|
|
|
end
|
2022-05-10 14:38:04 +02:00
|
|
|
end
|
2019-12-03 18:36:50 +01:00
|
|
|
end
|