Fixed #26138 -- Ensured geometry_field's geometry is always serialized

Thanks Bernd Schlapsi for the report.
This commit is contained in:
Claude Paroz 2016-01-26 11:06:29 +01:00
parent 31817dd2eb
commit 54236a2c1c
3 changed files with 21 additions and 2 deletions

View File

@ -18,6 +18,9 @@ class Serializer(JSONSerializer):
super(Serializer, self)._init_options() super(Serializer, self)._init_options()
self.geometry_field = self.json_kwargs.pop('geometry_field', None) self.geometry_field = self.json_kwargs.pop('geometry_field', None)
self.srid = self.json_kwargs.pop('srid', 4326) self.srid = self.json_kwargs.pop('srid', 4326)
if (self.selected_fields is not None and self.geometry_field is not None
and self.geometry_field not in self.selected_fields):
self.selected_fields = list(self.selected_fields) + [self.geometry_field]
def start_serialization(self): def start_serialization(self):
self._init_options() self._init_options()

View File

@ -85,3 +85,6 @@ Bugfixes
* Fixed a regression in Django 1.8.5 that broke copying a ``SimpleLazyObject`` * Fixed a regression in Django 1.8.5 that broke copying a ``SimpleLazyObject``
with ``copy.copy()`` (:ticket:`26122`). with ``copy.copy()`` (:ticket:`26122`).
* Always included ``geometry_field`` in the GeoJSON serializer output regardless
of the ``fields`` parameter (:ticket:`26138`).

View File

@ -47,8 +47,21 @@ class GeoJSONSerializerTests(TestCase):
geodata = json.loads(geojson) geodata = json.loads(geojson)
self.assertEqual(geodata['features'][0]['geometry']['type'], 'Point') self.assertEqual(geodata['features'][0]['geometry']['type'], 'Point')
geojson = serializers.serialize('geojson', MultiFields.objects.all(), geojson = serializers.serialize(
geometry_field='poly') 'geojson',
MultiFields.objects.all(),
geometry_field='poly'
)
geodata = json.loads(geojson)
self.assertEqual(geodata['features'][0]['geometry']['type'], 'Polygon')
# geometry_field is considered even if not in fields (#26138).
geojson = serializers.serialize(
'geojson',
MultiFields.objects.all(),
geometry_field='poly',
fields=('city',)
)
geodata = json.loads(geojson) geodata = json.loads(geojson)
self.assertEqual(geodata['features'][0]['geometry']['type'], 'Polygon') self.assertEqual(geodata['features'][0]['geometry']['type'], 'Polygon')