1
0
mirror of https://github.com/django/django.git synced 2025-10-24 14:16:09 +00:00

Updated doc links to point to Python 3 documentation

This commit is contained in:
Claude Paroz
2014-04-26 16:00:15 +02:00
parent 6d6af7244b
commit 680a0f08b1
22 changed files with 68 additions and 71 deletions

View File

@@ -118,10 +118,10 @@ show_authors = False
# The name of the Pygments (syntax highlighting) style to use. # The name of the Pygments (syntax highlighting) style to use.
pygments_style = 'trac' pygments_style = 'trac'
# Links to Python's docs should reference the most recent version of the 2.x # Links to Python's docs should reference the most recent version of the 3.x
# branch, which is located at this URL. # branch, which is located at this URL.
intersphinx_mapping = { intersphinx_mapping = {
'python': ('http://docs.python.org/', None), 'python': ('http://docs.python.org/3/', None),
'sphinx': ('http://sphinx-doc.org/', None), 'sphinx': ('http://sphinx-doc.org/', None),
'six': ('http://pythonhosted.org/six/', None), 'six': ('http://pythonhosted.org/six/', None),
'simplejson': ('http://simplejson.readthedocs.org/en/latest/', None), 'simplejson': ('http://simplejson.readthedocs.org/en/latest/', None),

View File

@@ -637,7 +637,7 @@ the Python import path to your :file:`mysite/settings.py` file.
>>> import django >>> import django
>>> django.setup() >>> django.setup()
If this raises an :exc:`~exceptions.AttributeError`, you're probably using If this raises an :exc:`AttributeError`, you're probably using
a version of Django that doesn't match this tutorial version. You'll want a version of Django that doesn't match this tutorial version. You'll want
to either switch to the older tutorial or the newer Django version. to either switch to the older tutorial or the newer Django version.

View File

@@ -106,9 +106,9 @@ This code includes a few things we haven't covered yet in this tutorial:
<django.http.HttpRequest.POST>` in our code, to ensure that data is only <django.http.HttpRequest.POST>` in our code, to ensure that data is only
altered via a POST call. altered via a POST call.
* ``request.POST['choice']`` will raise :exc:`~exceptions.KeyError` if * ``request.POST['choice']`` will raise :exc:`KeyError` if
``choice`` wasn't provided in POST data. The above code checks for ``choice`` wasn't provided in POST data. The above code checks for
:exc:`~exceptions.KeyError` and redisplays the question form with an error :exc:`KeyError` and redisplays the question form with an error
message if ``choice`` isn't given. message if ``choice`` isn't given.
* After incrementing the choice count, the code returns an * After incrementing the choice count, the code returns an

View File

@@ -209,8 +209,8 @@ Methods
.. method:: AppConfig.get_model(model_name) .. method:: AppConfig.get_model(model_name)
Returns the :class:`~django.db.models.Model` with the given Returns the :class:`~django.db.models.Model` with the given
``model_name``. Raises :exc:`~exceptions.LookupError` if no such model ``model_name``. Raises :exc:`LookupError` if no such model exists.
exists. ``model_name`` is case-insensitive. ``model_name`` is case-insensitive.
.. method:: AppConfig.ready() .. method:: AppConfig.ready()
@@ -284,8 +284,8 @@ Application registry
.. method:: apps.get_app_config(app_label) .. method:: apps.get_app_config(app_label)
Returns an :class:`~django.apps.AppConfig` for the application with the Returns an :class:`~django.apps.AppConfig` for the application with the
given ``app_label``. Raises :exc:`~exceptions.LookupError` if no such given ``app_label``. Raises :exc:`LookupError` if no such application
application exists. exists.
.. method:: apps.is_installed(app_name) .. method:: apps.is_installed(app_name)
@@ -303,9 +303,9 @@ Application registry
argument in the form ``app_label.model_name``. ``model_name`` is case- argument in the form ``app_label.model_name``. ``model_name`` is case-
insensitive. insensitive.
Raises :exc:`~exceptions.LookupError` if no such application or model Raises :exc:`LookupError` if no such application or model exists. Raises
exists. Raises :exc:`~exceptions.ValueError` when called with a single :exc:`ValueError` when called with a single argument that doesn't contain
argument that doesn't contain exactly one dot. exactly one dot.
.. _applications-troubleshooting: .. _applications-troubleshooting:

View File

@@ -279,8 +279,7 @@ Anonymous users
* :meth:`~django.contrib.auth.models.User.set_password()`, * :meth:`~django.contrib.auth.models.User.set_password()`,
:meth:`~django.contrib.auth.models.User.check_password()`, :meth:`~django.contrib.auth.models.User.check_password()`,
:meth:`~django.db.models.Model.save` and :meth:`~django.db.models.Model.save` and
:meth:`~django.db.models.Model.delete()` raise :meth:`~django.db.models.Model.delete()` raise :exc:`NotImplementedError`.
:exc:`~exceptions.NotImplementedError`.
In practice, you probably won't need to use In practice, you probably won't need to use
:class:`~django.contrib.auth.models.AnonymousUser` objects on your own, but :class:`~django.contrib.auth.models.AnonymousUser` objects on your own, but

View File

@@ -474,7 +474,7 @@ method takes an :class:`~django.http.HttpRequest` object. It's able to deduce
the ``domain`` and ``name`` by looking at the request's domain. It has the ``domain`` and ``name`` by looking at the request's domain. It has
``save()`` and ``delete()`` methods to match the interface of ``save()`` and ``delete()`` methods to match the interface of
:class:`~django.contrib.sites.models.Site`, but the methods raise :class:`~django.contrib.sites.models.Site`, but the methods raise
:exc:`~exceptions.NotImplementedError`.. :exc:`NotImplementedError`.
``get_current_site`` shortcut ``get_current_site`` shortcut
============================= =============================

View File

@@ -220,5 +220,4 @@ Python Exceptions
================= =================
Django raises built-in Python exceptions when appropriate as well. See the Django raises built-in Python exceptions when appropriate as well. See the
Python documentation for further information on the Python documentation for further information on the :ref:`bltin-exceptions`.
built-in :mod:`exceptions`.

View File

@@ -11,8 +11,8 @@ The ``File`` Class
.. class:: File(file_object) .. class:: File(file_object)
The :class:`File` class is a thin wrapper around Python's :py:ref:`built-in The :class:`File` class is a thin wrapper around a Python
file object<bltin-file-objects>` with some Django-specific additions. :py:term:`file object` with some Django-specific additions.
Internally, Django uses this class when it needs to represent a file. Internally, Django uses this class when it needs to represent a file.
:class:`File` objects have the following attributes and methods: :class:`File` objects have the following attributes and methods:
@@ -28,8 +28,7 @@ The ``File`` Class
.. attribute:: file .. attribute:: file
The underlying :py:ref:`built-in file object<bltin-file-objects>` that The underlying :py:term:`file object` that this class wraps.
this class wraps.
.. attribute:: mode .. attribute:: mode

View File

@@ -662,8 +662,8 @@ Methods
.. method:: HttpResponse.set_cookie(key, value='', max_age=None, expires=None, path='/', domain=None, secure=None, httponly=False) .. method:: HttpResponse.set_cookie(key, value='', max_age=None, expires=None, path='/', domain=None, secure=None, httponly=False)
Sets a cookie. The parameters are the same as in the :class:`Cookie.Morsel` Sets a cookie. The parameters are the same as in the
object in the Python standard library. :class:`~http.cookies.Morsel` cookie object in the Python standard library.
* ``max_age`` should be a number of seconds, or ``None`` (default) if * ``max_age`` should be a number of seconds, or ``None`` (default) if
the cookie should last only as long as the client's browser session. the cookie should last only as long as the client's browser session.
@@ -822,7 +822,7 @@ JsonResponse objects
The ``safe`` boolean parameter defaults to ``True``. If it's set to ``False``, The ``safe`` boolean parameter defaults to ``True``. If it's set to ``False``,
any object can be passed for serialization (otherwise only ``dict`` instances any object can be passed for serialization (otherwise only ``dict`` instances
are allowed). If ``safe`` is ``True`` and a non-``dict`` object is passed as are allowed). If ``safe`` is ``True`` and a non-``dict`` object is passed as
the first argument, a :exc:`~exceptions.TypeError` will be raised. the first argument, a :exc:`TypeError` will be raised.
Usage Usage
----- -----
@@ -843,7 +843,7 @@ parameter to ``False``::
>>> response = JsonResponse([1, 2, 3], safe=False) >>> response = JsonResponse([1, 2, 3], safe=False)
Without passing ``safe=False``, a :exc:`~exceptions.TypeError` will be raised. Without passing ``safe=False``, a :exc:`TypeError` will be raised.
.. warning:: .. warning::

View File

@@ -2465,7 +2465,7 @@ slightly different call:
The :mod:`staticfiles<django.contrib.staticfiles>` contrib app also ships The :mod:`staticfiles<django.contrib.staticfiles>` contrib app also ships
with a :ttag:`static template tag<staticfiles-static>` which uses with a :ttag:`static template tag<staticfiles-static>` which uses
``staticfiles'`` :setting:`STATICFILES_STORAGE` to build the URL of the ``staticfiles'`` :setting:`STATICFILES_STORAGE` to build the URL of the
given path (rather than simply using :func:`urlparse.urljoin` with the given path (rather than simply using :func:`urllib.parse.urljoin` with the
:setting:`STATIC_URL` setting and the given path). Use that instead if you :setting:`STATIC_URL` setting and the given path). Use that instead if you
have an advanced use case such as :ref:`using a cloud service to serve have an advanced use case such as :ref:`using a cloud service to serve
static files<staticfiles-from-cdn>`:: static files<staticfiles-from-cdn>`::

View File

@@ -133,8 +133,8 @@ results. Instead do::
The functions defined in this module share the following properties: The functions defined in this module share the following properties:
- They raise :exc:`~exceptions.ValueError` if their input is well formatted but - They raise :exc:`ValueError` if their input is well formatted but isn't a
isn't a valid date or time. valid date or time.
- They return ``None`` if it isn't well formatted at all. - They return ``None`` if it isn't well formatted at all.
- They accept up to picosecond resolution in input, but they truncate it to - They accept up to picosecond resolution in input, but they truncate it to
microseconds, since that's what Python supports. microseconds, since that's what Python supports.
@@ -688,7 +688,9 @@ escaping HTML.
.. function:: int_to_base36(i) .. function:: int_to_base36(i)
Converts a positive integer to a base 36 string. On Python 2 ``i`` must be Converts a positive integer to a base 36 string. On Python 2 ``i`` must be
smaller than :data:`sys.maxint`. smaller than `sys.maxint`_.
.. _sys.maxint: http://docs.python.org/2/library/sys.html#sys.maxint
.. function:: urlsafe_base64_encode(s) .. function:: urlsafe_base64_encode(s)

View File

@@ -68,7 +68,7 @@ to, or in lieu of custom ``field.clean()`` methods.
:param inverse_match: If not ``None``, overrides :attr:`inverse_match`. :param inverse_match: If not ``None``, overrides :attr:`inverse_match`.
:param flags: If not ``None``, overrides :attr:`flags`. In that case, :param flags: If not ``None``, overrides :attr:`flags`. In that case,
:attr:`regex` must be a regular expression string, or :attr:`regex` must be a regular expression string, or
:exc:`~exceptions.TypeError` is raised. :exc:`TypeError` is raised.
.. attribute:: regex .. attribute:: regex
@@ -102,7 +102,7 @@ to, or in lieu of custom ``field.clean()`` methods.
The flags used when compiling the regular expression string :attr:`regex`. The flags used when compiling the regular expression string :attr:`regex`.
If :attr:`regex` is a pre-compiled regular expression, and :attr:`flags` is overridden, If :attr:`regex` is a pre-compiled regular expression, and :attr:`flags` is overridden,
:exc:`~exceptions.TypeError` is raised. :exc:`TypeError` is raised.
Defaults to `0`. Defaults to `0`.
``URLValidator`` ``URLValidator``

View File

@@ -440,9 +440,9 @@ Settings
Better exceptions Better exceptions
~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~
The old :exc:`~exceptions.EnvironmentError` has split into an The old :exc:`EnvironmentError` has split into an
:exc:`~exceptions.ImportError` when Django fails to find the settings module :exc:`ImportError` when Django fails to find the settings module
and a :exc:`~exceptions.RuntimeError` when you try to reconfigure settings and a :exc:`RuntimeError` when you try to reconfigure settings
after having already used them. after having already used them.
:setting:`LOGIN_URL` has moved :setting:`LOGIN_URL` has moved
@@ -479,7 +479,7 @@ Different exception from ``get()``
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Managers now return a :exc:`~django.core.exceptions.MultipleObjectsReturned` Managers now return a :exc:`~django.core.exceptions.MultipleObjectsReturned`
exception instead of :exc:`~exceptions.AssertionError`: exception instead of :exc:`AssertionError`:
Old (0.96):: Old (0.96)::

View File

@@ -550,8 +550,7 @@ Miscellaneous
``QuerySet`` as the empty value instead of an empty list. ``QuerySet`` as the empty value instead of an empty list.
* :func:`~django.utils.http.int_to_base36` properly raises a * :func:`~django.utils.http.int_to_base36` properly raises a
:exc:`~exceptions.TypeError` instead of :exc:`~exceptions.ValueError` for :exc:`TypeError` instead of :exc:`ValueError` for non-integer inputs.
non-integer inputs.
* The ``slugify`` template filter is now available as a standard python * The ``slugify`` template filter is now available as a standard python
function at :func:`django.utils.text.slugify`. Similarly, ``remove_tags`` is function at :func:`django.utils.text.slugify`. Similarly, ``remove_tags`` is

View File

@@ -589,8 +589,7 @@ Miscellaneous
``QuerySet`` as the empty value instead of an empty list. ``QuerySet`` as the empty value instead of an empty list.
* :func:`~django.utils.http.int_to_base36` properly raises a * :func:`~django.utils.http.int_to_base36` properly raises a
:exc:`~exceptions.TypeError` instead of :exc:`~exceptions.ValueError` for :exc:`TypeError` instead of :exc:`ValueError` for non-integer inputs.
non-integer inputs.
* The ``slugify`` template filter is now available as a standard python * The ``slugify`` template filter is now available as a standard python
function at :func:`django.utils.text.slugify`. Similarly, ``remove_tags`` is function at :func:`django.utils.text.slugify`. Similarly, ``remove_tags`` is

View File

@@ -667,8 +667,7 @@ Miscellaneous
``QuerySet`` as the empty value instead of an empty list. ``QuerySet`` as the empty value instead of an empty list.
* :func:`~django.utils.http.int_to_base36` properly raises a * :func:`~django.utils.http.int_to_base36` properly raises a
:exc:`~exceptions.TypeError` instead of :exc:`~exceptions.ValueError` for :exc:`TypeError` instead of :exc:`ValueError` for non-integer inputs.
non-integer inputs.
* The ``slugify`` template filter is now available as a standard python * The ``slugify`` template filter is now available as a standard python
function at :func:`django.utils.text.slugify`. Similarly, ``remove_tags`` is function at :func:`django.utils.text.slugify`. Similarly, ``remove_tags`` is

View File

@@ -168,7 +168,7 @@ Minor features
:setting:`CSRF_COOKIE_HTTPONLY`. :setting:`CSRF_COOKIE_HTTPONLY`.
* The :meth:`~django.test.TransactionTestCase.assertQuerysetEqual` now checks * The :meth:`~django.test.TransactionTestCase.assertQuerysetEqual` now checks
for undefined order and raises :exc:`~exceptions.ValueError` if undefined for undefined order and raises :exc:`ValueError` if undefined
order is spotted. The order is seen as undefined if the given ``QuerySet`` order is spotted. The order is seen as undefined if the given ``QuerySet``
isn't ordered and there are more than one ordered values to compare against. isn't ordered and there are more than one ordered values to compare against.

View File

@@ -944,8 +944,8 @@ the app cache was a private API, obsolete methods and arguments will be
removed through a standard deprecation path, with the exception of the removed through a standard deprecation path, with the exception of the
following changes that take effect immediately: following changes that take effect immediately:
* ``get_model`` raises :exc:`~exceptions.LookupError` instead of returning * ``get_model`` raises :exc:`LookupError` instead of returning ``None`` when no
``None`` when no model is found. model is found.
* The ``only_installed`` argument of ``get_model`` and ``get_models`` no * The ``only_installed`` argument of ``get_model`` and ``get_models`` no
longer exists, nor does the ``seed_cache`` argument of ``get_model``. longer exists, nor does the ``seed_cache`` argument of ``get_model``.
@@ -1005,9 +1005,9 @@ pytz may be required
~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~
If your project handles datetimes before 1970 or after 2037 and Django raises If your project handles datetimes before 1970 or after 2037 and Django raises
a :exc:`~exceptions.ValueError` when encountering them, you will have to a :exc:`ValueError` when encountering them, you will have to install pytz_. You
install pytz_. You may be affected by this problem if you use Django's time may be affected by this problem if you use Django's time zone-related date
zone-related date formats or :mod:`django.contrib.syndication`. formats or :mod:`django.contrib.syndication`.
.. _pytz: https://pypi.python.org/pypi/pytz/ .. _pytz: https://pypi.python.org/pypi/pytz/

View File

@@ -78,7 +78,7 @@ Adding a second time is OK::
>>> a2.publications.add(p3) >>> a2.publications.add(p3)
Adding an object of the wrong type raises :exc:`~exceptions.TypeError`:: Adding an object of the wrong type raises :exc:`TypeError`::
>>> a2.publications.add(a1) >>> a2.publications.add(a1)
Traceback (most recent call last): Traceback (most recent call last):

View File

@@ -460,9 +460,8 @@ zone support.
Fixtures generated with ``USE_TZ = False``, or before Django 1.4, use the Fixtures generated with ``USE_TZ = False``, or before Django 1.4, use the
"naive" format. If your project contains such fixtures, after you enable time "naive" format. If your project contains such fixtures, after you enable time
zone support, you'll see :exc:`~exceptions.RuntimeWarning`\ s when you load zone support, you'll see :exc:`RuntimeWarning`\ s when you load them. To get
them. To get rid of the warnings, you must convert your fixtures to the "aware" rid of the warnings, you must convert your fixtures to the "aware" format.
format.
You can regenerate fixtures with :djadmin:`loaddata` then :djadmin:`dumpdata`. You can regenerate fixtures with :djadmin:`loaddata` then :djadmin:`dumpdata`.
Or, if they're small enough, you can simply edit them to add the UTC offset Or, if they're small enough, you can simply edit them to add the UTC offset

View File

@@ -78,8 +78,8 @@ wherever possible and avoid the ``b`` prefixes.
String handling String handling
--------------- ---------------
Python 2's :func:`unicode` type was renamed :func:`str` in Python 3, Python 2's `unicode`_ type was renamed :class:`str` in Python 3,
:func:`str` was renamed ``bytes()``, and :func:`basestring` disappeared. ``str()`` was renamed :func:`bytes`, and `basestring`_ disappeared.
six_ provides :ref:`tools <string-handling-with-six>` to deal with these six_ provides :ref:`tools <string-handling-with-six>` to deal with these
changes. changes.
@@ -131,35 +131,34 @@ and ``SafeText`` respectively.
For forwards compatibility, the new names work as of Django 1.4.2. For forwards compatibility, the new names work as of Django 1.4.2.
:meth:`~object.__str__` and :meth:`~object.__unicode__` methods :meth:`~object.__str__` and ` __unicode__()`_ methods
--------------------------------------------------------------- -----------------------------------------------------
In Python 2, the object model specifies :meth:`~object.__str__` and In Python 2, the object model specifies :meth:`~object.__str__` and
:meth:`~object.__unicode__` methods. If these methods exist, they must return ` __unicode__()`_ methods. If these methods exist, they must return
``str`` (bytes) and ``unicode`` (text) respectively. ``str`` (bytes) and ``unicode`` (text) respectively.
The ``print`` statement and the :func:`str` built-in call The ``print`` statement and the :class:`str` built-in call
:meth:`~object.__str__` to determine the human-readable representation of an :meth:`~object.__str__` to determine the human-readable representation of an
object. The :func:`unicode` built-in calls :meth:`~object.__unicode__` if it object. The ``unicode`` built-in calls ` __unicode__()`_ if it
exists, and otherwise falls back to :meth:`~object.__str__` and decodes the exists, and otherwise falls back to :meth:`~object.__str__` and decodes the
result with the system encoding. Conversely, the result with the system encoding. Conversely, the
:class:`~django.db.models.Model` base class automatically derives :class:`~django.db.models.Model` base class automatically derives
:meth:`~object.__str__` from :meth:`~object.__unicode__` by encoding to UTF-8. :meth:`~object.__str__` from ` __unicode__()`_ by encoding to UTF-8.
In Python 3, there's simply :meth:`~object.__str__`, which must return ``str`` In Python 3, there's simply :meth:`~object.__str__`, which must return ``str``
(text). (text).
(It is also possible to define ``__bytes__()``, but Django application have (It is also possible to define :meth:`~object.__bytes__`, but Django application
little use for that method, because they hardly ever deal with have little use for that method, because they hardly ever deal with ``bytes``.)
``bytes``.)
Django provides a simple way to define :meth:`~object.__str__` and Django provides a simple way to define :meth:`~object.__str__` and
:meth:`~object.__unicode__` methods that work on Python 2 and 3: you must ` __unicode__()`_ methods that work on Python 2 and 3: you must
define a :meth:`~object.__str__` method returning text and to apply the define a :meth:`~object.__str__` method returning text and to apply the
:func:`~django.utils.encoding.python_2_unicode_compatible` decorator. :func:`~django.utils.encoding.python_2_unicode_compatible` decorator.
On Python 3, the decorator is a no-op. On Python 2, it defines appropriate On Python 3, the decorator is a no-op. On Python 2, it defines appropriate
:meth:`~object.__unicode__` and :meth:`~object.__str__` methods (replacing the ` __unicode__()`_ and :meth:`~object.__str__` methods (replacing the
original :meth:`~object.__str__` method in the process). Here's an example:: original :meth:`~object.__str__` method in the process). Here's an example::
from __future__ import unicode_literals from __future__ import unicode_literals
@@ -233,7 +232,7 @@ In order to enable the same behavior in Python 2, every module must import
my_bytestring = b"This is a bytestring" my_bytestring = b"This is a bytestring"
If you need a byte string literal under Python 2 and a unicode string literal If you need a byte string literal under Python 2 and a unicode string literal
under Python 3, use the :func:`str` builtin:: under Python 3, use the :class:`str` builtin::
str('my string') str('my string')
@@ -402,3 +401,7 @@ extras.
In addition to six' defaults moves, Django's version provides ``thread`` as In addition to six' defaults moves, Django's version provides ``thread`` as
``_thread`` and ``dummy_thread`` as ``_dummy_thread``. ``_thread`` and ``dummy_thread`` as ``_dummy_thread``.
.. _unicode: http://docs.python.org/2/library/functions.html#unicode
.. _ __unicode__(): https://docs.python.org/2/reference/datamodel.html#object.__unicode__
.. _basestring: http://docs.python.org/2/library/functions.html#basestring

View File

@@ -77,8 +77,7 @@ Note a few important things about how the test client works:
The test client is not capable of retrieving Web pages that are not The test client is not capable of retrieving Web pages that are not
powered by your Django project. If you need to retrieve other Web pages, powered by your Django project. If you need to retrieve other Web pages,
use a Python standard library module such as :mod:`urllib` or use a Python standard library module such as :mod:`urllib`.
:mod:`urllib2`.
* To resolve URLs, the test client uses whatever URLconf is pointed-to by * To resolve URLs, the test client uses whatever URLconf is pointed-to by
your :setting:`ROOT_URLCONF` setting. your :setting:`ROOT_URLCONF` setting.
@@ -479,9 +478,9 @@ can access these properties as part of a test condition.
.. attribute:: Client.cookies .. attribute:: Client.cookies
A Python :class:`~Cookie.SimpleCookie` object, containing the current values A Python :class:`~http.cookies.SimpleCookie` object, containing the current
of all the client cookies. See the documentation of the :mod:`Cookie` module values of all the client cookies. See the documentation of the
for more. :mod:`http.cookies` module for more.
.. attribute:: Client.session .. attribute:: Client.session
@@ -1247,7 +1246,7 @@ your test suite.
Asserts that execution of callable ``callable_obj`` raised the Asserts that execution of callable ``callable_obj`` raised the
``expected_exception`` exception and that such exception has an ``expected_exception`` exception and that such exception has an
``expected_message`` representation. Any other outcome is reported as a ``expected_message`` representation. Any other outcome is reported as a
failure. Similar to unittest's :meth:`~unittest.TestCase.assertRaisesRegexp` failure. Similar to unittest's :meth:`~unittest.TestCase.assertRaisesRegex`
with the difference that ``expected_message`` isn't a regular expression. with the difference that ``expected_message`` isn't a regular expression.
.. method:: SimpleTestCase.assertFieldOutput(fieldclass, valid, invalid, field_args=None, field_kwargs=None, empty_value='') .. method:: SimpleTestCase.assertFieldOutput(fieldclass, valid, invalid, field_args=None, field_kwargs=None, empty_value='')