mirror of
				https://github.com/django/django.git
				synced 2025-10-25 14:46:09 +00:00 
			
		
		
		
	Added DatabaseFeatures.can_alter_geometry_field.
This commit is contained in:
		| @@ -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))) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user