1
0
mirror of https://github.com/django/django.git synced 2025-10-26 07:06:08 +00:00

Removed versionadded/changed annotations for 5.1.

This also removes remaining versionadded/changed annotations for older
versions.
This commit is contained in:
Sarah Boyce
2024-12-12 16:17:09 +01:00
parent 9b5ad4056c
commit 810edfd742
25 changed files with 0 additions and 307 deletions

View File

@@ -298,11 +298,6 @@ screen, one for a mobile screen, one for right-to-left languages on desktop,
one for the dark mode on desktop, and one for high contrast mode on desktop one for the dark mode on desktop, and one for high contrast mode on desktop
when using chrome. when using chrome.
.. versionchanged:: 5.1
The ``--screenshots`` option and ``@screenshot_cases`` decorator were
added.
.. _running-unit-tests-dependencies: .. _running-unit-tests-dependencies:
Running all the tests Running all the tests

View File

@@ -432,11 +432,6 @@ subclass::
collapsed, using an expandable widget with a toggle for switching collapsed, using an expandable widget with a toggle for switching
their visibility. their visibility.
.. versionchanged:: 5.1
``fieldsets`` using the ``collapse`` class now use ``<details>``
and ``<summary>`` elements, provided they define a ``name``.
* ``description`` * ``description``
A string of optional extra text to be displayed at the top of each A string of optional extra text to be displayed at the top of each
fieldset, under the heading of the fieldset. fieldset, under the heading of the fieldset.
@@ -639,11 +634,6 @@ subclass::
class PersonAdmin(admin.ModelAdmin): class PersonAdmin(admin.ModelAdmin):
list_display = ["name", "decade_born_in"] list_display = ["name", "decade_born_in"]
.. versionchanged:: 5.1
Support for using ``__`` lookups was added, when targeting related
fields.
A few special cases to note about ``list_display``: A few special cases to note about ``list_display``:
* If the field is a ``ForeignKey``, Django will display the * If the field is a ``ForeignKey``, Django will display the
@@ -2337,11 +2327,6 @@ The ``InlineModelAdmin`` class adds or customizes:
configured in :attr:`~ModelAdmin.fieldsets`, inlines with a ``collapse`` configured in :attr:`~ModelAdmin.fieldsets`, inlines with a ``collapse``
class will be initially collapsed using an expandable widget. class will be initially collapsed using an expandable widget.
.. versionchanged:: 5.1
``fieldsets`` using the ``collapse`` class now use ``<details>`` and
``<summary>`` elements, provided they define a ``name``.
.. attribute:: InlineModelAdmin.extra .. attribute:: InlineModelAdmin.extra
This controls the number of extra forms the formset will display in This controls the number of extra forms the formset will display in

View File

@@ -115,10 +115,6 @@ model it represents, or to retrieve objects from that model:
on that model, returning the corresponding object. The ``using`` argument on that model, returning the corresponding object. The ``using`` argument
can be used to specify a different database than the default one. can be used to specify a different database than the default one.
.. versionchanged:: 5.1
The ``using`` argument was added.
.. method:: ContentType.model_class() .. method:: ContentType.model_class()
Returns the model class represented by this Returns the model class represented by this

View File

@@ -238,10 +238,6 @@ polygon that can fully contain the geometry.
The ``num_seg`` parameter is used only on PostGIS. The ``num_seg`` parameter is used only on PostGIS.
.. versionchanged:: 5.1
SpatiaLite 5.1+ support was added.
``Centroid`` ``Centroid``
============ ============
@@ -367,10 +363,6 @@ Creates geometry from `Well-known binary (WKB)`_ representation. The optional
``srid`` argument allows to specify the SRID of the resulting geometry. ``srid`` argument allows to specify the SRID of the resulting geometry.
``srid`` is ignored on Oracle. ``srid`` is ignored on Oracle.
.. versionchanged:: 5.1
The ``srid`` argument was added.
``FromWKT`` ``FromWKT``
=========== ===========
@@ -384,10 +376,6 @@ Creates geometry from `Well-known text (WKT)`_ representation. The optional
``srid`` argument allows to specify the SRID of the resulting geometry. ``srid`` argument allows to specify the SRID of the resulting geometry.
``srid`` is ignored on Oracle. ``srid`` is ignored on Oracle.
.. versionchanged:: 5.1
The ``srid`` argument was added.
``GeoHash`` ``GeoHash``
=========== ===========

View File

