mirror of
				https://github.com/django/django.git
				synced 2025-10-25 22:56:12 +00:00 
			
		
		
		
	Fixed #33201 -- Made RenameModel operation a noop for models with db_table.
This commit is contained in:
		
				
					committed by
					
						 Mariusz Felisiak
						Mariusz Felisiak
					
				
			
			
				
	
			
			
			
						parent
						
							a754b82dac
						
					
				
				
					commit
					afeafd6036
				
			| @@ -320,12 +320,13 @@ class RenameModel(ModelOperation): | |||||||
|         new_model = to_state.apps.get_model(app_label, self.new_name) |         new_model = to_state.apps.get_model(app_label, self.new_name) | ||||||
|         if self.allow_migrate_model(schema_editor.connection.alias, new_model): |         if self.allow_migrate_model(schema_editor.connection.alias, new_model): | ||||||
|             old_model = from_state.apps.get_model(app_label, self.old_name) |             old_model = from_state.apps.get_model(app_label, self.old_name) | ||||||
|  |             old_db_table = old_model._meta.db_table | ||||||
|  |             new_db_table = new_model._meta.db_table | ||||||
|  |             # Don't alter when a table name is not changed. | ||||||
|  |             if old_db_table == new_db_table: | ||||||
|  |                 return | ||||||
|             # Move the main table |             # Move the main table | ||||||
|             schema_editor.alter_db_table( |             schema_editor.alter_db_table(new_model, old_db_table, new_db_table) | ||||||
|                 new_model, |  | ||||||
|                 old_model._meta.db_table, |  | ||||||
|                 new_model._meta.db_table, |  | ||||||
|             ) |  | ||||||
|             # Alter the fields pointing to us |             # Alter the fields pointing to us | ||||||
|             for related_object in old_model._meta.related_objects: |             for related_object in old_model._meta.related_objects: | ||||||
|                 if related_object.related_model == old_model: |                 if related_object.related_model == old_model: | ||||||
|   | |||||||
| @@ -793,6 +793,28 @@ class OperationTests(OperationTestBase): | |||||||
|         self.assertEqual(Rider.objects.count(), 2) |         self.assertEqual(Rider.objects.count(), 2) | ||||||
|         self.assertEqual(Pony._meta.get_field('riders').remote_field.through.objects.count(), 2) |         self.assertEqual(Pony._meta.get_field('riders').remote_field.through.objects.count(), 2) | ||||||
|  |  | ||||||
|  |     def test_rename_model_with_db_table_noop(self): | ||||||
|  |         app_label = 'test_rmwdbtn' | ||||||
|  |         project_state = self.apply_operations(app_label, ProjectState(), operations=[ | ||||||
|  |             migrations.CreateModel('Rider', fields=[ | ||||||
|  |                 ('id', models.AutoField(primary_key=True)), | ||||||
|  |             ], options={'db_table': 'rider'}), | ||||||
|  |             migrations.CreateModel('Pony', fields=[ | ||||||
|  |                 ('id', models.AutoField(primary_key=True)), | ||||||
|  |                 ('rider', models.ForeignKey('%s.Rider' % app_label, models.CASCADE)), | ||||||
|  |             ]), | ||||||
|  |         ]) | ||||||
|  |         new_state = project_state.clone() | ||||||
|  |         operation = migrations.RenameModel('Rider', 'Runner') | ||||||
|  |         operation.state_forwards(app_label, new_state) | ||||||
|  |  | ||||||
|  |         with connection.schema_editor() as editor: | ||||||
|  |             with self.assertNumQueries(0): | ||||||
|  |                 operation.database_forwards(app_label, editor, project_state, new_state) | ||||||
|  |         with connection.schema_editor() as editor: | ||||||
|  |             with self.assertNumQueries(0): | ||||||
|  |                 operation.database_backwards(app_label, editor, new_state, project_state) | ||||||
|  |  | ||||||
|     def test_rename_m2m_target_model(self): |     def test_rename_m2m_target_model(self): | ||||||
|         app_label = "test_rename_m2m_target_model" |         app_label = "test_rename_m2m_target_model" | ||||||
|         project_state = self.apply_operations(app_label, ProjectState(), operations=[ |         project_state = self.apply_operations(app_label, ProjectState(), operations=[ | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user