mirror of https://github.com/django/django.git
Added DatabaseFeatures.can_alter_geometry_field.
This commit is contained in:
parent
c7c7615d00
commit
0eee5c1b9c
|
@ -46,6 +46,9 @@ class BaseSpatialFeatures:
|
||||||
# Does the database support a unique index on geometry fields?
|
# Does the database support a unique index on geometry fields?
|
||||||
supports_geometry_field_unique_index = True
|
supports_geometry_field_unique_index = True
|
||||||
|
|
||||||
|
# Can SchemaEditor alter geometry fields?
|
||||||
|
can_alter_geometry_field = True
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def supports_bbcontains_lookup(self):
|
def supports_bbcontains_lookup(self):
|
||||||
return 'bbcontains' in self.connection.ops.gis_operators
|
return 'bbcontains' in self.connection.ops.gis_operators
|
||||||
|
|
|
@ -6,6 +6,7 @@ from django.utils.functional import cached_property
|
||||||
|
|
||||||
|
|
||||||
class DatabaseFeatures(BaseSpatialFeatures, SQLiteDatabaseFeatures):
|
class DatabaseFeatures(BaseSpatialFeatures, SQLiteDatabaseFeatures):
|
||||||
|
can_alter_geometry_field = False # Not implemented
|
||||||
supports_3d_storage = True
|
supports_3d_storage = True
|
||||||
|
|
||||||
@cached_property
|
@cached_property
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
from unittest import skipIf, skipUnless
|
from unittest import skipUnless
|
||||||
|
|
||||||
from django.contrib.gis.db.models import fields
|
from django.contrib.gis.db.models import fields
|
||||||
from django.contrib.gis.geos import MultiPolygon, Polygon
|
from django.contrib.gis.geos import MultiPolygon, Polygon
|
||||||
|
@ -10,7 +10,7 @@ from django.test import (
|
||||||
TransactionTestCase, skipIfDBFeature, skipUnlessDBFeature,
|
TransactionTestCase, skipIfDBFeature, skipUnlessDBFeature,
|
||||||
)
|
)
|
||||||
|
|
||||||
from ..utils import mysql, oracle, spatialite
|
from ..utils import mysql, oracle
|
||||||
|
|
||||||
try:
|
try:
|
||||||
GeometryColumns = connection.ops.geometry_columns()
|
GeometryColumns = connection.ops.geometry_columns()
|
||||||
|
@ -190,8 +190,7 @@ class OperationTests(OperationTestCase):
|
||||||
if connection.features.supports_raster:
|
if connection.features.supports_raster:
|
||||||
self.assertSpatialIndexExists('gis_neighborhood', 'rast', raster=True)
|
self.assertSpatialIndexExists('gis_neighborhood', 'rast', raster=True)
|
||||||
|
|
||||||
@skipUnlessDBFeature("supports_3d_storage")
|
@skipUnlessDBFeature('can_alter_geometry_field', 'supports_3d_storage')
|
||||||
@skipIf(spatialite, "Django currently doesn't support altering Spatialite geometry fields")
|
|
||||||
def test_alter_geom_field_dim(self):
|
def test_alter_geom_field_dim(self):
|
||||||
Neighborhood = self.current_state.apps.get_model('gis', 'Neighborhood')
|
Neighborhood = self.current_state.apps.get_model('gis', 'Neighborhood')
|
||||||
p1 = Polygon(((0, 0), (0, 1), (1, 1), (1, 0), (0, 0)))
|
p1 = Polygon(((0, 0), (0, 1), (1, 1), (1, 0), (0, 0)))
|
||||||
|
|
Loading…
Reference in New Issue