2015-08-13 15:55:19 +02:00
require 'spec_helper'
describe Dossier do
2018-05-25 18:05:28 +02:00
include ActiveJob :: TestHelper
2015-09-24 11:17:17 +02:00
let ( :user ) { create ( :user ) }
2016-07-19 16:44:26 +02:00
2017-10-10 18:35:00 +02:00
describe " without_followers scope " do
let! ( :dossier ) { create ( :dossier , :followed , :with_entreprise , user : user ) }
let! ( :dossier2 ) { create ( :dossier , :with_entreprise , user : user ) }
it { expect ( Dossier . without_followers . to_a ) . to eq ( [ dossier2 ] ) }
end
2018-03-04 14:39:08 +01:00
describe 'with_ordered_champs' do
let ( :procedure ) { create ( :procedure ) }
let ( :dossier ) { Dossier . create ( user : create ( :user ) , procedure : procedure ) }
before do
create ( :type_de_champ , libelle : 'l1' , order_place : 1 , procedure : procedure )
create ( :type_de_champ , libelle : 'l3' , order_place : 3 , procedure : procedure )
create ( :type_de_champ , libelle : 'l2' , order_place : 2 , procedure : procedure )
end
it do
expect ( Dossier . with_ordered_champs . find ( dossier . id ) . champs . map ( & :libelle ) ) . to match ( %w( l1 l2 l3 ) )
end
end
2015-08-21 11:37:13 +02:00
describe 'methods' do
2016-02-04 14:08:35 +01:00
let ( :dossier ) { create ( :dossier , :with_entreprise , user : user ) }
2015-08-21 11:37:13 +02:00
let ( :etablissement ) { dossier . etablissement }
2015-08-18 14:22:16 +02:00
2015-08-21 11:37:13 +02:00
subject { dossier }
2015-08-18 14:22:16 +02:00
2015-09-21 17:59:03 +02:00
describe '#types_de_piece_justificative' do
subject { dossier . types_de_piece_justificative }
2015-08-21 11:37:13 +02:00
it 'returns list of required piece justificative' do
2015-09-21 17:59:03 +02:00
expect ( subject . size ) . to eq ( 2 )
expect ( subject ) . to include ( TypeDePieceJustificative . find ( TypeDePieceJustificative . first . id ) )
2015-08-21 11:37:13 +02:00
end
2015-08-18 14:22:16 +02:00
end
2015-08-18 15:15:34 +02:00
2018-01-16 13:34:24 +01:00
describe '#retrieve_last_piece_justificative_by_type' , vcr : { cassette_name : 'models_dossier_retrieve_last_piece_justificative_by_type' } do
2016-03-17 14:50:10 +01:00
let ( :types_de_pj_dossier ) { dossier . procedure . types_de_piece_justificative }
subject { dossier . retrieve_last_piece_justificative_by_type types_de_pj_dossier . first }
2015-08-18 15:15:34 +02:00
before do
2016-03-17 14:50:10 +01:00
create :piece_justificative , :rib , dossier : dossier , type_de_piece_justificative : types_de_pj_dossier . first
2015-08-18 15:15:34 +02:00
end
2015-08-21 11:37:13 +02:00
2015-09-21 17:59:03 +02:00
it 'returns piece justificative with given type' do
2016-03-17 14:50:10 +01:00
expect ( subject . type ) . to eq ( types_de_pj_dossier . first . id )
2015-08-18 15:15:34 +02:00
end
end
2015-08-24 15:23:07 +02:00
2015-11-03 15:27:49 +01:00
describe '#build_default_champs' do
2016-08-08 12:52:30 +02:00
context 'when dossier is linked to a procedure with type_de_champ_public and private' do
2016-02-04 14:08:35 +01:00
let ( :dossier ) { create ( :dossier , user : user ) }
2015-11-03 15:27:49 +01:00
it 'build all champs needed' do
expect ( dossier . champs . count ) . to eq ( 1 )
end
2016-08-08 12:52:30 +02:00
it 'build all champs_private needed' do
expect ( dossier . champs_private . count ) . to eq ( 1 )
end
2015-11-03 15:27:49 +01:00
end
end
2016-08-30 11:18:43 +02:00
describe '#build_default_individual' do
context 'when dossier is linked to a procedure with for_individual attr false' do
let ( :dossier ) { create ( :dossier , user : user ) }
it 'have no object created' do
expect ( dossier . individual ) . to be_nil
end
end
context 'when dossier is linked to a procedure with for_individual attr true' do
let ( :dossier ) { create ( :dossier , user : user , procedure : ( create :procedure , for_individual : true ) ) }
it 'have no object created' do
expect ( dossier . individual ) . not_to be_nil
end
end
end
2015-08-24 15:23:07 +02:00
describe '#save' do
2016-02-02 18:37:38 +01:00
subject { build ( :dossier , procedure : procedure , user : user ) }
2015-11-03 15:27:49 +01:00
let! ( :procedure ) { create ( :procedure ) }
2016-06-13 12:03:05 +02:00
2015-09-21 17:59:03 +02:00
context 'when is linked to a procedure' do
2015-11-03 15:27:49 +01:00
it 'creates default champs' do
expect ( subject ) . to receive ( :build_default_champs )
2016-02-02 18:37:38 +01:00
subject . save
2015-08-24 15:23:07 +02:00
end
end
2015-09-21 17:59:03 +02:00
context 'when is not linked to a procedure' do
2016-06-13 12:03:05 +02:00
subject { create ( :dossier , procedure : nil , user : user ) }
2015-11-03 15:27:49 +01:00
2015-11-04 17:27:01 +01:00
it 'does not create default champs' do
2015-11-03 15:27:49 +01:00
expect ( subject ) . not_to receive ( :build_default_champs )
2018-03-02 16:27:03 +01:00
subject . update ( state : 'en_construction' )
2015-11-03 15:27:49 +01:00
end
2015-08-24 15:23:07 +02:00
end
end
2015-08-18 15:15:34 +02:00
end
2016-02-02 18:37:38 +01:00
2016-11-14 17:43:34 +01:00
describe '#convert_specific_hash_values_to_string(hash_to_convert)' do
2016-11-09 17:20:55 +01:00
let ( :procedure ) { create ( :procedure ) }
let ( :dossier ) { create ( :dossier , :with_entreprise , user : user , procedure : procedure ) }
let ( :dossier_serialized_attributes ) { DossierSerializer . new ( dossier ) . attributes }
2018-04-26 18:41:04 +02:00
subject { dossier . send ( :convert_specific_hash_values_to_string , dossier_serialized_attributes ) }
2016-11-09 17:20:55 +01:00
it { expect ( dossier_serialized_attributes [ :id ] ) . to be_an ( Integer ) }
it { expect ( dossier_serialized_attributes [ :created_at ] ) . to be_a ( Time ) }
it { expect ( dossier_serialized_attributes [ :updated_at ] ) . to be_a ( Time ) }
it { expect ( dossier_serialized_attributes [ :archived ] ) . to be_in ( [ true , false ] ) }
it { expect ( dossier_serialized_attributes [ :state ] ) . to be_a ( String ) }
it { expect ( subject [ :id ] ) . to be_a ( String ) }
it { expect ( subject [ :created_at ] ) . to be_a ( Time ) }
it { expect ( subject [ :updated_at ] ) . to be_a ( Time ) }
it { expect ( subject [ :archived ] ) . to be_a ( String ) }
it { expect ( subject [ :state ] ) . to be_a ( String ) }
end
2018-04-26 17:14:56 +02:00
describe '#export_etablissement_data' do
2016-07-19 16:44:26 +02:00
let ( :procedure ) { create ( :procedure ) }
2016-02-19 16:59:18 +01:00
let ( :dossier ) { create ( :dossier , :with_entreprise , user : user , procedure : procedure ) }
2016-11-09 17:20:55 +01:00
2018-04-26 18:41:04 +02:00
subject { dossier . send ( :export_etablissement_data ) }
2016-11-09 17:20:55 +01:00
it { expect ( subject [ :etablissement_siret ] ) . to eq ( '44011762001530' ) }
it { expect ( subject [ :etablissement_siege_social ] ) . to eq ( 'true' ) }
it { expect ( subject [ :etablissement_naf ] ) . to eq ( '4950Z' ) }
it { expect ( subject [ :etablissement_libelle_naf ] ) . to eq ( 'Transports par conduites' ) }
it { expect ( subject [ :etablissement_adresse ] ) . to eq ( 'GRTGAZ IMMEUBLE BORA 6 RUE RAOUL NORDLING 92270 BOIS COLOMBES' ) }
it { expect ( subject [ :etablissement_numero_voie ] ) . to eq ( '6' ) }
it { expect ( subject [ :etablissement_type_voie ] ) . to eq ( 'RUE' ) }
it { expect ( subject [ :etablissement_nom_voie ] ) . to eq ( 'RAOUL NORDLING' ) }
it { expect ( subject [ :etablissement_complement_adresse ] ) . to eq ( 'IMMEUBLE BORA' ) }
it { expect ( subject [ :etablissement_code_postal ] ) . to eq ( '92270' ) }
it { expect ( subject [ :etablissement_localite ] ) . to eq ( 'BOIS COLOMBES' ) }
it { expect ( subject [ :etablissement_code_insee_localite ] ) . to eq ( '92009' ) }
it { expect ( subject [ :entreprise_siren ] ) . to eq ( '440117620' ) }
it { expect ( subject [ :entreprise_capital_social ] ) . to eq ( '537100000' ) }
it { expect ( subject [ :entreprise_numero_tva_intracommunautaire ] ) . to eq ( 'FR27440117620' ) }
it { expect ( subject [ :entreprise_forme_juridique ] ) . to eq ( " SA à conseil d'administration (s.a.i.) " ) }
it { expect ( subject [ :entreprise_forme_juridique_code ] ) . to eq ( '5599' ) }
it { expect ( subject [ :entreprise_nom_commercial ] ) . to eq ( 'GRTGAZ' ) }
it { expect ( subject [ :entreprise_raison_sociale ] ) . to eq ( 'GRTGAZ' ) }
it { expect ( subject [ :entreprise_siret_siege_social ] ) . to eq ( '44011762001530' ) }
it { expect ( subject [ :entreprise_code_effectif_entreprise ] ) . to eq ( '51' ) }
2018-04-23 11:57:38 +02:00
it { expect ( subject [ :entreprise_date_creation ] ) . to eq ( '1990-04-24T00:00:00+00:00' ) }
2016-11-09 17:20:55 +01:00
it { expect ( subject [ :entreprise_nom ] ) . to be_nil }
it { expect ( subject [ :entreprise_prenom ] ) . to be_nil }
2016-11-17 16:55:41 +01:00
it { expect ( subject . count ) . to eq ( EntrepriseSerializer . new ( Entreprise . new ) . as_json . count + EtablissementSerializer . new ( Etablissement . new ) . as_json . count ) }
2016-11-09 17:20:55 +01:00
end
2017-01-26 17:54:04 +01:00
context 'when dossier is followed' do
2017-06-27 10:50:29 +02:00
let ( :procedure ) { create ( :procedure , :with_type_de_champ , :with_type_de_champ_private ) }
2017-01-26 17:54:04 +01:00
let ( :gestionnaire ) { create ( :gestionnaire ) }
2017-03-02 16:18:14 +01:00
let ( :date1 ) { 1 . day . ago }
let ( :date2 ) { 1 . hour . ago }
let ( :date3 ) { 1 . minute . ago }
2017-12-14 15:53:02 +01:00
let ( :dossier ) { create ( :dossier , :with_entreprise , user : user , procedure : procedure , en_construction_at : date1 , en_instruction_at : date2 , processed_at : date3 , motivation : " Motivation " ) }
2017-07-18 15:03:08 +02:00
let! ( :follow ) { create ( :follow , gestionnaire : gestionnaire , dossier : dossier ) }
2016-11-14 17:25:17 +01:00
2017-01-26 17:54:04 +01:00
describe '#export_headers' do
subject { dossier . export_headers }
2017-07-19 15:40:26 +02:00
it { expect ( subject ) . to include ( dossier . champs . first . libelle . parameterize . underscore . to_sym ) }
2017-04-13 15:05:55 +02:00
it { expect ( subject ) . to include ( :individual_gender ) }
it { expect ( subject ) . to include ( :individual_nom ) }
it { expect ( subject ) . to include ( :individual_prenom ) }
it { expect ( subject ) . to include ( :individual_birthdate ) }
2018-01-15 19:22:02 +01:00
it do
expect ( subject . count ) . to eq ( DossierTableExportSerializer . new ( dossier ) . attributes . count +
dossier . procedure . types_de_champ . count +
dossier . procedure . types_de_champ_private . count +
2018-04-26 18:41:04 +02:00
dossier . send ( :export_etablissement_data ) . count )
2018-01-15 19:22:02 +01:00
end
2017-01-26 17:54:04 +01:00
end
2018-04-26 18:42:06 +02:00
describe '#sorted_values' do
subject { dossier . send ( :sorted_values ) }
2017-01-26 17:54:04 +01:00
it { expect ( subject [ 0 ] ) . to be_a_kind_of ( Integer ) }
it { expect ( subject [ 1 ] ) . to be_a_kind_of ( Time ) }
it { expect ( subject [ 2 ] ) . to be_a_kind_of ( Time ) }
it { expect ( subject [ 3 ] ) . to be_in ( [ true , false ] ) }
2017-08-01 14:18:20 +02:00
it { expect ( subject [ 4 ] ) . to eq ( dossier . user . email ) }
2018-03-19 16:45:43 +01:00
it { expect ( subject [ 5 ] ) . to eq ( " brouillon " ) }
it { expect ( subject [ 6 ] ) . to eq ( date1 ) }
it { expect ( subject [ 7 ] ) . to eq ( date2 ) }
it { expect ( subject [ 8 ] ) . to eq ( date3 ) }
it { expect ( subject [ 9 ] ) . to be_a_kind_of ( String ) }
2017-06-19 10:20:46 +02:00
it { expect ( subject [ 10 ] ) . to be_a_kind_of ( String ) }
2018-03-19 16:45:43 +01:00
it { expect ( subject [ 11 ] ) . to be_nil }
2017-04-13 15:05:55 +02:00
it { expect ( subject [ 12 ] ) . to be_nil }
it { expect ( subject [ 13 ] ) . to be_nil }
2017-06-19 10:20:46 +02:00
it { expect ( subject [ 14 ] ) . to be_nil }
2017-06-27 10:50:29 +02:00
it { expect ( subject [ 15 ] ) . to be_nil }
2018-01-15 19:22:02 +01:00
it do
expect ( subject . count ) . to eq ( DossierTableExportSerializer . new ( dossier ) . attributes . count +
dossier . procedure . types_de_champ . count +
dossier . procedure . types_de_champ_private . count +
2018-04-26 18:41:04 +02:00
dossier . send ( :export_etablissement_data ) . count )
2018-01-15 19:22:02 +01:00
end
2017-04-13 15:05:55 +02:00
context 'dossier for individual' do
let ( :dossier_with_individual ) { create ( :dossier , :for_individual , user : user , procedure : procedure ) }
2018-04-26 18:42:06 +02:00
subject { dossier_with_individual . send ( :sorted_values ) }
2017-04-13 15:05:55 +02:00
2018-03-19 16:45:43 +01:00
it { expect ( subject [ 11 ] ) . to eq ( dossier_with_individual . individual . gender ) }
it { expect ( subject [ 12 ] ) . to eq ( dossier_with_individual . individual . prenom ) }
it { expect ( subject [ 13 ] ) . to eq ( dossier_with_individual . individual . nom ) }
it { expect ( subject [ 14 ] ) . to eq ( dossier_with_individual . individual . birthdate ) }
2017-04-13 15:05:55 +02:00
end
2017-01-26 17:54:04 +01:00
end
2017-04-05 15:10:58 +02:00
describe " # full_data_string " do
let ( :expected_string ) {
[
dossier . id . to_s ,
dossier . created_at ,
dossier . updated_at ,
" false " ,
2017-08-01 14:18:20 +02:00
dossier . user . email ,
2017-12-04 16:17:15 +01:00
" brouillon " ,
2017-12-14 15:51:45 +01:00
dossier . en_construction_at ,
2017-12-14 15:53:02 +01:00
dossier . en_instruction_at ,
2017-04-05 15:10:58 +02:00
dossier . processed_at ,
2017-06-19 10:20:46 +02:00
" Motivation " ,
2017-04-05 15:10:58 +02:00
gestionnaire . email ,
nil ,
2017-04-13 15:05:55 +02:00
nil ,
nil ,
nil ,
nil ,
2017-06-27 10:50:29 +02:00
nil ,
2017-04-05 15:10:58 +02:00
" 44011762001530 " ,
" true " ,
" 4950Z " ,
" Transports par conduites " ,
" GRTGAZ IMMEUBLE BORA 6 RUE RAOUL NORDLING 92270 BOIS COLOMBES " ,
" 6 " ,
" RUE " ,
" RAOUL NORDLING " ,
" IMMEUBLE BORA " ,
" 92270 " ,
" BOIS COLOMBES " ,
" 92009 " ,
" 440117620 " ,
" 537100000 " ,
" FR27440117620 " ,
" SA à conseil d'administration (s.a.i.) " ,
" 5599 " ,
" GRTGAZ " ,
" GRTGAZ " ,
" 44011762001530 " ,
" 51 " ,
2018-04-23 11:57:38 +02:00
" 1990-04-24T00:00:00+00:00 " ,
2017-04-05 15:10:58 +02:00
nil ,
nil
]
}
subject { dossier }
2018-04-26 18:25:59 +02:00
it { expect ( dossier . export_values ) . to eq ( expected_string ) }
2017-04-05 15:10:58 +02:00
end
2016-11-14 10:41:56 +01:00
end
2016-06-20 13:57:57 +02:00
describe '#reset!' do
let! ( :dossier ) { create :dossier , :with_entreprise , autorisation_donnees : true }
let! ( :exercice ) { create :exercice , etablissement : dossier . etablissement }
subject { dossier . reset! }
it { expect ( dossier . etablissement ) . not_to be_nil }
it { expect ( dossier . etablissement . exercices ) . not_to be_empty }
it { expect ( dossier . etablissement . exercices . size ) . to eq 1 }
it { expect ( dossier . autorisation_donnees ) . to be_truthy }
2016-07-19 16:44:26 +02:00
it { expect { subject } . to change ( Exercice , :count ) . by ( - 1 ) }
it { expect { subject } . to change ( Etablissement , :count ) . by ( - 1 ) }
2016-06-20 13:57:57 +02:00
context 'when method reset! is call' do
before do
subject
dossier . reload
end
it { expect ( dossier . etablissement ) . to be_nil }
it { expect ( dossier . autorisation_donnees ) . to be_falsey }
end
end
2016-06-21 12:41:28 +02:00
describe '#ordered_champs' do
2017-08-02 19:15:53 +02:00
let ( :procedure ) { create ( :procedure ) }
let ( :dossier ) { Dossier . create ( user : create ( :user ) , procedure : procedure ) }
2016-06-21 12:41:28 +02:00
before do
2018-02-13 17:00:19 +01:00
create ( :type_de_champ , libelle : 'l1' , order_place : 1 , procedure : procedure )
create ( :type_de_champ , libelle : 'l3' , order_place : 3 , procedure : procedure )
create ( :type_de_champ , libelle : 'l2' , order_place : 2 , procedure : procedure )
2016-06-21 12:41:28 +02:00
end
2017-08-02 19:15:53 +02:00
it { expect ( dossier . ordered_champs . pluck ( :libelle ) ) . to match ( %w( l1 l2 l3 ) ) }
2016-06-21 12:41:28 +02:00
end
2016-07-19 16:44:26 +02:00
2016-08-08 12:52:30 +02:00
describe '#ordered_champs_private' do
2017-07-27 20:54:02 +02:00
let ( :procedure ) { create :procedure }
let ( :dossier ) { Dossier . create ( user : create ( :user ) , procedure : procedure ) }
2016-08-08 12:52:30 +02:00
before do
2018-02-13 17:00:19 +01:00
create :type_de_champ , :private , libelle : 'l1' , order_place : 1 , procedure : procedure
create :type_de_champ , :private , libelle : 'l3' , order_place : 3 , procedure : procedure
create :type_de_champ , :private , libelle : 'l2' , order_place : 2 , procedure : procedure
2016-08-08 12:52:30 +02:00
end
2017-07-27 20:54:02 +02:00
it { expect ( dossier . ordered_champs_private . pluck ( :libelle ) ) . to match ( %w( l1 l2 l3 ) ) }
2016-08-08 12:52:30 +02:00
end
2016-07-19 16:44:26 +02:00
describe '#total_follow' do
let ( :dossier ) { create ( :dossier , :with_entreprise , user : user ) }
let ( :dossier2 ) { create ( :dossier , :with_entreprise , user : user ) }
subject { dossier . total_follow }
context 'when no body follow dossier' do
it { expect ( subject ) . to eq 0 }
end
context 'when 2 people follow dossier' do
before do
create :follow , dossier_id : dossier . id , gestionnaire_id : ( create :gestionnaire ) . id
create :follow , dossier_id : dossier . id , gestionnaire_id : ( create :gestionnaire ) . id
create :follow , dossier_id : dossier2 . id , gestionnaire_id : ( create :gestionnaire ) . id
create :follow , dossier_id : dossier2 . id , gestionnaire_id : ( create :gestionnaire ) . id
end
it { expect ( subject ) . to eq 2 }
end
end
2016-09-14 16:36:01 +02:00
2017-04-18 17:31:01 +02:00
describe " # text_summary " do
2017-04-26 15:11:50 +02:00
let ( :procedure ) { create ( :procedure , libelle : " Procédure " , organisation : " Organisme " ) }
2017-04-18 17:31:01 +02:00
2017-12-14 15:51:45 +01:00
context 'when the dossier has been en_construction' do
let ( :dossier ) { create :dossier , procedure : procedure , state : 'en_construction' , en_construction_at : " 31/12/2010 " . to_date }
2017-04-18 17:31:01 +02:00
subject { dossier . text_summary }
2017-04-26 15:11:50 +02:00
it { is_expected . to eq ( " Dossier déposé le 31/12/2010 sur la procédure Procédure gérée par l'organisme Organisme " ) }
2017-04-18 17:31:01 +02:00
end
2017-12-14 15:51:45 +01:00
context 'when the dossier has not been en_construction' do
2017-12-04 16:17:15 +01:00
let ( :dossier ) { create :dossier , procedure : procedure , state : 'brouillon' }
2017-04-18 17:31:01 +02:00
subject { dossier . text_summary }
2017-04-26 15:11:50 +02:00
it { is_expected . to eq ( " Dossier en brouillon répondant à la procédure Procédure gérée par l'organisme Organisme " ) }
2017-04-18 17:31:01 +02:00
end
end
2017-09-08 11:52:20 +02:00
describe '#avis_for' do
let! ( :procedure ) { create ( :procedure , :published ) }
2017-12-14 15:51:45 +01:00
let! ( :dossier ) { create ( :dossier , procedure : procedure , state : :en_construction ) }
2017-09-08 11:52:20 +02:00
let! ( :gestionnaire ) { create ( :gestionnaire , procedures : [ procedure ] ) }
let! ( :expert_1 ) { create ( :gestionnaire ) }
let! ( :expert_2 ) { create ( :gestionnaire ) }
context 'when there is a public advice asked from the dossiers gestionnaire' do
let! ( :avis ) { Avis . create ( dossier : dossier , claimant : gestionnaire , gestionnaire : expert_1 , confidentiel : false ) }
it { expect ( dossier . avis_for ( gestionnaire ) ) . to match ( [ avis ] ) }
it { expect ( dossier . avis_for ( expert_1 ) ) . to match ( [ avis ] ) }
it { expect ( dossier . avis_for ( expert_2 ) ) . to match ( [ avis ] ) }
end
context 'when there is a private advice asked from the dossiers gestionnaire' do
let! ( :avis ) { Avis . create ( dossier : dossier , claimant : gestionnaire , gestionnaire : expert_1 , confidentiel : true ) }
it { expect ( dossier . avis_for ( gestionnaire ) ) . to match ( [ avis ] ) }
it { expect ( dossier . avis_for ( expert_1 ) ) . to match ( [ avis ] ) }
it { expect ( dossier . avis_for ( expert_2 ) ) . to match ( [ ] ) }
end
context 'when there is a public advice asked from one expert to another' do
let! ( :avis ) { Avis . create ( dossier : dossier , claimant : expert_1 , gestionnaire : expert_2 , confidentiel : false ) }
it { expect ( dossier . avis_for ( gestionnaire ) ) . to match ( [ avis ] ) }
it { expect ( dossier . avis_for ( expert_1 ) ) . to match ( [ avis ] ) }
it { expect ( dossier . avis_for ( expert_2 ) ) . to match ( [ avis ] ) }
end
context 'when there is a private advice asked from one expert to another' do
let! ( :avis ) { Avis . create ( dossier : dossier , claimant : expert_1 , gestionnaire : expert_2 , confidentiel : true ) }
it { expect ( dossier . avis_for ( gestionnaire ) ) . to match ( [ avis ] ) }
it { expect ( dossier . avis_for ( expert_1 ) ) . to match ( [ avis ] ) }
it { expect ( dossier . avis_for ( expert_2 ) ) . to match ( [ avis ] ) }
end
context 'when they are a lot of advice' do
let! ( :avis_1 ) { Avis . create ( dossier : dossier , claimant : expert_1 , gestionnaire : expert_2 , confidentiel : false , created_at : DateTime . parse ( '10/01/2010' ) ) }
let! ( :avis_2 ) { Avis . create ( dossier : dossier , claimant : expert_1 , gestionnaire : expert_2 , confidentiel : false , created_at : DateTime . parse ( '9/01/2010' ) ) }
let! ( :avis_3 ) { Avis . create ( dossier : dossier , claimant : expert_1 , gestionnaire : expert_2 , confidentiel : false , created_at : DateTime . parse ( '11/01/2010' ) ) }
it { expect ( dossier . avis_for ( gestionnaire ) ) . to match ( [ avis_2 , avis_1 , avis_3 ] ) }
it { expect ( dossier . avis_for ( expert_1 ) ) . to match ( [ avis_2 , avis_1 , avis_3 ] ) }
end
end
2017-03-01 09:51:55 +01:00
describe '#update_state_dates' do
2017-12-04 16:17:15 +01:00
let ( :state ) { 'brouillon' }
2017-03-01 09:51:55 +01:00
let ( :dossier ) { create ( :dossier , state : state ) }
2017-03-01 11:13:48 +01:00
let ( :beginning_of_day ) { Time . now . beginning_of_day }
2017-03-01 09:51:55 +01:00
before do
2017-03-01 11:13:48 +01:00
Timecop . freeze ( beginning_of_day )
2017-03-01 09:51:55 +01:00
end
2017-12-14 15:51:45 +01:00
context 'when dossier is en_construction' do
2017-03-01 09:51:55 +01:00
before do
2017-12-14 15:51:45 +01:00
dossier . en_construction!
2017-03-01 09:51:55 +01:00
dossier . reload
end
2017-12-14 15:51:45 +01:00
it { expect ( dossier . state ) . to eq ( 'en_construction' ) }
it { expect ( dossier . en_construction_at ) . to eq ( beginning_of_day ) }
2017-03-01 09:51:55 +01:00
2017-12-14 15:51:45 +01:00
it 'should keep first en_construction_at date' do
2017-03-01 11:13:48 +01:00
Timecop . return
2017-12-14 15:53:02 +01:00
dossier . en_instruction!
2017-12-14 15:51:45 +01:00
dossier . en_construction!
2017-03-01 11:13:48 +01:00
2017-12-14 15:51:45 +01:00
expect ( dossier . en_construction_at ) . to eq ( beginning_of_day )
2017-03-01 11:13:48 +01:00
end
2017-03-01 09:51:55 +01:00
end
2017-12-14 15:53:02 +01:00
context 'when dossier is en_instruction' do
2017-12-14 15:51:45 +01:00
let ( :state ) { 'en_construction' }
2017-03-01 09:51:55 +01:00
before do
2017-12-14 15:53:02 +01:00
dossier . en_instruction!
2017-03-01 09:51:55 +01:00
dossier . reload
end
2017-12-14 15:53:02 +01:00
it { expect ( dossier . state ) . to eq ( 'en_instruction' ) }
it { expect ( dossier . en_instruction_at ) . to eq ( beginning_of_day ) }
2017-03-01 11:13:48 +01:00
2017-12-14 15:53:02 +01:00
it 'should keep first en_instruction_at date if dossier is set to en_construction again' do
2017-03-01 11:13:48 +01:00
Timecop . return
2017-12-14 15:51:45 +01:00
dossier . en_construction!
2017-12-14 15:53:02 +01:00
dossier . en_instruction!
2017-03-01 11:13:48 +01:00
2017-12-14 15:53:02 +01:00
expect ( dossier . en_instruction_at ) . to eq ( beginning_of_day )
2017-03-01 11:13:48 +01:00
end
2017-03-01 09:51:55 +01:00
end
shared_examples 'dossier is processed' do | new_state |
before do
dossier . update ( state : new_state )
dossier . reload
end
it { expect ( dossier . state ) . to eq ( new_state ) }
2017-03-01 11:13:48 +01:00
it { expect ( dossier . processed_at ) . to eq ( beginning_of_day ) }
2017-03-01 09:51:55 +01:00
end
2017-12-04 18:00:12 +01:00
context 'when dossier is accepte' do
2017-12-14 15:53:02 +01:00
let ( :state ) { 'en_instruction' }
2017-03-01 09:51:55 +01:00
2017-12-04 18:00:12 +01:00
it_behaves_like 'dossier is processed' , 'accepte'
2017-03-01 09:51:55 +01:00
end
2017-12-04 18:15:40 +01:00
context 'when dossier is refuse' do
2017-12-14 15:53:02 +01:00
let ( :state ) { 'en_instruction' }
2017-03-01 09:51:55 +01:00
2017-12-04 18:15:40 +01:00
it_behaves_like 'dossier is processed' , 'refuse'
2017-03-01 09:51:55 +01:00
end
2017-12-04 20:23:57 +01:00
context 'when dossier is sans_suite' do
2017-12-14 15:53:02 +01:00
let ( :state ) { 'en_instruction' }
2017-03-01 09:51:55 +01:00
2017-12-04 20:23:57 +01:00
it_behaves_like 'dossier is processed' , 'sans_suite'
2017-03-01 09:51:55 +01:00
end
2017-01-26 17:54:04 +01:00
end
2017-03-29 14:09:50 +02:00
2017-12-01 12:24:41 +01:00
describe '.downloadable_sorted' do
2017-03-29 14:09:50 +02:00
let ( :procedure ) { create ( :procedure ) }
2017-12-04 16:17:15 +01:00
let! ( :dossier ) { create ( :dossier , :with_entreprise , procedure : procedure , state : :brouillon ) }
2017-12-14 15:51:45 +01:00
let! ( :dossier2 ) { create ( :dossier , :with_entreprise , procedure : procedure , state : :en_construction , en_construction_at : DateTime . parse ( '03/01/2010' ) ) }
2017-12-14 15:53:02 +01:00
let! ( :dossier3 ) { create ( :dossier , :with_entreprise , procedure : procedure , state : :en_instruction , en_construction_at : DateTime . parse ( '01/01/2010' ) ) }
let! ( :dossier4 ) { create ( :dossier , :with_entreprise , procedure : procedure , state : :en_instruction , archived : true , en_construction_at : DateTime . parse ( '02/01/2010' ) ) }
2017-03-29 14:09:50 +02:00
2017-12-01 12:24:41 +01:00
subject { procedure . dossiers . downloadable_sorted }
2017-03-29 14:09:50 +02:00
2018-01-15 21:54:40 +01:00
it { is_expected . to match ( [ dossier3 , dossier4 , dossier2 ] ) }
2017-03-29 14:09:50 +02:00
end
2017-05-26 20:01:57 +02:00
2017-10-13 18:35:12 +02:00
describe " # send_dossier_received " do
2017-05-26 20:01:57 +02:00
let ( :procedure ) { create ( :procedure ) }
2017-12-14 15:51:45 +01:00
let ( :dossier ) { create ( :dossier , procedure : procedure , state : :en_construction ) }
2017-05-26 20:01:57 +02:00
before do
2017-10-13 18:35:12 +02:00
allow ( NotificationMailer ) . to receive ( :send_dossier_received ) . and_return ( double ( deliver_later : nil ) )
2017-05-26 20:01:57 +02:00
end
2017-12-14 15:53:02 +01:00
it " sends an email when the dossier becomes en_instruction " do
dossier . en_instruction!
2018-05-30 23:55:34 +02:00
expect ( NotificationMailer ) . to have_received ( :send_dossier_received ) . with ( dossier )
2017-05-26 20:01:57 +02:00
end
2017-12-04 18:00:12 +01:00
it " does not an email when the dossier becomes accepte " do
dossier . accepte!
2017-10-13 18:35:12 +02:00
expect ( NotificationMailer ) . to_not have_received ( :send_dossier_received )
2017-05-26 20:01:57 +02:00
end
end
2017-06-08 14:04:47 +02:00
2017-10-11 15:36:40 +02:00
describe " # send_draft_notification_email " do
let ( :procedure ) { create ( :procedure ) }
let ( :user ) { create ( :user ) }
before do
ActionMailer :: Base . deliveries . clear
end
it " send an email when the dossier is created for the very first time " do
2018-05-25 18:05:28 +02:00
ActiveJob :: Base . queue_adapter = :test
expect do
perform_enqueued_jobs do
Dossier . create ( procedure : procedure , state : " brouillon " , user : user )
end
end . to change ( ActionMailer :: Base . deliveries , :size ) . from ( 0 ) . to ( 1 )
2017-10-11 15:36:40 +02:00
mail = ActionMailer :: Base . deliveries . last
2018-05-31 15:50:13 +02:00
expect ( mail . subject ) . to eq ( " Retrouvez votre brouillon pour la démarche \" #{ procedure . libelle } \" " )
2017-10-11 15:36:40 +02:00
end
2017-12-04 16:17:15 +01:00
it " does not send an email when the dossier is created with a non brouillon state " do
2017-12-14 15:51:45 +01:00
expect { Dossier . create ( procedure : procedure , state : " en_construction " , user : user ) } . not_to change ( ActionMailer :: Base . deliveries , :size )
2017-12-14 15:53:02 +01:00
expect { Dossier . create ( procedure : procedure , state : " en_instruction " , user : user ) } . not_to change ( ActionMailer :: Base . deliveries , :size )
2017-12-04 18:00:12 +01:00
expect { Dossier . create ( procedure : procedure , state : " accepte " , user : user ) } . not_to change ( ActionMailer :: Base . deliveries , :size )
2017-12-04 18:15:40 +01:00
expect { Dossier . create ( procedure : procedure , state : " refuse " , user : user ) } . not_to change ( ActionMailer :: Base . deliveries , :size )
2017-12-04 20:23:57 +01:00
expect { Dossier . create ( procedure : procedure , state : " sans_suite " , user : user ) } . not_to change ( ActionMailer :: Base . deliveries , :size )
2017-10-11 15:36:40 +02:00
end
end
2018-04-06 13:09:37 +02:00
describe " # unspecified_attestation_champs " do
let ( :procedure ) { create ( :procedure , attestation_template : attestation_template ) }
let ( :dossier ) { create ( :dossier , procedure : procedure , state : :en_instruction ) }
subject { dossier . unspecified_attestation_champs . map ( & :libelle ) }
context " without attestation template " do
let ( :attestation_template ) { nil }
it { is_expected . to eq ( [ ] ) }
end
context " with attestation template " do
# Test all combinations:
# - with tag specified and unspecified
# - with tag in body and tag in title
# - with tag correponsing to a champ and an annotation privée
# - with a dash in the champ libelle / tag
2018-04-06 19:22:42 +02:00
let ( :title ) { " voici --specified champ-in-title-- un --unspecified champ-in-title-- beau --specified annotation privée-in-title-- titre --unspecified annotation privée-in-title-- non --numéro du dossier-- " }
2018-04-06 13:09:37 +02:00
let ( :body ) { " voici --specified champ-in-body-- un --unspecified champ-in-body-- beau --specified annotation privée-in-body-- body --unspecified annotation privée-in-body-- non ? " }
let ( :attestation_template ) { create ( :attestation_template , title : title , body : body , activated : activated ) }
context " which is disabled " do
let ( :activated ) { false }
it { is_expected . to eq ( [ ] ) }
end
context " wich is enabled " do
let ( :activated ) { true }
let! ( :tdc_1 ) { create ( :type_de_champ , libelle : " specified champ-in-title " , procedure : procedure ) }
let! ( :tdc_2 ) { create ( :type_de_champ , libelle : " unspecified champ-in-title " , procedure : procedure ) }
let! ( :tdc_3 ) { create ( :type_de_champ , libelle : " specified champ-in-body " , procedure : procedure ) }
let! ( :tdc_4 ) { create ( :type_de_champ , libelle : " unspecified champ-in-body " , procedure : procedure ) }
let! ( :tdc_5 ) { create ( :type_de_champ , private : true , libelle : " specified annotation privée-in-title " , procedure : procedure ) }
let! ( :tdc_6 ) { create ( :type_de_champ , private : true , libelle : " unspecified annotation privée-in-title " , procedure : procedure ) }
let! ( :tdc_7 ) { create ( :type_de_champ , private : true , libelle : " specified annotation privée-in-body " , procedure : procedure ) }
let! ( :tdc_8 ) { create ( :type_de_champ , private : true , libelle : " unspecified annotation privée-in-body " , procedure : procedure ) }
before do
( dossier . champs + dossier . champs_private )
. select { | c | c . libelle . match? ( / ^specified / ) }
. each { | c | c . update_attribute ( :value , " specified " ) }
end
it do
is_expected . to eq ( [
" unspecified champ-in-title " ,
" unspecified annotation privée-in-title " ,
" unspecified champ-in-body " ,
" unspecified annotation privée-in-body "
] )
end
end
end
end
2018-03-20 16:00:30 +01:00
describe '#build_attestation' do
2017-06-08 14:04:47 +02:00
let ( :attestation_template ) { nil }
let ( :procedure ) { create ( :procedure , attestation_template : attestation_template ) }
before :each do
2017-12-05 17:43:32 +01:00
dossier . attestation = dossier . build_attestation
2017-06-08 14:04:47 +02:00
dossier . reload
end
2017-12-14 15:53:02 +01:00
context 'when the dossier is in en_instruction state ' do
let! ( :dossier ) { create ( :dossier , procedure : procedure , state : :en_instruction ) }
2017-06-08 14:04:47 +02:00
context 'when the procedure has no attestation' do
it { expect ( dossier . attestation ) . to be_nil }
end
context 'when the procedure has an unactivated attestation' do
let ( :attestation_template ) { AttestationTemplate . new ( activated : false ) }
it { expect ( dossier . attestation ) . to be_nil }
end
context 'when the procedure attached has an activated attestation' do
let ( :attestation_template ) { AttestationTemplate . new ( activated : true ) }
it { expect ( dossier . attestation ) . not_to be_nil }
end
end
end
2017-06-27 15:26:40 +02:00
describe " .default_scope " do
let! ( :dossier ) { create ( :dossier , hidden_at : hidden_at ) }
context " when dossier is not hidden " do
let ( :hidden_at ) { nil }
it { expect ( Dossier . count ) . to eq ( 1 ) }
it { expect ( Dossier . all ) . to include ( dossier ) }
end
context " when dossier is hidden " do
let ( :hidden_at ) { 1 . day . ago }
it { expect ( Dossier . count ) . to eq ( 0 ) }
end
end
2017-10-02 17:03:38 +02:00
describe " # get_value " do
let ( :dossier ) { create ( :dossier , :with_entreprise , user : user ) }
before do
FranceConnectInformation . create ( france_connect_particulier_id : 123 , user : user , gender : 'male' )
@champ_public = dossier . champs . first
@champ_public . value = " kiwi "
@champ_public . save
@champ_private = dossier . champs_private . first
@champ_private . value = " banane "
@champ_private . save
end
it { expect ( dossier . get_value ( 'self' , 'created_at' ) ) . to eq ( dossier . created_at ) }
it { expect ( dossier . get_value ( 'user' , 'email' ) ) . to eq ( user . email ) }
it { expect ( dossier . get_value ( 'france_connect_information' , 'gender' ) ) . to eq ( user . france_connect_information . gender ) }
2018-04-23 11:57:38 +02:00
it { expect ( dossier . get_value ( 'entreprise' , 'siren' ) ) . to eq ( dossier . etablissement . entreprise_siren ) }
2017-10-02 17:03:38 +02:00
it { expect ( dossier . get_value ( 'etablissement' , 'siret' ) ) . to eq ( dossier . etablissement . siret ) }
it { expect ( dossier . get_value ( 'type_de_champ' , @champ_public . type_de_champ . id . to_s ) ) . to eq ( dossier . champs . first . value ) }
it { expect ( dossier . get_value ( 'type_de_champ_private' , @champ_private . type_de_champ . id . to_s ) ) . to eq ( dossier . champs_private . first . value ) }
end
2017-10-24 18:12:25 +02:00
2017-10-26 16:53:40 +02:00
describe 'updated_at' do
2017-10-24 18:12:25 +02:00
let! ( :dossier ) { create ( :dossier ) }
let ( :modif_date ) { DateTime . parse ( '01/01/2100' ) }
before { Timecop . freeze ( modif_date ) }
2017-11-29 16:07:39 +01:00
after { Timecop . return }
2017-10-24 18:12:25 +02:00
subject do
dossier . reload
dossier . updated_at
end
it { is_expected . not_to eq ( modif_date ) }
context 'when a piece justificative is modified' do
before { dossier . pieces_justificatives << create ( :piece_justificative , :contrat ) }
it { is_expected . to eq ( modif_date ) }
end
context 'when a champ is modified' do
before { dossier . champs . first . update_attribute ( 'value' , 'yop' ) }
it { is_expected . to eq ( modif_date ) }
end
context 'when a quartier_prioritaire is modified' do
before { dossier . quartier_prioritaires << create ( :quartier_prioritaire ) }
it { is_expected . to eq ( modif_date ) }
end
context 'when a cadastre is modified' do
before { dossier . cadastres << create ( :cadastre ) }
it { is_expected . to eq ( modif_date ) }
end
context 'when a commentaire is modified' do
before { dossier . commentaires << create ( :commentaire ) }
it { is_expected . to eq ( modif_date ) }
end
context 'when an avis is modified' do
before { dossier . avis << create ( :avis ) }
it { is_expected . to eq ( modif_date ) }
end
end
2017-11-17 23:40:51 +01:00
describe '#owner_name' do
let! ( :procedure ) { create ( :procedure ) }
subject { dossier . owner_name }
context 'when there is no entreprise or individual' do
2018-04-23 11:57:38 +02:00
let ( :dossier ) { create ( :dossier , individual : nil , procedure : procedure ) }
2017-11-17 23:40:51 +01:00
it { is_expected . to be_nil }
end
context 'when there is entreprise' do
let ( :dossier ) { create ( :dossier , :with_entreprise , procedure : procedure ) }
2018-04-23 11:57:38 +02:00
it { is_expected . to eq ( dossier . etablissement . entreprise_raison_sociale ) }
2017-11-17 23:40:51 +01:00
end
context 'when there is an individual' do
let ( :dossier ) { create ( :dossier , :for_individual , procedure : procedure ) }
it { is_expected . to eq ( " #{ dossier . individual . nom } #{ dossier . individual . prenom } " ) }
end
end
2017-10-30 16:54:33 +01:00
describe 'geometry' do
let ( :dossier ) { create ( :dossier , json_latlngs : json_latlngs ) }
let ( :json_latlngs ) { nil }
subject { dossier . user_geometry }
context 'when there are no map' do
it { is_expected . to eq ( nil ) }
end
context 'when there are 2 polygones' do
let ( :json_latlngs ) do
' [ [ { " lat " : 2 . 0 , " lng " : 102 . 0 } , { " lat " : 3 . 0 , " lng " : 103 . 0 } , { " lat " : 2 . 0 , " lng " : 102 . 0 } ] ,
[ { " lat " : 2 . 0 , " lng " : 102 . 0 } , { " lat " : 3 . 0 , " lng " : 103 . 0 } , { " lat " : 2 . 0 , " lng " : 102 . 0 } ] ] '
end
let ( :expected ) do
{
" type " : " MultiPolygon " ,
" coordinates " :
[
[
[
[ 102 . 0 , 2 . 0 ] ,
[ 103 . 0 , 3 . 0 ] ,
[ 102 . 0 , 2 . 0 ]
]
] ,
[
[
[ 102 . 0 , 2 . 0 ] ,
[ 103 . 0 , 3 . 0 ] ,
[ 102 . 0 , 2 . 0 ]
]
]
]
}
end
subject { dossier . user_geometry . value }
it { is_expected . to eq ( expected ) }
end
end
2018-03-01 17:04:05 +01:00
describe 'webhook' do
let ( :dossier ) { create ( :dossier ) }
it 'should not call webhook' do
expect {
dossier . accepte!
} . to_not have_enqueued_job ( WebHookJob )
end
it 'should call webhook' do
dossier . procedure . update_column ( :web_hook_url , '/webhook.json' )
expect {
dossier . update_column ( :motivation , 'bonjour' )
} . to_not have_enqueued_job ( WebHookJob )
expect {
dossier . en_construction!
} . to have_enqueued_job ( WebHookJob )
expect {
dossier . update_column ( :motivation , 'bonjour2' )
} . to_not have_enqueued_job ( WebHookJob )
expect {
dossier . en_instruction!
} . to have_enqueued_job ( WebHookJob )
end
end
2018-06-25 18:07:16 +02:00
describe " # can_transition_to_en_construction? " do
let ( :procedure ) { create ( :procedure , :published ) }
let ( :dossier ) { create ( :dossier , state : state , procedure : procedure ) }
subject { dossier . can_transition_to_en_construction? }
context " dossier state is brouillon " do
let ( :state ) { " brouillon " }
it { is_expected . to be true }
context " procedure is archived " do
before { procedure . archive }
it { is_expected . to be false }
end
end
context " dossier state is en_construction " do
let ( :state ) { " en_construction " }
it { is_expected . to be false }
end
context " dossier state is en_instruction " do
let ( :state ) { " en_instruction " }
it { is_expected . to be false }
end
context " dossier state is en_instruction " do
let ( :state ) { " accepte " }
it { is_expected . to be false }
end
context " dossier state is en_instruction " do
let ( :state ) { " refuse " }
it { is_expected . to be false }
end
context " dossier state is en_instruction " do
let ( :state ) { " sans_suite " }
it { is_expected . to be false }
end
end
2015-08-20 17:30:17 +02:00
end