5.1.txt 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489
  1. ============================================
  2. Django 5.1 release notes - UNDER DEVELOPMENT
  3. ============================================
  4. *Expected August 2024*
  5. Welcome to Django 5.1!
  6. These release notes cover the :ref:`new features <whats-new-5.1>`, as well as
  7. some :ref:`backwards incompatible changes <backwards-incompatible-5.1>` you'll
  8. want to be aware of when upgrading from Django 5.0 or earlier. We've
  9. :ref:`begun the deprecation process for some features
  10. <deprecated-features-5.1>`.
  11. See the :doc:`/howto/upgrade-version` guide if you're updating an existing
  12. project.
  13. Python compatibility
  14. ====================
  15. Django 5.1 supports Python 3.10, 3.11, and 3.12. We **highly recommend** and
  16. only officially support the latest release of each series.
  17. .. _whats-new-5.1:
  18. What's new in Django 5.1
  19. ========================
  20. Minor features
  21. --------------
  22. :mod:`django.contrib.admin`
  23. ~~~~~~~~~~~~~~~~~~~~~~~~~~~
  24. * :attr:`.ModelAdmin.list_display` now supports using ``__`` lookups to list
  25. fields from related models.
  26. :mod:`django.contrib.admindocs`
  27. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  28. * ...
  29. :mod:`django.contrib.auth`
  30. ~~~~~~~~~~~~~~~~~~~~~~~~~~
  31. * The default iteration count for the PBKDF2 password hasher is increased from
  32. 720,000 to 870,000.
  33. * :class:`~django.contrib.auth.forms.BaseUserCreationForm` and
  34. :class:`~django.contrib.auth.forms.AdminPasswordChangeForm` now support
  35. disabling password-based authentication by setting an unusable password on
  36. form save. This is now available in the admin when visiting the user creation
  37. and password change pages.
  38. * :func:`~.django.contrib.auth.decorators.login_required`,
  39. :func:`~.django.contrib.auth.decorators.permission_required`, and
  40. :func:`~.django.contrib.auth.decorators.user_passes_test` decorators now
  41. support wrapping asynchronous view functions.
  42. :mod:`django.contrib.contenttypes`
  43. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  44. * ...
  45. :mod:`django.contrib.gis`
  46. ~~~~~~~~~~~~~~~~~~~~~~~~~
  47. * :class:`~django.contrib.gis.db.models.functions.BoundingCircle` is now
  48. supported on SpatiaLite 5.1+.
  49. * :class:`~django.contrib.gis.db.models.Collect` is now supported on MySQL
  50. 8.0.24+.
  51. * :class:`~django.contrib.gis.geoip2.GeoIP2` now allows querying using
  52. :class:`ipaddress.IPv4Address` or :class:`ipaddress.IPv6Address` objects.
  53. * :meth:`.GeoIP2.country` now exposes the ``continent_code``,
  54. ``continent_name``, and ``is_in_european_union`` values.
  55. * :meth:`.GeoIP2.city` now exposes the ``accuracy_radius`` and ``region_name``
  56. values. In addition the ``dma_code`` and ``region`` values are now exposed as
  57. ``metro_code`` and ``region_code``, but the previous keys are also retained
  58. for backward compatibility.
  59. * :class:`~django.contrib.gis.measure.Area` now supports the ``ha`` unit.
  60. * The new :attr:`.OGRGeometry.is_3d` attribute allows checking if a geometry
  61. has a ``Z`` coordinate dimension.
  62. * The new :meth:`.OGRGeometry.set_3d` method allows addition and removal of the
  63. ``Z`` coordinate dimension.
  64. * :class:`~django.contrib.gis.gdal.OGRGeometry`,
  65. :class:`~django.contrib.gis.gdal.Point`,
  66. :class:`~django.contrib.gis.gdal.LineString`,
  67. :class:`~django.contrib.gis.gdal.Polygon`, and
  68. :class:`~django.contrib.gis.gdal.GeometryCollection` and its subclasses now
  69. support measured geometries via the new :attr:`.OGRGeometry.is_measured` and
  70. ``m`` properties, and the :meth:`.OGRGeometry.set_measured` method.
  71. * :attr:`.OGRGeometry.centroid` is now available on all supported geometry
  72. types.
  73. * :class:`FromWKB() <django.contrib.gis.db.models.functions.FromWKB>` and
  74. :class:`FromWKT() <django.contrib.gis.db.models.functions.FromWKT>` functions
  75. now support the optional ``srid`` argument (except for Oracle where it is
  76. ignored).
  77. :mod:`django.contrib.messages`
  78. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  79. * ...
  80. :mod:`django.contrib.postgres`
  81. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  82. * :class:`~django.contrib.postgres.indexes.BTreeIndex` now supports the
  83. ``deduplicate_items`` parameter.
  84. :mod:`django.contrib.redirects`
  85. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  86. * ...
  87. :mod:`django.contrib.sessions`
  88. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  89. * :class:`django.contrib.sessions.backends.cached_db.SessionStore` now handles
  90. exceptions when storing session information in the cache, logging proper
  91. error messages with their traceback via the newly added
  92. :ref:`sessions logger <django-contrib-sessions-logger>`.
  93. * :class:`django.contrib.sessions.backends.base.SessionBase` and all built-in
  94. session engines now provide async API. The new asynchronous methods all have
  95. ``a`` prefixed names, e.g. ``aget()``, ``akeys()``, or ``acycle_key()``.
  96. :mod:`django.contrib.sitemaps`
  97. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  98. * ...
  99. :mod:`django.contrib.sites`
  100. ~~~~~~~~~~~~~~~~~~~~~~~~~~~
  101. * ...
  102. :mod:`django.contrib.staticfiles`
  103. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  104. * ...
  105. :mod:`django.contrib.syndication`
  106. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  107. * ...
  108. Asynchronous views
  109. ~~~~~~~~~~~~~~~~~~
  110. * ...
  111. Cache
  112. ~~~~~
  113. * ...
  114. CSRF
  115. ~~~~
  116. * ...
  117. Database backends
  118. ~~~~~~~~~~~~~~~~~
  119. * ``"init_command"`` option is now supported in :setting:`OPTIONS` on SQLite
  120. to allow specifying :ref:`pragma options <sqlite-init-command>` to set upon
  121. connection.
  122. * ``"pool"`` option is now supported in :setting:`OPTIONS` on PostgreSQL to
  123. allow using :ref:`connection pools <postgresql-pool>`.
  124. Decorators
  125. ~~~~~~~~~~
  126. * ...
  127. Email
  128. ~~~~~
  129. * ...
  130. Error Reporting
  131. ~~~~~~~~~~~~~~~
  132. * In order to improve accessibility, the technical 404 and 500 error pages now
  133. use HTML landmark elements for the header, footer, and main content areas.
  134. File Storage
  135. ~~~~~~~~~~~~
  136. * ...
  137. File Uploads
  138. ~~~~~~~~~~~~
  139. * ...
  140. Forms
  141. ~~~~~
  142. * In order to improve accessibility and enable screen readers to associate
  143. fieldsets with their help text, the form fieldset now includes the
  144. ``aria-describedby`` HTML attribute.
  145. Generic Views
  146. ~~~~~~~~~~~~~
  147. * ...
  148. Internationalization
  149. ~~~~~~~~~~~~~~~~~~~~
  150. * ...
  151. Logging
  152. ~~~~~~~
  153. * ...
  154. Management Commands
  155. ~~~~~~~~~~~~~~~~~~~
  156. * :djadmin:`makemigrations` command now displays meaningful symbols for each
  157. operation to highlight :class:`operation categories
  158. <django.db.migrations.operations.base.OperationCategory>`.
  159. Migrations
  160. ~~~~~~~~~~
  161. * The new ``Operation.category`` attribute allows specifying an
  162. :class:`operation category
  163. <django.db.migrations.operations.base.OperationCategory>` used by the
  164. :djadmin:`makemigrations` to display a meaningful symbol for the operation.
  165. Models
  166. ~~~~~~
  167. * :meth:`.QuerySet.explain` now supports the ``generic_plan`` option on
  168. PostgreSQL 16+.
  169. * :class:`~django.db.models.expressions.RowRange` now accepts positive integers
  170. for the ``start`` argument and negative integers for the ``end`` argument.
  171. * The new ``exclusion`` argument of
  172. :class:`~django.db.models.expressions.RowRange` and
  173. :class:`~django.db.models.expressions.ValueRange` allows excluding rows,
  174. groups, and ties from the window frames.
  175. * :meth:`.QuerySet.order_by` now supports ordering by annotation transforms
  176. such as ``JSONObject`` keys and ``ArrayAgg`` indices.
  177. * :class:`F() <django.db.models.F>` and :class:`OuterRef()
  178. <django.db.models.OuterRef>` expressions that output
  179. :class:`~django.db.models.CharField`, :class:`~django.db.models.EmailField`,
  180. :class:`~django.db.models.SlugField`, :class:`~django.db.models.URLField`,
  181. :class:`~django.db.models.TextField`, or
  182. :class:`~django.contrib.postgres.fields.ArrayField` can now be :ref:`sliced
  183. <slicing-using-f>`.
  184. * The new ``from_queryset`` argument of :meth:`.Model.refresh_from_db` and
  185. :meth:`.Model.arefresh_from_db` allows customizing the queryset used to
  186. reload a model's value. This can be used to lock the row before reloading or
  187. to select related objects.
  188. * The new ``"transaction_mode"`` option is now supported in :setting:`OPTIONS`
  189. on SQLite to allow specifying the :ref:`sqlite-transaction-behavior`.
  190. Requests and Responses
  191. ~~~~~~~~~~~~~~~~~~~~~~
  192. * ...
  193. Security
  194. ~~~~~~~~
  195. * ...
  196. Serialization
  197. ~~~~~~~~~~~~~
  198. * ...
  199. Signals
  200. ~~~~~~~
  201. * ...
  202. Templates
  203. ~~~~~~~~~
  204. * Custom tags may now set extra data on the ``Parser`` object that will later
  205. be made available on the ``Template`` instance. Such data may be used, for
  206. example, by the template loader, or other template clients.
  207. * The new :ttag:`{% query_string %} <query_string>` template tag allows
  208. changing a :class:`~django.http.QueryDict` instance for use in links, for
  209. example, to generate a link to the next page while keeping any filtering
  210. options in place.
  211. Tests
  212. ~~~~~
  213. * :meth:`~django.test.SimpleTestCase.assertContains`,
  214. :meth:`~django.test.SimpleTestCase.assertNotContains`, and
  215. :meth:`~django.test.SimpleTestCase.assertInHTML` assertions now add haystacks
  216. to assertion error messages.
  217. * The :class:`~django.test.RequestFactory`,
  218. :class:`~django.test.AsyncRequestFactory`, :class:`~django.test.Client`, and
  219. :class:`~django.test.AsyncClient` classes now support the ``query_params``
  220. parameter, which accepts a dictionary of query string keys and values. This
  221. allows setting query strings on any HTTP methods more easily.
  222. .. code-block:: python
  223. self.client.post("/items/1", query_params={"action": "delete"})
  224. await self.async_client.post("/items/1", query_params={"action": "delete"})
  225. * The new :meth:`.SimpleTestCase.assertNotInHTML` assertion allows testing that
  226. an HTML fragment is not contained in the given HTML haystack.
  227. * In order to enforce test isolation, database connections inside threads are
  228. no longer allowed in :class:`~django.test.SimpleTestCase`.
  229. URLs
  230. ~~~~
  231. * ...
  232. Utilities
  233. ~~~~~~~~~
  234. * ...
  235. Validators
  236. ~~~~~~~~~~
  237. * ...
  238. .. _backwards-incompatible-5.1:
  239. Backwards incompatible changes in 5.1
  240. =====================================
  241. Database backend API
  242. --------------------
  243. This section describes changes that may be needed in third-party database
  244. backends.
  245. * ...
  246. :mod:`django.contrib.gis`
  247. -------------------------
  248. * Support for PostGIS 2.5 is removed.
  249. * Support for PROJ < 6 is removed.
  250. * Support for GDAL 2.4 is removed.
  251. * :class:`~django.contrib.gis.geoip2.GeoIP2` no longer opens both city and
  252. country databases when a directory path is provided, preferring the city
  253. database, if it is available. The country database is a subset of the city
  254. database and both are not typically needed. If you require use of the country
  255. database when in the same directory as the city database, explicitly pass the
  256. country database path to the constructor.
  257. Dropped support for MariaDB 10.4
  258. --------------------------------
  259. Upstream support for MariaDB 10.4 ends in June 2024. Django 5.1 supports
  260. MariaDB 10.5 and higher.
  261. Dropped support for PostgreSQL 12
  262. ---------------------------------
  263. Upstream support for PostgreSQL 12 ends in November 2024. Django 5.1 supports
  264. PostgreSQL 13 and higher.
  265. Miscellaneous
  266. -------------
  267. * In order to improve accessibility, the admin's changelist filter is now
  268. rendered in a ``<nav>`` tag instead of a ``<div>``.
  269. * In order to improve accessibility, the admin's footer is now rendered in
  270. a ``<footer>`` tag instead of a ``<div>``, and also moved below the
  271. ``<div id="main">`` element.
  272. * :meth:`.SimpleTestCase.assertURLEqual` and
  273. :meth:`~django.test.SimpleTestCase.assertInHTML` now add ``": "`` to the
  274. ``msg_prefix``. This is consistent with the behavior of other assertions.
  275. * ``django.utils.text.Truncator`` used by :tfilter:`truncatechars_html` and
  276. :tfilter:`truncatewords_html` template filters now uses
  277. :py:class:`html.parser.HTMLParser` subclasses. This results in a more robust
  278. and faster operation, but there may be small differences in the output.
  279. * The undocumented ``django.urls.converters.get_converter()`` function is
  280. removed.
  281. .. _deprecated-features-5.1:
  282. Features deprecated in 5.1
  283. ==========================
  284. Miscellaneous
  285. -------------
  286. * The ``ModelAdmin.log_deletion()`` and ``LogEntryManager.log_action()``
  287. methods are deprecated. Subclasses should implement
  288. ``ModelAdmin.log_deletions()`` and ``LogEntryManager.log_actions()``
  289. instead.
  290. * The undocumented ``django.utils.itercompat.is_iterable()`` function and the
  291. ``django.utils.itercompat`` module are deprecated. Use
  292. ``isinstance(..., collections.abc.Iterable)`` instead.
  293. * The ``django.contrib.gis.geoip2.GeoIP2.coords()`` method is deprecated. Use
  294. ``django.contrib.gis.geoip2.GeoIP2.lon_lat()`` instead.
  295. * The ``django.contrib.gis.geoip2.GeoIP2.open()`` method is deprecated. Use the
  296. :class:`~django.contrib.gis.geoip2.GeoIP2` constructor instead.
  297. * Passing positional arguments to :meth:`.Model.save` and :meth:`.Model.asave`
  298. is deprecated in favor of keyword-only arguments.
  299. * Setting ``django.contrib.gis.gdal.OGRGeometry.coord_dim`` is deprecated. Use
  300. :meth:`~django.contrib.gis.gdal.OGRGeometry.set_3d` instead.
  301. * Overriding existing converters with ``django.urls.register_converter()`` is
  302. deprecated.
  303. * The ``check`` keyword argument of ``CheckConstraint`` is deprecated in favor
  304. of ``condition``.
  305. Features removed in 5.1
  306. =======================
  307. These features have reached the end of their deprecation cycle and are removed
  308. in Django 5.1.
  309. See :ref:`deprecated-features-4.2` for details on these changes, including how
  310. to remove usage of these features.
  311. * The ``BaseUserManager.make_random_password()`` method is removed.
  312. * The model's ``Meta.index_together`` option is removed.
  313. * The ``length_is`` template filter is removed.
  314. * The ``django.contrib.auth.hashers.SHA1PasswordHasher``,
  315. ``django.contrib.auth.hashers.UnsaltedSHA1PasswordHasher``, and
  316. ``django.contrib.auth.hashers.UnsaltedMD5PasswordHasher`` are removed.
  317. * The model ``django.contrib.postgres.fields.CICharField``,
  318. ``django.contrib.postgres.fields.CIEmailField``, and
  319. ``django.contrib.postgres.fields.CITextField`` are removed, except for
  320. support in historical migrations.
  321. * The ``django.contrib.postgres.fields.CIText`` mixin is removed.
  322. * The ``map_width`` and ``map_height`` attributes of ``BaseGeometryWidget`` are
  323. removed.
  324. * The ``SimpleTestCase.assertFormsetError()`` method is removed.
  325. * The ``TransactionTestCase.assertQuerysetEqual()`` method is removed.
  326. * Support for passing encoded JSON string literals to ``JSONField`` and
  327. associated lookups and expressions is removed.
  328. * Support for passing positional arguments to ``Signer`` and
  329. ``TimestampSigner`` is removed.
  330. * The ``DEFAULT_FILE_STORAGE`` and ``STATICFILES_STORAGE`` settings is removed.
  331. * The ``django.core.files.storage.get_storage_class()`` function is removed.