require 'spec_helper' describe Users::DossiersController, type: :controller do let(:user) { create(:user) } describe '.index' do let!(:dossier) { create(:dossier, :with_entreprise, :with_procedure, user: user) } subject { get :index } context 'when user is not logged in' do it { is_expected.to redirect_to('/users/sign_in') } end context 'when user is logged in' do before do sign_in create(:user) end it { is_expected.to render_template('users/dossiers/index') } it { is_expected.to have_http_status(:success) } end end let(:use_api_carto) { false } let(:procedure) { create(:procedure, use_api_carto: use_api_carto) } let(:dossier) { create(:dossier, :with_entreprise, user: user, procedure: procedure) } let(:dossier_id) { dossier.id } let(:siret_not_found) { 999_999_999_999 } let(:siren) { dossier.siren } let(:siret) { dossier.siret } let(:bad_siret) { 1 } describe 'GET #show' do before do sign_in dossier.user end it 'returns http success with dossier_id valid' do get :show, id: dossier_id expect(response).to have_http_status(:success) end it 'redirection vers siret si mauvais dossier ID' do get :show, id: siret_not_found expect(response).to redirect_to('/users/siret') end end describe 'POST #create' do before do stub_request(:get, "https://api-dev.apientreprise.fr/api/v1/etablissements/#{siret_not_found}?token=#{SIADETOKEN}") .to_return(status: 404, body: 'fake body') stub_request(:get, "https://api-dev.apientreprise.fr/api/v1/etablissements/#{siret}?token=#{SIADETOKEN}") .to_return(status: 200, body: File.read('spec/support/files/etablissement.json')) stub_request(:get, "https://api-dev.apientreprise.fr/api/v1/entreprises/#{siren}?token=#{SIADETOKEN}") .to_return(status: 200, body: File.read('spec/support/files/entreprise.json')) stub_request(:get, "https://api-dev.apientreprise.fr/api/v1/etablissements/exercices/#{siret}?token=#{SIADETOKEN}") .to_return(status: 200, body: File.read('spec/support/files/exercices.json')) end describe 'professionnel fills form' do let(:user) { create(:user) } context 'when pro_dossier_id is empty' do context 'with valid siret ' do before do sign_in user end subject { post :create, siret: siret, pro_dossier_id: '', procedure_id: Procedure.last } it 'create a dossier' do expect { subject }.to change { Dossier.count }.by(1) end it 'creates entreprise' do expect { subject }.to change { Entreprise.count }.by(1) end it 'links entreprise to dossier' do subject expect(Entreprise.last.dossier).to eq(Dossier.last) end it "links dossier to user" do subject expect(Dossier.last.user).to eq(user) end it 'creates etablissement for dossier' do expect { subject }.to change { Etablissement.count }.by(1) end it 'links etablissement to dossier' do subject expect(Etablissement.last.dossier).to eq(Dossier.last) end it 'links etablissement to entreprise' do subject expect(Etablissement.last.entreprise).to eq(Entreprise.last) end it 'creates exercices for dossier' do expect { subject }.to change { Exercice.count }.by(3) end it 'links procedure to dossier' do subject expect(Dossier.last.procedure).to eq(Procedure.last) end it 'state of dossier is draft' do subject expect(Dossier.last.state).to eq('draft') end end context 'with non existant siret' do before do sign_in create(:user) end let(:siret_not_found) { '11111111111111' } subject { post :create, siret: siret_not_found, pro_dossier_id: '', procedure_id: procedure.id } it 'does not create new dossier' do expect { subject }.not_to change { Dossier.count } end it 'redirects to show' do expect(subject).to redirect_to(controller: :siret, procedure_id: procedure.id) end end end end end describe 'PUT #update' do before do sign_in dossier.user put :update, id: dossier_id, dossier: { autorisation_donnees: autorisation_donnees } end context 'when Checkbox is checked' do let(:autorisation_donnees) { '1' } 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 let(:use_api_carto) { true } before do put :update, id: dossier_id, dossier: { autorisation_donnees: autorisation_donnees } end it 'redirects to carte' do expect(response).to redirect_to(controller: :carte, action: :show, dossier_id: dossier.id) end 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 end end end