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.
|
|
|
|
|
2023-01-18 09:46:01 +01:00
|
|
|
The Django 4.2.x series is the last to support Python 3.8 and 3.9.
|
|
|
|
|
2023-01-06 07:31:13 +01:00
|
|
|
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
|
|
|
|
========================
|
|
|
|
|
2023-02-16 13:23:24 +01:00
|
|
|
Facet filters in the admin
|
|
|
|
--------------------------
|
|
|
|
|
2023-03-05 14:01:19 +01:00
|
|
|
Facet counts are now shown for applied filters in the admin changelist when
|
2023-02-16 13:23:24 +01:00
|
|
|
toggled on via the UI. This behavior can be changed via the new
|
|
|
|
:attr:`.ModelAdmin.show_facets` attribute. For more information see
|
|
|
|
:ref:`facet-filters`.
|
|
|
|
|
2022-11-02 21:13:16 +01:00
|
|
|
Simplified templates for form field rendering
|
|
|
|
---------------------------------------------
|
|
|
|
|
|
|
|
Django 5.0 introduces the concept of a field group, and field group templates.
|
|
|
|
This simplifies rendering of the related elements of a Django form field such
|
|
|
|
as its label, widget, help text, and errors.
|
|
|
|
|
|
|
|
For example, the template below:
|
|
|
|
|
|
|
|
.. code-block:: html+django
|
|
|
|
|
|
|
|
<form>
|
|
|
|
...
|
|
|
|
<div>
|
2023-06-01 12:19:11 +02:00
|
|
|
{{ form.name.label_tag }}
|
2022-11-02 21:13:16 +01:00
|
|
|
{% if form.name.help_text %}
|
2023-06-01 16:44:57 +02:00
|
|
|
<div class="helptext" id="{{ form.name.id_for_label }}_helptext">
|
|
|
|
{{ form.name.help_text|safe }}
|
|
|
|
</div>
|
2022-11-02 21:13:16 +01:00
|
|
|
{% endif %}
|
|
|
|
{{ form.name.errors }}
|
|
|
|
{{ form.name }}
|
|
|
|
<div class="row">
|
|
|
|
<div class="col">
|
2023-06-01 12:19:11 +02:00
|
|
|
{{ form.email.label_tag }}
|
2022-11-02 21:13:16 +01:00
|
|
|
{% if form.email.help_text %}
|
2023-06-01 16:44:57 +02:00
|
|
|
<div class="helptext" id="{{ form.email.id_for_label }}_helptext">
|
|
|
|
{{ form.email.help_text|safe }}
|
|
|
|
</div>
|
2022-11-02 21:13:16 +01:00
|
|
|
{% endif %}
|
|
|
|
{{ form.email.errors }}
|
|
|
|
{{ form.email }}
|
|
|
|
</div>
|
|
|
|
<div class="col">
|
2023-06-01 12:19:11 +02:00
|
|
|
{{ form.password.label_tag }}
|
2022-11-02 21:13:16 +01:00
|
|
|
{% if form.password.help_text %}
|
2023-06-01 16:44:57 +02:00
|
|
|
<div class="helptext" id="{{ form.password.id_for_label }}_helptext">
|
|
|
|
{{ form.password.help_text|safe }}
|
|
|
|
</div>
|
2022-11-02 21:13:16 +01:00
|
|
|
{% endif %}
|
|
|
|
{{ form.password.errors }}
|
|
|
|
{{ form.password }}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
...
|
|
|
|
</form>
|
|
|
|
|
|
|
|
Can now be simplified to:
|
|
|
|
|
|
|
|
.. code-block:: html+django
|
|
|
|
|
|
|
|
<form>
|
|
|
|
...
|
|
|
|
<div>
|
|
|
|
{{ form.name.as_field_group }}
|
|
|
|
<div class="row">
|
|
|
|
<div class="col">{{ form.email.as_field_group }}</div>
|
|
|
|
<div class="col">{{ form.password.as_field_group }}</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
...
|
|
|
|
</form>
|
|
|
|
|
|
|
|
:meth:`~django.forms.BoundField.as_field_group` renders fields with the
|
|
|
|
``"django/forms/field.html"`` template by default and can be customized on a
|
|
|
|
per-project, per-field, or per-request basis. See
|
|
|
|
:ref:`reusable-field-group-templates`.
|
|
|
|
|
2020-11-22 23:27:57 +01:00
|
|
|
Database-computed default values
|
|
|
|
--------------------------------
|
|
|
|
|
|
|
|
The new :attr:`Field.db_default <django.db.models.Field.db_default>` parameter
|
|
|
|
sets a database-computed default value. For example::
|
|
|
|
|
|
|
|
from django.db import models
|
|
|
|
from django.db.models.functions import Now, Pi
|
|
|
|
|
|
|
|
|
|
|
|
class MyModel(models.Model):
|
|
|
|
age = models.IntegerField(db_default=18)
|
|
|
|
created = models.DateTimeField(db_default=Now())
|
|
|
|
circumference = models.FloatField(db_default=2 * Pi())
|
|
|
|
|
2023-08-31 03:57:40 +02:00
|
|
|
More options for declaring field choices
|
|
|
|
----------------------------------------
|
|
|
|
|
|
|
|
:attr:`.Field.choices` *(for model fields)* and :attr:`.ChoiceField.choices`
|
|
|
|
*(for form fields)* allow for more flexibility when declaring their values. In
|
|
|
|
previous versions of Django, ``choices`` should either be a list of 2-tuples,
|
|
|
|
or an :ref:`field-choices-enum-types` subclass, but the latter required
|
|
|
|
accessing the ``.choices`` attribute to provide the values in the expected
|
|
|
|
form::
|
|
|
|
|
|
|
|
from django.db import models
|
|
|
|
|
|
|
|
Medal = models.TextChoices("Medal", "GOLD SILVER BRONZE")
|
|
|
|
|
|
|
|
SPORT_CHOICES = [
|
|
|
|
("Martial Arts", [("judo", "Judo"), ("karate", "Karate")]),
|
|
|
|
("Racket", [("badminton", "Badminton"), ("tennis", "Tennis")]),
|
|
|
|
("unknown", "Unknown"),
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
|
class Winners(models.Model):
|
|
|
|
name = models.CharField(...)
|
|
|
|
medal = models.CharField(..., choices=Medal.choices)
|
|
|
|
sport = models.CharField(..., choices=SPORT_CHOICES)
|
|
|
|
|
|
|
|
Django 5.0 supports providing a mapping instead of an iterable, and also no
|
|
|
|
longer requires ``.choices`` to be used directly to expand :ref:`enumeration
|
|
|
|
types <field-choices-enum-types>`::
|
|
|
|
|
|
|
|
from django.db import models
|
|
|
|
|
|
|
|
Medal = models.TextChoices("Medal", "GOLD SILVER BRONZE")
|
|
|
|
|
|
|
|
SPORT_CHOICES = { # Using a mapping instead of a list of 2-tuples.
|
|
|
|
"Martial Arts": {"judo": "Judo", "karate": "Karate"},
|
|
|
|
"Racket": {"badminton": "Badminton", "tennis": "Tennis"},
|
|
|
|
"unknown": "Unknown",
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
class Winners(models.Model):
|
|
|
|
name = models.CharField(...)
|
|
|
|
medal = models.CharField(..., choices=Medal) # Using `.choices` not required.
|
|
|
|
sport = models.CharField(..., choices=SPORT_CHOICES)
|
|
|
|
|
|
|
|
Under the hood the provided ``choices`` are normalized into a list of 2-tuples
|
|
|
|
as the canonical form whenever the ``choices`` value is updated.
|
|
|
|
|
2023-01-06 07:31:13 +01:00
|
|
|
Minor features
|
|
|
|
--------------
|
|
|
|
|
|
|
|
:mod:`django.contrib.admin`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
2023-02-08 18:37:32 +01:00
|
|
|
* The new :meth:`.AdminSite.get_log_entries` method allows customizing the
|
|
|
|
queryset for the site's listed log entries.
|
2023-01-06 07:31:13 +01:00
|
|
|
|
2023-03-06 15:24:39 +01:00
|
|
|
* The ``django.contrib.admin.AllValuesFieldListFilter``,
|
|
|
|
``ChoicesFieldListFilter``, ``RelatedFieldListFilter``, and
|
|
|
|
``RelatedOnlyFieldListFilter`` admin filters now handle multi-valued query
|
|
|
|
parameters.
|
|
|
|
|
2023-04-18 16:11:40 +02:00
|
|
|
* ``XRegExp`` is upgraded from version 3.2.0 to 5.1.1.
|
|
|
|
|
2023-07-07 08:06:01 +02:00
|
|
|
* The new :meth:`.AdminSite.get_model_admin` method returns an admin class for
|
|
|
|
the given model class.
|
|
|
|
|
2023-01-06 07:31:13 +01:00
|
|
|
:mod:`django.contrib.admindocs`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
2023-01-25 22:25:29 +01:00
|
|
|
* ...
|
2023-01-06 07:31:13 +01:00
|
|
|
|
|
|
|
:mod:`django.contrib.auth`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
2023-01-25 22:25:29 +01:00
|
|
|
* The default iteration count for the PBKDF2 password hasher is increased from
|
2023-02-04 13:37:44 +01:00
|
|
|
600,000 to 720,000.
|
2023-01-06 07:31:13 +01:00
|
|
|
|
2023-02-11 02:43:26 +01:00
|
|
|
* The new asynchronous functions are now provided, using an
|
|
|
|
``a`` prefix: :func:`django.contrib.auth.aauthenticate`,
|
|
|
|
:func:`~.django.contrib.auth.aget_user`,
|
|
|
|
:func:`~.django.contrib.auth.alogin`, :func:`~.django.contrib.auth.alogout`,
|
|
|
|
and :func:`~.django.contrib.auth.aupdate_session_auth_hash`.
|
|
|
|
|
2023-02-14 00:24:35 +01:00
|
|
|
* ``AuthenticationMiddleware`` now adds an :meth:`.HttpRequest.auser`
|
|
|
|
asynchronous method that returns the currently logged-in user.
|
|
|
|
|
2023-05-14 18:12:22 +02:00
|
|
|
* The new :func:`django.contrib.auth.hashers.acheck_password` asynchronous
|
|
|
|
function and :meth:`.AbstractBaseUser.acheck_password` method allow
|
|
|
|
asynchronous checking of user passwords.
|
|
|
|
|
2023-01-06 07:31:13 +01:00
|
|
|
:mod:`django.contrib.contenttypes`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.gis`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
2023-01-13 17:48:27 +01:00
|
|
|
* The new
|
|
|
|
:class:`ClosestPoint() <django.contrib.gis.db.models.functions.ClosestPoint>`
|
|
|
|
function returns a 2-dimensional point on the geometry that is closest to
|
|
|
|
another geometry.
|
2023-01-06 07:31:13 +01:00
|
|
|
|
2023-06-03 15:54:22 +02:00
|
|
|
* :ref:`GIS aggregates <gis-aggregation-functions>` now support the ``filter``
|
|
|
|
argument.
|
|
|
|
|
2023-06-30 06:03:08 +02:00
|
|
|
* Added support for GDAL 3.7.
|
|
|
|
|
2023-07-10 17:43:19 +02:00
|
|
|
* Added support for GEOS 3.12.
|
|
|
|
|
2023-07-26 23:18:29 +02:00
|
|
|
* The new :meth:`.GEOSGeometry.equals_identical` method allows point-wise
|
|
|
|
equivalence checking of geometries.
|
|
|
|
|
2023-01-06 07:31:13 +01:00
|
|
|
:mod:`django.contrib.messages`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.postgres`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
2023-02-14 21:06:45 +01:00
|
|
|
* The new :attr:`~.ExclusionConstraint.violation_error_code` attribute of
|
|
|
|
:class:`~django.contrib.postgres.constraints.ExclusionConstraint` allows
|
|
|
|
customizing the ``code`` of ``ValidationError`` raised during
|
|
|
|
:ref:`model validation <validating-objects>`.
|
2023-01-06 07:31:13 +01:00
|
|
|
|
|
|
|
:mod:`django.contrib.redirects`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.sessions`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.sitemaps`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.sites`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.staticfiles`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.syndication`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
2022-12-21 20:25:24 +01:00
|
|
|
Asynchronous views
|
|
|
|
~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* Under ASGI, ``http.disconnect`` events are now handled. This allows views to
|
|
|
|
perform any necessary cleanup if a client disconnects before the response is
|
|
|
|
generated. See :ref:`async-handling-disconnect` for more details.
|
|
|
|
|
2023-01-06 07:31:13 +01:00
|
|
|
Cache
|
|
|
|
~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
CSRF
|
|
|
|
~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Decorators
|
|
|
|
~~~~~~~~~~
|
|
|
|
|
2023-04-26 08:08:33 +02:00
|
|
|
* The following decorators now support wrapping asynchronous view functions:
|
|
|
|
|
|
|
|
* :func:`~django.views.decorators.cache.cache_control`
|
|
|
|
* :func:`~django.views.decorators.cache.never_cache`
|
2023-05-19 15:14:32 +02:00
|
|
|
* :func:`~django.views.decorators.common.no_append_slash`
|
2023-07-08 22:00:42 +02:00
|
|
|
* :func:`~django.views.decorators.csrf.csrf_exempt`
|
2023-05-07 05:20:00 +02:00
|
|
|
* :func:`~django.views.decorators.debug.sensitive_variables`
|
|
|
|
* :func:`~django.views.decorators.debug.sensitive_post_parameters`
|
2023-04-11 13:40:55 +02:00
|
|
|
* :func:`~django.views.decorators.http.condition`
|
|
|
|
* :func:`~django.views.decorators.http.etag`
|
|
|
|
* :func:`~django.views.decorators.http.last_modified`
|
|
|
|
* :func:`~django.views.decorators.http.require_http_methods`
|
|
|
|
* :func:`~django.views.decorators.http.require_GET`
|
|
|
|
* :func:`~django.views.decorators.http.require_POST`
|
|
|
|
* :func:`~django.views.decorators.http.require_safe`
|
2023-07-08 22:54:37 +02:00
|
|
|
* :func:`~django.views.decorators.vary.vary_on_cookie`
|
|
|
|
* :func:`~django.views.decorators.vary.vary_on_headers`
|
2023-04-26 08:08:33 +02:00
|
|
|
* ``xframe_options_deny()``
|
|
|
|
* ``xframe_options_sameorigin()``
|
|
|
|
* ``xframe_options_exempt()``
|
2023-01-06 07:31:13 +01:00
|
|
|
|
|
|
|
Email
|
|
|
|
~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Error Reporting
|
|
|
|
~~~~~~~~~~~~~~~
|
|
|
|
|
2023-05-07 05:20:00 +02:00
|
|
|
* :func:`~django.views.decorators.debug.sensitive_variables` and
|
|
|
|
:func:`~django.views.decorators.debug.sensitive_post_parameters` can now be
|
|
|
|
used with asynchronous functions.
|
2023-01-06 07:31:13 +01:00
|
|
|
|
|
|
|
File Storage
|
|
|
|
~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
File Uploads
|
|
|
|
~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Forms
|
|
|
|
~~~~~
|
|
|
|
|
2023-03-08 20:12:34 +01:00
|
|
|
* The new ``assume_scheme`` argument for :class:`~django.forms.URLField` allows
|
|
|
|
specifying a default URL scheme.
|
|
|
|
|
2023-06-01 16:44:57 +02:00
|
|
|
* In order to improve accessibility and enable screen readers to associate form
|
|
|
|
fields with their help text, the form field now includes the
|
|
|
|
``aria-describedby`` HTML attribute.
|
|
|
|
|
2023-06-02 16:27:24 +02:00
|
|
|
* In order to improve accessibility, the invalid form field now includes the
|
|
|
|
``aria-invalid="true"`` HTML attribute.
|
|
|
|
|
2023-01-06 07:31:13 +01:00
|
|
|
Generic Views
|
|
|
|
~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Internationalization
|
|
|
|
~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
2023-08-12 11:07:34 +02:00
|
|
|
* Added support and translations for the Uyghur language.
|
2023-01-06 07:31:13 +01:00
|
|
|
|
|
|
|
Logging
|
|
|
|
~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Management Commands
|
|
|
|
~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Migrations
|
|
|
|
~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Models
|
|
|
|
~~~~~~
|
|
|
|
|
2023-01-31 03:39:15 +01:00
|
|
|
* The new ``create_defaults`` argument of :meth:`.QuerySet.update_or_create`
|
|
|
|
and :meth:`.QuerySet.aupdate_or_create` methods allows specifying a different
|
|
|
|
field values for the create operation.
|
2023-01-06 07:31:13 +01:00
|
|
|
|
2023-02-14 21:06:45 +01:00
|
|
|
* The new ``violation_error_code`` attribute of
|
|
|
|
:class:`~django.db.models.BaseConstraint`,
|
|
|
|
:class:`~django.db.models.CheckConstraint`, and
|
|
|
|
:class:`~django.db.models.UniqueConstraint` allows customizing the ``code``
|
|
|
|
of ``ValidationError`` raised during
|
|
|
|
:ref:`model validation <validating-objects>`.
|
|
|
|
|
2023-06-22 14:53:11 +02:00
|
|
|
* The :ref:`force_insert <ref-models-force-insert>` argument of
|
|
|
|
:meth:`.Model.save` now allows specifying a tuple of parent classes that must
|
|
|
|
be forced to be inserted.
|
|
|
|
|
2023-07-07 13:08:17 +02:00
|
|
|
* :meth:`.QuerySet.bulk_create` and :meth:`.QuerySet.abulk_create` methods now
|
|
|
|
set the primary key on each model instance when the ``update_conflicts``
|
|
|
|
parameter is enabled (if the database supports it).
|
|
|
|
|
2023-07-08 01:43:51 +02:00
|
|
|
* The new :attr:`.UniqueConstraint.nulls_distinct` attribute allows customizing
|
|
|
|
the treatment of ``NULL`` values on PostgreSQL 15+.
|
|
|
|
|
2023-07-20 17:50:06 +02:00
|
|
|
* The new :func:`~django.shortcuts.aget_object_or_404` and
|
|
|
|
:func:`~django.shortcuts.aget_list_or_404` asynchronous shortcuts allow
|
|
|
|
asynchronous getting objects.
|
|
|
|
|
2023-07-27 23:38:12 +02:00
|
|
|
* The new :func:`~django.db.models.aprefetch_related_objects` function allows
|
|
|
|
asynchronous prefetching of model instances.
|
|
|
|
|
|
|
|
* :meth:`.QuerySet.aiterator` now supports previous calls to
|
|
|
|
``prefetch_related()``.
|
|
|
|
|
2022-10-19 14:20:48 +02:00
|
|
|
* On MariaDB 10.7+, ``UUIDField`` is now created as ``UUID`` column rather than
|
|
|
|
``CHAR(32)`` column. See the migration guide above for more details on
|
|
|
|
:ref:`migrating-uuidfield`.
|
|
|
|
|
2022-07-12 08:22:40 +02:00
|
|
|
* Django now supports `oracledb`_ version 1.3.2 or higher. Support for
|
|
|
|
``cx_Oracle`` is deprecated as of this release and will be removed in Django
|
|
|
|
6.0.
|
|
|
|
|
2023-04-10 03:30:40 +02:00
|
|
|
Pagination
|
|
|
|
~~~~~~~~~~
|
|
|
|
|
|
|
|
* The new :attr:`django.core.paginator.Paginator.error_messages` argument
|
|
|
|
allows customizing the error messages raised by :meth:`.Paginator.page`.
|
|
|
|
|
2023-01-06 07:31:13 +01:00
|
|
|
Requests and Responses
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Security
|
|
|
|
~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Serialization
|
|
|
|
~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Signals
|
|
|
|
~~~~~~~
|
|
|
|
|
2020-11-07 11:19:20 +01:00
|
|
|
* The new :meth:`.Signal.asend` and :meth:`.Signal.asend_robust` methods allow
|
|
|
|
asynchronous signal dispatch. Signal receivers may be synchronous or
|
|
|
|
asynchronous, and will be automatically adapted to the correct calling style.
|
2023-01-06 07:31:13 +01:00
|
|
|
|
|
|
|
Templates
|
|
|
|
~~~~~~~~~
|
|
|
|
|
2023-05-20 00:33:51 +02:00
|
|
|
* The new :tfilter:`escapeseq` template filter applies :tfilter:`escape` to
|
|
|
|
each element of a sequence.
|
2023-01-06 07:31:13 +01:00
|
|
|
|
|
|
|
Tests
|
|
|
|
~~~~~
|
|
|
|
|
2023-02-11 02:43:26 +01:00
|
|
|
* :class:`~django.test.Client` and :class:`~django.test.AsyncClient` now
|
|
|
|
provide asynchronous methods, using an ``a`` prefix:
|
|
|
|
:meth:`~django.test.Client.asession`, :meth:`~django.test.Client.alogin`,
|
|
|
|
:meth:`~django.test.Client.aforce_login`, and
|
|
|
|
:meth:`~django.test.Client.alogout`.
|
2023-01-06 07:31:13 +01:00
|
|
|
|
2023-08-04 09:14:19 +02:00
|
|
|
* :class:`~django.test.AsyncClient` now supports the ``follow`` parameter.
|
|
|
|
|
2023-01-06 07:31:13 +01:00
|
|
|
URLs
|
|
|
|
~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Utilities
|
|
|
|
~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Validators
|
|
|
|
~~~~~~~~~~
|
|
|
|
|
2023-04-08 22:10:17 +02:00
|
|
|
* The new ``offset`` argument of
|
|
|
|
:class:`~django.core.validators.StepValueValidator` allows specifying an
|
|
|
|
offset for valid values.
|
2023-01-06 07:31:13 +01:00
|
|
|
|
|
|
|
.. _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.
|
|
|
|
|
2020-11-22 23:27:57 +01:00
|
|
|
* ``DatabaseFeatures.supports_expression_defaults`` should be set to ``False``
|
|
|
|
if the database doesn't support using database functions as defaults.
|
|
|
|
|
|
|
|
* ``DatabaseFeatures.supports_default_keyword_in_insert`` should be set to
|
|
|
|
``False`` if the database doesn't support the ``DEFAULT`` keyword in
|
|
|
|
``INSERT`` queries.
|
|
|
|
|
|
|
|
* ``DatabaseFeatures.supports_default_keyword_in_bulk insert`` should be set to
|
|
|
|
``False`` if the database doesn't support the ``DEFAULT`` keyword in bulk
|
|
|
|
``INSERT`` queries.
|
2023-01-06 07:31:13 +01:00
|
|
|
|
2023-08-03 18:54:29 +02:00
|
|
|
Dropped support for MySQL < 8.0.11
|
|
|
|
----------------------------------
|
|
|
|
|
|
|
|
Support for pre-releases of MySQL 8.0.x series is removed. Django 5.0 supports
|
|
|
|
MySQL 8.0.11 and higher.
|
|
|
|
|
2023-06-29 09:11:30 +02:00
|
|
|
:mod:`django.contrib.gis`
|
|
|
|
-------------------------
|
|
|
|
|
|
|
|
* Support for GDAL 2.2 and 2.3 is removed.
|
|
|
|
|
2023-06-29 21:45:36 +02:00
|
|
|
* Support for GEOS 3.6 and 3.7 is removed.
|
|
|
|
|
2023-07-02 22:48:56 +02:00
|
|
|
:mod:`django.contrib.sitemaps`
|
|
|
|
------------------------------
|
|
|
|
|
|
|
|
* The ``django.contrib.sitemaps.ping_google()`` function and the
|
|
|
|
``ping_google`` management command are removed as the Google
|
|
|
|
Sitemaps ping endpoint is deprecated and will be removed in January 2024.
|
|
|
|
|
|
|
|
* The ``django.contrib.sitemaps.SitemapNotFound`` exception class is removed.
|
|
|
|
|
2023-01-31 03:39:15 +01:00
|
|
|
Using ``create_defaults__exact`` may now be required with ``QuerySet.update_or_create()``
|
|
|
|
-----------------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
:meth:`.QuerySet.update_or_create` now supports the parameter
|
|
|
|
``create_defaults``. As a consequence, any models that have a field named
|
|
|
|
``create_defaults`` that are used with an ``update_or_create()`` should specify
|
|
|
|
the field in the lookup with ``create_defaults__exact``.
|
|
|
|
|
2022-10-19 14:20:48 +02:00
|
|
|
.. _migrating-uuidfield:
|
|
|
|
|
|
|
|
Migrating existing ``UUIDField`` on MariaDB 10.7+
|
|
|
|
-------------------------------------------------
|
|
|
|
|
|
|
|
On MariaDB 10.7+, ``UUIDField`` is now created as ``UUID`` column rather than
|
|
|
|
``CHAR(32)`` column. As a consequence, any ``UUIDField`` created in
|
|
|
|
Django < 5.0 should be replaced with a ``UUIDField`` subclass backed by
|
|
|
|
``CHAR(32)``::
|
|
|
|
|
|
|
|
class Char32UUIDField(models.UUIDField):
|
|
|
|
def db_type(self, connection):
|
|
|
|
return "char(32)"
|
|
|
|
|
|
|
|
For example::
|
|
|
|
|
|
|
|
class MyModel(models.Model):
|
|
|
|
uuid = models.UUIDField(primary_key=True, default=uuid.uuid4)
|
|
|
|
|
|
|
|
Should become::
|
|
|
|
|
|
|
|
class Char32UUIDField(models.UUIDField):
|
|
|
|
def db_type(self, connection):
|
|
|
|
return "char(32)"
|
|
|
|
|
|
|
|
|
|
|
|
class MyModel(models.Model):
|
|
|
|
uuid = Char32UUIDField(primary_key=True, default=uuid.uuid4)
|
|
|
|
|
|
|
|
Running the :djadmin:`makemigrations` command will generate a migration
|
|
|
|
containing a no-op ``AlterField`` operation.
|
|
|
|
|
2023-01-06 07:31:13 +01:00
|
|
|
Miscellaneous
|
|
|
|
-------------
|
|
|
|
|
2023-02-07 14:18:58 +01:00
|
|
|
* The ``instance`` argument of the undocumented
|
|
|
|
``BaseModelFormSet.save_existing()`` method is renamed to ``obj``.
|
2023-01-06 07:31:13 +01:00
|
|
|
|
2023-01-31 19:05:03 +01:00
|
|
|
* The undocumented ``django.contrib.admin.helpers.checkbox`` is removed.
|
|
|
|
|
2023-03-01 23:13:00 +01:00
|
|
|
* Integer fields are now validated as 64-bit integers on SQLite to match the
|
|
|
|
behavior of ``sqlite3``.
|
|
|
|
|
2023-03-13 15:03:28 +01:00
|
|
|
* The undocumented ``Query.annotation_select_mask`` attribute is changed from a
|
|
|
|
set of strings to an ordered list of strings.
|
|
|
|
|
2023-04-26 09:22:43 +02:00
|
|
|
* ``ImageField.update_dimension_fields()`` is no longer called on the
|
|
|
|
``post_init`` signal if ``width_field`` and ``height_field`` are not set.
|
|
|
|
|
2023-05-11 18:22:55 +02:00
|
|
|
* :class:`~django.db.models.functions.Now` database function now uses
|
|
|
|
``LOCALTIMESTAMP`` instead of ``CURRENT_TIMESTAMP`` on Oracle.
|
|
|
|
|
2023-06-02 12:54:07 +02:00
|
|
|
* :attr:`.AdminSite.site_header` is now rendered in a ``<div>`` tag instead of
|
|
|
|
``<h1>``. Screen reader users rely on heading elements for navigation within
|
|
|
|
a page. Having two ``<h1>`` elements was confusing and the site header wasn't
|
|
|
|
helpful as it is repeated on all pages.
|
|
|
|
|
2023-05-30 06:59:22 +02:00
|
|
|
* On databases without native support for the SQL ``XOR`` operator, ``^`` as
|
|
|
|
the exclusive or (``XOR``) operator now returns rows that are matched by an
|
|
|
|
odd number of operands rather than exactly one operand. This is consistent
|
|
|
|
with the behavior of MySQL, MariaDB, and Python.
|
|
|
|
|
2023-06-23 21:52:04 +02:00
|
|
|
* The minimum supported version of ``asgiref`` is increased from 3.6.0 to
|
|
|
|
3.7.0.
|
|
|
|
|
2023-06-26 14:22:54 +02:00
|
|
|
* The minimum supported version of ``selenium`` is increased from 3.8.0 to
|
|
|
|
4.8.0.
|
|
|
|
|
2023-07-07 13:22:06 +02:00
|
|
|
* The ``AlreadyRegistered`` and ``NotRegistered`` exceptions are moved from
|
|
|
|
``django.contrib.admin.sites`` to ``django.contrib.admin.exceptions``.
|
|
|
|
|
2023-08-04 06:35:13 +02:00
|
|
|
* The minimum supported version of SQLite is increased from 3.21.0 to 3.27.0.
|
|
|
|
|
2023-08-09 12:41:47 +02:00
|
|
|
* Support for ``cx_Oracle`` < 8.3 is removed.
|
|
|
|
|
2023-06-01 16:39:52 +02:00
|
|
|
* Executing SQL queries before the app registry has been fully populated now
|
|
|
|
raises :exc:`RuntimeWarning`.
|
|
|
|
|
2023-08-25 21:27:22 +02:00
|
|
|
* :exc:`~django.core.exceptions.BadRequest` is raised for non-UTF-8 encoded
|
|
|
|
requests with the :mimetype:`application/x-www-form-urlencoded` content type.
|
|
|
|
See :rfc:`1866` for more details.
|
|
|
|
|
2023-01-06 07:31:13 +01:00
|
|
|
.. _deprecated-features-5.0:
|
|
|
|
|
|
|
|
Features deprecated in 5.0
|
|
|
|
==========================
|
|
|
|
|
|
|
|
Miscellaneous
|
|
|
|
-------------
|
|
|
|
|
2023-01-18 11:08:39 +01:00
|
|
|
* The ``DjangoDivFormRenderer`` and ``Jinja2DivFormRenderer`` transitional form
|
|
|
|
renderers are deprecated.
|
2023-01-06 07:31:13 +01:00
|
|
|
|
2023-02-20 14:28:21 +01:00
|
|
|
* Passing positional arguments ``name`` and ``violation_error_message`` to
|
|
|
|
:class:`~django.db.models.BaseConstraint` is deprecated in favor of
|
|
|
|
keyword-only arguments.
|
|
|
|
|
2023-04-13 11:46:47 +02:00
|
|
|
* ``request`` is added to the signature of :meth:`.ModelAdmin.lookup_allowed`.
|
|
|
|
Support for ``ModelAdmin`` subclasses that do not accept this argument is
|
|
|
|
deprecated.
|
|
|
|
|
2023-04-18 10:20:32 +02:00
|
|
|
* The ``get_joining_columns()`` method of ``ForeignObject`` and
|
|
|
|
``ForeignObjectRel`` is deprecated. Starting with Django 6.0,
|
|
|
|
``django.db.models.sql.datastructures.Join`` will no longer fallback to
|
|
|
|
``get_joining_columns()``. Subclasses should implement
|
|
|
|
``get_joining_fields()`` instead.
|
|
|
|
|
|
|
|
* The ``ForeignObject.get_reverse_joining_columns()`` method is deprecated.
|
|
|
|
|
2023-03-08 20:12:34 +01:00
|
|
|
* The default scheme for ``forms.URLField`` will change from ``"http"`` to
|
|
|
|
``"https"`` in Django 6.0.
|
|
|
|
|
2023-06-06 10:56:53 +02:00
|
|
|
* Support for calling ``format_html()`` without passing args or kwargs will be
|
|
|
|
removed.
|
|
|
|
|
2022-07-12 08:22:40 +02:00
|
|
|
* Support for ``cx_Oracle`` is deprecated in favor of `oracledb`_ 1.3.2+ Python
|
|
|
|
driver.
|
|
|
|
|
|
|
|
.. _`oracledb`: https://oracle.github.io/python-oracledb/
|
|
|
|
|
2023-01-06 07:31:13 +01:00
|
|
|
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.
|
2023-01-13 08:36:50 +01:00
|
|
|
|
|
|
|
* The ``django.contrib.gis.admin.OpenLayersWidget`` is removed.
|
2023-01-13 09:09:58 +01:00
|
|
|
|
|
|
|
+ The ``django.contrib.auth.hashers.CryptPasswordHasher`` is removed.
|
2023-01-13 09:32:35 +01:00
|
|
|
|
|
|
|
* The ``"django/forms/default.html"`` and
|
|
|
|
``"django/forms/formsets/default.html"`` templates are removed.
|
|
|
|
|
|
|
|
* The default form and formset rendering style is changed to the div-based.
|
2023-01-13 09:49:28 +01:00
|
|
|
|
|
|
|
* Passing ``nulls_first=False`` or ``nulls_last=False`` to ``Expression.asc()``
|
|
|
|
and ``Expression.desc()`` methods, and the ``OrderBy`` expression is no
|
|
|
|
longer allowed.
|