[1.8.x] Fixed #25510 -- Allowed runserver to start with incorrect INSTALLED_APPS.

In that case, the content of INSTALLED_APPS will be ignored until it's
fixed and the autoreloader kicks in. I confirmed this behavior manually.
As explained on the ticket it's hard to write a test for this case

Backport of df0a446f from master.
This commit is contained in:
Aymeric Augustin 2015-10-15 22:03:25 +02:00
parent 61ea371822
commit 9ccb92ad01
2 changed files with 11 additions and 4 deletions

View File

@ -1,6 +1,6 @@
from __future__ import unicode_literals from __future__ import unicode_literals
import collections from collections import OrderedDict, defaultdict
from importlib import import_module from importlib import import_module
import os import os
import pkgutil import pkgutil
@ -145,7 +145,7 @@ class ManagementUtility(object):
"", "",
"Available subcommands:", "Available subcommands:",
] ]
commands_dict = collections.defaultdict(lambda: []) commands_dict = defaultdict(lambda: [])
for name, app in six.iteritems(get_commands()): for name, app in six.iteritems(get_commands()):
if app == 'django.core': if app == 'django.core':
app = 'django' app = 'django'
@ -317,8 +317,11 @@ class ManagementUtility(object):
autoreload.check_errors(django.setup)() autoreload.check_errors(django.setup)()
except Exception: except Exception:
# The exception will be raised later in the child process # The exception will be raised later in the child process
# started by the autoreloader. # started by the autoreloader. Pretend it didn't happen by
pass # loading an empty list of applications.
apps.all_models = defaultdict(OrderedDict)
apps.app_configs = OrderedDict()
apps.apps_ready = apps.models_ready = apps.ready = True
# In all other cases, django.setup() is required to succeed. # In all other cases, django.setup() is required to succeed.
else: else:

View File

@ -25,3 +25,7 @@ Bugfixes
* Allowed filtering over a ``RawSQL`` annotation (:ticket:`25506`). * Allowed filtering over a ``RawSQL`` annotation (:ticket:`25506`).
* Made the ``Concat`` database function idempotent on SQLite (:ticket:`25517`). * Made the ``Concat`` database function idempotent on SQLite (:ticket:`25517`).
* Avoided a confusing stack trace when starting :djadmin:`runserver` with an
invalid :setting:`INSTALLED_APPS` setting (:ticket:`25510`). This regression
appeared in 1.8.5 as a side effect of fixing :ticket:`24704`.