5.1.txt 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416
  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. * ...
  25. :mod:`django.contrib.admindocs`
  26. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  27. * ...
  28. :mod:`django.contrib.auth`
  29. ~~~~~~~~~~~~~~~~~~~~~~~~~~
  30. * The default iteration count for the PBKDF2 password hasher is increased from
  31. 720,000 to 870,000.
  32. :mod:`django.contrib.contenttypes`
  33. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  34. * ...
  35. :mod:`django.contrib.gis`
  36. ~~~~~~~~~~~~~~~~~~~~~~~~~
  37. * :class:`~django.contrib.gis.db.models.functions.BoundingCircle` is now
  38. supported on SpatiaLite 5.1+.
  39. * :class:`~django.contrib.gis.db.models.Collect` is now supported on MySQL
  40. 8.0.24+.
  41. * :class:`~django.contrib.gis.geoip2.GeoIP2` now allows querying using
  42. :class:`ipaddress.IPv4Address` or :class:`ipaddress.IPv6Address` objects.
  43. * :meth:`.GeoIP2.country` now exposes the ``continent_code``,
  44. ``continent_name``, and ``is_in_european_union`` values.
  45. * :meth:`.GeoIP2.city` now exposes the ``accuracy_radius`` and ``region_name``
  46. values. In addition the ``dma_code`` and ``region`` values are now exposed as
  47. ``metro_code`` and ``region_code``, but the previous keys are also retained
  48. for backward compatibility.
  49. * :class:`~django.contrib.gis.measure.Area` now supports the ``ha`` unit.
  50. :mod:`django.contrib.messages`
  51. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  52. * ...
  53. :mod:`django.contrib.postgres`
  54. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  55. * :class:`~django.contrib.postgres.indexes.BTreeIndex` now supports the
  56. ``deduplicate_items`` parameter.
  57. :mod:`django.contrib.redirects`
  58. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  59. * ...
  60. :mod:`django.contrib.sessions`
  61. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  62. * ...
  63. :mod:`django.contrib.sitemaps`
  64. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  65. * ...
  66. :mod:`django.contrib.sites`
  67. ~~~~~~~~~~~~~~~~~~~~~~~~~~~
  68. * ...
  69. :mod:`django.contrib.staticfiles`
  70. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  71. * ...
  72. :mod:`django.contrib.syndication`
  73. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  74. * ...
  75. Asynchronous views
  76. ~~~~~~~~~~~~~~~~~~
  77. * ...
  78. Cache
  79. ~~~~~
  80. * ...
  81. CSRF
  82. ~~~~
  83. * ...
  84. Decorators
  85. ~~~~~~~~~~
  86. * ...
  87. Email
  88. ~~~~~
  89. * ...
  90. Error Reporting
  91. ~~~~~~~~~~~~~~~
  92. * ...
  93. File Storage
  94. ~~~~~~~~~~~~
  95. * ...
  96. File Uploads
  97. ~~~~~~~~~~~~
  98. * ...
  99. Forms
  100. ~~~~~
  101. * In order to improve accessibility and enable screen readers to associate
  102. fieldsets with their help text, the form fieldset now includes the
  103. ``aria-describedby`` HTML attribute.
  104. Generic Views
  105. ~~~~~~~~~~~~~
  106. * ...
  107. Internationalization
  108. ~~~~~~~~~~~~~~~~~~~~
  109. * ...
  110. Logging
  111. ~~~~~~~
  112. * ...
  113. Management Commands
  114. ~~~~~~~~~~~~~~~~~~~
  115. * :djadmin:`makemigrations` command now displays meaningful symbols for each
  116. operation to highlight :class:`operation categories
  117. <django.db.migrations.operations.base.OperationCategory>`.
  118. Migrations
  119. ~~~~~~~~~~
  120. * The new ``Operation.category`` attribute allows specifying an
  121. :class:`operation category
  122. <django.db.migrations.operations.base.OperationCategory>` used by the
  123. :djadmin:`makemigrations` to display a meaningful symbol for the operation.
  124. Models
  125. ~~~~~~
  126. * :meth:`.QuerySet.explain` now supports the ``generic_plan`` option on
  127. PostgreSQL 16+.
  128. * :class:`~django.db.models.expressions.RowRange` now accepts positive integers
  129. for the ``start`` argument and negative integers for the ``end`` argument.
  130. * The new ``exclusion`` argument of
  131. :class:`~django.db.models.expressions.RowRange` and
  132. :class:`~django.db.models.expressions.ValueRange` allows excluding rows,
  133. groups, and ties from the window frames.
  134. * :meth:`.QuerySet.order_by` now supports ordering by annotation transforms
  135. such as ``JSONObject`` keys and ``ArrayAgg`` indices.
  136. * :class:`F() <django.db.models.F>` and :class:`OuterRef()
  137. <django.db.models.OuterRef>` expressions that output
  138. :class:`~django.db.models.CharField`, :class:`~django.db.models.EmailField`,
  139. :class:`~django.db.models.SlugField`, :class:`~django.db.models.URLField`,
  140. :class:`~django.db.models.TextField`, or
  141. :class:`~django.contrib.postgres.fields.ArrayField` can now be :ref:`sliced
  142. <slicing-using-f>`.
  143. * The new ``from_queryset`` argument of :meth:`.Model.refresh_from_db` and
  144. :meth:`.Model.arefresh_from_db` allows customizing the queryset used to
  145. reload a model's value. This can be used to lock the row before reloading or
  146. to select related objects.
  147. Requests and Responses
  148. ~~~~~~~~~~~~~~~~~~~~~~
  149. * ...
  150. Security
  151. ~~~~~~~~
  152. * ...
  153. Serialization
  154. ~~~~~~~~~~~~~
  155. * ...
  156. Signals
  157. ~~~~~~~
  158. * ...
  159. Templates
  160. ~~~~~~~~~
  161. * Custom tags may now set extra data on the ``Parser`` object that will later
  162. be made available on the ``Template`` instance. Such data may be used, for
  163. example, by the template loader, or other template clients.
  164. * The new :ttag:`{% query_string %} <query_string>` template tag allows
  165. changing a :class:`~django.http.QueryDict` instance for use in links, for
  166. example, to generate a link to the next page while keeping any filtering
  167. options in place.
  168. Tests
  169. ~~~~~
  170. * :meth:`~django.test.SimpleTestCase.assertContains`,
  171. :meth:`~django.test.SimpleTestCase.assertNotContains`, and
  172. :meth:`~django.test.SimpleTestCase.assertInHTML` assertions now add haystacks
  173. to assertion error messages.
  174. * The Django test runner now supports a ``--screenshots`` option to save
  175. screenshots for Selenium tests.
  176. * The :class:`~django.test.RequestFactory`,
  177. :class:`~django.test.AsyncRequestFactory`, :class:`~django.test.Client`, and
  178. :class:`~django.test.AsyncClient` classes now support the ``query_params``
  179. parameter, which accepts a dictionary of query string keys and values. This
  180. allows setting query strings on any HTTP methods more easily.
  181. .. code-block:: python
  182. self.client.post("/items/1", query_params={"action": "delete"})
  183. await self.async_client.post("/items/1", query_params={"action": "delete"})
  184. * The new :meth:`.SimpleTestCase.assertNotInHTML` assertion allows testing that
  185. an HTML fragment is not contained in the given HTML haystack.
  186. * In order to enforce test isolation, database connections inside threads are
  187. no longer allowed in :class:`~django.test.SimpleTestCase`.
  188. URLs
  189. ~~~~
  190. * ...
  191. Utilities
  192. ~~~~~~~~~
  193. * ...
  194. Validators
  195. ~~~~~~~~~~
  196. * ...
  197. .. _backwards-incompatible-5.1:
  198. Backwards incompatible changes in 5.1
  199. =====================================
  200. Database backend API
  201. --------------------
  202. This section describes changes that may be needed in third-party database
  203. backends.
  204. * ...
  205. :mod:`django.contrib.gis`
  206. -------------------------
  207. * Support for PostGIS 2.5 is removed.
  208. * Support for PROJ < 6 is removed.
  209. * Support for GDAL 2.4 is removed.
  210. * :class:`~django.contrib.gis.geoip2.GeoIP2` no longer opens both city and
  211. country databases when a directory path is provided, preferring the city
  212. database, if it is available. The country database is a subset of the city
  213. database and both are not typically needed. If you require use of the country
  214. database when in the same directory as the city database, explicitly pass the
  215. country database path to the constructor.
  216. Dropped support for MariaDB 10.4
  217. --------------------------------
  218. Upstream support for MariaDB 10.4 ends in June 2024. Django 5.1 supports
  219. MariaDB 10.5 and higher.
  220. Dropped support for PostgreSQL 12
  221. ---------------------------------
  222. Upstream support for PostgreSQL 12 ends in November 2024. Django 5.1 supports
  223. PostgreSQL 13 and higher.
  224. Miscellaneous
  225. -------------
  226. * In order to improve accessibility, the admin's changelist filter is now
  227. rendered in a ``<nav>`` tag instead of a ``<div>``.
  228. * :meth:`.SimpleTestCase.assertURLEqual` and
  229. :meth:`~django.test.SimpleTestCase.assertInHTML` now add ``": "`` to the
  230. ``msg_prefix``. This is consistent with the behavior of other assertions.
  231. .. _deprecated-features-5.1:
  232. Features deprecated in 5.1
  233. ==========================
  234. Miscellaneous
  235. -------------
  236. * The ``ModelAdmin.log_deletion()`` and ``LogEntryManager.log_action()``
  237. methods are deprecated. Subclasses should implement
  238. ``ModelAdmin.log_deletions()`` and ``LogEntryManager.log_actions()``
  239. instead.
  240. * The undocumented ``django.utils.itercompat.is_iterable()`` function and the
  241. ``django.utils.itercompat`` module are deprecated. Use
  242. ``isinstance(..., collections.abc.Iterable)`` instead.
  243. * The ``django.contrib.gis.geoip2.GeoIP2.coords()`` method is deprecated. Use
  244. ``django.contrib.gis.geoip2.GeoIP2.lon_lat()`` instead.
  245. * The ``django.contrib.gis.geoip2.GeoIP2.open()`` method is deprecated. Use the
  246. :class:`~django.contrib.gis.geoip2.GeoIP2` constructor instead.
  247. * Passing positional arguments to :meth:`.Model.save` and :meth:`.Model.asave`
  248. is deprecated in favor of keyword-only arguments.
  249. Features removed in 5.1
  250. =======================
  251. These features have reached the end of their deprecation cycle and are removed
  252. in Django 5.1.
  253. See :ref:`deprecated-features-4.2` for details on these changes, including how
  254. to remove usage of these features.
  255. * The ``BaseUserManager.make_random_password()`` method is removed.
  256. * The model's ``Meta.index_together`` option is removed.
  257. * The ``length_is`` template filter is removed.
  258. * The ``django.contrib.auth.hashers.SHA1PasswordHasher``,
  259. ``django.contrib.auth.hashers.UnsaltedSHA1PasswordHasher``, and
  260. ``django.contrib.auth.hashers.UnsaltedMD5PasswordHasher`` are removed.
  261. * The model ``django.contrib.postgres.fields.CICharField``,
  262. ``django.contrib.postgres.fields.CIEmailField``, and
  263. ``django.contrib.postgres.fields.CITextField`` are removed, except for
  264. support in historical migrations.
  265. * The ``django.contrib.postgres.fields.CIText`` mixin is removed.
  266. * The ``map_width`` and ``map_height`` attributes of ``BaseGeometryWidget`` are
  267. removed.
  268. * The ``SimpleTestCase.assertFormsetError()`` method is removed.
  269. * The ``TransactionTestCase.assertQuerysetEqual()`` method is removed.
  270. * Support for passing encoded JSON string literals to ``JSONField`` and
  271. associated lookups and expressions is removed.
  272. * Support for passing positional arguments to ``Signer`` and
  273. ``TimestampSigner`` is removed.
  274. * The ``DEFAULT_FILE_STORAGE`` and ``STATICFILES_STORAGE`` settings is removed.
  275. * The ``django.core.files.storage.get_storage_class()`` function is removed.