Fixed #25356 -- Removed default_app_config from startapp template.

Also discouraged its use outside the intended use case.
This commit is contained in:
Tim Graham 2015-09-07 09:28:15 -04:00
parent 29d52583e7
commit 862de0b254
6 changed files with 8 additions and 12 deletions

View File

@ -1 +0,0 @@
default_app_config = '{{ app_name }}.apps.{{ camel_case_app_name }}Config'

View File

@ -199,14 +199,14 @@ But first we need to tell our project that the ``polls`` app is installed.
Django installation. Django installation.
Edit the :file:`mysite/settings.py` file again, and change the Edit the :file:`mysite/settings.py` file again, and change the
:setting:`INSTALLED_APPS` setting to include the string ``'polls'``. So it'll :setting:`INSTALLED_APPS` setting to include the string
look like this: ``'polls.apps.PollsConfig'``. It'll look like this:
.. snippet:: .. snippet::
:filename: mysite/settings.py :filename: mysite/settings.py
INSTALLED_APPS = [ INSTALLED_APPS = [
'polls', 'polls.apps.PollsConfig',
'django.contrib.admin', 'django.contrib.admin',
'django.contrib.auth', 'django.contrib.auth',
'django.contrib.contenttypes', 'django.contrib.contenttypes',

View File

@ -81,7 +81,9 @@ subclass by default as follows::
That will cause ``RockNRollConfig`` to be used when :setting:`INSTALLED_APPS` That will cause ``RockNRollConfig`` to be used when :setting:`INSTALLED_APPS`
just contains ``'rock_n_roll'``. This allows you to make use of just contains ``'rock_n_roll'``. This allows you to make use of
:class:`~django.apps.AppConfig` features without requiring your users to :class:`~django.apps.AppConfig` features without requiring your users to
update their :setting:`INSTALLED_APPS` setting. update their :setting:`INSTALLED_APPS` setting. Besides this use case, it's
best to avoid using ``default_app_config`` and instead specify the app config
class in :setting:`INSTALLED_APPS` as described next.
Of course, you can also tell your users to put Of course, you can also tell your users to put
``'rock_n_roll.apps.RockNRollConfig'`` in their :setting:`INSTALLED_APPS` ``'rock_n_roll.apps.RockNRollConfig'`` in their :setting:`INSTALLED_APPS`

View File

@ -1523,7 +1523,7 @@ Default: ``[]`` (Empty list)
A list of strings designating all applications that are enabled in this A list of strings designating all applications that are enabled in this
Django installation. Each string should be a dotted Python path to: Django installation. Each string should be a dotted Python path to:
* an application configuration class, or * an application configuration class (preferred), or
* a package containing an application. * a package containing an application.
:doc:`Learn more about application configurations </ref/applications>`. :doc:`Learn more about application configurations </ref/applications>`.

View File

@ -409,8 +409,7 @@ Management Commands
* The :djadmin:`createcachetable` command now has a ``--dry-run`` flag to * The :djadmin:`createcachetable` command now has a ``--dry-run`` flag to
print out the SQL rather than execute it. print out the SQL rather than execute it.
* The :djadmin:`startapp` command creates an ``apps.py`` file and adds * The :djadmin:`startapp` command creates an ``apps.py`` file.
``default_app_config`` in ``__init__.py``.
* When using the PostgreSQL backend, the :djadmin:`dbshell` command can connect * When using the PostgreSQL backend, the :djadmin:`dbshell` command can connect
to the database using the password from your settings file (instead of to the database using the password from your settings file (instead of

View File

@ -599,10 +599,6 @@ class DjangoAdminSettingsDirectory(AdminScriptTestCase):
content = f.read() content = f.read()
self.assertIn("class SettingsTestConfig(AppConfig)", content) self.assertIn("class SettingsTestConfig(AppConfig)", content)
self.assertIn("name = 'settings_test'", content) self.assertIn("name = 'settings_test'", content)
with open(os.path.join(app_path, '__init__.py'), 'r') as f:
content = f.read()
expected_content = "default_app_config = 'settings_test.apps.SettingsTestConfig'"
self.assertIn(expected_content, content)
if not PY3: if not PY3:
with open(os.path.join(app_path, 'models.py'), 'r') as fp: with open(os.path.join(app_path, 'models.py'), 'r') as fp:
content = fp.read() content = fp.read()