Skip to main content

Run-time type checker for Python

Project description

Build Status Code Coverage Code Climate

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 two principal ways to use type checking, each with its pros and cons:

  1. calling check_type_arguments() from within the function body:

    debugger friendly but cannot check the type of the return value

  2. decorating the function with @typechecked:

    can check the type of the return value but adds an extra frame to the call stack for every call to a decorated function

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_type_arguments():

from typeguard import check_argument_types

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

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:
   ...

The following types from the typing package have specialized support:

Type

Notes

Dict

Keys and values are typechecked

List

Contents are typechecked

Set

Contents are typechecked

Tuple

Contents are typechecked

Callable

Argument count is checked but types are not (yet)

TypeVar

Constraints, bound types and co/contravariance are supported but custom generic types are not (due to type erasure)

Union

Project details


Release history Release notifications | RSS feed

This version

1.0.1

Download files

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

Source Distribution

typeguard-1.0.1.tar.gz (9.1 kB view details)

Uploaded Source

Built Distribution

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

typeguard-1.0.1-py3-none-any.whl (8.1 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for typeguard-1.0.1.tar.gz
Algorithm Hash digest
SHA256 7f4aefb6d6ba0b0695586c70782d48bd97b98aa98a5af38bc8b1cb96c06c7a65
MD5 fa7116d2a90b046ae4cd028357db0d77
BLAKE2b-256 728cf839129d1b857d3136480b488a521280159c4d7fb4227e35e1954d6dce29

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for typeguard-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 04110050ebc7ee7abd9ae79a5e8b053462d7cc198bbb909c49729dde09328dc6
MD5 eec89e0c764b791c444ef4962e0b9cdd
BLAKE2b-256 629faed19afb26d81acd3665642eea7d8a32e2c4200bb487ead896cc46f3f79a

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