diff --git a/app/models/geo_area.rb b/app/models/geo_area.rb index 364a088aa..6e847abac 100644 --- a/app/models/geo_area.rb +++ b/app/models/geo_area.rb @@ -65,7 +65,7 @@ class GeoArea < ApplicationRecord def label case source when GeoArea.sources.fetch(:cadastre) - I18n.t("cadastre", scope: 'geo_area.label', numero: numero, prefixe: prefixe, section: section, surface: surface.round, commune: commune) + I18n.t("cadastre", scope: 'geo_area.label', numero: numero, prefixe: prefixe, section: section, surface: surface&.round, commune: commune) when GeoArea.sources.fetch(:selection_utilisateur) if polygon? if area > 0 diff --git a/spec/models/geo_area_spec.rb b/spec/models/geo_area_spec.rb index 0c8554286..0707782fa 100644 --- a/spec/models/geo_area_spec.rb +++ b/spec/models/geo_area_spec.rb @@ -143,6 +143,16 @@ RSpec.describe GeoArea, type: :model do it "should return the label" do expect(geo_area.label).to eq("Parcelle n° 42 - Feuille 000 A11 - 123 m² – commune 75127") end + + context "when area is nil" do + let(:geo_area) { build(:geo_area, :selection_utilisateur, :cadastre, properties: { "description" => "48°51'45.81\"N 2°17'15,33\"E" }, geometry: { "type" => "Point", "coordinates" => [7.754444, 48.610556] }, champ: nil) } + + before { allow(geo_area).to receive(:area).and_return(nil) } + + it "should not crash" do + expect(geo_area.label).to eq("Parcelle n° - Feuille - m² – commune ") + end + end end end end