Fixed #25356 -- Removed default_app_config from startapp template.
Also discouraged its use outside the intended use case.
This commit is contained in:
parent
29d52583e7
commit
862de0b254
|
@ -1 +0,0 @@
|
||||||
default_app_config = '{{ app_name }}.apps.{{ camel_case_app_name }}Config'
|
|
|
@ -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',
|
||||||
|
|
|
@ -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`
|
||||||
|
|
|
@ -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>`.
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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()
|
||||||
|
|
Loading…
Reference in New Issue