2015-09-23 12:04:57 +02:00
require 'spec_helper'
describe Users :: DossiersController , type : :controller do
2015-09-24 11:17:17 +02:00
let ( :user ) { create ( :user ) }
2015-11-27 13:56:54 +01:00
2016-06-09 17:49:38 +02:00
let ( :procedure ) { create ( :procedure , :published ) }
2015-12-03 12:00:22 +01:00
let ( :procedure_id ) { procedure . id }
2016-06-20 13:57:57 +02:00
let ( :dossier ) { create ( :dossier , user : user , procedure : procedure ) }
2015-09-23 19:20:03 +02:00
let ( :dossier_id ) { dossier . id }
let ( :siret_not_found ) { 999_999_999_999 }
2015-12-11 12:36:44 +01:00
let ( :rna_status ) { 404 }
let ( :rna_body ) { '' }
2016-06-20 13:57:57 +02:00
let ( :user ) { create :user }
2016-01-20 10:34:22 +01:00
let ( :exercices_status ) { 200 }
let ( :exercices_body ) { File . read ( 'spec/support/files/exercices.json' ) }
2016-06-20 13:57:57 +02:00
let ( :siren ) { '440117620' }
let ( :siret ) { '44011762001530' }
2016-05-24 15:43:05 +02:00
let ( :siret_with_whitespaces ) { '440 1176 2001 530' }
2015-09-23 19:20:03 +02:00
let ( :bad_siret ) { 1 }
describe 'GET #show' do
before do
2015-11-27 13:56:54 +01:00
sign_in dossier . user
2015-09-23 19:20:03 +02:00
end
it 'returns http success with dossier_id valid' do
2016-11-15 05:54:27 +01:00
get :show , params : { id : dossier_id }
2015-09-23 19:20:03 +02:00
expect ( response ) . to have_http_status ( :success )
end
2015-12-03 12:00:22 +01:00
it 'redirection vers liste dossier si mauvais dossier ID' do
2016-11-15 05:54:27 +01:00
get :show , params : { id : siret_not_found }
2016-01-25 15:54:21 +01:00
expect ( response ) . to redirect_to root_path
end
describe 'before_action authorized_routes?' do
context 'when dossier does not have a valid state' do
before do
2017-02-23 17:54:11 +01:00
dossier . state = 'received'
2016-01-25 15:54:21 +01:00
dossier . save
2016-11-15 05:54:27 +01:00
get :show , params : { id : dossier . id }
2016-01-25 15:54:21 +01:00
end
it { is_expected . to redirect_to root_path }
end
2015-12-03 12:00:22 +01:00
end
end
describe 'GET #new' do
2016-11-15 05:54:27 +01:00
subject { get :new , params : { procedure_id : procedure_id } }
2015-12-03 12:00:22 +01:00
context 'when params procedure_id is present' do
context 'when procedure_id is valid' do
context 'when user is logged in' do
before do
2016-06-20 13:57:57 +02:00
sign_in user
2015-12-03 12:00:22 +01:00
end
2016-06-20 13:57:57 +02:00
it { is_expected . to have_http_status ( 302 ) }
it { is_expected . to redirect_to users_dossier_path ( id : Dossier . last ) }
it { expect { subject } . to change ( Dossier , :count ) . by 1 }
describe 'save user siret' do
context 'when user have not a saved siret' do
context 'when siret is present on request' do
2016-11-15 05:54:27 +01:00
subject { get :new , params : { procedure_id : procedure_id , siret : siret } }
2016-06-20 13:57:57 +02:00
before do
subject
user . reload
end
it { expect ( user . siret ) . to eq siret }
end
context 'when siret is not present on the request' do
before do
subject
user . reload
end
it { expect ( user . siret ) . to eq nil }
end
end
context 'when user have a saved siret' do
before do
user . siret = '53029478400026'
user . save
user . reload
end
context 'when siret is present on request' do
2016-11-15 05:54:27 +01:00
subject { get :new , params : { procedure_id : procedure_id , siret : siret } }
2016-06-20 13:57:57 +02:00
before do
subject
user . reload
end
it { expect ( user . siret ) . to eq siret }
end
context 'when siret is not present on the request' do
before do
subject
user . reload
end
it { expect ( user . siret ) . to eq '53029478400026' }
end
end
end
2015-12-03 12:00:22 +01:00
context 'when procedure is archived' do
2017-07-10 23:42:33 +02:00
let ( :procedure ) { create ( :procedure , archived_at : Time . now ) }
2015-12-03 12:00:22 +01:00
2015-12-24 15:22:30 +01:00
it { is_expected . to redirect_to users_dossiers_path }
2015-12-03 12:00:22 +01:00
end
end
context 'when user is not logged' do
it { is_expected . to have_http_status ( 302 ) }
2016-06-20 13:57:57 +02:00
it { is_expected . to redirect_to new_user_session_path }
2015-12-03 12:00:22 +01:00
end
end
context 'when procedure_id is not valid' do
let ( :procedure_id ) { 0 }
before do
2016-06-20 13:57:57 +02:00
sign_in user
2015-12-03 12:00:22 +01:00
end
2015-12-24 15:22:30 +01:00
it { is_expected . to redirect_to users_dossiers_path }
2015-12-03 12:00:22 +01:00
end
2016-06-09 17:49:38 +02:00
context 'when procedure is not published' do
2017-07-11 14:21:10 +02:00
let ( :procedure ) { create ( :procedure , published_at : nil ) }
2016-06-09 17:49:38 +02:00
before do
2016-06-20 13:57:57 +02:00
sign_in user
2016-06-09 17:49:38 +02:00
end
it { is_expected . to redirect_to users_dossiers_path }
end
2015-09-23 19:20:03 +02:00
end
end
2016-06-29 17:35:34 +02:00
describe 'GET #commencer' do
2017-07-06 14:40:06 +02:00
subject { get :commencer , params : { procedure_path : procedure . path } }
2016-06-29 17:35:34 +02:00
it { expect ( subject . status ) . to eq 302 }
it { expect ( subject ) . to redirect_to new_users_dossier_path ( procedure_id : procedure . id ) }
2016-11-07 17:08:33 +01:00
context 'when procedure is archived' do
2017-07-10 23:42:33 +02:00
let ( :procedure ) { create ( :procedure , :published , archived_at : Time . now ) }
2016-11-07 17:08:33 +01:00
before do
2017-07-10 23:42:33 +02:00
procedure . update_column :archived_at , Time . now
2016-11-07 17:08:33 +01:00
end
it { expect ( subject . status ) . to eq 200 }
end
2017-07-06 14:40:06 +02:00
context 'when procedure is hidden' do
let ( :procedure ) { create ( :procedure , :published , hidden_at : DateTime . now ) }
it { expect ( subject ) . to redirect_to ( root_path ) }
end
2016-06-29 17:35:34 +02:00
end
2016-06-20 13:57:57 +02:00
describe 'POST #siret_informations' do
2016-07-22 11:34:34 +02:00
let ( :user ) { create ( :user ) }
2015-09-23 19:20:03 +02:00
before do
2016-06-13 10:13:37 +02:00
stub_request ( :get , " https://api-dev.apientreprise.fr/v2/etablissements/ #{ siret_not_found } ?token= #{ SIADETOKEN } " )
2015-11-27 13:56:54 +01:00
. to_return ( status : 404 , body : 'fake body' )
2015-09-23 19:20:03 +02:00
2016-06-13 10:13:37 +02:00
stub_request ( :get , " https://api-dev.apientreprise.fr/v2/etablissements/ #{ siret } ?token= #{ SIADETOKEN } " )
2016-07-22 11:34:34 +02:00
. to_return ( status : status_entreprise_call , body : File . read ( 'spec/support/files/etablissement.json' ) )
2015-09-23 19:20:03 +02:00
2016-06-13 10:13:37 +02:00
stub_request ( :get , " https://api-dev.apientreprise.fr/v2/entreprises/ #{ siren } ?token= #{ SIADETOKEN } " )
2016-07-22 11:34:34 +02:00
. to_return ( status : status_entreprise_call , body : File . read ( 'spec/support/files/entreprise.json' ) )
2015-11-16 11:23:29 +01:00
2016-06-13 10:13:37 +02:00
stub_request ( :get , " https://api-dev.apientreprise.fr/v1/etablissements/exercices/ #{ siret } ?token= #{ SIADETOKEN } " )
2016-01-20 10:34:22 +01:00
. to_return ( status : exercices_status , body : exercices_body )
2015-12-11 12:36:44 +01:00
2016-06-13 10:13:37 +02:00
stub_request ( :get , " https://api-dev.apientreprise.fr/v1/associations/ #{ siret } ?token= #{ SIADETOKEN } " )
2015-12-11 12:36:44 +01:00
. to_return ( status : rna_status , body : rna_body )
2016-06-20 13:57:57 +02:00
dossier
2015-09-23 19:20:03 +02:00
end
2015-12-11 12:36:44 +01:00
describe 'dossier attributs' do
2016-07-22 11:34:34 +02:00
let ( :status_entreprise_call ) { 200 }
2016-05-24 15:43:05 +02:00
shared_examples 'with valid siret' do
2015-12-03 12:00:22 +01:00
before do
sign_in user
end
2015-09-23 19:20:03 +02:00
2016-11-15 05:54:27 +01:00
subject { post :siret_informations , params : { dossier_id : dossier . id , dossier : { siret : example_siret } } }
2015-09-23 19:20:03 +02:00
2015-12-03 12:00:22 +01:00
it 'create a dossier' do
2016-06-20 13:57:57 +02:00
expect { subject } . to change { Dossier . count } . by ( 0 )
2015-12-03 12:00:22 +01:00
end
2015-09-23 19:20:03 +02:00
2015-12-03 12:00:22 +01:00
it 'creates entreprise' do
expect { subject } . to change { Entreprise . count } . by ( 1 )
end
2015-09-23 19:20:03 +02:00
2015-12-03 12:00:22 +01:00
it 'links entreprise to dossier' do
subject
expect ( Entreprise . last . dossier ) . to eq ( Dossier . last )
end
2015-09-23 19:20:03 +02:00
2015-12-03 12:00:22 +01:00
it " links dossier to user " do
subject
expect ( Dossier . last . user ) . to eq ( user )
end
2015-09-24 11:17:17 +02:00
2015-12-03 12:00:22 +01:00
it 'creates etablissement for dossier' do
expect { subject } . to change { Etablissement . count } . by ( 1 )
end
2015-09-23 19:20:03 +02:00
2015-12-03 12:00:22 +01:00
it 'links etablissement to dossier' do
subject
expect ( Etablissement . last . dossier ) . to eq ( Dossier . last )
end
2015-09-23 19:20:03 +02:00
2015-12-03 12:00:22 +01:00
it 'links etablissement to entreprise' do
subject
expect ( Etablissement . last . entreprise ) . to eq ( Entreprise . last )
end
2015-09-23 19:20:03 +02:00
2015-12-03 12:00:22 +01:00
it 'creates exercices for dossier' do
expect { subject } . to change { Exercice . count } . by ( 3 )
expect ( Exercice . last . etablissement ) . to eq ( Dossier . last . etablissement )
end
2015-11-16 11:23:29 +01:00
2016-01-20 10:34:22 +01:00
context 'when siret have no exercices' do
let ( :exercices_status ) { 404 }
let ( :exercices_body ) { '' }
it { expect { subject } . not_to change { Exercice . count } }
end
2015-12-03 12:00:22 +01:00
it 'links procedure to dossier' do
subject
expect ( Dossier . last . procedure ) . to eq ( Procedure . last )
end
2015-09-23 19:20:03 +02:00
2015-12-03 12:00:22 +01:00
it 'state of dossier is draft' do
subject
expect ( Dossier . last . state ) . to eq ( 'draft' )
2015-09-23 19:20:03 +02:00
end
2015-12-11 12:36:44 +01:00
2016-01-06 14:17:08 +01:00
describe 'Mandataires Sociaux' do
2016-01-21 17:06:09 +01:00
let ( :france_connect_information ) { create ( :france_connect_information , given_name : given_name , family_name : family_name , birthdate : birthdate , france_connect_particulier_id : '1234567' ) }
let ( :user ) { create ( :user , france_connect_information : france_connect_information ) }
2016-01-06 14:17:08 +01:00
before do
subject
end
context 'when user is present in mandataires sociaux' do
let ( :given_name ) { 'GERARD' }
let ( :family_name ) { 'DEGONSE' }
let ( :birthdate ) { '1947-07-03' }
it { expect ( Dossier . last . mandataire_social ) . to be_truthy }
end
context 'when user is not present in mandataires sociaux' do
let ( :given_name ) { 'plop' }
let ( :family_name ) { 'plip' }
let ( :birthdate ) { '1965-01-27' }
it { expect ( Dossier . last . mandataire_social ) . to be_falsey }
end
end
2015-12-11 12:36:44 +01:00
describe 'get rna informations' do
context 'when siren have not rna informations' do
let ( :rna_status ) { 404 }
let ( :rna_body ) { '' }
it 'not creates rna information for entreprise' do
expect { subject } . to change { RNAInformation . count } . by ( 0 )
end
end
context 'when siren have rna informations' do
let ( :rna_status ) { 200 }
let ( :rna_body ) { File . read ( 'spec/support/files/rna.json' ) }
it 'creates rna information for entreprise' do
expect { subject } . to change { RNAInformation . count } . by ( 1 )
end
it 'links rna informations to entreprise' do
subject
expect ( RNAInformation . last . entreprise ) . to eq ( Entreprise . last )
end
end
end
2015-12-03 12:00:22 +01:00
end
2015-09-23 19:20:03 +02:00
2016-05-24 15:43:05 +02:00
describe " with siret without whitespaces " do
let ( :example_siret ) { siret }
2017-02-21 22:05:22 +01:00
if ENV [ 'CIRCLECI' ] . nil?
it_should_behave_like " with valid siret "
end
2016-05-24 15:43:05 +02:00
end
describe " with siret with whitespaces " do
let ( :example_siret ) { siret_with_whitespaces }
2017-02-21 22:05:22 +01:00
if ENV [ 'CIRCLECI' ] . nil?
it_should_behave_like " with valid siret "
end
2016-05-24 15:43:05 +02:00
end
2015-12-03 12:00:22 +01:00
context 'with non existant siret' do
before do
2016-06-20 13:57:57 +02:00
sign_in user
subject
2015-12-03 12:00:22 +01:00
end
2015-09-23 19:20:03 +02:00
2015-12-03 12:00:22 +01:00
let ( :siret_not_found ) { '11111111111111' }
2016-11-15 05:54:27 +01:00
subject { post :siret_informations , params : { dossier_id : dossier . id , dossier : { siret : siret_not_found } } }
2016-06-20 13:57:57 +02:00
2015-12-03 12:00:22 +01:00
it 'does not create new dossier' do
expect { subject } . not_to change { Dossier . count }
end
2015-09-23 19:20:03 +02:00
2016-06-20 13:57:57 +02:00
it { expect ( response . status ) . to eq 200 }
it { expect ( flash . alert ) . to eq 'Le siret est incorrect' }
it { expect ( response . to_a [ 2 ] ) . to be_an_instance_of ActionDispatch :: Response :: RackBody }
2015-09-23 19:20:03 +02:00
end
end
2016-07-22 11:34:34 +02:00
context 'when REST error 400 is return' do
let ( :status_entreprise_call ) { 400 }
2016-11-15 05:54:27 +01:00
subject { post :siret_informations , params : { dossier_id : dossier . id , dossier : { siret : siret } } }
2016-07-22 11:34:34 +02:00
before do
sign_in user
subject
end
it { expect ( response . status ) . to eq 200 }
end
2015-09-23 19:20:03 +02:00
end
describe 'PUT #update' do
2016-12-20 17:02:36 +01:00
let ( :params ) { { id : dossier_id , dossier : { id : dossier_id , autorisation_donnees : autorisation_donnees } } }
subject { put :update , params : params }
2016-06-20 13:57:57 +02:00
2015-09-23 19:20:03 +02:00
before do
2015-10-09 17:33:33 +02:00
sign_in dossier . user
2016-06-20 13:57:57 +02:00
subject
2015-09-23 19:20:03 +02:00
end
2016-06-20 13:57:57 +02:00
2016-12-20 17:02:36 +01:00
context 'when procedure is for individual' do
let ( :params ) { { id : dossier_id , dossier : { id : dossier_id , autorisation_donnees : '1' , individual_attributes : individual_params } } }
2017-03-27 15:32:11 +02:00
let ( :individual_params ) { { gender : 'M.' , nom : 'Julien' , prenom : 'Xavier' , birthdate : '20/01/1991' } }
2016-12-20 17:02:36 +01:00
let ( :procedure ) { create ( :procedure , :published , for_individual : true ) }
2016-12-21 15:39:41 +01:00
before do
dossier . reload
end
2017-06-12 16:12:03 +02:00
it { expect ( dossier . individual . gender ) . to eq 'M.' }
it { expect ( dossier . individual . nom ) . to eq 'Julien' }
it { expect ( dossier . individual . prenom ) . to eq 'Xavier' }
it { expect ( dossier . individual . birthdate ) . to eq '20/01/1991' }
2016-12-20 17:02:36 +01:00
it { expect ( dossier . procedure . for_individual ) . to eq true }
end
2015-09-23 19:20:03 +02:00
context 'when Checkbox is checked' do
let ( :autorisation_donnees ) { '1' }
2015-09-28 18:55:16 +02:00
context 'procedure not use api carto' do
it 'redirects to demande' do
expect ( response ) . to redirect_to ( controller : :description , action : :show , dossier_id : dossier . id )
end
end
context 'procedure use api carto' do
2015-12-08 10:11:58 +01:00
let ( :procedure ) { create ( :procedure , :with_api_carto ) }
2015-09-28 18:55:16 +02:00
before do
2016-06-20 13:57:57 +02:00
subject
2015-09-28 18:55:16 +02:00
end
it 'redirects to carte' do
expect ( response ) . to redirect_to ( controller : :carte , action : :show , dossier_id : dossier . id )
end
2015-09-23 19:20:03 +02:00
end
it 'update dossier' do
dossier . reload
expect ( dossier . autorisation_donnees ) . to be_truthy
end
end
context 'when Checkbox is not checked' do
let ( :autorisation_donnees ) { '0' }
it 'uses flash alert to display message' do
expect ( flash [ :alert ] ) . to have_content ( 'Les conditions sont obligatoires.' )
end
it " doesn't update dossier autorisation_donnees " do
dossier . reload
expect ( dossier . autorisation_donnees ) . to be_falsy
end
2016-06-20 13:57:57 +02:00
it { is_expected . to redirect_to users_dossier_path ( id : dossier . id ) }
end
end
2016-10-25 17:39:53 +02:00
describe 'DELETE #destroy' do
2016-11-15 05:54:27 +01:00
let ( :user ) { create ( :user ) }
let! ( :dossier_draft ) { create :dossier , state : " draft " , user : user }
2016-10-25 17:39:53 +02:00
let! ( :dossier_not_draft ) { create :dossier , state : " initiated " , user : user }
2016-11-15 05:54:27 +01:00
subject { delete :destroy , params : { id : dossier . id } }
2016-10-25 17:39:53 +02:00
before do
sign_in user
end
context 'when dossier is draft' do
let ( :dossier ) { dossier_draft }
it { expect ( subject . status ) . to eq 302 }
describe 'flash notice' do
before do
subject
end
it { expect ( flash [ :notice ] ) . to be_present }
end
it 'destroy dossier is call' do
expect_any_instance_of ( Dossier ) . to receive ( :destroy )
subject
end
it { expect { subject } . to change { Dossier . count } . by ( - 1 ) }
end
context 'when dossier is not a draft' do
let ( :dossier ) { dossier_not_draft }
it { expect { subject } . to change { Dossier . count } . by ( 0 ) }
end
end
2016-06-20 13:57:57 +02:00
describe 'PUT #change_siret' do
let ( :dossier ) { create ( :dossier , :with_entreprise , user : user , procedure : procedure ) }
2016-11-15 05:54:27 +01:00
subject { put :change_siret , params : { dossier_id : dossier . id } }
2016-06-20 13:57:57 +02:00
before do
sign_in user
end
it { expect ( subject . status ) . to eq 200 }
it 'function dossier.reset! is call' do
expect_any_instance_of ( Dossier ) . to receive ( :reset! )
subject
2015-09-23 19:20:03 +02:00
end
end
2015-11-27 13:56:54 +01:00
2015-11-30 14:48:37 +01:00
describe 'GET #a_traiter' do
context 'when user is connected' do
before do
sign_in user
end
it 'returns http success' do
2016-11-15 05:54:27 +01:00
get :index , params : { liste : :a_traiter }
2015-11-30 14:48:37 +01:00
expect ( response ) . to have_http_status ( 200 )
end
end
end
2016-10-19 17:25:24 +02:00
describe 'GET #en_instruction' do
context 'when user is connected' do
before do
sign_in user
end
it 'returns http success' do
2016-11-15 05:54:27 +01:00
get :index , params : { liste : :en_instruction }
2016-10-19 17:25:24 +02:00
expect ( response ) . to have_http_status ( 200 )
end
end
end
describe 'GET #brouillon' do
context 'when user is connected' do
before do
sign_in user
end
it 'returns http success' do
2016-11-15 05:54:27 +01:00
get :index , params : { liste : :brouillon }
2015-11-30 14:48:37 +01:00
expect ( response ) . to have_http_status ( 200 )
end
end
end
describe 'GET #termine' do
context 'when user is connected' do
before do
sign_in user
end
it 'returns http success' do
2016-11-15 05:54:27 +01:00
get :index , params : { liste : :termine }
2015-11-30 14:48:37 +01:00
expect ( response ) . to have_http_status ( 200 )
end
end
end
2016-02-09 12:23:31 +01:00
describe 'GET #invite' do
context 'when user is connected' do
before do
sign_in user
end
it 'returns http success' do
2016-11-15 05:54:27 +01:00
get :index , params : { liste : :invite }
2016-02-09 12:23:31 +01:00
expect ( response ) . to have_http_status ( 200 )
end
end
end
2016-10-11 18:05:49 +02:00
describe 'GET #list_fake' do
context 'when user is connected' do
before do
sign_in user
end
it 'returns http success' do
2016-11-15 05:54:27 +01:00
get :index , params : { liste : :list_fake }
2016-10-11 18:05:49 +02:00
expect ( response ) . to redirect_to ( users_dossiers_path )
end
end
end
2017-04-26 16:15:48 +02:00
describe 'Get #text_summary' do
2017-03-28 13:17:58 +02:00
let! ( :dossier ) { create ( :dossier , procedure : procedure ) }
context 'when user is connected' do
before { sign_in user }
context 'when the dossier exist' do
2017-04-26 16:15:48 +02:00
before { get :text_summary , params : { dossier_id : dossier . id } }
2017-03-28 13:17:58 +02:00
it 'returns the procedure name' do
2017-04-26 15:08:15 +02:00
expect ( JSON . parse ( response . body ) ) . to eq ( " textSummary " = > " Dossier en brouillon répondant à la procédure #{ procedure . libelle } gérée par l'organisme #{ procedure . organisation } " )
2017-03-28 13:17:58 +02:00
end
end
context 'when the dossier does not exist' do
2017-04-26 16:15:48 +02:00
before { get :text_summary , params : { dossier_id : 666 } }
2017-03-28 13:17:58 +02:00
it { expect ( response . code ) . to eq ( '404' ) }
end
end
context 'when user is not connected' do
2017-04-26 16:15:48 +02:00
before { get :text_summary , params : { dossier_id : dossier . id } }
2017-03-28 13:17:58 +02:00
it { expect ( response . code ) . to eq ( '302' ) }
end
end
2016-10-25 17:39:53 +02:00
end