Skip to main content

A simple library for runtime type-checking.

Project description

Python versions PyPI version PyPI status Checked with Mypy Documentation Status Python package status standard-readme compliant

Typing-validation is a small library to perform runtime validation of Python objects using PEP 484 type hints.

Install

You can install the latest release from PyPI as follows:

pip install --upgrade typing-validation

Usage

The core functionality of this library is provided by the validate function:

>>> from typing_validation import validate

The validate function is invoked with a value and a type as its arguments and it returns nothing when the given value is valid for the given type:

>>> validate(12, int)
# nothing is returned => 12 is a valid int

If the value is invalid for the given type, the validate function raises a TypeError:

>>> validate(12, str)
TypeError: For type <class 'str'>, invalid value: 12

For nested types (e.g. parametric collection/mapping types), the full chain of validation failures is shown by the type error:

>>> validate([0, 1, "hi"], list[int])
TypeError: For type list[int], invalid value: [0, 1, 'hi']
  For type <class 'int'>, invalid value: 'hi'

API

For the full API documentation, see https://typing-validation.readthedocs.io/

Contributing

Please see CONTRIBUTING.md.

License

MIT © Hashberg Ltd.

Project details


Download files

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

Source Distribution

typing-validation-1.1.0.tar.gz (767.7 kB view details)

Uploaded Source

Built Distribution

typing_validation-1.1.0-py3-none-any.whl (16.8 kB view details)

Uploaded Python 3

File details

Details for the file typing-validation-1.1.0.tar.gz.

File metadata

  • Download URL: typing-validation-1.1.0.tar.gz
  • Upload date:
  • Size: 767.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.12.0

File hashes

Hashes for typing-validation-1.1.0.tar.gz
Algorithm Hash digest
SHA256 dbfa1b797e1e6d32cbe3015141d7a60b40404b043db5ae5de889761c6f85d03b
MD5 29b8b5a7fea9ec341aeaf5f72ee44448
BLAKE2b-256 d422d2920f9ee2e695ec2607786327dcdb5e9e76372bf4b0f29b6259274e993b

See more details on using hashes here.

File details

Details for the file typing_validation-1.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for typing_validation-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a2bf0ed7cc91faf17c7530170ebf1a59363e560846de48c5938821e67877bb74
MD5 db1dbe9bd79299a8336bcba7a4201f65
BLAKE2b-256 38d784437a843857b5b741bd76cc899c9f5ca087aaa1e8aad2bda3fd62d0c1ff

See more details on using hashes here.

Supported by

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