1.11.txt 37 KB

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