1
0
mirror of https://github.com/django/django.git synced 2025-10-24 14:16:09 +00:00

Fixed #25583 -- Allowed calling transform with CoordTransform even if SRID is invalid.

This commit is contained in:
Sergey Fedoseev
2015-10-24 19:12:38 +05:00
committed by Tim Graham
parent 02ef96c5e5
commit a7bb5af50b
3 changed files with 31 additions and 18 deletions

View File

@@ -494,14 +494,18 @@ class GEOSGeometry(GEOSBase, ListMixin):
else: else:
return return
if (srid is None) or (srid < 0): if isinstance(ct, gdal.CoordTransform):
# We don't care about SRID because CoordTransform presupposes
# source SRS.
srid = None
elif srid is None or srid < 0:
raise GEOSException("Calling transform() with no SRID set is not supported") raise GEOSException("Calling transform() with no SRID set is not supported")
if not gdal.HAS_GDAL: if not gdal.HAS_GDAL:
raise GEOSException("GDAL library is not available to transform() geometry.") raise GEOSException("GDAL library is not available to transform() geometry.")
# Creating an OGR Geometry, which is then transformed. # Creating an OGR Geometry, which is then transformed.
g = self.ogr g = gdal.OGRGeometry(self.wkb, srid)
g.transform(ct) g.transform(ct)
# Getting a new GEOS pointer # Getting a new GEOS pointer
ptr = wkb_r().read(g.wkb) ptr = wkb_r().read(g.wkb)

View File

@@ -553,6 +553,14 @@ is returned instead.
Requires GDAL. Raises :class:`~django.contrib.gis.geos.GEOSException` if Requires GDAL. Raises :class:`~django.contrib.gis.geos.GEOSException` if
GDAL is not available or if the geometry's SRID is ``None`` or less than 0. GDAL is not available or if the geometry's SRID is ``None`` or less than 0.
It doesn't impose any constraints on the geometry's SRID if called with a
:class:`~django.contrib.gis.gdal.CoordTransform` object.
.. versionchanged:: 1.10
In previous versions, it required the geometry's SRID to be a positive
integer even if it was called with a
:class:`~django.contrib.gis.gdal.CoordTransform` object.
``Point`` ``Point``
--------- ---------

View File

@@ -656,23 +656,24 @@ class GEOSTest(unittest.TestCase, TestDataMixin):
@skipUnless(HAS_GDAL, "GDAL is required.") @skipUnless(HAS_GDAL, "GDAL is required.")
def test_custom_srid(self): def test_custom_srid(self):
""" Test with a srid unknown from GDAL """ """Test with a null srid and a srid unknown to GDAL."""
pnt = Point(111200, 220900, srid=999999) for srid in [None, 999999]:
self.assertTrue(pnt.ewkt.startswith("SRID=999999;POINT (111200.0")) pnt = Point(111200, 220900, srid=srid)
self.assertIsInstance(pnt.ogr, gdal.OGRGeometry) self.assertTrue(pnt.ewkt.startswith(("SRID=%s;" % srid if srid else '') + "POINT (111200.0"))
self.assertIsNone(pnt.srs) self.assertIsInstance(pnt.ogr, gdal.OGRGeometry)
self.assertIsNone(pnt.srs)
# Test conversion from custom to a known srid # Test conversion from custom to a known srid
c2w = gdal.CoordTransform( c2w = gdal.CoordTransform(
gdal.SpatialReference( gdal.SpatialReference(
'+proj=mill +lat_0=0 +lon_0=0 +x_0=0 +y_0=0 +R_A +ellps=WGS84 ' '+proj=mill +lat_0=0 +lon_0=0 +x_0=0 +y_0=0 +R_A +ellps=WGS84 '
'+datum=WGS84 +units=m +no_defs' '+datum=WGS84 +units=m +no_defs'
), ),
gdal.SpatialReference(4326)) gdal.SpatialReference(4326))
new_pnt = pnt.transform(c2w, clone=True) new_pnt = pnt.transform(c2w, clone=True)
self.assertEqual(new_pnt.srid, 4326) self.assertEqual(new_pnt.srid, 4326)
self.assertAlmostEqual(new_pnt.x, 1, 3) self.assertAlmostEqual(new_pnt.x, 1, 3)
self.assertAlmostEqual(new_pnt.y, 2, 3) self.assertAlmostEqual(new_pnt.y, 2, 3)
def test_mutable_geometries(self): def test_mutable_geometries(self):
"Testing the mutability of Polygons and Geometry Collections." "Testing the mutability of Polygons and Geometry Collections."