refactor(etablissement): update champ value json address from model
This commit is contained in:
parent
2e873254fe
commit
a400045964
5 changed files with 43 additions and 9 deletions
|
@ -5,5 +5,6 @@ class APIEntreprise::EntrepriseJob < APIEntreprise::Job
|
||||||
find_etablissement(etablissement_id)
|
find_etablissement(etablissement_id)
|
||||||
etablissement_params = APIEntreprise::EntrepriseAdapter.new(etablissement.siret, procedure_id).to_params
|
etablissement_params = APIEntreprise::EntrepriseAdapter.new(etablissement.siret, procedure_id).to_params
|
||||||
etablissement.update!(etablissement_params)
|
etablissement.update!(etablissement_params)
|
||||||
|
etablissement.update_champ_value_json!
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -204,6 +204,16 @@ class Etablissement < ApplicationRecord
|
||||||
adresse.nil? # TOOD: maybe dedicated column or more robust way
|
adresse.nil? # TOOD: maybe dedicated column or more robust way
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def update_champ_value_json!
|
||||||
|
return if champ.nil?
|
||||||
|
|
||||||
|
champ.update!(value_json: champ_value_json)
|
||||||
|
end
|
||||||
|
|
||||||
|
def champ_value_json
|
||||||
|
APIGeoService.parse_etablissement_address(self)
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
def bilans_new_keys
|
def bilans_new_keys
|
||||||
|
|
|
@ -22,10 +22,7 @@ class APIEntrepriseService
|
||||||
|
|
||||||
etablissement = dossier_or_champ.build_etablissement(etablissement_params)
|
etablissement = dossier_or_champ.build_etablissement(etablissement_params)
|
||||||
etablissement.save!
|
etablissement.save!
|
||||||
|
etablissement.update_champ_value_json!
|
||||||
if dossier_or_champ.is_a?(Champ)
|
|
||||||
dossier_or_champ.update!(value_json: APIGeoService.parse_etablissement_address(etablissement))
|
|
||||||
end
|
|
||||||
|
|
||||||
perform_later_fetch_jobs(etablissement, procedure_id, user_id)
|
perform_later_fetch_jobs(etablissement, procedure_id, user_id)
|
||||||
|
|
||||||
|
@ -49,10 +46,7 @@ class APIEntrepriseService
|
||||||
return nil if etablissement_params.empty?
|
return nil if etablissement_params.empty?
|
||||||
|
|
||||||
etablissement.update!(etablissement_params)
|
etablissement.update!(etablissement_params)
|
||||||
|
etablissement.update_champ_value_json!
|
||||||
if etablissement.champ.present?
|
|
||||||
etablissement.champ.update!(value_json: APIGeoService.parse_etablissement_address(etablissement))
|
|
||||||
end
|
|
||||||
|
|
||||||
etablissement
|
etablissement
|
||||||
end
|
end
|
||||||
|
|
|
@ -12,7 +12,7 @@ module Maintenance
|
||||||
|
|
||||||
def process(champ)
|
def process(champ)
|
||||||
return if champ.etablissement.blank?
|
return if champ.etablissement.blank?
|
||||||
champ.update!(value_json: APIGeoService.parse_etablissement_address(champ.etablissement))
|
champ.update!(value_json: champ.etablissement.champ_value_json)
|
||||||
rescue ActiveRecord::RecordInvalid
|
rescue ActiveRecord::RecordInvalid
|
||||||
# noop, just a champ without dossier
|
# noop, just a champ without dossier
|
||||||
end
|
end
|
||||||
|
|
|
@ -130,6 +130,35 @@ describe Etablissement do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe '#update_champ_value_json!' do
|
||||||
|
let(:procedure) { create(:procedure, types_de_champ_public: [{ type: :siret }]) }
|
||||||
|
let(:dossier) { create(:dossier, procedure:) }
|
||||||
|
let(:etablissement) { create(:etablissement) }
|
||||||
|
let(:champ) { dossier.champs[0] }
|
||||||
|
let(:address_data) do
|
||||||
|
{
|
||||||
|
"street_number" => "6",
|
||||||
|
"street_name" => "RAOUL NORDLING",
|
||||||
|
"postal_code" => "92270",
|
||||||
|
"city_name" => "BOIS COLOMBES"
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
before do
|
||||||
|
allow(APIGeoService).to receive(:parse_etablissement_address)
|
||||||
|
.with(etablissement)
|
||||||
|
.and_return(address_data.dup)
|
||||||
|
|
||||||
|
etablissement.champ = champ
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'updates the associated champ value_json with geocoded address' do
|
||||||
|
etablissement.update_champ_value_json!
|
||||||
|
|
||||||
|
expect(champ.reload.value_json).to eq(address_data)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
def csv_to_array_of_hash(lines)
|
def csv_to_array_of_hash(lines)
|
||||||
|
|
Loading…
Reference in a new issue