@@ -562,14 +562,10 @@ coordinate transformation:
.. attribute:: is_3d .. attribute:: is_3d
.. versionadded:: 5.1
A boolean indicating if this geometry has Z coordinates. A boolean indicating if this geometry has Z coordinates.
.. method:: set_3d(value) .. method:: set_3d(value)
.. versionadded:: 5.1
A method that adds or removes the Z coordinate dimension. A method that adds or removes the Z coordinate dimension.
.. code-block:: pycon .. code-block:: pycon
@@ -583,14 +579,10 @@ coordinate transformation:
.. attribute:: is_measured .. attribute:: is_measured
.. versionadded:: 5.1
A boolean indicating if this geometry has M coordinates. A boolean indicating if this geometry has M coordinates.
.. method:: set_measured(value) .. method:: set_measured(value)
.. versionadded:: 5.1
A method to add or remove the M coordinate dimension. A method to add or remove the M coordinate dimension.
.. code-block:: pycon .. code-block:: pycon
@@ -863,11 +855,6 @@ coordinate transformation:
Returns a :class:`Point` representing the centroid of this geometry. Returns a :class:`Point` representing the centroid of this geometry.
.. versionchanged:: 5.1
``centroid`` was promoted from a :class:`.Polygon` only attribute to
being available on all geometry types.
.. attribute:: tuple .. attribute:: tuple
Returns the coordinates of a point geometry as a tuple, the Returns the coordinates of a point geometry as a tuple, the
@@ -916,8 +903,6 @@ coordinate transformation:
.. attribute:: m .. attribute:: m
.. versionadded:: 5.1
Returns the M coordinate of this point, or ``None`` if the Point does not Returns the M coordinate of this point, or ``None`` if the Point does not
have an M coordinate: have an M coordinate:
@@ -958,8 +943,6 @@ coordinate transformation:
.. attribute:: m .. attribute:: m
.. versionadded:: 5.1
Returns a list of M coordinates in this line or ``None`` if the line does Returns a list of M coordinates in this line or ``None`` if the line does
not have M coordinates: not have M coordinates:

View File

@@ -894,10 +894,6 @@ aggregate, except it can be several orders of magnitude faster than performing
a union because it rolls up geometries into a collection or multi object, not a union because it rolls up geometries into a collection or multi object, not
caring about dissolving boundaries. caring about dissolving boundaries.
.. versionchanged:: 5.1
MySQL 8.0.24+ support was added.
.. versionchanged:: 5.2 .. versionchanged:: 5.2
MariaDB 11.7+ support was added. MariaDB 11.7+ support was added.

View File

@@ -125,10 +125,6 @@ Unit Attribute Full name or alias(es)
``ha`` Hectare ``ha`` Hectare
================================= ======================================== ================================= ========================================
.. versionchanged:: 5.1
Support for the ``ha`` unit was added.
Measurement API Measurement API
=============== ===============

View File

@@ -57,10 +57,6 @@ available from the ``django.contrib.postgres.indexes`` module.
whether deduplication is enabled. PostgreSQL enables deduplication by whether deduplication is enabled. PostgreSQL enables deduplication by
default. default.
.. versionchanged:: 5.1
The ``deduplicate_items`` parameter was added.
.. _fillfactor: https://www.postgresql.org/docs/current/sql-createindex.html#SQL-CREATEINDEX-STORAGE-PARAMETERS .. _fillfactor: https://www.postgresql.org/docs/current/sql-createindex.html#SQL-CREATEINDEX-STORAGE-PARAMETERS
.. _deduplicate_items: https://www.postgresql.org/docs/current/btree-implementation.html#BTREE-DEDUPLICATION .. _deduplicate_items: https://www.postgresql.org/docs/current/btree-implementation.html#BTREE-DEDUPLICATION

View File

@@ -250,8 +250,6 @@ database configuration in :setting:`DATABASES`::
Connection pool Connection pool
--------------- ---------------
.. versionadded:: 5.1
To use a connection pool with `psycopg`_, you can either set ``"pool"`` in the To use a connection pool with `psycopg`_, you can either set ``"pool"`` in the
:setting:`OPTIONS` part of your database configuration in :setting:`DATABASES` :setting:`OPTIONS` part of your database configuration in :setting:`DATABASES`
to be a dict to be passed to :class:`~psycopg:psycopg_pool.ConnectionPool`, or to be a dict to be passed to :class:`~psycopg:psycopg_pool.ConnectionPool`, or
@@ -898,8 +896,6 @@ If you're getting this error, you can solve it by:
Transactions behavior Transactions behavior
~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~
.. versionadded:: 5.1
SQLite supports three transaction modes: ``DEFERRED``, ``IMMEDIATE``, and SQLite supports three transaction modes: ``DEFERRED``, ``IMMEDIATE``, and
``EXCLUSIVE``. ``EXCLUSIVE``.
@@ -969,8 +965,6 @@ To enable the JSON1 extension you can follow the instruction on
Setting pragma options Setting pragma options
---------------------- ----------------------
.. versionadded:: 5.1
`Pragma options`_ can be set upon connection by using the ``init_command`` in `Pragma options`_ can be set upon connection by using the ``init_command`` in
the :setting:`OPTIONS` part of your database configuration in the :setting:`OPTIONS` part of your database configuration in
:setting:`DATABASES`. The example below shows how to enable extra durability of :setting:`DATABASES`. The example below shows how to enable extra durability of

View File

@@ -80,8 +80,6 @@ The ``FileSystemStorage`` class
.. attribute:: allow_overwrite .. attribute:: allow_overwrite
.. versionadded:: 5.1
Flag to control allowing saving a new file over an existing one. Flag to control allowing saving a new file over an existing one.
Defaults to ``False``. Defaults to ``False``.

View File

