mirror of
				https://github.com/django/django.git
				synced 2025-10-26 07:06:08 +00:00 
			
		
		
		
	[5.1.x] Refs #35074 -- Avoided failed attempts to remove spatial indexes on nullable fields on MySQL.
MySQL doesn't support spatial indexes on NULL columns, so there is no
point in removing them.
Backport of 20c2d625d3 from main.
			
			
This commit is contained in:
		
				
					committed by
					
						 Sarah Boyce
						Sarah Boyce
					
				
			
			
				
	
			
			
			
						parent
						
							ba81b3f0a3
						
					
				
				
					commit
					adb72fa854
				
			| @@ -134,6 +134,24 @@ class OperationTests(OperationTestCase): | ||||
|         if self.has_spatial_indexes: | ||||
|             self.assertSpatialIndexExists("gis_neighborhood", "path") | ||||
|  | ||||
|     @skipUnless(connection.vendor == "mysql", "MySQL specific test") | ||||
|     def test_remove_geom_field_nullable_with_index(self): | ||||
|         # MySQL doesn't support spatial indexes on NULL columns. | ||||
|         with self.assertNumQueries(1) as ctx: | ||||
|             self.alter_gis_model( | ||||
|                 migrations.AddField, | ||||
|                 "Neighborhood", | ||||
|                 "path", | ||||
|                 fields.LineStringField, | ||||
|                 field_class_kwargs={"null": True}, | ||||
|             ) | ||||
|         self.assertColumnExists("gis_neighborhood", "path") | ||||
|         self.assertNotIn("CREATE SPATIAL INDEX", ctx.captured_queries[0]["sql"]) | ||||
|  | ||||
|         with self.assertNumQueries(1), self.assertNoLogs("django.contrib.gis", "ERROR"): | ||||
|             self.alter_gis_model(migrations.RemoveField, "Neighborhood", "path") | ||||
|         self.assertColumnNotExists("gis_neighborhood", "path") | ||||
|  | ||||
|     @skipUnless(HAS_GEOMETRY_COLUMNS, "Backend doesn't support GeometryColumns.") | ||||
|     def test_geom_col_name(self): | ||||
|         self.assertEqual( | ||||
|   | ||||
		Reference in New Issue
	
	Block a user