3.0.txt 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400
  1. ============================================
  2. Django 3.0 release notes - UNDER DEVELOPMENT
  3. ============================================
  4. *Expected December 2019*
  5. Welcome to Django 3.0!
  6. These release notes cover the :ref:`new features <whats-new-3.0>`, as well as
  7. some :ref:`backwards incompatible changes <backwards-incompatible-3.0>` you'll
  8. want to be aware of when upgrading from Django 2.2 or earlier. We've
  9. :ref:`dropped some features<removed-features-3.0>` that have reached the end of
  10. their deprecation cycle, and we've :ref:`begun the deprecation process for
  11. some features <deprecated-features-3.0>`.
  12. See the :doc:`/howto/upgrade-version` guide if you're updating an existing
  13. project.
  14. Python compatibility
  15. ====================
  16. Django 3.0 supports Python 3.6, 3.7, and 3.8. We **highly recommend** and only
  17. officially support the latest release of each series.
  18. The Django 2.2.x series is the last to support Python 3.5.
  19. Third-party library support for older version of Django
  20. =======================================================
  21. Following the release of Django 3.0, we suggest that third-party app authors
  22. drop support for all versions of Django prior to 2.2. At that time, you should
  23. be able to run your package's tests using ``python -Wd`` so that deprecation
  24. warnings appear. After making the deprecation warning fixes, your app should be
  25. compatible with Django 3.0.
  26. .. _whats-new-3.0:
  27. What's new in Django 3.0
  28. ========================
  29. Minor features
  30. --------------
  31. :mod:`django.contrib.admin`
  32. ~~~~~~~~~~~~~~~~~~~~~~~~~~~
  33. * ...
  34. :mod:`django.contrib.admindocs`
  35. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  36. * ...
  37. :mod:`django.contrib.auth`
  38. ~~~~~~~~~~~~~~~~~~~~~~~~~~
  39. * ...
  40. :mod:`django.contrib.contenttypes`
  41. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  42. * ...
  43. :mod:`django.contrib.gis`
  44. ~~~~~~~~~~~~~~~~~~~~~~~~~
  45. * Allowed MySQL spatial lookup functions to operate on real geometries.
  46. Previous support was limited to bounding boxes.
  47. * Added the :class:`~django.contrib.gis.db.models.functions.GeometryDistance`
  48. function, supported on PostGIS.
  49. :mod:`django.contrib.messages`
  50. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  51. * ...
  52. :mod:`django.contrib.postgres`
  53. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  54. * ...
  55. :mod:`django.contrib.redirects`
  56. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  57. * ...
  58. :mod:`django.contrib.sessions`
  59. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  60. * ...
  61. :mod:`django.contrib.sitemaps`
  62. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  63. * ...
  64. :mod:`django.contrib.sites`
  65. ~~~~~~~~~~~~~~~~~~~~~~~~~~~
  66. * ...
  67. :mod:`django.contrib.staticfiles`
  68. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  69. * ...
  70. :mod:`django.contrib.syndication`
  71. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  72. * ...
  73. Cache
  74. ~~~~~
  75. * ...
  76. CSRF
  77. ~~~~
  78. * ...
  79. Email
  80. ~~~~~
  81. * ...
  82. File Storage
  83. ~~~~~~~~~~~~
  84. * ...
  85. File Uploads
  86. ~~~~~~~~~~~~
  87. * ...
  88. Forms
  89. ~~~~~
  90. * ...
  91. Generic Views
  92. ~~~~~~~~~~~~~
  93. * ...
  94. Internationalization
  95. ~~~~~~~~~~~~~~~~~~~~
  96. * ...
  97. Management Commands
  98. ~~~~~~~~~~~~~~~~~~~
  99. * The new :option:`compilemessages --ignore` option allows ignoring specific
  100. directories when searching for ``.po`` files to compile.
  101. * :option:`showmigrations --list` now shows the applied datetimes when
  102. ``--verbosity`` is 2 and above.
  103. Migrations
  104. ~~~~~~~~~~
  105. * ...
  106. Models
  107. ~~~~~~
  108. * Added hash database functions :class:`~django.db.models.functions.MD5`,
  109. :class:`~django.db.models.functions.SHA1`,
  110. :class:`~django.db.models.functions.SHA224`,
  111. :class:`~django.db.models.functions.SHA256`,
  112. :class:`~django.db.models.functions.SHA384`, and
  113. :class:`~django.db.models.functions.SHA512`.
  114. * The new ``is_dst`` parameter of the
  115. :class:`~django.db.models.functions.Trunc` database functions determines the
  116. treatment of nonexistent and ambiguous datetimes.
  117. Requests and Responses
  118. ~~~~~~~~~~~~~~~~~~~~~~
  119. * ...
  120. Serialization
  121. ~~~~~~~~~~~~~
  122. * ...
  123. Signals
  124. ~~~~~~~
  125. * ...
  126. Templates
  127. ~~~~~~~~~
  128. * ...
  129. Tests
  130. ~~~~~
  131. * The new test :class:`~django.test.Client` argument
  132. ``raise_request_exception`` allows controlling whether or not exceptions
  133. raised during the request should also be raised in the test. The value
  134. defaults to ``True`` for backwards compatibility. If it is ``False`` and an
  135. exception occurs, the test client will return a 500 response with the
  136. attribute :attr:`~django.test.Response.exc_info`, a tuple providing
  137. information of the exception that occurred.
  138. URLs
  139. ~~~~
  140. * ...
  141. Validators
  142. ~~~~~~~~~~
  143. * ...
  144. .. _backwards-incompatible-3.0:
  145. Backwards incompatible changes in 3.0
  146. =====================================
  147. Database backend API
  148. --------------------
  149. This section describes changes that may be needed in third-party database
  150. backends.
  151. * The second argument of ``DatabaseIntrospection.get_geometry_type()`` is now
  152. the row description instead of the column name.
  153. * ``DatabaseIntrospection.get_field_type()`` may no longer return tuples.
  154. * If the database can create foreign keys in the same SQL statement that adds a
  155. field, add ``SchemaEditor.sql_create_column_inline_fk`` with the appropriate
  156. SQL; otherwise, set ``DatabaseFeatures.can_create_inline_fk = False``.
  157. * ``DatabaseFeatures.can_return_id_from_insert`` and
  158. ``can_return_ids_from_bulk_insert`` are renamed to
  159. ``can_return_columns_from_insert`` and ``can_return_rows_from_bulk_insert``.
  160. :mod:`django.contrib.gis`
  161. -------------------------
  162. * Support for PostGIS 2.1 is removed.
  163. * Support for SpatiaLite 4.1 and 4.2 is removed.
  164. * Support for GDAL 1.11 and GEOS 3.4 is removed.
  165. Dropped support for PostgreSQL 9.4
  166. ----------------------------------
  167. Upstream support for PostgreSQL 9.4 ends in December 2019. Django 3.0 supports
  168. PostgreSQL 9.5 and higher.
  169. Dropped support for Oracle 12.1
  170. -------------------------------
  171. Upstream support for Oracle 12.1 ends in July 2021. Django 2.2 will be
  172. supported until April 2022. Django 3.0 officially supports Oracle 12.2 and 18c.
  173. Removed private Python 2 compatibility APIs
  174. -------------------------------------------
  175. While Python 2 support was removed in Django 2.0, some private APIs weren't
  176. removed from Django so that third party apps could continue using them until
  177. the Python 2 end-of-life.
  178. Since we expect apps to drop Python 2 compatibility when adding support for
  179. Django 3.0, we're removing these APIs at this time.
  180. * ``django.test.utils.str_prefix()`` - Strings don't have 'u' prefixes in
  181. Python 3.
  182. * ``django.test.utils.patch_logger()`` - Use
  183. :meth:`unittest.TestCase.assertLogs` instead.
  184. * ``django.utils.lru_cache.lru_cache()`` - Alias of
  185. :func:`functools.lru_cache`.
  186. * ``django.utils.decorators.available_attrs()`` - This function returns
  187. ``functools.WRAPPER_ASSIGNMENTS``.
  188. * ``django.utils.decorators.ContextDecorator`` - Alias of
  189. :class:`contextlib.ContextDecorator`.
  190. * ``django.utils._os.abspathu()`` - Alias of :func:`os.path.abspath`.
  191. * ``django.utils._os.upath()`` and ``npath()`` - These functions do nothing on
  192. Python 3.
  193. * ``django.utils.six`` - Remove usage of this vendored library or switch to
  194. `six <https://pypi.org/project/six/>`_.
  195. * ``django.utils.encoding.python_2_unicode_compatible()`` - Alias of
  196. ``six.python_2_unicode_compatible()``.
  197. * ``django.utils.functional.curry()`` - Use :func:`functools.partial` or
  198. :class:`functools.partialmethod`. See :commit:`5b1c389603a353625ae1603`.
  199. * ``django.utils.safestring.SafeBytes`` - Unused since Django 2.0.
  200. New default value for the ``FILE_UPLOAD_PERMISSIONS`` setting
  201. -------------------------------------------------------------
  202. In older versions, the :setting:`FILE_UPLOAD_PERMISSIONS` setting defaults to
  203. ``None``. With the default :setting:`FILE_UPLOAD_HANDLERS`, this results in
  204. uploaded files having different permissions depending on their size and which
  205. upload handler is used.
  206. ``FILE_UPLOAD_PERMISSION`` now defaults to ``0o644`` to avoid this
  207. inconsistency.
  208. Miscellaneous
  209. -------------
  210. * ``ContentType.__str__()`` now includes the model's ``app_label`` to
  211. disambiguate model's with the same name in different apps.
  212. * Because accessing the language in the session rather than in the cookie is
  213. deprecated, ``LocaleMiddleware`` no longer looks for the user's language in
  214. the session and :func:`django.contrib.auth.logout` no longer preserves the
  215. session's language after logout.
  216. .. _deprecated-features-3.0:
  217. Features deprecated in 3.0
  218. ==========================
  219. ``django.utils.encoding.force_text()`` and ``smart_text()``
  220. -----------------------------------------------------------
  221. The ``smart_text()`` and ``force_text()`` aliases (since Django 2.0) of
  222. ``smart_str()`` and ``force_str()`` are deprecated. Ignore this deprecation if
  223. your code supports Python 2 as the behavior of ``smart_str()`` and
  224. ``force_str()`` is different there.
  225. Miscellaneous
  226. -------------
  227. * ``django.utils.http.urlquote()``, ``urlquote_plus()``, ``urlunquote()``, and
  228. ``urlunquote_plus()`` are deprecated in favor of the functions that they're
  229. aliases for: :func:`urllib.parse.quote`, :func:`~urllib.parse.quote_plus`,
  230. :func:`~urllib.parse.unquote`, and :func:`~urllib.parse.unquote_plus`.
  231. * ``django.utils.translation.ugettext()``, ``ugettext_lazy()``,
  232. ``ugettext_noop()``, ``ungettext()``, and ``ungettext_lazy()`` are deprecated
  233. in favor of the functions that they're aliases for:
  234. :func:`django.utils.translation.gettext`,
  235. :func:`~django.utils.translation.gettext_lazy`,
  236. :func:`~django.utils.translation.gettext_noop`,
  237. :func:`~django.utils.translation.ngettext`, and
  238. :func:`~django.utils.translation.ngettext_lazy`.
  239. * To limit creation of sessions and hence favor some caching strategies,
  240. :func:`django.views.i18n.set_language` will stop setting the user's language
  241. in the session in Django 4.0. Since Django 2.1, the language is always stored
  242. in the :setting:`LANGUAGE_COOKIE_NAME` cookie.
  243. .. _removed-features-3.0:
  244. Features removed in 3.0
  245. =======================
  246. These features have reached the end of their deprecation cycle and are removed
  247. in Django 3.0.
  248. See :ref:`deprecated-features-2.0` for details on these changes, including how
  249. to remove usage of these features.
  250. * The ``django.db.backends.postgresql_psycopg2`` module is removed.
  251. * ``django.shortcuts.render_to_response()`` is removed.
  252. * The ``DEFAULT_CONTENT_TYPE`` setting is removed.
  253. * ``HttpRequest.xreadlines()`` is removed.
  254. * Support for the ``context`` argument of ``Field.from_db_value()`` and
  255. ``Expression.convert_value()`` is removed.
  256. * The ``field_name`` keyword argument of ``QuerySet.earliest()`` and
  257. ``latest()`` is removed.
  258. See :ref:`deprecated-features-2.1` for details on these changes, including how
  259. to remove usage of these features.
  260. * The ``ForceRHR`` GIS function is removed.
  261. * ``django.utils.http.cookie_date()`` is removed.
  262. * The ``staticfiles`` and ``admin_static`` template tag libraries are removed.
  263. * ``django.contrib.staticfiles.templatetags.staticfiles.static()`` is removed.