mirror of
				https://github.com/django/django.git
				synced 2025-10-25 14:46:09 +00:00 
			
		
		
		
	Fixed #36184 -- Allowed migrating forward to squashed migrations.
This commit is contained in:
		| @@ -37,18 +37,18 @@ class MigrationExecutor: | |||||||
|                             if migration in applied: |                             if migration in applied: | ||||||
|                                 plan.append((self.loader.graph.nodes[migration], True)) |                                 plan.append((self.loader.graph.nodes[migration], True)) | ||||||
|                                 applied.pop(migration) |                                 applied.pop(migration) | ||||||
|             # If the migration is already applied, do backwards mode, |  | ||||||
|             # otherwise do forwards mode. |  | ||||||
|             elif target in applied: |  | ||||||
|             # If the target is missing, it's likely a replaced migration. |             # If the target is missing, it's likely a replaced migration. | ||||||
|             # Reload the graph without replacements. |             # Reload the graph without replacements. | ||||||
|                 if ( |             elif ( | ||||||
|                 self.loader.replace_migrations |                 self.loader.replace_migrations | ||||||
|                 and target not in self.loader.graph.node_map |                 and target not in self.loader.graph.node_map | ||||||
|             ): |             ): | ||||||
|                 self.loader.replace_migrations = False |                 self.loader.replace_migrations = False | ||||||
|                 self.loader.build_graph() |                 self.loader.build_graph() | ||||||
|                 return self.migration_plan(targets, clean_start=clean_start) |                 return self.migration_plan(targets, clean_start=clean_start) | ||||||
|  |             # If the migration is already applied, do backwards mode, | ||||||
|  |             # otherwise do forwards mode. | ||||||
|  |             elif target in applied: | ||||||
|                 # Don't migrate backwards all the way to the target node (that |                 # Don't migrate backwards all the way to the target node (that | ||||||
|                 # may roll back dependencies in other apps that don't need to |                 # may roll back dependencies in other apps that don't need to | ||||||
|                 # be rolled back); instead roll back through target's immediate |                 # be rolled back); instead roll back through target's immediate | ||||||
|   | |||||||
| @@ -1328,6 +1328,16 @@ class MigrateTests(MigrationTestBase): | |||||||
|                 # Unmigrate everything. |                 # Unmigrate everything. | ||||||
|                 call_command("migrate", "migrations", "zero", verbosity=0) |                 call_command("migrate", "migrations", "zero", verbosity=0) | ||||||
|  |  | ||||||
|  |     @override_settings( | ||||||
|  |         MIGRATION_MODULES={"migrations": "migrations.test_migrations_squashed"} | ||||||
|  |     ) | ||||||
|  |     def test_migrate_forward_to_squashed_migration(self): | ||||||
|  |         try: | ||||||
|  |             call_command("migrate", "migrations", "0001_initial", verbosity=0) | ||||||
|  |         finally: | ||||||
|  |             # Unmigrate everything. | ||||||
|  |             call_command("migrate", "migrations", "zero", verbosity=0) | ||||||
|  |  | ||||||
|     @override_settings( |     @override_settings( | ||||||
|         MIGRATION_MODULES={"migrations": "migrations.test_migrations_squashed"} |         MIGRATION_MODULES={"migrations": "migrations.test_migrations_squashed"} | ||||||
|     ) |     ) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user