1.11.txt 33 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818
  1. =============================================
  2. Django 1.11 release notes - UNDER DEVELOPMENT
  3. =============================================
  4. Welcome to Django 1.11!
  5. These release notes cover the :ref:`new features <whats-new-1.11>`, as well as
  6. some :ref:`backwards incompatible changes <backwards-incompatible-1.11>` you'll
  7. want to be aware of when upgrading from Django 1.10 or older versions. We've
  8. :ref:`begun the deprecation process for some features
  9. <deprecated-features-1.11>`.
  10. See the :doc:`/howto/upgrade-version` guide if you're updating an existing
  11. project.
  12. Django 1.11 is designated as a :term:`long-term support release`. It will
  13. receive security updates for at least three years after its release. Support
  14. for the previous LTS, Django 1.8, will end in April 2018.
  15. Python compatibility
  16. ====================
  17. Django 1.11 requires Python 2.7, 3.4, 3.5, or 3.6. Django 1.11 is the first
  18. release to support Python 3.6. We **highly recommend** and only officially
  19. support the latest release of each series.
  20. The Django 1.11.x series is the last to support Python 2. The next major
  21. release, Django 2.0, will only support Python 3.5+.
  22. Deprecating warnings are no longer loud by default
  23. ==================================================
  24. Unlike older versions of Django, Django's own deprecation warnings are no
  25. longer displayed by default. This is consistent with Python's default behavior.
  26. This change allows third-party apps to support both Django 1.11 LTS and Django
  27. 1.8 LTS without having to add code to avoid deprecation warnings.
  28. Following the release of Django 2.0, we suggest that third-party app authors
  29. drop support for all versions of Django prior to 1.11. At that time, you should
  30. be able run your package's tests using ``python -Wd`` so that deprecation
  31. warnings do appear. After making the deprecation warning fixes, your app should
  32. be compatible with Django 2.0.
  33. .. _whats-new-1.11:
  34. What's new in Django 1.11
  35. =========================
  36. Class-based model indexes
  37. -------------------------
  38. The new :mod:`django.db.models.indexes` module contains classes which ease
  39. creating database indexes. Indexes are added to models using the
  40. :attr:`Meta.indexes <django.db.models.Options.indexes>` option.
  41. The :class:`~django.db.models.Index` class creates a b-tree index, as if you
  42. used :attr:`~django.db.models.Field.db_index` on the model field or
  43. :attr:`~django.db.models.Options.index_together` on the model ``Meta`` class.
  44. It can be subclassed to support different index types, such as
  45. :class:`~django.contrib.postgres.indexes.GinIndex`. It also allows defining the
  46. order (ASC/DESC) for the columns of the index.
  47. Template-based widget rendering
  48. -------------------------------
  49. To ease customizing widgets, form widget rendering is now done using the
  50. template system rather than in Python. See :doc:`/ref/forms/renderers`.
  51. You may need to adjust any custom widgets that you've written for a few
  52. :ref:`backwards incompatible changes <template-widget-incompatibilities-1-11>`.
  53. ``Subquery`` expressions
  54. ------------------------
  55. The new :class:`~django.db.models.Subquery` and
  56. :class:`~django.db.models.Exists` database expressions allow creating
  57. explicit subqueries. Subqueries may refer to fields from the outer queryset
  58. using the :class:`~django.db.models.OuterRef` class.
  59. Minor features
  60. --------------
  61. :mod:`django.contrib.admin`
  62. ~~~~~~~~~~~~~~~~~~~~~~~~~~~
  63. * :attr:`.ModelAdmin.date_hierarchy` can now reference fields across relations.
  64. * The new :meth:`ModelAdmin.get_exclude()
  65. <django.contrib.admin.ModelAdmin.get_exclude>` hook allows specifying the
  66. exclude fields based on the request or model instance.
  67. * The ``popup_response.html`` template can now be overridden per app, per
  68. model, or by setting the :attr:`.ModelAdmin.popup_response_template`
  69. attribute.
  70. :mod:`django.contrib.auth`
  71. ~~~~~~~~~~~~~~~~~~~~~~~~~~
  72. * The default iteration count for the PBKDF2 password hasher is increased by
  73. 20%.
  74. * The :class:`~django.contrib.auth.views.LoginView` and
  75. :class:`~django.contrib.auth.views.LogoutView` class-based views supersede the
  76. deprecated ``login()`` and ``logout()`` function-based views.
  77. * The :class:`~django.contrib.auth.views.PasswordChangeView`,
  78. :class:`~django.contrib.auth.views.PasswordChangeDoneView`,
  79. :class:`~django.contrib.auth.views.PasswordResetView`,
  80. :class:`~django.contrib.auth.views.PasswordResetDoneView`,
  81. :class:`~django.contrib.auth.views.PasswordResetConfirmView`, and
  82. :class:`~django.contrib.auth.views.PasswordResetCompleteView` class-based
  83. views supersede the deprecated ``password_change()``,
  84. ``password_change_done()``, ``password_reset()``, ``password_reset_done()``,
  85. ``password_reset_confirm()``, and ``password_reset_complete()`` function-based
  86. views.
  87. * The new ``post_reset_login`` attribute for
  88. :class:`~django.contrib.auth.views.PasswordResetConfirmView` allows
  89. automatically logging in a user after a successful password reset.
  90. * To avoid the possibility of leaking a password reset token via the HTTP
  91. Referer header (for example, if the reset page includes a reference to CSS or
  92. JavaScript hosted on another domain), the
  93. :class:`~django.contrib.auth.views.PasswordResetConfirmView` (but not the
  94. deprecated ``password_reset_confirm()`` function-based view) stores the token
  95. in a session and redirects to itself to present the password change form to
  96. the user without the token in the URL.
  97. * :func:`~django.contrib.auth.update_session_auth_hash` now rotates the session
  98. key to allow a password change to invalidate stolen session cookies.
  99. * The new ``success_url_allowed_hosts`` attribute for
  100. :class:`~django.contrib.auth.views.LoginView` and
  101. :class:`~django.contrib.auth.views.LogoutView` allows specifying a set of
  102. hosts that are safe for redirecting after login and logout.
  103. * Added password validators ``help_text`` to
  104. :class:`~django.contrib.auth.forms.UserCreationForm`.
  105. * The ``HttpRequest`` is now passed to :func:`~django.contrib.auth.authenticate`
  106. which in turn passes it to the authentication backend if it accepts a
  107. ``request`` argument.
  108. * The :func:`~django.contrib.auth.signals.user_login_failed` signal now
  109. receives a ``request`` argument.
  110. * :class:`~django.contrib.auth.forms.PasswordResetForm` supports custom user
  111. models that use an email field named something other than ``'email'``.
  112. Set :attr:`CustomUser.EMAIL_FIELD
  113. <django.contrib.auth.models.CustomUser.EMAIL_FIELD>` to the name of the field.
  114. * :func:`~django.contrib.auth.get_user_model` can now be called at import time,
  115. even in modules that define models.
  116. :mod:`django.contrib.contenttypes`
  117. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  118. * When stale content types are detected in the
  119. :djadmin:`remove_stale_contenttypes` command, there's now a list of related
  120. objects such as ``auth.Permission``\s that will also be deleted. Previously,
  121. only the content types were listed (and this prompt was after ``migrate``
  122. rather than in a separate command).
  123. :mod:`django.contrib.gis`
  124. ~~~~~~~~~~~~~~~~~~~~~~~~~
  125. * The new :meth:`.GEOSGeometry.from_gml` and :meth:`.OGRGeometry.from_gml`
  126. methods allow creating geometries from GML.
  127. * Added support for the :lookup:`dwithin` lookup on SpatiaLite.
  128. * The :class:`~django.contrib.gis.db.models.functions.Area` function,
  129. :class:`~django.contrib.gis.db.models.functions.Distance` function, and
  130. distance lookups now work with geodetic coordinates on SpatiaLite.
  131. * The OpenLayers-based form widgets now use ``OpenLayers.js`` from
  132. ``https://cdnjs.cloudflare.com`` which is more suitable for production use
  133. than the the old ``http://openlayers.org`` source. They are also updated to
  134. use OpenLayers 3.
  135. * PostGIS migrations can now change field dimensions.
  136. * Added the ability to pass the `size`, `shape`, and `offset` parameter when
  137. creating :class:`~django.contrib.gis.gdal.GDALRaster` objects.
  138. * Added SpatiaLite support for the
  139. :class:`~django.contrib.gis.db.models.functions.IsValid` function,
  140. :class:`~django.contrib.gis.db.models.functions.MakeValid` function, and
  141. :lookup:`isvalid` lookup.
  142. * Added Oracle support for the
  143. :class:`~django.contrib.gis.db.models.functions.AsGML` function,
  144. :class:`~django.contrib.gis.db.models.functions.BoundingCircle` function,
  145. :class:`~django.contrib.gis.db.models.functions.IsValid` function, and
  146. :lookup:`isvalid` lookup.
  147. :mod:`django.contrib.postgres`
  148. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  149. * The new ``distinct`` argument for
  150. :class:`~django.contrib.postgres.aggregates.StringAgg` determines if
  151. concatenated values will be distinct.
  152. * The new :class:`~django.contrib.postgres.indexes.GinIndex` and
  153. :class:`~django.contrib.postgres.indexes.BrinIndex` classes allow
  154. creating ``GIN`` and ``BRIN`` indexes in the database.
  155. * :class:`~django.contrib.postgres.fields.JSONField` accepts a new ``encoder``
  156. parameter to specify a custom class to encode data types not supported by the
  157. standard encoder.
  158. * The new :class:`~django.contrib.postgres.fields.CITextField` and
  159. :class:`~django.contrib.postgres.operations.CITextExtension` migration
  160. operation allow using PostgreSQL's ``citext`` extension for case-insensitive
  161. lookups.
  162. * The new :class:`~django.contrib.postgres.aggregates.JSONBAgg` allows
  163. aggregating values as a JSON array.
  164. * :class:`~django.contrib.postgres.fields.HStoreField` and
  165. :class:`~django.contrib.postgres.forms.HStoreField` allow storing null
  166. values.
  167. Cache
  168. ~~~~~
  169. * Memcached backends now pass the contents of :setting:`OPTIONS <CACHES-OPTIONS>`
  170. as keyword arguments to the client constructors, allowing for more advanced
  171. control of client behavior. See the :ref:`cache arguments <cache_arguments>`
  172. documentation for examples.
  173. * Memcached backends now allow defining multiple servers as a comma-delimited
  174. string in :setting:`LOCATION <CACHES-LOCATION>`, for convenience with
  175. third-party services that use such strings in environment variables.
  176. CSRF
  177. ~~~~
  178. * Added the :setting:`CSRF_USE_SESSIONS` setting to allow storing the CSRF
  179. token in the user's session rather than in a cookie.
  180. Database backends
  181. ~~~~~~~~~~~~~~~~~
  182. * Added the ``skip_locked`` argument to :meth:`.QuerySet.select_for_update()`
  183. on PostgreSQL 9.5+ and Oracle to execute queries with
  184. ``FOR UPDATE SKIP LOCKED``.
  185. * Added the :setting:`TEST['TEMPLATE'] <TEST_TEMPLATE>` setting to let
  186. PostgreSQL users specify a template for creating the test database.
  187. * :meth:`.QuerySet.iterator()` now uses :ref:`server-side cursors
  188. <psycopg2:server-side-cursors>` on PostgreSQL. This feature transfers some of
  189. the worker memory load (used to hold query results) to the database and might
  190. increase database memory usage.
  191. * Added MySQL support for the ``'isolation_level'`` option in
  192. :setting:`OPTIONS` to allow specifying the :ref:`transaction isolation level
  193. <mysql-isolation-level>`. To avoid possible data loss, it's recommended to
  194. switch from MySQL's default level, repeatable read, to read committed.
  195. Email
  196. ~~~~~
  197. * Added the :setting:`EMAIL_USE_LOCALTIME` setting to allow sending SMTP date
  198. headers in the local time zone rather than in UTC.
  199. * ``EmailMessage.attach()`` and ``attach_file()`` now fall back to MIME type
  200. ``application/octet-stream`` when binary content that can't be decoded as
  201. UTF-8 is specified for a ``text/*`` attachment.
  202. File Storage
  203. ~~~~~~~~~~~~
  204. * To make it wrappable by :class:`io.TextIOWrapper`,
  205. :class:`~django.core.files.File` now has the ``readable()``, ``writable()``,
  206. and ``seekable()`` methods.
  207. Forms
  208. ~~~~~
  209. * The new :attr:`CharField.empty_value <django.forms.CharField.empty_value>`
  210. attribute allows specifying the Python value to use to represent "empty".
  211. * The new :meth:`Form.get_initial_for_field()
  212. <django.forms.Form.get_initial_for_field>` method returns initial data for a
  213. form field.
  214. Internationalization
  215. ~~~~~~~~~~~~~~~~~~~~
  216. * Number formatting and the :setting:`NUMBER_GROUPING` setting support
  217. non-uniform digit grouping.
  218. Management Commands
  219. ~~~~~~~~~~~~~~~~~~~
  220. * The new :option:`loaddata --exclude` option allows excluding models and apps
  221. while loading data from fixtures.
  222. * The new :option:`diffsettings --default` option allows specifying a settings
  223. module other than Django's default settings to compare against.
  224. * ``app_label``\s arguments now limit the :option:`showmigrations --plan`
  225. output.
  226. Migrations
  227. ~~~~~~~~~~
  228. * Added support for serialization of ``uuid.UUID`` objects.
  229. Models
  230. ~~~~~~
  231. * Added support for callable values in the ``defaults`` argument of
  232. :meth:`QuerySet.update_or_create()
  233. <django.db.models.query.QuerySet.update_or_create>` and
  234. :meth:`~django.db.models.query.QuerySet.get_or_create`.
  235. * :class:`~django.db.models.ImageField` now has a default
  236. :data:`~django.core.validators.validate_image_file_extension` validator.
  237. * Added support for time truncation to
  238. :class:`~django.db.models.functions.datetime.Trunc` functions.
  239. * Added the :class:`~django.db.models.functions.datetime.ExtractWeek` function
  240. to extract the week from :class:`~django.db.models.DateField` and
  241. :class:`~django.db.models.DateTimeField` and exposed it through the
  242. :lookup:`week` lookup.
  243. * Added the :class:`~django.db.models.functions.datetime.TruncTime` function
  244. to truncate :class:`~django.db.models.DateTimeField` to its time component
  245. and exposed it through the :lookup:`time` lookup.
  246. * Added support for expressions in :meth:`.QuerySet.values` and
  247. :meth:`~.QuerySet.values_list`.
  248. * Added support for query expressions on lookups that take multiple arguments,
  249. such as ``range``.
  250. * You can now use the ``unique=True`` option with
  251. :class:`~django.db.models.FileField`.
  252. * Added the ``nulls_first`` and ``nulls_last`` parameters to
  253. :class:`Expression.asc() <django.db.models.Expression.asc>` and
  254. :meth:`~django.db.models.Expression.desc` to control
  255. the ordering of null values.
  256. * The new ``F`` expression ``bitleftshift()`` and ``bitrightshift()`` methods
  257. allow :ref:`bitwise shift operations <using-f-expressions-in-filters>`.
  258. * Added :meth:`.QuerySet.union`, :meth:`~.QuerySet.intersection`, and
  259. :meth:`~.QuerySet.difference`.
  260. Requests and Responses
  261. ~~~~~~~~~~~~~~~~~~~~~~
  262. * Added :meth:`QueryDict.fromkeys() <django.http.QueryDict.fromkeys>`.
  263. * :class:`~django.middleware.common.CommonMiddleware` now sets the
  264. ``Content-Length`` response header for non-streaming responses.
  265. * Added the :setting:`SECURE_HSTS_PRELOAD` setting to allow appending the
  266. ``preload`` directive to the ``Strict-Transport-Security`` header.
  267. * :class:`~django.middleware.http.ConditionalGetMiddleware` now adds the
  268. ``ETag`` header to responses.
  269. Serialization
  270. ~~~~~~~~~~~~~
  271. * The new ``django.core.serializers.base.Serializer.stream_class`` attribute
  272. allows subclasses to customize the default stream.
  273. * The encoder used by the :ref:`JSON serializer <serialization-formats-json>`
  274. can now be customized by passing a ``cls`` keyword argument to the
  275. ``serializers.serialize()`` function.
  276. * :class:`~django.core.serializers.json.DjangoJSONEncoder` now serializes
  277. :class:`~datetime.timedelta` objects (used by
  278. :class:`~django.db.models.DurationField`).
  279. Templates
  280. ~~~~~~~~~
  281. * :meth:`~django.utils.safestring.mark_safe` can now be used as a decorator.
  282. * The :class:`~django.template.backends.jinja2.Jinja2` template backend now
  283. supports context processors by setting the ``'context_processors'`` option in
  284. :setting:`OPTIONS <TEMPLATES-OPTIONS>`.
  285. * The :ttag:`regroup` tag now returns ``namedtuple``\s instead of dictionaries
  286. so you can unpack the group object directly in a loop, e.g.
  287. ``{% for grouper, list in regrouped %}``.
  288. * Added a :ttag:`resetcycle` template tag to allow resetting the sequence of
  289. the :ttag:`cycle` template tag.
  290. * You can now specify specific directories for a particular
  291. :class:`filesystem.Loader <django.template.loaders.filesystem.Loader>`.
  292. Tests
  293. ~~~~~
  294. * Added :meth:`.DiscoverRunner.get_test_runner_kwargs` to allow customizing the
  295. keyword arguments passed to the test runner.
  296. * Added the :option:`test --debug-mode` option to help troubleshoot test
  297. failures by setting the :setting:`DEBUG` setting to ``True``.
  298. * The new :func:`django.test.utils.setup_databases` (moved from
  299. ``django.test.runner``) and :func:`~django.test.utils.teardown_databases`
  300. functions make it easier to build custom test runners.
  301. * Added support for :meth:`python:unittest.TestCase.subTest`’s when using the
  302. :option:`test --parallel` option.
  303. * ``DiscoverRunner`` now runs the system checks at the start of a test run.
  304. Override the :meth:`.DiscoverRunner.run_checks` method if you want to disable
  305. that.
  306. Validators
  307. ~~~~~~~~~~
  308. * Added :class:`~django.core.validators.FileExtensionValidator` to validate
  309. file extensions and
  310. :data:`~django.core.validators.validate_image_file_extension` to validate
  311. image files.
  312. .. _backwards-incompatible-1.11:
  313. Backwards incompatible changes in 1.11
  314. ======================================
  315. :mod:`django.contrib.gis`
  316. -------------------------
  317. * To simplify the codebase and because it's easier to install than when
  318. ``contrib.gis`` was first released, :ref:`gdalbuild` is now a required
  319. dependency for GeoDjango. In older versions, it's only required for SQLite.
  320. * ``contrib.gis.maps`` is removed as it interfaces with a retired version of
  321. the Google Maps API and seems to be unmaintained. If you're using it, `let
  322. us know <https://code.djangoproject.com/ticket/14284>`_.
  323. * The ``GEOSGeometry`` equality operator now also compares SRID.
  324. * The OpenLayers-based form widgets now use OpenLayers 3, and the
  325. ``gis/openlayers.html`` and ``gis/openlayers-osm.html`` templates have been
  326. updated. Check your project if you subclass these widgets or extend the
  327. templates.
  328. * Support for SpatiaLite < 4.0 is dropped.
  329. * Support for GDAL 1.7 and 1.8 is dropped.
  330. :mod:`django.contrib.staticfiles`
  331. ---------------------------------
  332. * ``collectstatic`` may now fail during post-processing when using a hashed
  333. static files storage if a reference loop exists (e.g. ``'foo.css'``
  334. references ``'bar.css'`` which itself references ``'foo.css'``) or if the
  335. chain of files referencing other files is too deep to resolve in several
  336. passes. In the latter case, increase the number of passes using
  337. :attr:`.ManifestStaticFilesStorage.max_post_process_passes`.
  338. * When using ``ManifestStaticFilesStorage``, static files not found in the
  339. manifest at runtime now raise a ``ValueError`` instead of returning an
  340. unchanged path. You can revert to the old behavior by setting
  341. :attr:`.ManifestStaticFilesStorage.manifest_strict` to ``False``.
  342. Database backend API
  343. --------------------
  344. * The ``DatabaseOperations.time_trunc_sql()`` method is added to support
  345. ``TimeField`` truncation. It accepts a ``lookup_type`` and ``field_name``
  346. arguments and returns the appropriate SQL to truncate the given time field
  347. ``field_name`` to a time object with only the given specificity. The
  348. ``lookup_type`` argument can be either ``'hour'``, ``'minute'``, or
  349. ``'second'``.
  350. * The ``DatabaseOperations.datetime_cast_time_sql()`` method is added to
  351. support the :lookup:`time` lookup. It accepts a ``field_name`` and ``tzname``
  352. arguments and returns the SQL necessary to cast a datetime value to time value.
  353. * To enable ``FOR UPDATE SKIP LOCKED`` support, set
  354. ``DatabaseFeatures.has_select_for_update_skip_locked = True``.
  355. * The new ``DatabaseFeatures.supports_index_column_ordering`` attribute
  356. specifies if a database allows defining ordering for columns in indexes. The
  357. default value is ``True`` and the ``DatabaseIntrospection.get_constraints()``
  358. method should include an ``'orders'`` key in each of the returned
  359. dictionaries with a list of ``'ASC'`` and/or ``'DESC'`` values corresponding
  360. to the the ordering of each column in the index.
  361. * :djadmin:`inspectdb` no longer calls ``DatabaseIntrospection.get_indexes()``
  362. which is deprecated. Custom database backends should ensure all types of
  363. indexes are returned by ``DatabaseIntrospection.get_constraints()``.
  364. * Renamed the ``ignores_quoted_identifier_case`` feature to
  365. ``ignores_table_name_case`` to more accurately reflect how it is used.
  366. * The ``name`` keyword argument is added to the
  367. ``DatabaseWrapper.create_cursor(self, name=None)`` method to allow usage of
  368. server-side cursors on backends that support it.
  369. Dropped support for PostgreSQL 9.2 and PostGIS 2.0
  370. --------------------------------------------------
  371. Upstream support for PostgreSQL 9.2 ends in September 2017. As a consequence,
  372. Django 1.11 sets PostgreSQL 9.3 as the minimum version it officially supports.
  373. Support for PostGIS 2.0 is also removed as PostgreSQL 9.2 is the last version
  374. to support it.
  375. ``LiveServerTestCase`` binds to port zero
  376. -----------------------------------------
  377. Rather than taking a port range and iterating to find a free port,
  378. ``LiveServerTestCase`` binds to port zero and relies on the operating system
  379. to assign a free port. The ``DJANGO_LIVE_TEST_SERVER_ADDRESS`` environment
  380. variable is no longer used, and as it's also no longer used, the
  381. ``manage.py test --liveserver`` option is removed.
  382. Protection against insecure redirects in :mod:`django.contrib.auth` and ``i18n`` views
  383. --------------------------------------------------------------------------------------
  384. ``LoginView``, ``LogoutView`` (and the deprecated function-based equivalents),
  385. and :func:`~django.views.i18n.set_language` protect users from being redirected
  386. to non-HTTPS ``next`` URLs when the app is running over HTTPS.
  387. ``QuerySet.get_or_create()`` and ``update_or_create()`` validate arguments
  388. --------------------------------------------------------------------------
  389. To prevent typos from passing silently,
  390. :meth:`~django.db.models.query.QuerySet.get_or_create` and
  391. :meth:`~django.db.models.query.QuerySet.update_or_create` check that their
  392. arguments are model fields. This should be backwards-incompatible only in the
  393. fact that it might expose a bug in your project.
  394. ``pytz`` is a required dependency and support for ``settings.TIME_ZONE = None`` is removed
  395. ------------------------------------------------------------------------------------------
  396. To simplify Django's timezone handling, ``pytz`` is now a required dependency.
  397. It's automatically installed along with Django.
  398. Support for ``settings.TIME_ZONE = None`` is removed as the behavior isn't
  399. commonly used and is questionably useful. If you want to automatically detect
  400. the timezone based on the system timezone, you can use `tzlocal
  401. <https://pypi.python.org/pypi/tzlocal>`_::
  402. from tzlocal import get_localzone
  403. TIME_ZONE = get_localzone().zone
  404. This works similar to ``settings.TIME_ZONE = None`` except that it also sets
  405. ``os.environ['TZ']``. `Let us know
  406. <https://groups.google.com/d/topic/django-developers/OAV3FChfuPM/discussion>`__
  407. if there's a use case where you find you can't adapt your code to set a
  408. ``TIME_ZONE``.
  409. HTML changes in admin templates
  410. -------------------------------
  411. ``<p class="help">`` is replaced with a ``<div>`` tag to allow including lists
  412. inside help text.
  413. Read-only fields are wrapped in ``<div class="readonly">...</div>`` instead of
  414. ``<p>...</p>`` to allow any kind of HTML as the field's content.
  415. .. _template-widget-incompatibilities-1-11:
  416. Changes due to the introduction of template-based widget rendering
  417. ------------------------------------------------------------------
  418. Some undocumented classes in ``django.forms.widgets`` are removed:
  419. * ``SubWidget``
  420. * ``RendererMixin``, ``ChoiceFieldRenderer``, ``RadioFieldRenderer``,
  421. ``CheckboxFieldRenderer``
  422. * ``ChoiceInput``, ``RadioChoiceInput``, ``CheckboxChoiceInput``
  423. The ``Widget.format_output()`` method is removed. Use a custom widget template
  424. instead.
  425. Some widget values, such as ``<select>`` options, are now localized if
  426. ``settings.USE_L10N=True``. You could revert to the old behavior with custom
  427. widget templates that uses the :ttag:`localize` template tag to turn off
  428. localization.
  429. ``django.Template.render()`` prohibits non-dict context
  430. -------------------------------------------------------
  431. For compatibility with multiple template engines, ``django.Template.render()``
  432. must receive a dictionary of context rather than ``Context`` or
  433. ``RequestContext``. If you were passing either of the two classes, pass a
  434. dictionary instead -- doing so is backwards-compatible with older versions of
  435. Django.
  436. Model state changes in migration operations
  437. -------------------------------------------
  438. To improve the speed of applying migrations, rendering of related models is
  439. delayed until an operation that needs them (e.g. ``RunPython``). If you have a
  440. custom operation that works with model classes or model instances from the
  441. ``from_state`` argument in ``database_forwards()`` or ``database_backwards()``,
  442. you must render model states using the ``clear_delayed_apps_cache()`` method as
  443. described in :ref:`writing your own migration operation
  444. <writing-your-own-migration-operation>`.
  445. Miscellaneous
  446. -------------
  447. * If no items in the feed have a ``pubdate`` or ``updateddate`` attribute,
  448. :meth:`SyndicationFeed.latest_post_date()
  449. <django.utils.feedgenerator.SyndicationFeed.latest_post_date>` now returns
  450. the current UTC date/time, instead of a datetime without any timezone
  451. information.
  452. * CSRF failures are logged to the ``django.security.csrf`` logger instead of
  453. ``django.request``.
  454. * :setting:`ALLOWED_HOSTS` validation is no longer disabled when running tests.
  455. If your application includes tests with custom host names, you must include
  456. those host names in :setting:`ALLOWED_HOSTS`. See
  457. :ref:`topics-testing-advanced-multiple-hosts`.
  458. * Using a foreign key's id (e.g. ``'field_id'``) in ``ModelAdmin.list_display``
  459. displays the related object's ID. Remove the ``_id`` suffix if you want the
  460. old behavior of the string representation of the object.
  461. * In model forms, :class:`~django.db.models.CharField` with ``null=True`` now
  462. saves ``NULL`` for blank values instead of empty strings.
  463. * On Oracle, :meth:`Model.validate_unique()
  464. <django.db.models.Model.validate_unique>` no longer checks empty strings for
  465. uniqueness as the database interprets the value as ``NULL``.
  466. * If you subclass :class:`.AbstractUser` and override ``clean()``, be sure it
  467. calls ``super()``. :meth:`.BaseUserManager.normalize_email` is called in a
  468. new :meth:`.AbstractUser.clean` method so that normalization is applied in
  469. cases like model form validation.
  470. * ``EmailField`` and ``URLField`` no longer accept the ``strip`` keyword
  471. argument. Remove it because it doesn't have an effect in older versions of
  472. Django as these fields alway strip whitespace.
  473. * The ``checked`` and ``selected`` attribute rendered by form widgets now uses
  474. HTML5 boolean syntax rather than XHTML's ``checked='checked'`` and
  475. ``selected='selected'``.
  476. * :meth:`RelatedManager.add()
  477. <django.db.models.fields.related.RelatedManager.add>`,
  478. :meth:`~django.db.models.fields.related.RelatedManager.remove`,
  479. :meth:`~django.db.models.fields.related.RelatedManager.clear`, and
  480. :meth:`~django.db.models.fields.related.RelatedManager.set` now
  481. clear the ``prefetch_related()`` cache.
  482. * To prevent possible loss of saved settings,
  483. :func:`~django.test.utils.setup_test_environment` now raises an exception if
  484. called a second time before calling
  485. :func:`~django.test.utils.teardown_test_environment`.
  486. * The undocumented ``DateTimeAwareJSONEncoder`` alias for
  487. :class:`~django.core.serializers.json.DjangoJSONEncoder` (renamed in Django
  488. 1.0) is removed.
  489. * The :class:`cached template loader <django.template.loaders.cached.Loader>`
  490. is now enabled if :setting:`DEBUG` is ``False`` and
  491. :setting:`OPTIONS['loaders'] <TEMPLATES-OPTIONS>` isn't specified. This could
  492. be backwards-incompatible if you have some :ref:`template tags that aren't
  493. thread safe <template_tag_thread_safety>`.
  494. * The prompt for stale content type deletion no longer occurs after running the
  495. ``migrate`` command. Use the new :djadmin:`remove_stale_contenttypes` command
  496. instead.
  497. * The admin's widget for ``IntegerField`` uses ``type="number"`` rather than
  498. ``type="text"``.
  499. * Conditional HTTP headers are now parsed and compared according to the
  500. :rfc:`7232` Conditional Requests specification rather than the older
  501. :rfc:`2616`.
  502. * :func:`~django.utils.cache.patch_response_headers` no longer adds a
  503. ``Last-Modified`` header. According to the :rfc:`7234#section-4.2.2`, this
  504. header is useless alongside other caching headers that provide an explicit
  505. expiration time, e.g. ``Expires`` or ``Cache-Control``.
  506. :class:`~django.middleware.cache.UpdateCacheMiddleware` and
  507. :func:`~django.utils.cache.add_never_cache_headers` call
  508. ``patch_response_headers()`` and therefore are also affected by this change.
  509. * In the admin templates, ``<p class="help">`` is replaced with a ``<div>`` tag
  510. to allow including lists inside help text.
  511. * :class:`~django.middleware.http.ConditionalGetMiddleware` no longer sets the
  512. ``Date`` header as Web servers set that header. It also no longer sets the
  513. ``Content-Length`` header as this is now done by
  514. :class:`~django.middleware.common.CommonMiddleware`.
  515. * :meth:`~django.apps.AppConfig.get_model` and
  516. :meth:`~django.apps.AppConfig.get_models` now raise
  517. :exc:`~django.core.exceptions.AppRegistryNotReady` if they're called before
  518. models of all applications have been loaded. Previously they only required
  519. the target application's models to be loaded and thus could return models
  520. without all their relations set up. If you need the old behavior of
  521. ``get_model()``, set the ``require_ready`` argument to ``False``.
  522. * The unused ``BaseCommand.can_import_settings`` attribute is removed.
  523. * The undocumented ``django.utils.functional.lazy_property`` is removed.
  524. * For consistency with non-multipart requests, ``MultiPartParser.parse()`` now
  525. leaves ``request.POST`` immutable. If you're modifying that ``QueryDict``,
  526. you must now first copy it, e.g. ``request.POST.copy()``.
  527. * Support for ``cx_Oracle`` < 5.2 is removed.
  528. * Support for IPython < 1.0 is removed from the ``shell`` command.
  529. .. _deprecated-features-1.11:
  530. Features deprecated in 1.11
  531. ===========================
  532. ``models.permalink()`` decorator
  533. --------------------------------
  534. Use :func:`django.urls.reverse` instead. For example::
  535. from django.db import models
  536. class MyModel(models.Model):
  537. ...
  538. @models.permalink
  539. def url(self):
  540. return ('guitarist_detail', [self.slug])
  541. becomes::
  542. from django.db import models
  543. from django.urls import reverse
  544. class MyModel(models.Model):
  545. ...
  546. def url(self):
  547. return reverse('guitarist_detail', args=[self.slug])
  548. Miscellaneous
  549. -------------
  550. * ``contrib.auth``’s ``login()`` and ``logout()`` function-based views are
  551. deprecated in favor of new class-based views
  552. :class:`~django.contrib.auth.views.LoginView` and
  553. :class:`~django.contrib.auth.views.LogoutView`.
  554. * The unused ``extra_context`` parameter of
  555. ``contrib.auth.views.logout_then_login()`` is deprecated.
  556. * ``contrib.auth``’s ``password_change()``, ``password_change_done()``,
  557. ``password_reset()``, ``password_reset_done()``, ``password_reset_confirm()``,
  558. and ``password_reset_complete()`` function-based views are deprecated in favor
  559. of new class-based views
  560. :class:`~django.contrib.auth.views.PasswordChangeView`,
  561. :class:`~django.contrib.auth.views.PasswordChangeDoneView`,
  562. :class:`~django.contrib.auth.views.PasswordResetView`,
  563. :class:`~django.contrib.auth.views.PasswordResetDoneView`,
  564. :class:`~django.contrib.auth.views.PasswordResetConfirmView`, and
  565. :class:`~django.contrib.auth.views.PasswordResetCompleteView`.
  566. * ``django.test.runner.setup_databases()`` is moved to
  567. :func:`django.test.utils.setup_databases`. The old location is deprecated.
  568. * ``django.utils.translation.string_concat()`` is deprecated in
  569. favor of :func:`django.utils.text.format_lazy`. ``string_concat(*strings)``
  570. can be replaced by ``format_lazy('{}' * len(strings), *strings)``.
  571. * For the ``PyLibMCCache`` cache backend, passing ``pylibmc`` behavior settings
  572. as top-level attributes of ``OPTIONS`` is deprecated. Set them under a
  573. ``behaviors`` key within ``OPTIONS`` instead.
  574. * The ``host`` parameter of ``django.utils.http.is_safe_url()`` is deprecated
  575. in favor of the new ``allowed_hosts`` parameter.
  576. * Silencing exceptions raised while rendering the
  577. :ttag:`{% include %} <include>` template tag is deprecated as the behavior is
  578. often more confusing than helpful. In Django 2.1, the exception will be
  579. raised.
  580. * ``DatabaseIntrospection.get_indexes()`` is deprecated in favor of
  581. ``DatabaseIntrospection.get_constraints()``.
  582. * :func:`~django.contrib.auth.authenticate` now passes a ``request`` argument
  583. to the ``authenticate()`` method of authentication backends. Support for
  584. methods that don't accept ``request`` will be removed in Django 2.1.
  585. * The ``USE_ETAGS`` setting is deprecated in favor of
  586. :class:`~django.middleware.http.ConditionalGetMiddleware` which now adds the
  587. ``ETag`` header to responses regardless of the setting. ``CommonMiddleware``
  588. and ``django.utils.cache.patch_response_headers()`` will no longer set ETags
  589. when the deprecation ends.
  590. * ``Model._meta.has_auto_field`` is deprecated in favor of checking if
  591. ``Model._meta.auto_field is not None``.
  592. * Using regular expression groups with ``iLmsu#`` in ``url()`` is deprecated.
  593. The only group that's useful is ``(?i)`` for case-insensitive URLs, however,
  594. case-insensitive URLs aren't a good practice because they create multiple
  595. entries for search engines, for example. An alternative solution could be to
  596. create a :data:`~django.conf.urls.handler404` that looks for uppercase
  597. characters in the URL and redirects to a lowercase equivalent.
  598. * The ``renderer`` argument is added to the :meth:`Widget.render()
  599. <django.forms.Widget.render>` method. Methods that don't accept that argument
  600. will work through a deprecation period.