2023-01-06 07:31:13 +01:00
|
|
|
============================================
|
|
|
|
Django 5.0 release notes - UNDER DEVELOPMENT
|
|
|
|
============================================
|
|
|
|
|
|
|
|
*Expected December 2023*
|
|
|
|
|
|
|
|
Welcome to Django 5.0!
|
|
|
|
|
|
|
|
These release notes cover the :ref:`new features <whats-new-5.0>`, as well as
|
|
|
|
some :ref:`backwards incompatible changes <backwards-incompatible-5.0>` you'll
|
|
|
|
want to be aware of when upgrading from Django 4.2 or earlier. We've
|
|
|
|
:ref:`begun the deprecation process for some features
|
|
|
|
<deprecated-features-5.0>`.
|
|
|
|
|
|
|
|
See the :doc:`/howto/upgrade-version` guide if you're updating an existing
|
|
|
|
project.
|
|
|
|
|
|
|
|
Python compatibility
|
|
|
|
====================
|
|
|
|
|
|
|
|
Django 5.0 supports Python 3.10, 3.11, and 3.12. We **highly recommend** and
|
|
|
|
only officially support the latest release of each series.
|
|
|
|
|
|
|
|
Third-party library support for older version of Django
|
|
|
|
=======================================================
|
|
|
|
|
|
|
|
Following the release of Django 5.0, we suggest that third-party app authors
|
|
|
|
drop support for all versions of Django prior to 4.2. At that time, you should
|
|
|
|
be able to run your package's tests using ``python -Wd`` so that deprecation
|
|
|
|
warnings appear. After making the deprecation warning fixes, your app should be
|
|
|
|
compatible with Django 5.0.
|
|
|
|
|
|
|
|
.. _whats-new-5.0:
|
|
|
|
|
|
|
|
What's new in Django 5.0
|
|
|
|
========================
|
|
|
|
|
|
|
|
Minor features
|
|
|
|
--------------
|
|
|
|
|
|
|
|
:mod:`django.contrib.admin`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.admindocs`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.auth`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.contenttypes`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.gis`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.messages`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.postgres`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.redirects`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.sessions`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.sitemaps`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.sites`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.staticfiles`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.syndication`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Cache
|
|
|
|
~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
CSRF
|
|
|
|
~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Decorators
|
|
|
|
~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Email
|
|
|
|
~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Error Reporting
|
|
|
|
~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
File Storage
|
|
|
|
~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
File Uploads
|
|
|
|
~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Forms
|
|
|
|
~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Generic Views
|
|
|
|
~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Internationalization
|
|
|
|
~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Logging
|
|
|
|
~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Management Commands
|
|
|
|
~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Migrations
|
|
|
|
~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Models
|
|
|
|
~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Requests and Responses
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Security
|
|
|
|
~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Serialization
|
|
|
|
~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Signals
|
|
|
|
~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Templates
|
|
|
|
~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Tests
|
|
|
|
~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
URLs
|
|
|
|
~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Utilities
|
|
|
|
~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Validators
|
|
|
|
~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
.. _backwards-incompatible-5.0:
|
|
|
|
|
|
|
|
Backwards incompatible changes in 5.0
|
|
|
|
=====================================
|
|
|
|
|
|
|
|
Database backend API
|
|
|
|
--------------------
|
|
|
|
|
|
|
|
This section describes changes that may be needed in third-party database
|
|
|
|
backends.
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Miscellaneous
|
|
|
|
-------------
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
.. _deprecated-features-5.0:
|
|
|
|
|
|
|
|
Features deprecated in 5.0
|
|
|
|
==========================
|
|
|
|
|
|
|
|
Miscellaneous
|
|
|
|
-------------
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Features removed in 5.0
|
|
|
|
=======================
|
|
|
|
|
|
|
|
These features have reached the end of their deprecation cycle and are removed
|
|
|
|
in Django 5.0.
|
|
|
|
|
|
|
|
See :ref:`deprecated-features-4.0` for details on these changes, including how
|
|
|
|
to remove usage of these features.
|
|
|
|
|
2023-01-06 09:28:25 +01:00
|
|
|
* The ``SERIALIZE`` test setting is removed.
|
2023-01-06 07:31:13 +01:00
|
|
|
|
2023-01-06 09:33:02 +01:00
|
|
|
* The undocumented ``django.utils.baseconv`` module is removed.
|
|
|
|
|
2023-01-06 09:37:41 +01:00
|
|
|
* The undocumented ``django.utils.datetime_safe`` module is removed.
|
|
|
|
|
2023-01-06 12:30:23 +01:00
|
|
|
* The default value of the ``USE_TZ`` setting is changed from ``False`` to
|
|
|
|
``True``.
|
|
|
|
|
2023-01-06 12:55:14 +01:00
|
|
|
* The default sitemap protocol for sitemaps built outside the context of a
|
|
|
|
request is changed from ``'http'`` to ``'https'``.
|
|
|
|
|
2023-01-06 13:12:23 +01:00
|
|
|
* The ``extra_tests`` argument for ``DiscoverRunner.build_suite()`` and
|
|
|
|
``DiscoverRunner.run_tests()`` is removed.
|
|
|
|
|
2023-01-06 13:53:42 +01:00
|
|
|
* The ``django.contrib.postgres.aggregates.ArrayAgg``, ``JSONBAgg``, and
|
|
|
|
``StringAgg`` aggregates no longer return ``[]``, ``[]``, and ``''``,
|
|
|
|
respectively, when there are no rows.
|
|
|
|
|
2023-01-06 14:46:33 +01:00
|
|
|
* The ``USE_L10N`` setting is removed.
|
|
|
|
|
2023-01-09 09:03:38 +01:00
|
|
|
* The ``USE_DEPRECATED_PYTZ`` transitional setting is removed.
|
|
|
|
|
|
|
|
* Support for ``pytz`` timezones is removed.
|
|
|
|
|
2023-01-09 09:52:26 +01:00
|
|
|
* The ``is_dst`` argument is removed from:
|
|
|
|
|
|
|
|
* ``QuerySet.datetimes()``
|
|
|
|
* ``django.utils.timezone.make_aware()``
|
|
|
|
* ``django.db.models.functions.Trunc()``
|
|
|
|
* ``django.db.models.functions.TruncSecond()``
|
|
|
|
* ``django.db.models.functions.TruncMinute()``
|
|
|
|
* ``django.db.models.functions.TruncHour()``
|
|
|
|
* ``django.db.models.functions.TruncDay()``
|
|
|
|
* ``django.db.models.functions.TruncWeek()``
|
|
|
|
* ``django.db.models.functions.TruncMonth()``
|
|
|
|
* ``django.db.models.functions.TruncQuarter()``
|
|
|
|
* ``django.db.models.functions.TruncYear()``
|
|
|
|
|
2023-01-10 13:01:14 +01:00
|
|
|
* The ``django.contrib.gis.admin.GeoModelAdmin`` and ``OSMGeoAdmin`` classes
|
|
|
|
are removed.
|
|
|
|
|
2023-01-10 13:43:21 +01:00
|
|
|
* The undocumented ``BaseForm._html_output()`` method is removed.
|
|
|
|
|
2023-01-11 06:07:16 +01:00
|
|
|
* The ability to return a ``str``, rather than a ``SafeString``, when rendering
|
|
|
|
an ``ErrorDict`` and ``ErrorList`` is removed.
|
|
|
|
|
2023-01-06 07:31:13 +01:00
|
|
|
See :ref:`deprecated-features-4.1` for details on these changes, including how
|
|
|
|
to remove usage of these features.
|
|
|
|
|
2023-01-12 12:34:42 +01:00
|
|
|
* The ``SitemapIndexItem.__str__()`` method is removed.
|
2023-01-12 12:47:42 +01:00
|
|
|
|
|
|
|
* The ``CSRF_COOKIE_MASKED`` transitional setting is removed.
|
2023-01-12 13:00:18 +01:00
|
|
|
|
|
|
|
* The ``name`` argument of ``django.utils.functional.cached_property()`` is
|
|
|
|
removed.
|
2023-01-12 13:20:08 +01:00
|
|
|
|
|
|
|
* The ``opclasses`` argument of
|
|
|
|
``django.contrib.postgres.constraints.ExclusionConstraint`` is removed.
|
2023-01-12 14:32:00 +01:00
|
|
|
|
|
|
|
* The undocumented ability to pass ``errors=None`` to
|
|
|
|
``SimpleTestCase.assertFormError()`` and ``assertFormsetError()`` is removed.
|
2023-01-12 14:43:48 +01:00
|
|
|
|
|
|
|
* ``django.contrib.sessions.serializers.PickleSerializer`` is removed.
|
2023-01-12 19:13:22 +01:00
|
|
|
|
|
|
|
* The usage of ``QuerySet.iterator()`` on a queryset that prefetches related
|
|
|
|
objects without providing the ``chunk_size`` argument is no longer allowed.
|
2023-01-12 19:31:49 +01:00
|
|
|
|
|
|
|
* Passing unsaved model instances to related filters is no longer allowed.
|
2023-01-13 05:49:36 +01:00
|
|
|
|
|
|
|
* ``created=True`` is required in the signature of
|
|
|
|
``RemoteUserBackend.configure_user()`` subclasses.
|
2023-01-13 06:03:29 +01:00
|
|
|
|
|
|
|
* Support for logging out via ``GET`` requests in the
|
|
|
|
``django.contrib.auth.views.LogoutView`` and
|
|
|
|
``django.contrib.auth.views.logout_then_login()`` is removed.
|
2023-01-13 08:22:41 +01:00
|
|
|
|
|
|
|
* The ``django.utils.timezone.utc`` alias to ``datetime.timezone.utc`` is
|
|
|
|
removed.
|
2023-01-13 08:31:30 +01:00
|
|
|
|
|
|
|
* Passing a response object and a form/formset name to
|
|
|
|
``SimpleTestCase.assertFormError()`` and ``assertFormSetError()`` is no
|
|
|
|
longer allowed.
|