describe ChampSerializer do describe '#attributes' do subject { ChampSerializer.new(serializable_object).serializable_hash } let(:serializable_object) { champ } context 'when type champ is piece justificative' do let(:champ) { create(:champ_piece_justificative) } it { expect(subject[:value]).to a_string_matching('/rails/active_storage/disk/') } end context 'when type champ is not piece justificative' do let(:champ) { create(:champ_text, value: "blah") } it { is_expected.to include(value: "blah") } end context 'when type champ is carte' do let(:champ) { create(:champ_carte, geo_areas: [geo_area].compact) } let(:geo_area) { create(:geo_area, :cadastre, :multi_polygon) } let(:geo_json) { attributes_for(:geo_area, :multi_polygon)[:geometry].stringify_keys } let(:serialized_champ) { { type_de_champ: serialized_type_de_champ, value: serialized_value } } let(:serialized_type_de_champ) { { description: serialized_description, id: serialized_id, libelle: serialized_libelle, order_place: serialized_order_place, type_champ: serialized_type_champ } } let(:serialized_id) { -1 } let(:serialized_description) { "" } let(:serialized_order_place) { -1 } let(:serialized_value) { geo_json } context 'and geo_area is selection_utilisateur' do let(:geo_area) { create(:geo_area, :selection_utilisateur, :polygon) } context 'old_api' do let(:serialized_libelle) { "user geometry" } let(:serialized_type_champ) { "user_geometry" } let(:serializable_object) { champ.selection_utilisateur_legacy_geo_area } context 'when value is coordinates' do it { expect(subject).to eq(serialized_champ) } end end context 'new_api' do let(:geo_area) { nil } let(:serialized_champ) { { type_de_champ: serialized_type_de_champ, geo_areas: [], value: serialized_value } } let(:serialized_id) { champ.type_de_champ.stable_id } let(:serialized_description) { champ.description } let(:serialized_libelle) { champ.libelle } let(:serialized_type_champ) { champ.type_champ } let(:serialized_value) { nil } context 'when value is coordinates' do let(:value) { coordinates.to_json } it { expect(subject).to eq(serialized_champ) } end end end context 'and geo_area is cadastre' do context 'new_api' do it { expect(subject[:geo_areas].first).to include( source: GeoArea.sources.fetch(:cadastre), geometry: geo_json, numero: '42', section: 'A11' ) expect(subject[:geo_areas].first.key?(:nom)).to be_falsey } end context 'old_api' do let(:serializable_object) { champ.geo_areas.first } let(:serialized_libelle) { "cadastre" } let(:serialized_type_champ) { "cadastre" } it { expect(subject).to eq(serialized_champ) } end end end context 'when type champ is siret' do let(:etablissement) { create(:etablissement) } let(:champ) { create(:champ_siret, etablissement:, value: etablissement.siret) } it { is_expected.to include(value: etablissement.siret) expect(subject[:etablissement]).to include(siret: etablissement.siret) expect(subject[:entreprise]).to include(capital_social: etablissement.entreprise_capital_social) } end context 'when type champ yes_no' do context 'true' do let(:champ) { create(:champ_yes_no, value: 'true') } it { is_expected.to include(value: 'true') } end context 'false' do let(:champ) { create(:champ_yes_no, value: 'false') } it { is_expected.to include(value: 'false') } end context 'nil' do let(:champ) { create(:champ_yes_no, value: nil) } it { is_expected.to include(value: nil) } end end context 'when type champ checkbox' do context 'true' do let(:champ) { create(:champ_checkbox, value: 'true') } it { is_expected.to include(value: 'true') } end context 'false' do let(:champ) { create(:champ_checkbox, value: 'false') } it { is_expected.to include(value: 'false') } end context 'nil' do let(:champ) { create(:champ_checkbox, value: nil) } it { is_expected.to include(value: nil) } end end end end