mirror of
https://github.com/django/django.git
synced 2025-10-24 06:06:09 +00:00
Refs #24554 -- Prevented rendering of unused migrations
Thanks Claude Paroz and Tim Graham for the review
This commit is contained in:
@@ -86,11 +86,20 @@ class MigrationExecutor(object):
|
|||||||
# models will be recursively reloaded as explained in
|
# models will be recursively reloaded as explained in
|
||||||
# `django.db.migrations.state.get_related_models_recursive()`.
|
# `django.db.migrations.state.get_related_models_recursive()`.
|
||||||
for migration, _ in full_plan:
|
for migration, _ in full_plan:
|
||||||
|
if not migrations_to_run:
|
||||||
|
# We remove every migration whose state was already computed
|
||||||
|
# from the set below (`migrations_to_run.remove(migration)`).
|
||||||
|
# If no states for migrations must be computed, we can exit
|
||||||
|
# this loop. Migrations that occur after the latest migration
|
||||||
|
# that is about to be applied would only trigger unneeded
|
||||||
|
# mutate_state() calls.
|
||||||
|
break
|
||||||
do_run = migration in migrations_to_run
|
do_run = migration in migrations_to_run
|
||||||
if do_run:
|
if do_run:
|
||||||
if 'apps' not in state.__dict__:
|
if 'apps' not in state.__dict__:
|
||||||
state.apps # Render all real_apps -- performance critical
|
state.apps # Render all real_apps -- performance critical
|
||||||
states[migration] = state.clone()
|
states[migration] = state.clone()
|
||||||
|
migrations_to_run.remove(migration)
|
||||||
# Only preserve the state if the migration is being run later
|
# Only preserve the state if the migration is being run later
|
||||||
state = migration.mutate_state(state, preserve=do_run)
|
state = migration.mutate_state(state, preserve=do_run)
|
||||||
if self.progress_callback:
|
if self.progress_callback:
|
||||||
|
Reference in New Issue
Block a user