2015-08-13 15:55:19 +02:00
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
2020-01-28 16:46:05 +01:00
describe 'scopes' do
describe '.default_scope' do
let! ( :dossier ) { create ( :dossier ) }
2020-02-05 16:09:03 +01:00
let! ( :discarded_dossier ) { create ( :dossier , :discarded ) }
2020-01-28 16:46:05 +01:00
subject { Dossier . all }
it { is_expected . to match_array ( [ dossier ] ) }
end
describe '.without_followers' do
let! ( :dossier_with_follower ) { create ( :dossier , :followed , :with_entreprise , user : user ) }
let! ( :dossier_without_follower ) { create ( :dossier , :with_entreprise , user : user ) }
it { expect ( Dossier . without_followers . to_a ) . to eq ( [ dossier_without_follower ] ) }
end
end
2020-01-07 16:36:04 +01:00
describe 'validations' do
let ( :procedure ) { create ( :procedure , :for_individual ) }
subject ( :dossier ) { create ( :dossier , procedure : procedure ) }
it { is_expected . to validate_presence_of ( :individual ) }
end
2018-08-30 11:51:35 +02:00
describe 'with_champs' do
2018-03-04 14:39:08 +01:00
let ( :procedure ) { create ( :procedure ) }
2019-08-22 17:58:31 +02:00
let ( :dossier ) { Dossier . create ( user : create ( :user ) , groupe_instructeur : procedure . defaut_groupe_instructeur ) }
2018-03-04 14:39:08 +01:00
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
2018-10-01 13:55:12 +02:00
expect ( Dossier . with_champs . find ( dossier . id ) . champs . map ( & :libelle ) ) . to match ( [ 'l1' , 'l2' , 'l3' ] )
2018-03-04 14:39:08 +01:00
end
end
2020-02-26 17:36:24 +01:00
describe 'brouillon_close_to_expiration' do
2020-03-24 12:50:59 +01:00
let ( :procedure ) { create ( :procedure , :published , duree_conservation_dossiers_dans_ds : 6 ) }
2020-02-26 17:36:24 +01:00
let! ( :young_dossier ) { create ( :dossier , :en_construction , procedure : procedure ) }
let! ( :expiring_dossier ) { create ( :dossier , created_at : 170 . days . ago , procedure : procedure ) }
let! ( :just_expired_dossier ) { create ( :dossier , created_at : ( 6 . months + 1 . hour + 10 . seconds ) . ago , procedure : procedure ) }
let! ( :long_expired_dossier ) { create ( :dossier , created_at : 1 . year . ago , procedure : procedure ) }
subject { Dossier . brouillon_close_to_expiration }
it do
is_expected . not_to include ( young_dossier )
is_expected . to include ( expiring_dossier )
is_expected . to include ( just_expired_dossier )
is_expected . to include ( long_expired_dossier )
end
end
describe 'en_construction_close_to_expiration' do
2020-03-24 12:50:59 +01:00
let ( :procedure ) { create ( :procedure , :published , duree_conservation_dossiers_dans_ds : 6 ) }
2018-08-31 12:56:30 +02:00
let! ( :young_dossier ) { create ( :dossier , procedure : procedure ) }
2020-02-26 17:36:24 +01:00
let! ( :expiring_dossier ) { create ( :dossier , :en_construction , en_construction_at : 170 . days . ago , procedure : procedure ) }
let! ( :just_expired_dossier ) { create ( :dossier , :en_construction , en_construction_at : ( 6 . months + 1 . hour + 10 . seconds ) . ago , procedure : procedure ) }
let! ( :long_expired_dossier ) { create ( :dossier , :en_construction , en_construction_at : 1 . year . ago , procedure : procedure ) }
2018-08-31 12:56:30 +02:00
2020-02-26 17:36:24 +01:00
subject { Dossier . en_construction_close_to_expiration }
2018-08-31 12:56:30 +02:00
2020-02-26 17:36:24 +01:00
it do
is_expected . not_to include ( young_dossier )
is_expected . to include ( expiring_dossier )
is_expected . to include ( just_expired_dossier )
is_expected . to include ( long_expired_dossier )
2018-08-31 12:56:30 +02:00
end
2020-03-20 15:32:36 +01:00
context 'does not include an expiring dossier that has been postponed' do
before do
expiring_dossier . update ( en_construction_conservation_extension : 1 . month )
expiring_dossier . reload
end
it { is_expected . not_to include ( expiring_dossier ) }
end
2020-02-26 17:36:24 +01:00
end
2018-08-31 12:56:30 +02:00
2020-02-26 17:36:24 +01:00
describe 'en_instruction_close_to_expiration' do
2020-03-24 12:50:59 +01:00
let ( :procedure ) { create ( :procedure , :published , duree_conservation_dossiers_dans_ds : 6 ) }
2020-02-26 17:36:24 +01:00
let! ( :young_dossier ) { create ( :dossier , procedure : procedure ) }
let! ( :expiring_dossier ) { create ( :dossier , :en_instruction , en_instruction_at : 170 . days . ago , procedure : procedure ) }
let! ( :just_expired_dossier ) { create ( :dossier , :en_instruction , en_instruction_at : ( 6 . months + 1 . hour + 10 . seconds ) . ago , procedure : procedure ) }
let! ( :long_expired_dossier ) { create ( :dossier , :en_instruction , en_instruction_at : 1 . year . ago , procedure : procedure ) }
2018-08-31 12:56:30 +02:00
2020-02-26 17:36:24 +01:00
subject { Dossier . en_instruction_close_to_expiration }
it do
is_expected . not_to include ( young_dossier )
is_expected . to include ( expiring_dossier )
is_expected . to include ( just_expired_dossier )
is_expected . to include ( long_expired_dossier )
2018-08-31 12:56:30 +02:00
end
end
2019-09-23 14:38:12 +02:00
describe 'with_notifications' do
let ( :dossier ) { create ( :dossier ) }
let ( :instructeur ) { create ( :instructeur ) }
before do
create ( :follow , dossier : dossier , instructeur : instructeur , messagerie_seen_at : 2 . hours . ago )
end
subject { instructeur . followed_dossiers . with_notifications }
context ( 'without changes' ) do
it { is_expected . to eq [ ] }
end
context ( 'with changes' ) do
before { dossier . commentaires << create ( :commentaire , email : 'test@exemple.fr' ) }
it { is_expected . to match ( [ dossier ] ) }
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
2018-07-25 19:34:06 +02:00
describe '#update_search_terms' do
let ( :etablissement ) { build ( :etablissement , entreprise_nom : 'Dupont' , entreprise_prenom : 'Thomas' , association_rna : '12345' , association_titre : 'asso de test' , association_objet : 'tests unitaires' ) }
let ( :procedure ) { create ( :procedure , :with_type_de_champ , :with_type_de_champ_private ) }
let ( :dossier ) { create ( :dossier , etablissement : etablissement , user : user , procedure : procedure ) }
let ( :france_connect_information ) { build ( :france_connect_information , given_name : 'Chris' , family_name : 'Harrisson' ) }
let ( :user ) { build ( :user , france_connect_information : france_connect_information ) }
2018-08-22 17:48:25 +02:00
let ( :champ_public ) { dossier . champs . first }
let ( :champ_private ) { dossier . champs_private . first }
2018-07-25 19:34:06 +02:00
before do
2018-08-22 17:48:25 +02:00
champ_public . update_attribute ( :value , " champ public " )
champ_private . update_attribute ( :value , " champ privé " )
2018-07-25 19:34:06 +02:00
dossier . update_search_terms
end
2018-10-01 12:59:34 +02:00
it { expect ( dossier . search_terms ) . to eq ( " #{ user . email } champ public #{ etablissement . entreprise_siren } #{ etablissement . entreprise_numero_tva_intracommunautaire } #{ etablissement . entreprise_forme_juridique } #{ etablissement . entreprise_forme_juridique_code } #{ etablissement . entreprise_nom_commercial } #{ etablissement . entreprise_raison_sociale } #{ etablissement . entreprise_siret_siege_social } #{ etablissement . entreprise_nom } #{ etablissement . entreprise_prenom } #{ etablissement . association_rna } #{ etablissement . association_titre } #{ etablissement . association_objet } #{ etablissement . siret } #{ etablissement . naf } #{ etablissement . libelle_naf } #{ etablissement . adresse } #{ etablissement . code_postal } #{ etablissement . localite } #{ etablissement . code_insee_localite } " ) }
2018-07-25 19:34:06 +02:00
it { expect ( dossier . private_search_terms ) . to eq ( 'champ privé' ) }
2018-08-22 17:48:25 +02:00
context 'with an update' do
before do
dossier . update (
champs_attributes : [ { id : champ_public . id , value : 'nouvelle valeur publique' } ] ,
champs_private_attributes : [ { id : champ_private . id , value : 'nouvelle valeur privee' } ]
)
end
it { expect ( dossier . search_terms ) . to include ( 'nouvelle valeur publique' ) }
it { expect ( dossier . private_search_terms ) . to include ( 'nouvelle valeur privee' ) }
end
2018-07-25 19:34:06 +02:00
end
2020-01-07 16:36:04 +01:00
describe '#create' do
let ( :procedure ) { create ( :procedure , :with_type_de_champ , :with_type_de_champ_private ) }
let ( :dossier ) { create ( :dossier , procedure : procedure , user : user ) }
2016-08-08 12:52:30 +02:00
2020-01-07 16:36:04 +01:00
it 'builds public and private champs' do
expect ( dossier . champs . count ) . to eq ( 1 )
expect ( dossier . champs_private . count ) . to eq ( 1 )
2015-11-03 15:27:49 +01:00
end
2020-01-07 16:36:04 +01:00
context 'when the dossier belongs to a procedure for individuals' do
let ( :procedure ) { create ( :procedure , :with_type_de_champ , for_individual : true ) }
2016-08-30 11:18:43 +02:00
2020-01-07 16:36:04 +01:00
it 'creates a default individual' do
expect ( dossier . individual ) . to be_present
expect ( dossier . individual . nom ) . to be_nil
expect ( dossier . individual . prenom ) . to be_nil
expect ( dossier . individual . gender ) . to be_nil
2016-08-30 11:18:43 +02:00
end
2020-01-07 16:36:04 +01:00
context 'and the user signs-in using France Connect' do
let ( :france_connect_information ) { build ( :france_connect_information ) }
let ( :user ) { build ( :user , france_connect_information : france_connect_information ) }
2016-08-30 11:18:43 +02:00
2020-01-07 16:36:04 +01:00
it 'fills the individual with the informations from France Connect' do
expect ( dossier . individual . nom ) . to eq ( 'DUBOIS' )
expect ( dossier . individual . prenom ) . to eq ( 'Angela Claire Louise' )
expect ( dossier . individual . gender ) . to eq ( Individual :: GENDER_FEMALE )
end
2016-08-30 11:18:43 +02:00
end
end
2016-06-13 12:03:05 +02:00
2020-01-07 16:36:04 +01:00
context 'when the dossier belongs to a procedure for moral personas' do
let ( :procedure ) { create ( :procedure , :with_type_de_champ , for_individual : false ) }
2015-11-03 15:27:49 +01:00
2020-01-07 16:36:04 +01:00
it 'doesn’ t create a individual' do
expect ( dossier . individual ) . to be_nil
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
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 ) }
2019-08-06 11:02:54 +02:00
let ( :instructeur ) { create ( :instructeur ) }
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 " ) }
2019-08-06 11:02:54 +02:00
let! ( :follow ) { create ( :follow , instructeur : instructeur , dossier : dossier ) }
2016-11-14 17:25:17 +01:00
2019-08-06 11:02:54 +02:00
describe " followers_instructeurs " do
let ( :non_following_instructeur ) { create ( :instructeur ) }
subject { dossier . followers_instructeurs }
2018-07-11 16:28:54 +02:00
2019-08-06 11:02:54 +02:00
it { expect ( subject ) . to eq [ instructeur ] }
it { expect ( subject ) . not_to include ( non_following_instructeur ) }
2018-07-11 16:28:54 +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 }
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
2018-08-30 11:51:35 +02:00
describe '#champs' do
2017-08-02 19:15:53 +02:00
let ( :procedure ) { create ( :procedure ) }
2019-08-22 17:58:31 +02:00
let ( :dossier ) { Dossier . create ( user : create ( :user ) , groupe_instructeur : procedure . defaut_groupe_instructeur ) }
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
2018-10-01 13:55:12 +02:00
it { expect ( dossier . champs . pluck ( :libelle ) ) . to match ( [ 'l1' , 'l2' , 'l3' ] ) }
2016-06-21 12:41:28 +02:00
end
2016-07-19 16:44:26 +02:00
2018-08-30 11:51:35 +02:00
describe '#champs_private' do
2017-07-27 20:54:02 +02:00
let ( :procedure ) { create :procedure }
2019-08-22 17:58:31 +02:00
let ( :dossier ) { Dossier . create ( user : create ( :user ) , groupe_instructeur : procedure . defaut_groupe_instructeur ) }
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
2018-10-01 13:55:12 +02:00
it { expect ( dossier . champs_private . pluck ( :libelle ) ) . to match ( [ 'l1' , 'l2' , 'l3' ] ) }
2016-08-08 12:52:30 +02:00
end
2017-04-18 17:31:01 +02:00
describe " # text_summary " do
2019-02-05 11:29:49 +01:00
let ( :service ) { create ( :service , nom : 'nom du service' ) }
let ( :procedure ) { create ( :procedure , libelle : " Démarche " , organisation : " Organisme " , service : service ) }
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
2018-08-28 14:10:55 +02:00
let ( :dossier ) { create :dossier , procedure : procedure , state : Dossier . states . fetch ( :en_construction ) , en_construction_at : " 31/12/2010 " . to_date }
2017-04-18 17:31:01 +02:00
subject { dossier . text_summary }
2019-02-05 11:29:49 +01:00
it { is_expected . to eq ( " Dossier déposé le 31/12/2010 sur la démarche Démarche gérée par l'organisme nom du service " ) }
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
2018-08-28 14:10:55 +02:00
let ( :dossier ) { create :dossier , procedure : procedure , state : Dossier . states . fetch ( :brouillon ) }
2017-04-18 17:31:01 +02:00
subject { dossier . text_summary }
2019-02-05 11:29:49 +01:00
it { is_expected . to eq ( " Dossier en brouillon répondant à la démarche Démarche gérée par l'organisme nom du service " ) }
2017-04-18 17:31:01 +02:00
end
end
2017-09-08 11:52:20 +02:00
describe '#avis_for' do
2019-08-21 16:16:53 +02:00
let! ( :instructeur ) { create ( :instructeur ) }
let! ( :procedure ) { create ( :procedure , :published , instructeurs : [ instructeur ] ) }
2018-08-28 14:10:55 +02:00
let! ( :dossier ) { create ( :dossier , procedure : procedure , state : Dossier . states . fetch ( :en_construction ) ) }
2017-09-08 11:52:20 +02:00
2019-08-06 11:02:54 +02:00
let! ( :expert_1 ) { create ( :instructeur ) }
let! ( :expert_2 ) { create ( :instructeur ) }
2017-09-08 11:52:20 +02:00
2019-08-06 11:02:54 +02:00
context 'when there is a public advice asked from the dossiers instructeur' do
let! ( :avis ) { Avis . create ( dossier : dossier , claimant : instructeur , instructeur : expert_1 , confidentiel : false ) }
2017-09-08 11:52:20 +02:00
2019-08-06 11:02:54 +02:00
it { expect ( dossier . avis_for ( instructeur ) ) . to match ( [ avis ] ) }
2017-09-08 11:52:20 +02:00
it { expect ( dossier . avis_for ( expert_1 ) ) . to match ( [ avis ] ) }
it { expect ( dossier . avis_for ( expert_2 ) ) . to match ( [ avis ] ) }
end
2019-08-06 11:02:54 +02:00
context 'when there is a private advice asked from the dossiers instructeur' do
let! ( :avis ) { Avis . create ( dossier : dossier , claimant : instructeur , instructeur : expert_1 , confidentiel : true ) }
2017-09-08 11:52:20 +02:00
2019-08-06 11:02:54 +02:00
it { expect ( dossier . avis_for ( instructeur ) ) . to match ( [ avis ] ) }
2017-09-08 11:52:20 +02:00
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
2019-08-06 11:02:54 +02:00
let! ( :avis ) { Avis . create ( dossier : dossier , claimant : expert_1 , instructeur : expert_2 , confidentiel : false ) }
2017-09-08 11:52:20 +02:00
2019-08-06 11:02:54 +02:00
it { expect ( dossier . avis_for ( instructeur ) ) . to match ( [ avis ] ) }
2017-09-08 11:52:20 +02:00
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
2019-08-06 11:02:54 +02:00
let! ( :avis ) { Avis . create ( dossier : dossier , claimant : expert_1 , instructeur : expert_2 , confidentiel : true ) }
2017-09-08 11:52:20 +02:00
2019-08-06 11:02:54 +02:00
it { expect ( dossier . avis_for ( instructeur ) ) . to match ( [ avis ] ) }
2017-09-08 11:52:20 +02:00
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
2019-08-06 11:02:54 +02:00
let! ( :avis_1 ) { Avis . create ( dossier : dossier , claimant : expert_1 , instructeur : expert_2 , confidentiel : false , created_at : Time . zone . parse ( '10/01/2010' ) ) }
let! ( :avis_2 ) { Avis . create ( dossier : dossier , claimant : expert_1 , instructeur : expert_2 , confidentiel : false , created_at : Time . zone . parse ( '9/01/2010' ) ) }
let! ( :avis_3 ) { Avis . create ( dossier : dossier , claimant : expert_1 , instructeur : expert_2 , confidentiel : false , created_at : Time . zone . parse ( '11/01/2010' ) ) }
2017-09-08 11:52:20 +02:00
2019-08-06 11:02:54 +02:00
it { expect ( dossier . avis_for ( instructeur ) ) . to match ( [ avis_2 , avis_1 , avis_3 ] ) }
2017-09-08 11:52:20 +02:00
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
2018-08-28 14:10:55 +02:00
let ( :state ) { Dossier . states . fetch ( :brouillon ) }
2017-03-01 09:51:55 +01:00
let ( :dossier ) { create ( :dossier , state : state ) }
2018-10-25 15:11:12 +02:00
let ( :beginning_of_day ) { Time . zone . now . beginning_of_day }
2017-03-01 09:51:55 +01:00
2018-08-14 11:38:37 +02:00
before { Timecop . freeze ( beginning_of_day ) }
after { Timecop . return }
2017-03-01 09:51:55 +01:00
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
2018-08-28 14:10:55 +02:00
it { expect ( dossier . state ) . to eq ( Dossier . states . fetch ( :en_construction ) ) }
2017-12-14 15:51:45 +01:00
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
2018-08-28 14:10:55 +02:00
let ( :state ) { Dossier . states . fetch ( :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
2018-08-28 14:10:55 +02:00
it { expect ( dossier . state ) . to eq ( Dossier . states . fetch ( :en_instruction ) ) }
2017-12-14 15:53:02 +01:00
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
2018-08-28 14:10:55 +02:00
let ( :state ) { Dossier . states . fetch ( :en_instruction ) }
2017-03-01 09:51:55 +01:00
2018-08-28 14:10:55 +02:00
it_behaves_like 'dossier is processed' , Dossier . states . fetch ( :accepte )
2017-03-01 09:51:55 +01:00
end
2017-12-04 18:15:40 +01:00
context 'when dossier is refuse' do
2018-08-28 14:10:55 +02:00
let ( :state ) { Dossier . states . fetch ( :en_instruction ) }
2017-03-01 09:51:55 +01:00
2018-08-28 14:10:55 +02:00
it_behaves_like 'dossier is processed' , Dossier . states . fetch ( :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
2018-08-28 14:10:55 +02:00
let ( :state ) { Dossier . states . fetch ( :en_instruction ) }
2017-03-01 09:51:55 +01:00
2018-08-28 14:10:55 +02:00
it_behaves_like 'dossier is processed' , Dossier . states . fetch ( :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 ) }
2018-08-28 14:10:55 +02:00
let! ( :dossier ) { create ( :dossier , :with_entreprise , procedure : procedure , state : Dossier . states . fetch ( :brouillon ) ) }
2018-10-25 15:17:33 +02:00
let! ( :dossier2 ) { create ( :dossier , :with_entreprise , procedure : procedure , state : Dossier . states . fetch ( :en_construction ) , en_construction_at : Time . zone . parse ( '03/01/2010' ) ) }
let! ( :dossier3 ) { create ( :dossier , :with_entreprise , procedure : procedure , state : Dossier . states . fetch ( :en_instruction ) , en_construction_at : Time . zone . parse ( '01/01/2010' ) ) }
let! ( :dossier4 ) { create ( :dossier , :with_entreprise , procedure : procedure , state : Dossier . states . fetch ( :en_instruction ) , archived : true , en_construction_at : Time . zone . 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
2020-02-26 12:30:52 +01:00
describe " # assign_to_groupe_instructeur " do
let ( :procedure ) { create ( :procedure ) }
let ( :new_groupe_instructeur_new_procedure ) { create ( :groupe_instructeur ) }
let ( :new_groupe_instructeur ) { create ( :groupe_instructeur , procedure : procedure ) }
let ( :dossier ) { create ( :dossier , :en_construction , procedure : procedure ) }
it " can change groupe instructeur " do
expect ( dossier . assign_to_groupe_instructeur ( new_groupe_instructeur_new_procedure ) ) . to be_falsey
expect ( dossier . groupe_instructeur ) . not_to eq ( new_groupe_instructeur_new_procedure )
end
it " can not change groupe instructeur if new groupe is from another procedure " do
expect ( dossier . assign_to_groupe_instructeur ( new_groupe_instructeur ) ) . to be_truthy
expect ( dossier . groupe_instructeur ) . to eq ( new_groupe_instructeur )
end
end
2020-02-25 15:51:30 +01:00
describe " # unfollow_stale_instructeurs " do
2020-03-24 12:50:59 +01:00
let ( :procedure ) { create ( :procedure , :published ) }
2020-02-25 15:51:30 +01:00
let ( :instructeur ) { create ( :instructeur ) }
2020-02-26 12:30:52 +01:00
let ( :new_groupe_instructeur ) { create ( :groupe_instructeur , procedure : procedure ) }
2020-02-25 15:51:30 +01:00
let ( :instructeur2 ) { create ( :instructeur , groupe_instructeurs : [ procedure . defaut_groupe_instructeur , new_groupe_instructeur ] ) }
2020-02-26 12:30:52 +01:00
let ( :dossier ) { create ( :dossier , :en_construction , procedure : procedure ) }
2020-02-26 10:28:37 +01:00
let ( :last_operation ) { DossierOperationLog . last }
2020-02-25 15:51:30 +01:00
2020-02-25 18:16:21 +01:00
before do
allow ( DossierMailer ) . to receive ( :notify_groupe_instructeur_changed ) . and_return ( double ( deliver_later : nil ) )
end
2020-02-25 15:51:30 +01:00
it " unfollows stale instructeurs when groupe instructeur change " do
instructeur . follow ( dossier )
instructeur2 . follow ( dossier )
2020-02-26 12:30:52 +01:00
dossier . reload . assign_to_groupe_instructeur ( new_groupe_instructeur , procedure . administrateurs . first )
2020-02-25 15:51:30 +01:00
expect ( dossier . reload . followers_instructeurs ) . not_to include ( instructeur )
expect ( dossier . reload . followers_instructeurs ) . to include ( instructeur2 )
2020-02-26 10:28:37 +01:00
2020-02-25 18:16:21 +01:00
expect ( DossierMailer ) . to have_received ( :notify_groupe_instructeur_changed ) . with ( instructeur , dossier )
expect ( DossierMailer ) . not_to have_received ( :notify_groupe_instructeur_changed ) . with ( instructeur2 , dossier )
2020-02-26 10:28:37 +01:00
expect ( last_operation . operation ) . to eq ( " changer_groupe_instructeur " )
expect ( last_operation . dossier ) . to eq ( dossier )
expect ( last_operation . automatic_operation? ) . to be_falsey
2020-02-25 15:51:30 +01:00
end
end
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 ) }
2018-08-28 14:10:55 +02:00
let ( :dossier ) { create ( :dossier , procedure : procedure , state : Dossier . states . fetch ( :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
2018-08-08 11:56:58 +02:00
include Rails . application . routes . url_helpers
2017-10-11 15:36:40 +02:00
let ( :procedure ) { create ( :procedure ) }
let ( :user ) { create ( :user ) }
it " send an email when the dossier is created for the very first time " do
2018-08-08 11:56:58 +02:00
dossier = nil
2018-05-25 18:05:28 +02:00
expect do
perform_enqueued_jobs do
2019-08-22 17:58:31 +02:00
dossier = Dossier . create ( groupe_instructeur : procedure . defaut_groupe_instructeur , state : Dossier . states . fetch ( :brouillon ) , user : user )
2018-05-25 18:05:28 +02:00
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
2019-07-17 13:42:14 +02:00
expect ( mail . subject ) . to eq ( " Retrouvez votre brouillon pour la démarche « #{ procedure . libelle } » " )
2018-08-08 11:56:58 +02:00
expect ( mail . html_part . body ) . to include ( dossier_url ( dossier ) )
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
2019-08-22 17:58:31 +02:00
expect { Dossier . create ( groupe_instructeur : procedure . defaut_groupe_instructeur , state : Dossier . states . fetch ( :en_construction ) , user : user ) } . not_to change ( ActionMailer :: Base . deliveries , :size )
expect { Dossier . create ( groupe_instructeur : procedure . defaut_groupe_instructeur , state : Dossier . states . fetch ( :en_instruction ) , user : user ) } . not_to change ( ActionMailer :: Base . deliveries , :size )
expect { Dossier . create ( groupe_instructeur : procedure . defaut_groupe_instructeur , state : Dossier . states . fetch ( :accepte ) , user : user ) } . not_to change ( ActionMailer :: Base . deliveries , :size )
expect { Dossier . create ( groupe_instructeur : procedure . defaut_groupe_instructeur , state : Dossier . states . fetch ( :refuse ) , user : user ) } . not_to change ( ActionMailer :: Base . deliveries , :size )
expect { Dossier . create ( groupe_instructeur : procedure . defaut_groupe_instructeur , state : Dossier . states . fetch ( :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 ) }
2018-08-28 14:10:55 +02:00
let ( :dossier ) { create ( :dossier , procedure : procedure , state : Dossier . states . fetch ( :en_instruction ) ) }
2018-04-06 13:09:37 +02:00
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 )
2019-09-12 11:26:22 +02:00
. filter { | c | c . libelle . match? ( / ^specified / ) }
2018-04-06 13:09:37 +02:00
. 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
2018-08-28 14:10:55 +02:00
let! ( :dossier ) { create ( :dossier , procedure : procedure , state : Dossier . states . fetch ( :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
2017-10-26 16:53:40 +02:00
describe 'updated_at' do
2017-10-24 18:12:25 +02:00
let! ( :dossier ) { create ( :dossier ) }
2018-10-25 15:17:33 +02:00
let ( :modif_date ) { Time . zone . parse ( '01/01/2100' ) }
2017-10-24 18:12:25 +02:00
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 champ is modified' do
before { dossier . champs . first . update_attribute ( 'value' , 'yop' ) }
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
2020-01-07 17:45:39 +01:00
let ( :procedure ) { create ( :procedure ) }
2017-11-17 23:40:51 +01:00
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
2020-01-07 17:45:39 +01:00
let ( :procedure ) { create ( :procedure , :for_individual ) }
2020-01-07 17:47:22 +01:00
let ( :dossier ) { create ( :dossier , :with_individual , procedure : procedure ) }
2017-11-17 23:40:51 +01:00
it { is_expected . to eq ( " #{ dossier . individual . nom } #{ dossier . individual . prenom } " ) }
end
end
2017-10-30 16:54:33 +01:00
2020-03-25 18:08:32 +01:00
describe " # discard_and_keep_track! " do
2020-03-19 11:53:25 +01:00
let ( :dossier ) { create ( :dossier , :en_construction ) }
let ( :deleted_dossier ) { DeletedDossier . find_by ( dossier_id : dossier . id ) }
2019-07-15 16:00:49 +02:00
let ( :last_operation ) { dossier . dossier_operation_logs . last }
2020-03-19 11:53:25 +01:00
let ( :reason ) { :user_request }
2018-07-23 14:44:42 +02:00
before do
allow ( DossierMailer ) . to receive ( :notify_deletion_to_user ) . and_return ( double ( deliver_later : nil ) )
allow ( DossierMailer ) . to receive ( :notify_deletion_to_administration ) . and_return ( double ( deliver_later : nil ) )
end
2020-03-25 18:08:32 +01:00
subject! { dossier . discard_and_keep_track! ( dossier . user , reason ) }
2018-07-23 14:44:42 +02:00
2020-03-19 11:53:25 +01:00
context 'brouillon' do
let ( :dossier ) { create ( :dossier ) }
2018-07-23 14:44:42 +02:00
2020-03-19 11:53:25 +01:00
it 'hides the dossier' do
expect ( dossier . discarded? ) . to be_truthy
end
2018-07-23 14:44:42 +02:00
2020-03-19 11:53:25 +01:00
it 'do not creates a DeletedDossier record' do
expect ( deleted_dossier ) . to be_nil
end
2018-07-23 15:06:06 +02:00
2020-03-19 11:53:25 +01:00
it 'do not records the operation in the log' do
expect ( last_operation ) . to be_nil
end
2019-07-15 16:00:49 +02:00
end
2020-03-19 11:53:25 +01:00
context 'en_construction' do
it 'hides the dossier' do
expect ( dossier . hidden_at ) . to be_present
2018-07-23 15:06:06 +02:00
end
2020-03-19 11:53:25 +01:00
it 'creates a DeletedDossier record' do
expect ( deleted_dossier . reason ) . to eq DeletedDossier . reasons . fetch ( reason )
expect ( deleted_dossier . dossier_id ) . to eq dossier . id
expect ( deleted_dossier . procedure ) . to eq dossier . procedure
expect ( deleted_dossier . state ) . to eq dossier . state
expect ( deleted_dossier . deleted_at ) . to be_present
2018-07-23 15:06:06 +02:00
end
2020-03-19 11:53:25 +01:00
it 'notifies the user' do
expect ( DossierMailer ) . to have_received ( :notify_deletion_to_user ) . with ( deleted_dossier , dossier . user . email )
2018-07-23 15:06:06 +02:00
end
2018-08-02 16:36:50 +02:00
2020-03-19 11:53:25 +01:00
it 'records the operation in the log' do
expect ( last_operation . operation ) . to eq ( " supprimer " )
expect ( last_operation . automatic_operation? ) . to be_falsey
end
context 'where instructeurs are following the dossier' do
let ( :dossier ) { create ( :dossier , :en_construction , :followed ) }
let! ( :non_following_instructeur ) do
non_following_instructeur = create ( :instructeur )
non_following_instructeur . groupe_instructeurs << dossier . procedure . defaut_groupe_instructeur
non_following_instructeur
end
it 'notifies the following instructeurs' do
expect ( DossierMailer ) . to have_received ( :notify_deletion_to_administration ) . once
expect ( DossierMailer ) . to have_received ( :notify_deletion_to_administration ) . with ( deleted_dossier , dossier . followers_instructeurs . first . email )
end
end
context 'when there are no following instructeurs' do
let ( :dossier ) { create ( :dossier , :en_construction ) }
it 'notifies the procedure administrateur' do
expect ( DossierMailer ) . to have_received ( :notify_deletion_to_administration ) . once
expect ( DossierMailer ) . to have_received ( :notify_deletion_to_administration ) . with ( deleted_dossier , dossier . procedure . administrateurs . first . email )
end
end
context 'when dossier is brouillon' do
let ( :dossier ) { create ( :dossier ) }
it 'do not notifies the procedure administrateur' do
expect ( DossierMailer ) . not_to have_received ( :notify_deletion_to_administration )
end
end
context 'with reason: manager_request' do
let ( :reason ) { :manager_request }
it 'hides the dossier' do
expect ( dossier . discarded? ) . to be_truthy
end
it 'records the operation in the log' do
expect ( last_operation . operation ) . to eq ( " supprimer " )
expect ( last_operation . automatic_operation? ) . to be_falsey
end
end
context 'with reason: user_removed' do
let ( :reason ) { :user_removed }
it 'hides the dossier' do
expect ( dossier . discarded? ) . to be_truthy
end
it 'records the operation in the log' do
expect ( last_operation . operation ) . to eq ( " supprimer " )
expect ( last_operation . automatic_operation? ) . to be_falsey
end
2018-08-02 16:36:50 +02:00
end
end
2018-07-23 14:44:42 +02:00
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
2018-08-28 14:10:55 +02:00
let ( :state ) { Dossier . states . fetch ( :brouillon ) }
2018-06-25 18:07:16 +02:00
it { is_expected . to be true }
2019-11-14 09:43:45 +01:00
context " procedure is closed " do
before { procedure . close! }
2018-06-25 18:07:16 +02:00
it { is_expected . to be false }
end
end
context " dossier state is en_construction " do
2018-08-28 14:10:55 +02:00
let ( :state ) { Dossier . states . fetch ( :en_construction ) }
2018-06-25 18:07:16 +02:00
it { is_expected . to be false }
end
context " dossier state is en_instruction " do
2018-08-28 14:10:55 +02:00
let ( :state ) { Dossier . states . fetch ( :en_instruction ) }
2018-06-25 18:07:16 +02:00
it { is_expected . to be false }
end
context " dossier state is en_instruction " do
2018-08-28 14:10:55 +02:00
let ( :state ) { Dossier . states . fetch ( :accepte ) }
2018-06-25 18:07:16 +02:00
it { is_expected . to be false }
end
context " dossier state is en_instruction " do
2018-08-28 14:10:55 +02:00
let ( :state ) { Dossier . states . fetch ( :refuse ) }
2018-06-25 18:07:16 +02:00
it { is_expected . to be false }
end
context " dossier state is en_instruction " do
2018-08-28 14:10:55 +02:00
let ( :state ) { Dossier . states . fetch ( :sans_suite ) }
2018-06-25 18:07:16 +02:00
it { is_expected . to be false }
end
end
2018-08-31 15:44:07 +02:00
2019-06-20 09:58:53 +02:00
describe " # messagerie_available? " do
let ( :procedure ) { create ( :procedure ) }
let ( :dossier ) { create ( :dossier , procedure : procedure ) }
subject { dossier . messagerie_available? }
context " dossier is brouillon " do
before { dossier . state = Dossier . states . fetch ( :brouillon ) }
it { is_expected . to be false }
end
2019-07-11 15:37:04 +02:00
context " dossier is submitted " do
before { dossier . state = Dossier . states . fetch ( :en_instruction ) }
2019-06-20 09:58:53 +02:00
2019-07-11 15:37:04 +02:00
it { is_expected . to be true }
2019-06-20 09:58:53 +02:00
end
2019-07-11 15:37:04 +02:00
context " dossier is archived " do
before { dossier . archived = true }
2019-06-20 09:58:53 +02:00
it { is_expected . to be false }
end
end
2019-01-16 11:00:25 +01:00
describe '#accepter!' do
2019-07-02 15:38:23 +02:00
let ( :dossier ) { create ( :dossier , :en_instruction ) }
2019-05-02 16:22:16 +02:00
let ( :last_operation ) { dossier . dossier_operation_logs . last }
let ( :operation_serialized ) { JSON . parse ( last_operation . serialized . download ) }
2019-08-06 11:02:54 +02:00
let! ( :instructeur ) { create ( :instructeur ) }
2019-01-16 11:00:25 +01:00
let! ( :now ) { Time . zone . parse ( '01/01/2100' ) }
let ( :attestation ) { Attestation . new }
before do
allow ( NotificationMailer ) . to receive ( :send_closed_notification ) . and_return ( double ( deliver_later : true ) )
allow ( dossier ) . to receive ( :build_attestation ) . and_return ( attestation )
Timecop . freeze ( now )
2019-08-06 11:02:54 +02:00
dossier . accepter! ( instructeur , 'motivation' )
2019-01-16 11:00:25 +01:00
dossier . reload
end
after { Timecop . return }
it { expect ( dossier . motivation ) . to eq ( 'motivation' ) }
2019-07-02 15:38:23 +02:00
it { expect ( dossier . en_instruction_at ) . to eq ( dossier . en_instruction_at ) }
2019-01-16 11:00:25 +01:00
it { expect ( dossier . processed_at ) . to eq ( now ) }
it { expect ( dossier . state ) . to eq ( 'accepte' ) }
2019-05-02 16:22:16 +02:00
it { expect ( last_operation . operation ) . to eq ( 'accepter' ) }
it { expect ( last_operation . automatic_operation? ) . to be_falsey }
it { expect ( operation_serialized [ 'operation' ] ) . to eq ( 'accepter' ) }
it { expect ( operation_serialized [ 'dossier_id' ] ) . to eq ( dossier . id ) }
it { expect ( operation_serialized [ 'executed_at' ] ) . to eq ( last_operation . executed_at . iso8601 ) }
2019-01-16 11:00:25 +01:00
it { expect ( NotificationMailer ) . to have_received ( :send_closed_notification ) . with ( dossier ) }
it { expect ( dossier . attestation ) . to eq ( attestation ) }
end
describe '#accepter_automatiquement!' do
2019-07-02 15:38:23 +02:00
let ( :dossier ) { create ( :dossier , :en_construction ) }
2019-05-02 16:22:16 +02:00
let ( :last_operation ) { dossier . dossier_operation_logs . last }
2019-01-16 11:00:25 +01:00
let! ( :now ) { Time . zone . parse ( '01/01/2100' ) }
let ( :attestation ) { Attestation . new }
before do
allow ( NotificationMailer ) . to receive ( :send_closed_notification ) . and_return ( double ( deliver_later : true ) )
allow ( dossier ) . to receive ( :build_attestation ) . and_return ( attestation )
Timecop . freeze ( now )
dossier . accepter_automatiquement!
dossier . reload
end
after { Timecop . return }
it { expect ( dossier . motivation ) . to eq ( nil ) }
it { expect ( dossier . en_instruction_at ) . to eq ( now ) }
it { expect ( dossier . processed_at ) . to eq ( now ) }
it { expect ( dossier . state ) . to eq ( 'accepte' ) }
2019-05-02 16:22:16 +02:00
it { expect ( last_operation . operation ) . to eq ( 'accepter' ) }
it { expect ( last_operation . automatic_operation? ) . to be_truthy }
2019-01-16 11:00:25 +01:00
it { expect ( NotificationMailer ) . to have_received ( :send_closed_notification ) . with ( dossier ) }
it { expect ( dossier . attestation ) . to eq ( attestation ) }
end
2019-01-10 17:23:48 +01:00
describe '#passer_en_instruction!' do
2019-07-02 15:38:23 +02:00
let ( :dossier ) { create ( :dossier , :en_construction ) }
2019-05-02 16:22:16 +02:00
let ( :last_operation ) { dossier . dossier_operation_logs . last }
let ( :operation_serialized ) { JSON . parse ( last_operation . serialized . download ) }
2019-08-06 11:02:54 +02:00
let ( :instructeur ) { create ( :instructeur ) }
2019-01-10 17:23:48 +01:00
2019-08-06 11:02:54 +02:00
before { dossier . passer_en_instruction! ( instructeur ) }
2019-01-10 17:23:48 +01:00
it { expect ( dossier . state ) . to eq ( 'en_instruction' ) }
2019-08-06 11:02:54 +02:00
it { expect ( dossier . followers_instructeurs ) . to include ( instructeur ) }
2019-05-02 16:22:16 +02:00
it { expect ( last_operation . operation ) . to eq ( 'passer_en_instruction' ) }
it { expect ( last_operation . automatic_operation? ) . to be_falsey }
it { expect ( operation_serialized [ 'operation' ] ) . to eq ( 'passer_en_instruction' ) }
it { expect ( operation_serialized [ 'dossier_id' ] ) . to eq ( dossier . id ) }
it { expect ( operation_serialized [ 'executed_at' ] ) . to eq ( last_operation . executed_at . iso8601 ) }
2019-01-10 17:23:48 +01:00
end
describe '#passer_automatiquement_en_instruction!' do
2019-07-02 15:38:23 +02:00
let ( :dossier ) { create ( :dossier , :en_construction ) }
2019-05-02 16:22:16 +02:00
let ( :last_operation ) { dossier . dossier_operation_logs . last }
let ( :operation_serialized ) { JSON . parse ( last_operation . serialized . download ) }
2019-08-06 11:02:54 +02:00
let ( :instructeur ) { create ( :instructeur ) }
2019-01-10 17:23:48 +01:00
before { dossier . passer_automatiquement_en_instruction! }
2019-08-06 11:02:54 +02:00
it { expect ( dossier . followers_instructeurs ) . not_to include ( instructeur ) }
2019-05-02 16:22:16 +02:00
it { expect ( last_operation . operation ) . to eq ( 'passer_en_instruction' ) }
it { expect ( last_operation . automatic_operation? ) . to be_truthy }
it { expect ( operation_serialized [ 'operation' ] ) . to eq ( 'passer_en_instruction' ) }
it { expect ( operation_serialized [ 'dossier_id' ] ) . to eq ( dossier . id ) }
it { expect ( operation_serialized [ 'executed_at' ] ) . to eq ( last_operation . executed_at . iso8601 ) }
2019-01-10 17:23:48 +01:00
end
2019-01-30 16:14:15 +01:00
describe " # check_mandatory_champs " do
let ( :procedure ) { create ( :procedure , :with_type_de_champ ) }
2019-07-09 15:57:48 +02:00
let ( :dossier ) { create ( :dossier , procedure : procedure ) }
2019-01-30 16:14:15 +01:00
it 'no mandatory champs' do
expect ( dossier . check_mandatory_champs ) . to be_empty
end
context " with mandatory champs " do
let ( :procedure ) { create ( :procedure , :with_type_de_champ_mandatory ) }
let ( :champ_with_error ) { dossier . champs . first }
before do
champ_with_error . value = nil
champ_with_error . save
end
it 'should have errors' do
errors = dossier . check_mandatory_champs
expect ( errors ) . not_to be_empty
expect ( errors . first ) . to eq ( " Le champ #{ champ_with_error . libelle } doit être rempli. " )
end
end
2019-03-28 11:28:27 +01:00
context " with mandatory SIRET champ " do
let ( :type_de_champ ) { create ( :type_de_champ_siret , mandatory : true ) }
let ( :champ_siret ) { create ( :champ_siret , type_de_champ : type_de_champ ) }
before do
dossier . champs << champ_siret
end
it 'should not have errors' do
errors = dossier . check_mandatory_champs
expect ( errors ) . to be_empty
end
context " and invalid SIRET " do
before do
champ_siret . update ( value : " 1234 " )
dossier . reload
end
it 'should have errors' do
errors = dossier . check_mandatory_champs
expect ( errors ) . not_to be_empty
expect ( errors . first ) . to eq ( " Le champ #{ champ_siret . libelle } doit être rempli. " )
end
end
end
2019-01-30 16:14:15 +01:00
context " with champ repetition " do
let ( :procedure ) { create ( :procedure ) }
let ( :type_de_champ_repetition ) { create ( :type_de_champ_repetition , mandatory : true ) }
before do
procedure . types_de_champ << type_de_champ_repetition
type_de_champ_repetition . types_de_champ << create ( :type_de_champ_text , mandatory : true )
end
context " when no champs " do
2019-07-09 15:57:48 +02:00
let ( :champ_with_error ) do
repetition_champ = dossier . champs . first
text_champ = repetition_champ . rows . first . first
text_champ
end
2019-01-30 16:14:15 +01:00
it 'should have errors' do
errors = dossier . check_mandatory_champs
expect ( errors ) . not_to be_empty
expect ( errors . first ) . to eq ( " Le champ #{ champ_with_error . libelle } doit être rempli. " )
end
end
context " when mandatory champ inside repetition " do
let ( :champ_with_error ) { dossier . champs . first . champs . first }
before do
dossier . champs . first . add_row
end
it 'should have errors' do
errors = dossier . check_mandatory_champs
expect ( errors ) . not_to be_empty
expect ( errors . first ) . to eq ( " Le champ #{ champ_with_error . libelle } doit être rempli. " )
end
end
end
end
2019-02-13 16:13:37 +01:00
2019-07-01 17:45:03 +02:00
describe '#repasser_en_instruction!' do
2020-05-12 19:01:25 +02:00
let ( :dossier ) { create ( :dossier , :refuse , :with_attestation , archived : true ) }
2019-08-06 11:02:54 +02:00
let! ( :instructeur ) { create ( :instructeur ) }
2019-07-01 17:45:03 +02:00
let ( :last_operation ) { dossier . dossier_operation_logs . last }
before do
Timecop . freeze
allow ( DossierMailer ) . to receive ( :notify_revert_to_instruction )
. and_return ( double ( deliver_later : true ) )
2019-08-06 11:02:54 +02:00
dossier . repasser_en_instruction! ( instructeur )
2019-07-01 17:45:03 +02:00
dossier . reload
end
it { expect ( dossier . state ) . to eq ( 'en_instruction' ) }
2020-05-12 19:01:25 +02:00
it { expect ( dossier . archived ) . to be_falsey }
2019-07-01 17:45:03 +02:00
it { expect ( dossier . processed_at ) . to be_nil }
it { expect ( dossier . motivation ) . to be_nil }
it { expect ( dossier . attestation ) . to be_nil }
it { expect ( last_operation . operation ) . to eq ( 'repasser_en_instruction' ) }
2019-08-06 11:02:54 +02:00
it { expect ( JSON . parse ( last_operation . serialized . download ) [ 'author' ] [ 'email' ] ) . to eq ( instructeur . email ) }
2019-07-01 17:45:03 +02:00
it { expect ( DossierMailer ) . to have_received ( :notify_revert_to_instruction ) . with ( dossier ) }
after { Timecop . return }
end
2019-07-01 15:55:37 +02:00
describe '#attachments_downloadable?' do
let ( :dossier ) { create ( :dossier , user : user ) }
# subject { dossier.attachments_downloadable? }
context " no attachments " do
it {
expect ( PiecesJustificativesService ) . to receive ( :liste_pieces_justificatives ) . and_return ( [ ] )
expect ( dossier . attachments_downloadable? ) . to be false
}
end
context " with a small attachment " do
it {
expect ( PiecesJustificativesService ) . to receive ( :liste_pieces_justificatives ) . and_return ( [ Champ . new ] )
expect ( PiecesJustificativesService ) . to receive ( :pieces_justificatives_total_size ) . and_return ( 4 . megabytes )
expect ( dossier . attachments_downloadable? ) . to be true
}
end
context " with a too large attachment " do
it {
expect ( PiecesJustificativesService ) . to receive ( :liste_pieces_justificatives ) . and_return ( [ Champ . new ] )
expect ( PiecesJustificativesService ) . to receive ( :pieces_justificatives_total_size ) . and_return ( 100 . megabytes )
expect ( dossier . attachments_downloadable? ) . to be false
}
end
end
2019-07-31 16:56:39 +02:00
2019-09-18 13:07:30 +02:00
describe '#for_procedure' do
let! ( :procedure_1 ) { create ( :procedure ) }
let! ( :procedure_2 ) { create ( :procedure ) }
let! ( :dossier_1_1 ) { create ( :dossier , procedure : procedure_1 ) }
let! ( :dossier_1_2 ) { create ( :dossier , procedure : procedure_1 ) }
let! ( :dossier_2_1 ) { create ( :dossier , procedure : procedure_2 ) }
before do
gi_1_2 = procedure_1 . groupe_instructeurs . create ( label : 2 )
gi_1_2 . dossiers << dossier_1_2
end
it { expect ( Dossier . for_procedure ( procedure_1 ) ) . to contain_exactly ( dossier_1_1 , dossier_1_2 ) }
it { expect ( Dossier . for_procedure ( procedure_2 ) ) . to contain_exactly ( dossier_2_1 ) }
end
2019-12-03 10:31:10 +01:00
2020-02-05 22:10:22 +01:00
describe '#notify_draft_not_submitted' do
let! ( :user1 ) { create ( :user ) }
let! ( :user2 ) { create ( :user ) }
2020-04-29 19:18:12 +02:00
let! ( :procedure_near_closing ) { create ( :procedure , :published , auto_archive_on : Time . zone . today + Dossier :: REMAINING_DAYS_BEFORE_CLOSING . days ) }
let! ( :procedure_closed_later ) { create ( :procedure , :published , auto_archive_on : Time . zone . today + Dossier :: REMAINING_DAYS_BEFORE_CLOSING . days + 1 . day ) }
let! ( :procedure_closed_before ) { create ( :procedure , :published , auto_archive_on : Time . zone . today + Dossier :: REMAINING_DAYS_BEFORE_CLOSING . days - 1 . day ) }
2020-02-05 22:10:22 +01:00
# user 1 has three draft dossiers where one is for procedure that closes in two days ==> should trigger one mail
2020-03-25 04:09:14 +01:00
let! ( :draft_near_closing ) { create ( :dossier , user : user1 , procedure : procedure_near_closing ) }
2020-02-05 22:10:22 +01:00
let! ( :draft_before ) { create ( :dossier , user : user1 , procedure : procedure_closed_before ) }
let! ( :draft_later ) { create ( :dossier , user : user1 , procedure : procedure_closed_later ) }
# user 2 submitted a draft and en_construction dossier for the same procedure ==> should not trigger the mail
2020-03-25 04:09:14 +01:00
let! ( :draft_near_closing_2 ) { create ( :dossier , :en_construction , user : user2 , procedure : procedure_near_closing ) }
let! ( :submitted_near_closing_2 ) { create ( :dossier , user : user2 , procedure : procedure_near_closing ) }
2020-02-05 22:10:22 +01:00
before do
2020-03-19 03:46:12 +01:00
allow ( DossierMailer ) . to receive ( :notify_brouillon_not_submitted ) . and_return ( double ( deliver_later : nil ) )
2020-02-05 22:10:22 +01:00
Dossier . notify_draft_not_submitted
end
it 'notifies draft is not submitted' do
2020-03-19 03:46:12 +01:00
expect ( DossierMailer ) . to have_received ( :notify_brouillon_not_submitted ) . once
expect ( DossierMailer ) . to have_received ( :notify_brouillon_not_submitted ) . with ( draft_near_closing )
2020-02-05 22:10:22 +01:00
end
end
2020-01-14 19:00:17 +01:00
describe '#geo_position' do
let ( :lat ) { " 46.538192 " }
let ( :lon ) { " 2.428462 " }
let ( :zoom ) { " 13 " }
let ( :etablissement_geo_adresse_lat ) { " 40.7143528 " }
let ( :etablissement_geo_adresse_lon ) { " -74.0059731 " }
let ( :result ) { { lat : lat , lon : lon , zoom : zoom } }
let ( :dossier ) { create ( :dossier ) }
it 'should geolocate' do
expect ( dossier . geo_position ) . to eq ( result )
end
context 'with etablissement' do
before do
Geocoder :: Lookup :: Test . add_stub (
dossier . etablissement . geo_adresse , [
{
'coordinates' = > [ etablissement_geo_adresse_lat . to_f , etablissement_geo_adresse_lon . to_f ]
}
]
)
end
let ( :dossier ) { create ( :dossier , :with_entreprise ) }
let ( :result ) { { lat : etablissement_geo_adresse_lat , lon : etablissement_geo_adresse_lon , zoom : zoom } }
it 'should geolocate' do
expect ( dossier . geo_position ) . to eq ( result )
end
end
end
2020-03-19 18:33:38 +01:00
describe 'dossier_operation_log after dossier deletion' do
let ( :dossier ) { create ( :dossier ) }
let ( :dossier_operation_log ) { create ( :dossier_operation_log , dossier : dossier ) }
it 'should nullify dossier link' do
expect ( dossier_operation_log . dossier ) . to eq ( dossier )
expect ( DossierOperationLog . count ) . to eq ( 1 )
dossier . destroy
expect ( dossier_operation_log . reload . dossier ) . to be_nil
expect ( DossierOperationLog . count ) . to eq ( 1 )
end
end
2020-03-19 13:11:45 +01:00
describe 'discarded_brouillon_expired and discarded_en_construction_expired' do
2020-03-26 09:08:52 +01:00
let ( :administration ) { create ( :administration ) }
2020-03-19 13:11:45 +01:00
before do
create ( :dossier )
create ( :dossier , :en_construction )
create ( :dossier ) . discard!
create ( :dossier , :en_construction ) . discard!
Timecop . travel ( 2 . months . ago ) do
create ( :dossier ) . discard!
create ( :dossier , :en_construction ) . discard!
2020-03-26 09:08:52 +01:00
create ( :dossier ) . procedure . discard_and_keep_track! ( administration )
create ( :dossier , :en_construction ) . procedure . discard_and_keep_track! ( administration )
2020-03-19 13:11:45 +01:00
end
Timecop . travel ( 1 . week . ago ) do
create ( :dossier ) . discard!
create ( :dossier , :en_construction ) . discard!
end
end
it { expect ( Dossier . discarded_brouillon_expired . count ) . to eq ( 2 ) }
2020-03-26 17:37:55 +01:00
it { expect ( Dossier . discarded_en_construction_expired . count ) . to eq ( 2 ) }
2020-03-19 13:11:45 +01:00
end
2020-03-31 14:51:07 +02:00
describe " discarded procedure dossier should be able to access it's procedure " do
let ( :dossier ) { create ( :dossier ) }
let ( :procedure ) { dossier . reload . procedure }
before { dossier . procedure . discard! }
it { expect ( procedure ) . not_to be_nil }
it { expect ( procedure . discarded? ) . to be_truthy }
end
2020-04-30 15:49:43 +02:00
describe " to_feature_collection " do
let ( :geo_area ) { create ( :geo_area , :selection_utilisateur , :polygon ) }
let ( :champ ) { create ( :champ_carte , geo_areas : [ geo_area ] ) }
let ( :dossier ) { create ( :dossier , champs : [ champ ] ) }
it 'should have all champs carto' do
expect ( dossier . to_feature_collection ) . to eq ( {
type : 'FeatureCollection' ,
id : dossier . id ,
bbox : [ 2 . 428439855575562 , 46 . 538491597754714 , 2 . 42824137210846 , 46 . 53841410755813 ] ,
features : [
{
type : 'Feature' ,
geometry : {
'coordinates' = > [ [ [ 2 . 428439855575562 , 46 . 538476837725796 ] , [ 2 . 4284291267395024 , 46 . 53842148758162 ] , [ 2 . 4282521009445195 , 46 . 53841410755813 ] , [ 2 . 42824137210846 , 46 . 53847314771794 ] , [ 2 . 428284287452698 , 46 . 53847314771794 ] , [ 2 . 428364753723145 , 46 . 538487907747864 ] , [ 2 . 4284291267395024 , 46 . 538491597754714 ] , [ 2 . 428439855575562 , 46 . 538476837725796 ] ] ] ,
'type' = > 'Polygon'
} ,
properties : {
area : 219 . 0 ,
champ_id : champ . stable_id ,
dossier_id : dossier . id ,
id : geo_area . id ,
source : 'selection_utilisateur'
}
}
]
} )
end
end
2020-04-29 19:18:12 +02:00
describe " with_notifiable_procedure " do
let ( :test_procedure ) { create ( :procedure ) }
let ( :published_procedure ) { create ( :procedure , :published ) }
let ( :closed_procedure ) { create ( :procedure , :closed ) }
let ( :unpublished_procedure ) { create ( :procedure , :unpublished ) }
let! ( :dossier_on_test_procedure ) { create ( :dossier , procedure : test_procedure ) }
let! ( :dossier_on_published_procedure ) { create ( :dossier , procedure : published_procedure ) }
let! ( :dossier_on_closed_procedure ) { create ( :dossier , procedure : closed_procedure ) }
let! ( :dossier_on_unpublished_procedure ) { create ( :dossier , procedure : unpublished_procedure ) }
let ( :notify_on_closed ) { false }
let ( :dossiers ) { Dossier . with_notifiable_procedure ( notify_on_closed : notify_on_closed ) }
it 'should find dossiers with notifiable procedure' do
expect ( dossiers ) . to match_array ( [ dossier_on_published_procedure , dossier_on_unpublished_procedure ] )
end
context 'when notify on closed is true' do
let ( :notify_on_closed ) { true }
it 'should find dossiers with notifiable procedure' do
expect ( dossiers ) . to match_array ( [ dossier_on_published_procedure , dossier_on_closed_procedure , dossier_on_unpublished_procedure ] )
end
end
end
2015-08-20 17:30:17 +02:00
end