@@ -320,10 +320,6 @@ inside ``aria-describedby``:
>>> print(f["username"]) >>> print(f["username"])
<input type="text" name="username" aria-describedby="custom-description id_username_helptext" maxlength="255" id="id_username" required> <input type="text" name="username" aria-describedby="custom-description id_username_helptext" maxlength="255" id="id_username" required>
.. versionchanged:: 5.1
``aria-describedby`` support was added for ``<fieldset>``.
``error_messages`` ``error_messages``
------------------ ------------------
@@ -799,10 +795,6 @@ For each field, we describe the default widget used if you don't specify
Defaults to 39, and behaves the same way as it does for Defaults to 39, and behaves the same way as it does for
:class:`CharField`. :class:`CharField`.
.. versionchanged:: 4.2.18
The default value for ``max_length`` was set to 39 characters.
``ImageField`` ``ImageField``
-------------- --------------

View File

@@ -214,8 +214,6 @@ messages during filesystem inspection and event subscription processes.
``django.contrib.auth`` ``django.contrib.auth``
~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~
.. versionadded:: 4.2.16
Log messages related to :doc:`contrib/auth`, particularly ``ERROR`` messages Log messages related to :doc:`contrib/auth`, particularly ``ERROR`` messages
are generated when a :class:`~django.contrib.auth.forms.PasswordResetForm` is are generated when a :class:`~django.contrib.auth.forms.PasswordResetForm` is
successfully submitted but the password reset email cannot be delivered due to successfully submitted but the password reset email cannot be delivered due to

View File

