Exercices and RNA information are optional and should not block the request

This commit is contained in:
Paul Chavard 2019-05-03 17:24:42 +02:00
parent 0ebb2f55eb
commit 96b3547788
2 changed files with 113 additions and 7 deletions

View file

@ -11,14 +11,19 @@ class ApiEntrepriseService
entreprise_params = ApiEntreprise::EntrepriseAdapter.new(siret, procedure_id).to_params entreprise_params = ApiEntreprise::EntrepriseAdapter.new(siret, procedure_id).to_params
if etablissement_params.present? && entreprise_params.present? if etablissement_params.present? && entreprise_params.present?
association_params = ApiEntreprise::RNAAdapter.new(siret, procedure_id).to_params begin
exercices_params = ApiEntreprise::ExercicesAdapter.new(siret, procedure_id).to_params association_params = ApiEntreprise::RNAAdapter.new(siret, procedure_id).to_params
etablissement_params.merge!(association_params)
rescue RestClient::RequestFailed
end
etablissement_params.merge( begin
entreprise_params, exercices_params = ApiEntreprise::ExercicesAdapter.new(siret, procedure_id).to_params
association_params, etablissement_params.merge!(exercices_params)
exercices_params rescue RestClient::RequestFailed
) end
etablissement_params.merge(entreprise_params)
end end
end end
end end

View file

@ -0,0 +1,101 @@
require 'spec_helper'
describe ApiEntrepriseService do
describe '#get_etablissement_params_for_siret' do
before do
stub_request(:get, /https:\/\/entreprise.api.gouv.fr\/v2\/entreprises\/#{siren}?.*token=/)
.to_return(body: entreprises_body, status: entreprises_status)
stub_request(:get, /https:\/\/entreprise.api.gouv.fr\/v2\/etablissements\/#{siret}?.*token=/)
.to_return(body: etablissements_body, status: etablissements_status)
stub_request(:get, /https:\/\/entreprise.api.gouv.fr\/v2\/exercices\/.*token=/)
.to_return(body: exercices_body, status: exercices_status)
stub_request(:get, /https:\/\/entreprise.api.gouv.fr\/v2\/associations\/.*token=/)
.to_return(body: associations_body, status: associations_status)
end
let(:siren) { '418166096' }
let(:siret) { '41816609600051' }
let(:rna) { 'W595001988' }
let(:entreprises_status) { 200 }
let(:entreprises_body) { File.read('spec/fixtures/files/api_entreprise/entreprises.json') }
let(:etablissements_status) { 200 }
let(:etablissements_body) { File.read('spec/fixtures/files/api_entreprise/etablissements.json') }
let(:exercices_status) { 200 }
let(:exercices_body) { File.read('spec/fixtures/files/api_entreprise/exercices.json') }
let(:associations_status) { 200 }
let(:associations_body) { File.read('spec/fixtures/files/api_entreprise/associations.json') }
let(:result) { ApiEntrepriseService.get_etablissement_params_for_siret(siret, '1') }
context 'when service is up' do
it 'should fetch etablissement params' do
expect(result[:entreprise_siren]).to eq(siren)
expect(result[:siret]).to eq(siret)
expect(result[:association_rna]).to eq(rna)
expect(result[:exercices_attributes]).to_not be_empty
end
end
context 'when exercices api down' do
let(:exercices_status) { 400 }
let(:exercices_body) { '' }
it 'should fetch etablissement params' do
expect(result[:entreprise_siren]).to eq(siren)
expect(result[:siret]).to eq(siret)
expect(result[:exercices_attributes]).to be_nil
end
end
context 'when associations api down' do
let(:associations_status) { 400 }
let(:associations_body) { '' }
it 'should fetch etablissement params' do
expect(result[:entreprise_siren]).to eq(siren)
expect(result[:siret]).to eq(siret)
expect(result[:association_rna]).to be_nil
end
end
context 'when entreprise api down' do
let(:entreprises_status) { 400 }
let(:entreprises_body) { '' }
it 'should raise RestClient::RequestFailed' do
expect { result }.to raise_error(RestClient::RequestFailed)
end
end
context 'when etablissement api down' do
let(:etablissements_status) { 400 }
let(:etablissements_body) { '' }
it 'should raise RestClient::RequestFailed' do
expect { result }.to raise_error(RestClient::RequestFailed)
end
end
context 'when etablissement not found' do
let(:etablissements_status) { 404 }
let(:etablissements_body) { '' }
it 'should return nil' do
expect(result).to be_nil
end
end
context 'when entreprise not found' do
let(:etablissements_status) { 404 }
let(:etablissements_body) { '' }
it 'should return nil' do
expect(result).to be_nil
end
end
end
end