Skip to main content

Run-time type checker for Python

Project description

.. image:: https://travis-ci.org/agronholm/typeguard.svg?branch=master
:target: https://travis-ci.org/agronholm/typeguard
:alt: Build Status
.. image:: https://coveralls.io/repos/agronholm/typeguard/badge.svg?branch=master&service=github
:target: https://coveralls.io/github/agronholm/typeguard?branch=master
:alt: Code Coverage

.. highlight:: python

This library provides run-time type checking for functions defined with argument type annotations.

The ``typing`` module introduced in Python 3.5 (and available on PyPI for older versions of
Python 3) is supported. See below for details.

There are three principal ways to use type checking, each with its pros and cons:

#. calling ``check_argument_types()`` from within the function body:

* debugger friendly
* cannot check the type of the return value
* does not work reliably with dynamically defined type hints (e.g. in nested functions)
#. decorating the function with ``@typechecked``:

* can check the type of the return value
* adds an extra frame to the call stack for every call to a decorated function
#. using ``with TypeChecker() as checker:``:

* emits warnings instead of raising ``TypeError``
* eliminates boilerplate
* multiple TypeCheckers can be stacked/nested
* noninvasive (only records type violations; does not raise exceptions)
* does not work reliably with dynamically defined type hints (e.g. in nested functions)
* may cause problems with badly behaving debuggers or profilers

If a function is called with incompatible argument types or a ``@typechecked`` decorated function
returns a value incompatible with the declared type, a descriptive ``TypeError`` exception is
raised.

Type checks can be fairly expensive so it is recommended to run Python in "optimized" mode
(``python -O`` or setting the ``PYTHONOPTIMIZE`` environment variable) when running code containing
type checks in production. The optimized mode will disable the type checks, by virtue of removing
all ``assert`` statements and setting the ``__debug__`` constant to ``False``.

Using ``check_argument_types()``::

from typeguard import check_argument_types

def some_function(a: int, b: float, c: str, *args: str):
assert check_argument_types()
...

Using ``@typechecked``::

from typeguard import typechecked

@typechecked
def some_function(a: int, b: float, c: str, *args: str) -> bool:
...

To enable type checks even in optimized mode::

@typechecked(always=True)
def foo(a: str, b: int, c: Union[str, int]) -> bool:
...

Using ``TypeChecker``::

from warnings import filterwarnings

from typeguard import TypeChecker, TypeWarning

# Display all TypeWarnings, not just the first one
filterwarnings('always', category=TypeWarning)

# Run your entire application inside this context block
with TypeChecker(['mypackage', 'otherpackage']):
mypackage.run_app()

# Alternatively, manually start (and stop) the checker:
checker = TypeChecker('mypackage')
checker.start()
mypackage.start_app()

.. hint:: Some other things you can do with ``TypeChecker``:
* display all warnings from the start with ``python -W always::typeguard.TypeWarning``
* redirect them to logging using ``logging.captureWarnings()``
* record warnings in your pytest test suite and fail test(s) if you get any
(see the `pytest documentation <http://doc.pytest.org/en/latest/recwarn.html>`_ about that)

The following types from the ``typing`` package have specialized support:

============== ============================================================
Type Notes
============== ============================================================
``Callable`` Argument count is checked but types are not (yet)
``Dict`` Keys and values are typechecked
``List`` Contents are typechecked
``NamedTuple`` Field values are typechecked
``Set`` Contents are typechecked
``Tuple`` Contents are typechecked
``Type``
``TypeVar`` Constraints, bound types and co/contravariance are supported
but custom generic types are not (due to type erasure)
``Union``
============== ============================================================


Project links
-------------

* `Change log <https://github.com/agronholm/typeguard/blob/master/CHANGELOG.rst>`_
* `Source repository <https://github.com/agronholm/typeguard>`_
* `Issue tracker <https://github.com/agronholm/typeguard/issues>`_

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

typeguard-2.1.0.tar.gz (17.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

typeguard-2.1.0-py3-none-any.whl (11.9 kB view details)

Uploaded Python 3

File details

Details for the file typeguard-2.1.0.tar.gz.

File metadata

  • Download URL: typeguard-2.1.0.tar.gz
  • Upload date:
  • Size: 17.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for typeguard-2.1.0.tar.gz
Algorithm Hash digest
SHA256 817fc7f46ab1d04c50b805a0fe63706bb6d84091ae55c2247ab70e945003ad90
MD5 02670addd68a7079133812f9c17a80ff
BLAKE2b-256 8fe65c3b4ff71b82d27cd087db2a97b1384f6732574af3f1e2d340a8024df880

See more details on using hashes here.

File details

Details for the file typeguard-2.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for typeguard-2.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 fb1d1ebabdc706437b2d7fdab04ae800d3d3df8e0f3a5ad0f0b6b33d5ac4fe95
MD5 3c5ccada302050eb3f91a06debcc4508
BLAKE2b-256 f3c54fc2dbe0c85769312b6735a494c126018acc9198a05367df57414af75cb9

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page