@@ -523,8 +523,6 @@ every incoming ``HttpRequest`` object. See :ref:`Authentication in web requests
``None``), or :attr:`redirect_field_name`. If ``None`` is returned, a query ``None``), or :attr:`redirect_field_name`. If ``None`` is returned, a query
parameter won't be added. parameter won't be added.
.. versionadded:: 5.1
Redirects all unauthenticated requests to a login page, except for views Redirects all unauthenticated requests to a login page, except for views
excluded with :func:`~.django.contrib.auth.decorators.login_not_required`. The excluded with :func:`~.django.contrib.auth.decorators.login_not_required`. The
login page defaults to :setting:`settings.LOGIN_URL <LOGIN_URL>`, but can be login page defaults to :setting:`settings.LOGIN_URL <LOGIN_URL>`, but can be
@@ -682,8 +680,6 @@ Here are some hints about the ordering of various Django middleware classes:
#. :class:`~django.contrib.auth.middleware.LoginRequiredMiddleware` #. :class:`~django.contrib.auth.middleware.LoginRequiredMiddleware`
.. versionadded:: 5.1
After ``AuthenticationMiddleware``: uses user object. After ``AuthenticationMiddleware``: uses user object.
#. :class:`~django.contrib.messages.middleware.MessageMiddleware` #. :class:`~django.contrib.messages.middleware.MessageMiddleware`

View File

@@ -498,8 +498,6 @@ For an example using ``SeparateDatabaseAndState``, see
Operation category Operation category
================== ==================
.. versionadded:: 5.1
.. currentmodule:: django.db.migrations.operations.base .. currentmodule:: django.db.migrations.operations.base
.. class:: OperationCategory .. class:: OperationCategory

View File

@@ -188,8 +188,6 @@ the field value of each one, and saving each one back to the database::
Slicing ``F()`` expressions Slicing ``F()`` expressions
~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~
.. versionadded:: 5.1
For string-based fields, text-based fields, and For string-based fields, text-based fields, and
:class:`~django.contrib.postgres.fields.ArrayField`, you can use Python's :class:`~django.contrib.postgres.fields.ArrayField`, you can use Python's
array-slicing syntax. The indices are 0-based and the ``step`` argument to array-slicing syntax. The indices are 0-based and the ``step`` argument to
@@ -920,20 +918,12 @@ ordinary sequence of rows.
the standard start and end points, such as ``CURRENT ROW`` and ``UNBOUNDED the standard start and end points, such as ``CURRENT ROW`` and ``UNBOUNDED
FOLLOWING``. FOLLOWING``.
.. versionchanged:: 5.1
The ``exclusion`` argument was added.
.. class:: RowRange(start=None, end=None, exclusion=None) .. class:: RowRange(start=None, end=None, exclusion=None)
.. attribute:: frame_type .. attribute:: frame_type
This attribute is set to ``'ROWS'``. This attribute is set to ``'ROWS'``.
.. versionchanged:: 5.1
The ``exclusion`` argument was added.
Both classes return SQL with the template: Both classes return SQL with the template:
.. code-block:: sql .. code-block:: sql
@@ -942,8 +932,6 @@ Both classes return SQL with the template:
.. class:: WindowFrameExclusion .. class:: WindowFrameExclusion
.. versionadded:: 5.1
.. attribute:: CURRENT_ROW .. attribute:: CURRENT_ROW
.. attribute:: GROUP .. attribute:: GROUP
@@ -1024,11 +1012,6 @@ released between twelve months before and twelve months after each movie:
... ), ... ),
... ) ... )
.. versionchanged:: 5.1
Support for positive integer ``start`` and negative integer ``end`` was
added for ``RowRange``.
.. currentmodule:: django.db.models .. currentmodule:: django.db.models
Technical Information Technical Information
@@ -1059,8 +1042,6 @@ calling the appropriate methods on the wrapped expression.
.. attribute:: constraint_validation_compatible .. attribute:: constraint_validation_compatible
.. versionadded:: 5.1
Tells Django that this expression can be used during a constraint Tells Django that this expression can be used during a constraint
validation. Expressions with ``constraint_validation_compatible`` set validation. Expressions with ``constraint_validation_compatible`` set
to ``False`` must have only one source expression. Defaults to to ``False`` must have only one source expression. Defaults to

View File

@@ -214,10 +214,6 @@ values::
obj.refresh_from_db(from_queryset=MyModel.objects.select_for_update()) obj.refresh_from_db(from_queryset=MyModel.objects.select_for_update())
.. versionchanged:: 5.1
The ``from_queryset`` argument was added.
.. method:: Model.get_deferred_fields() .. method:: Model.get_deferred_fields()
A helper method that returns a set containing the attribute names of all those A helper method that returns a set containing the attribute names of all those

View File

@@ -3106,10 +3106,6 @@ adverse effects on your database. For example, the ``ANALYZE`` flag supported
by MariaDB, MySQL 8.0.18+, and PostgreSQL could result in changes to data if by MariaDB, MySQL 8.0.18+, and PostgreSQL could result in changes to data if
there are triggers or if a function is called, even for a ``SELECT`` query. there are triggers or if a function is called, even for a ``SELECT`` query.
.. versionchanged:: 5.1
Support for the ``generic_plan`` option on PostgreSQL 16+ was added.
.. versionchanged:: 5.2 .. versionchanged:: 5.2
Support for the ``memory`` and ``serialize`` options on PostgreSQL 17+ was Support for the ``memory`` and ``serialize`` options on PostgreSQL 17+ was

View File

@@ -957,8 +957,6 @@ output (as a string) inside a variable. This is useful if you want to use
``querystring`` ``querystring``
---------------- ----------------
.. versionadded:: 5.1
Outputs a URL-encoded formatted query string based on the provided parameters. Outputs a URL-encoded formatted query string based on the provided parameters.
This tag requires a :class:`~django.http.QueryDict` instance, which defaults to This tag requires a :class:`~django.http.QueryDict` instance, which defaults to

View File

@@ -1179,11 +1179,6 @@ For a complete discussion on the usage of the following see the
Raises :exc:`LookupError` if nothing is found. Raises :exc:`LookupError` if nothing is found.
.. versionchanged:: 4.2.15
In older versions, ``lang_code`` values over 500 characters were
processed without raising a :exc:`LookupError`.
.. function:: to_locale(language) .. function:: to_locale(language)
Turns a language name (en-us) into a locale name (en_US). Turns a language name (en-us) into a locale name (en_US).

View File

@@ -162,8 +162,6 @@ to, or in lieu of custom ``field.clean()`` methods.
``DomainNameValidator`` ``DomainNameValidator``
----------------------- -----------------------
.. versionadded:: 5.1
.. class:: DomainNameValidator(accept_idna=True, message=None, code=None) .. class:: DomainNameValidator(accept_idna=True, message=None, code=None)
A :class:`RegexValidator` subclass that ensures a value looks like a domain A :class:`RegexValidator` subclass that ensures a value looks like a domain
@@ -223,8 +221,6 @@ to, or in lieu of custom ``field.clean()`` methods.
``validate_domain_name`` ``validate_domain_name``
------------------------ ------------------------
.. versionadded:: 5.1
.. data:: validate_domain_name .. data:: validate_domain_name
A :class:`DomainNameValidator` instance without any customizations. A :class:`DomainNameValidator` instance without any customizations.

View File

@@ -601,10 +601,6 @@ The ``login_required`` decorator
:func:`django.contrib.admin.views.decorators.staff_member_required` :func:`django.contrib.admin.views.decorators.staff_member_required`
decorator a useful alternative to ``login_required()``. decorator a useful alternative to ``login_required()``.
.. versionchanged:: 5.1
Support for wrapping asynchronous view functions was added.
.. currentmodule:: django.contrib.auth.mixins .. currentmodule:: django.contrib.auth.mixins
The ``LoginRequiredMixin`` mixin The ``LoginRequiredMixin`` mixin
@@ -647,8 +643,6 @@ inheritance list.
The ``login_not_required`` decorator The ``login_not_required`` decorator
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
.. versionadded:: 5.1
When :class:`~django.contrib.auth.middleware.LoginRequiredMiddleware` is When :class:`~django.contrib.auth.middleware.LoginRequiredMiddleware` is
installed, all views require authentication by default. Some views, such as the installed, all views require authentication by default. Some views, such as the
login view, may need to disable this behavior. login view, may need to disable this behavior.
@@ -719,11 +713,6 @@ email in the desired domain and if not, redirects to the login page::
@user_passes_test(email_check, login_url="/login/") @user_passes_test(email_check, login_url="/login/")
def my_view(request): ... def my_view(request): ...
.. versionchanged:: 5.1
Support for wrapping asynchronous view functions and using asynchronous
test callables was added.
.. currentmodule:: django.contrib.auth.mixins .. currentmodule:: django.contrib.auth.mixins
.. class:: UserPassesTestMixin .. class:: UserPassesTestMixin
@@ -828,10 +817,6 @@ The ``permission_required`` decorator
``redirect_authenticated_user=True`` and the logged-in user doesn't have ``redirect_authenticated_user=True`` and the logged-in user doesn't have
all of the required permissions. all of the required permissions.
.. versionchanged:: 5.1
Support for wrapping asynchronous view functions was added.
.. currentmodule:: django.contrib.auth.mixins .. currentmodule:: django.contrib.auth.mixins
The ``PermissionRequiredMixin`` mixin The ``PermissionRequiredMixin`` mixin
@@ -1640,15 +1625,8 @@ provides several built-in forms located in :mod:`django.contrib.auth.forms`:
Takes the ``user`` as the first positional argument. Takes the ``user`` as the first positional argument.
.. versionchanged:: 5.1
Option to disable (or reenable) password-based authentication was
added.
.. class:: AdminUserCreationForm .. class:: AdminUserCreationForm
.. versionadded:: 5.1.1
A form used in the admin interface to create a new user. Inherits from A form used in the admin interface to create a new user. Inherits from
:class:`UserCreationForm`. :class:`UserCreationForm`.

View File

@@ -195,10 +195,6 @@ the only difference is that the check is a classmethod, not an instance method::
# ... your own checks ... # ... your own checks ...
return errors return errors
.. versionchanged:: 5.1
In older versions, template engines didn't implement a ``check()`` method.
Writing tests Writing tests
------------- -------------

View File

@@ -81,10 +81,6 @@ writing to the cache fails, the exception is handled and logged via the
:ref:`sessions logger <django-contrib-sessions-logger>`, to avoid failing an :ref:`sessions logger <django-contrib-sessions-logger>`, to avoid failing an
otherwise successful write operation. otherwise successful write operation.
.. versionchanged:: 5.1
Handling and logging of exceptions when writing to the cache was added.
Session reads use the cache, or the database if the data has been evicted from Session reads use the cache, or the database if the data has been evicted from
the cache. To use this backend, set :setting:`SESSION_ENGINE` to the cache. To use this backend, set :setting:`SESSION_ENGINE` to
``"django.contrib.sessions.backends.cached_db"``, and follow the configuration ``"django.contrib.sessions.backends.cached_db"``, and follow the configuration
@@ -202,14 +198,8 @@ You can edit it multiple times.
Example: ``fav_color = request.session.get('fav_color', 'red')`` Example: ``fav_color = request.session.get('fav_color', 'red')``
.. versionchanged:: 5.1
``aget()`` function was added.
.. method:: aset(key, value) .. method:: aset(key, value)
.. versionadded:: 5.1
Example: ``await request.session.aset('fav_color', 'red')`` Example: ``await request.session.aset('fav_color', 'red')``
.. method:: update(dict) .. method:: update(dict)
@@ -219,10 +209,6 @@ You can edit it multiple times.
Example: ``request.session.update({'fav_color': 'red'})`` Example: ``request.session.update({'fav_color': 'red'})``
.. versionchanged:: 5.1
``aupdate()`` function was added.
.. method:: pop(key, default=__not_given) .. method:: pop(key, default=__not_given)
.. method:: apop(key, default=__not_given) .. method:: apop(key, default=__not_given)
@@ -230,55 +216,31 @@ You can edit it multiple times.
Example: ``fav_color = request.session.pop('fav_color', 'blue')`` Example: ``fav_color = request.session.pop('fav_color', 'blue')``
.. versionchanged:: 5.1
``apop()`` function was added.
.. method:: keys() .. method:: keys()
.. method:: akeys() .. method:: akeys()
*Asynchronous version*: ``akeys()`` *Asynchronous version*: ``akeys()``
.. versionchanged:: 5.1
``akeys()`` function was added.
.. method:: values() .. method:: values()
.. method:: avalues() .. method:: avalues()
*Asynchronous version*: ``avalues()`` *Asynchronous version*: ``avalues()``
.. versionchanged:: 5.1
``avalues()`` function was added.
.. method:: has_key(key) .. method:: has_key(key)
.. method:: ahas_key(key) .. method:: ahas_key(key)
*Asynchronous version*: ``ahas_key()`` *Asynchronous version*: ``ahas_key()``
.. versionchanged:: 5.1
``ahas_key()`` function was added.
.. method:: items() .. method:: items()
.. method:: aitems() .. method:: aitems()
*Asynchronous version*: ``aitems()`` *Asynchronous version*: ``aitems()``
.. versionchanged:: 5.1
``aitems()`` function was added.
.. method:: setdefault() .. method:: setdefault()
.. method:: asetdefault() .. method:: asetdefault()
*Asynchronous version*: ``asetdefault()`` *Asynchronous version*: ``asetdefault()``
.. versionchanged:: 5.1
``asetdefault()`` function was added.
.. method:: clear() .. method:: clear()
It also has these methods: It also has these methods:
@@ -293,10 +255,6 @@ You can edit it multiple times.
can't be accessed again from the user's browser (for example, the can't be accessed again from the user's browser (for example, the
:func:`django.contrib.auth.logout()` function calls it). :func:`django.contrib.auth.logout()` function calls it).
.. versionchanged:: 5.1
``aflush()`` function was added.
.. method:: set_test_cookie() .. method:: set_test_cookie()
.. method:: aset_test_cookie() .. method:: aset_test_cookie()
@@ -307,10 +265,6 @@ You can edit it multiple times.
until the user's next page request. See `Setting test cookies`_ below for until the user's next page request. See `Setting test cookies`_ below for
more information. more information.
.. versionchanged:: 5.1
``aset_test_cookie()`` function was added.
.. method:: test_cookie_worked() .. method:: test_cookie_worked()
.. method:: atest_cookie_worked() .. method:: atest_cookie_worked()
@@ -322,10 +276,6 @@ You can edit it multiple times.
previous, separate page request. previous, separate page request.
See `Setting test cookies`_ below for more information. See `Setting test cookies`_ below for more information.
.. versionchanged:: 5.1
``atest_cookie_worked()`` function was added.
.. method:: delete_test_cookie() .. method:: delete_test_cookie()
.. method:: adelete_test_cookie() .. method:: adelete_test_cookie()
@@ -333,10 +283,6 @@ You can edit it multiple times.
Deletes the test cookie. Use this to clean up after yourself. Deletes the test cookie. Use this to clean up after yourself.
.. versionchanged:: 5.1
``adelete_test_cookie()`` function was added.
.. method:: get_session_cookie_age() .. method:: get_session_cookie_age()
Returns the value of the setting :setting:`SESSION_COOKIE_AGE`. This can Returns the value of the setting :setting:`SESSION_COOKIE_AGE`. This can
@@ -368,10 +314,6 @@ You can edit it multiple times.
purposes. Session expiration is computed from the last time the purposes. Session expiration is computed from the last time the
session was *modified*. session was *modified*.
.. versionchanged:: 5.1
``aset_expiry()`` function was added.
.. method:: get_expiry_age() .. method:: get_expiry_age()
.. method:: aget_expiry_age() .. method:: aget_expiry_age()
@@ -404,10 +346,6 @@ You can edit it multiple times.
expires_at = modification + timedelta(seconds=settings.SESSION_COOKIE_AGE) expires_at = modification + timedelta(seconds=settings.SESSION_COOKIE_AGE)
.. versionchanged:: 5.1
``aget_expiry_age()`` function was added.
.. method:: get_expiry_date() .. method:: get_expiry_date()
.. method:: aget_expiry_date() .. method:: aget_expiry_date()
@@ -420,10 +358,6 @@ You can edit it multiple times.
This function accepts the same keyword arguments as This function accepts the same keyword arguments as
:meth:`get_expiry_age`, and similar notes on usage apply. :meth:`get_expiry_age`, and similar notes on usage apply.
.. versionchanged:: 5.1
``aget_expiry_date()`` function was added.
.. method:: get_expire_at_browser_close() .. method:: get_expire_at_browser_close()
.. method:: aget_expire_at_browser_close() .. method:: aget_expire_at_browser_close()
@@ -432,10 +366,6 @@ You can edit it multiple times.
Returns either ``True`` or ``False``, depending on whether the user's Returns either ``True`` or ``False``, depending on whether the user's
session cookie will expire when the user's web browser is closed. session cookie will expire when the user's web browser is closed.
.. versionchanged:: 5.1
``aget_expire_at_browser_close()`` function was added.
.. method:: clear_expired() .. method:: clear_expired()
.. method:: aclear_expired() .. method:: aclear_expired()
@@ -444,10 +374,6 @@ You can edit it multiple times.
Removes expired sessions from the session store. This class method is Removes expired sessions from the session store. This class method is
called by :djadmin:`clearsessions`. called by :djadmin:`clearsessions`.
.. versionchanged:: 5.1
``aclear_expired()`` function was added.
.. method:: cycle_key() .. method:: cycle_key()
.. method:: acycle_key() .. method:: acycle_key()
@@ -457,10 +383,6 @@ You can edit it multiple times.
:func:`django.contrib.auth.login()` calls this method to mitigate against :func:`django.contrib.auth.login()` calls this method to mitigate against
session fixation. session fixation.
.. versionchanged:: 5.1
``acycle_key()`` function was added.
.. _session_serialization: .. _session_serialization:
Session serialization Session serialization
@@ -616,10 +538,6 @@ Here's a typical usage example::
request.session.set_test_cookie() request.session.set_test_cookie()
return render(request, "foo/login_form.html") return render(request, "foo/login_form.html")
.. versionchanged:: 5.1
Support for setting test cookies in asynchronous view functions was added.
Using sessions out of views Using sessions out of views
=========================== ===========================
@@ -868,11 +786,6 @@ You can extend the session engines, but doing so with database-backed session
engines generally requires some extra effort (see the next section for engines generally requires some extra effort (see the next section for
details). details).
.. versionchanged:: 5.1
``aexists()``, ``acreate()``, ``asave()``, ``adelete()``, ``aload()``, and
``aclear_expired()`` methods were added.
.. _extending-database-backed-session-engines: .. _extending-database-backed-session-engines:
Extending database-backed session engines Extending database-backed session engines

View File

@@ -32,10 +32,6 @@ restricted subset of the test client API:
attributes must be supplied by the test itself if required attributes must be supplied by the test itself if required
for the view to function properly. for the view to function properly.
.. versionchanged:: 5.1
The ``query_params`` parameter was added.
Example Example
------- -------
@@ -89,10 +85,6 @@ difference being that it returns ``ASGIRequest`` instances rather than
Arbitrary keyword arguments in ``defaults`` are added directly into the ASGI Arbitrary keyword arguments in ``defaults`` are added directly into the ASGI
scope. scope.
.. versionchanged:: 5.1
The ``query_params`` parameter was added.
Testing class-based views Testing class-based views
========================= =========================

View File

@@ -158,10 +158,6 @@ Use the ``django.test.Client`` class to make requests.
The ``json_encoder`` argument allows setting a custom JSON encoder for The ``json_encoder`` argument allows setting a custom JSON encoder for
the JSON serialization that's described in :meth:`post`. the JSON serialization that's described in :meth:`post`.
.. versionchanged:: 5.1
The ``query_params`` argument was added.
Once you have a ``Client`` instance, you can call any of the following Once you have a ``Client`` instance, you can call any of the following
methods: methods:
@@ -241,10 +237,6 @@ Use the ``django.test.Client`` class to make requests.
If you set ``secure`` to ``True`` the client will emulate an HTTPS If you set ``secure`` to ``True`` the client will emulate an HTTPS
request. request.
.. versionchanged:: 5.1
The ``query_params`` argument was added.
.. method:: Client.post(path, data=None, content_type=MULTIPART_CONTENT, follow=False, secure=False, *, headers=None, query_params=None, **extra) .. method:: Client.post(path, data=None, content_type=MULTIPART_CONTENT, follow=False, secure=False, *, headers=None, query_params=None, **extra)
Makes a POST request on the provided ``path`` and returns a Makes a POST request on the provided ``path`` and returns a
@@ -360,10 +352,6 @@ Use the ``django.test.Client`` class to make requests.
If you set ``secure`` to ``True`` the client will emulate an HTTPS If you set ``secure`` to ``True`` the client will emulate an HTTPS
request. request.
.. versionchanged:: 5.1
The ``query_params`` argument was added.
.. method:: Client.head(path, data=None, follow=False, secure=False, *, headers=None, query_params=None, **extra) .. method:: Client.head(path, data=None, follow=False, secure=False, *, headers=None, query_params=None, **extra)
Makes a HEAD request on the provided ``path`` and returns a Makes a HEAD request on the provided ``path`` and returns a
@@ -371,10 +359,6 @@ Use the ``django.test.Client`` class to make requests.
including the ``follow``, ``secure``, ``headers``, ``query_params``, including the ``follow``, ``secure``, ``headers``, ``query_params``,
and ``extra`` parameters, except it does not return a message body. and ``extra`` parameters, except it does not return a message body.
.. versionchanged:: 5.1
The ``query_params`` argument was added.
.. method:: Client.options(path, data='', content_type='application/octet-stream', follow=False, secure=False, *, headers=None, query_params=None, **extra) .. method:: Client.options(path, data='', content_type='application/octet-stream', follow=False, secure=False, *, headers=None, query_params=None, **extra)
Makes an OPTIONS request on the provided ``path`` and returns a Makes an OPTIONS request on the provided ``path`` and returns a
@@ -386,10 +370,6 @@ Use the ``django.test.Client`` class to make requests.
The ``follow``, ``secure``, ``headers``, ``query_params``, and The ``follow``, ``secure``, ``headers``, ``query_params``, and
``extra`` parameters act the same as for :meth:`Client.get`. ``extra`` parameters act the same as for :meth:`Client.get`.
.. versionchanged:: 5.1
The ``query_params`` argument was added.
.. method:: Client.put(path, data='', content_type='application/octet-stream', follow=False, secure=False, *, headers=None, query_params=None, **extra) .. method:: Client.put(path, data='', content_type='application/octet-stream', follow=False, secure=False, *, headers=None, query_params=None, **extra)
Makes a PUT request on the provided ``path`` and returns a Makes a PUT request on the provided ``path`` and returns a
@@ -401,10 +381,6 @@ Use the ``django.test.Client`` class to make requests.
The ``follow``, ``secure``, ``headers``, ``query_params``, and The ``follow``, ``secure``, ``headers``, ``query_params``, and
``extra`` parameters act the same as for :meth:`Client.get`. ``extra`` parameters act the same as for :meth:`Client.get`.
.. versionchanged:: 5.1
The ``query_params`` argument was added.
.. method:: Client.patch(path, data='', content_type='application/octet-stream', follow=False, secure=False, *, headers=None, query_params=None, **extra) .. method:: Client.patch(path, data='', content_type='application/octet-stream', follow=False, secure=False, *, headers=None, query_params=None, **extra)
Makes a PATCH request on the provided ``path`` and returns a Makes a PATCH request on the provided ``path`` and returns a
@@ -413,10 +389,6 @@ Use the ``django.test.Client`` class to make requests.
The ``follow``, ``secure``, ``headers``, ``query_params``, and The ``follow``, ``secure``, ``headers``, ``query_params``, and
``extra`` parameters act the same as for :meth:`Client.get`. ``extra`` parameters act the same as for :meth:`Client.get`.
.. versionchanged:: 5.1
The ``query_params`` argument was added.
.. method:: Client.delete(path, data='', content_type='application/octet-stream', follow=False, secure=False, *, headers=None, query_params=None, **extra) .. method:: Client.delete(path, data='', content_type='application/octet-stream', follow=False, secure=False, *, headers=None, query_params=None, **extra)
Makes a DELETE request on the provided ``path`` and returns a Makes a DELETE request on the provided ``path`` and returns a
@@ -428,10 +400,6 @@ Use the ``django.test.Client`` class to make requests.
The ``follow``, ``secure``, ``headers``, ``query_params``, and The ``follow``, ``secure``, ``headers``, ``query_params``, and
``extra`` parameters act the same as for :meth:`Client.get`. ``extra`` parameters act the same as for :meth:`Client.get`.
.. versionchanged:: 5.1
The ``query_params`` argument was added.
.. method:: Client.trace(path, follow=False, secure=False, *, headers=None, query_params=None, **extra) .. method:: Client.trace(path, follow=False, secure=False, *, headers=None, query_params=None, **extra)
Makes a TRACE request on the provided ``path`` and returns a Makes a TRACE request on the provided ``path`` and returns a
@@ -444,10 +412,6 @@ Use the ``django.test.Client`` class to make requests.
The ``follow``, ``secure``, ``headers``, ``query_params``, and The ``follow``, ``secure``, ``headers``, ``query_params``, and
``extra`` parameters act the same as for :meth:`Client.get`. ``extra`` parameters act the same as for :meth:`Client.get`.
.. versionchanged:: 5.1
The ``query_params`` argument was added.
.. method:: Client.login(**credentials) .. method:: Client.login(**credentials)
.. method:: Client.alogin(**credentials) .. method:: Client.alogin(**credentials)
@@ -1548,11 +1512,6 @@ LOCALE_PATHS, LANGUAGE_CODE Default translation and loaded translations
STATIC_ROOT, STATIC_URL, STORAGES Storages configuration STATIC_ROOT, STATIC_URL, STORAGES Storages configuration
================================= ======================== ================================= ========================
.. versionchanged:: 5.1
Resetting the default renderer when the ``FORM_RENDERER`` setting is
changed was added.
Isolating apps Isolating apps
-------------- --------------
@@ -1740,10 +1699,6 @@ your test suite.
attribute ordering is not significant. See attribute ordering is not significant. See
:meth:`~SimpleTestCase.assertHTMLEqual` for more details. :meth:`~SimpleTestCase.assertHTMLEqual` for more details.
.. versionchanged:: 5.1
In older versions, error messages didn't contain the response content.
.. method:: SimpleTestCase.assertNotContains(response, text, status_code=200, msg_prefix='', html=False) .. method:: SimpleTestCase.assertNotContains(response, text, status_code=200, msg_prefix='', html=False)
Asserts that a :class:`response <django.http.HttpResponse>` produced the Asserts that a :class:`response <django.http.HttpResponse>` produced the
@@ -1756,10 +1711,6 @@ your test suite.
attribute ordering is not significant. See attribute ordering is not significant. See
:meth:`~SimpleTestCase.assertHTMLEqual` for more details. :meth:`~SimpleTestCase.assertHTMLEqual` for more details.
.. versionchanged:: 5.1
In older versions, error messages didn't contain the response content.
.. method:: SimpleTestCase.assertTemplateUsed(response, template_name, msg_prefix='', count=None) .. method:: SimpleTestCase.assertTemplateUsed(response, template_name, msg_prefix='', count=None)
Asserts that the template with the given name was used in rendering the Asserts that the template with the given name was used in rendering the
@@ -1896,14 +1847,8 @@ your test suite.
Whitespace in most cases is ignored, and attribute ordering is not Whitespace in most cases is ignored, and attribute ordering is not
significant. See :meth:`~SimpleTestCase.assertHTMLEqual` for more details. significant. See :meth:`~SimpleTestCase.assertHTMLEqual` for more details.
.. versionchanged:: 5.1
In older versions, error messages didn't contain the ``haystack``.
.. method:: SimpleTestCase.assertNotInHTML(needle, haystack, msg_prefix="") .. method:: SimpleTestCase.assertNotInHTML(needle, haystack, msg_prefix="")
.. versionadded:: 5.1
Asserts that the HTML fragment ``needle`` is *not* contained in the Asserts that the HTML fragment ``needle`` is *not* contained in the
``haystack``. ``haystack``.
@@ -2058,10 +2003,6 @@ test client, with the following exceptions:
>>> c = AsyncClient() >>> c = AsyncClient()
>>> c.get("/customers/details/", {"name": "fred", "age": 7}, ACCEPT="application/json") >>> c.get("/customers/details/", {"name": "fred", "age": 7}, ACCEPT="application/json")
.. versionchanged:: 5.1
The ``query_params`` argument was added.
Using ``AsyncClient`` any method that makes a request must be awaited:: Using ``AsyncClient`` any method that makes a request must be awaited::
async def test_my_thing(self): async def test_my_thing(self):