Skip to main content

Yet another validation lib ;). Provides tools for general-purpose variable validation, function inputs/outputs validation as well as class fields validation. All entry points raise consistent ValidationError including all contextual details, with dynamic inheritance of ValueError/TypeError as appropriate.

Project description

Build Status Tests Status codecov Documentation PyPI

“valid8ing is not a crime” ;-)

valid8 provides user-friendly tools for

  • general-purpose inline validation,

  • function inputs/outputs validation

  • class fields validation.

All entry points raise consistent ValidationError including all contextual details, with dynamic inheritance of ValueError/TypeError as appropriate. Originally from the autoclass project.

This is the readme for developers. The documentation for users is available here: https://smarie.github.io/python-valid8/

Want to contribute ?

Contributions are welcome ! Simply fork this project on github, commit your contributions, and create pull requests.

Here is a non-exhaustive list of interesting open topics: https://github.com/smarie/python-valid8/issues

Running the tests

This project uses pytest.

pytest -v valid8/tests/

You may need to install requirements for setup beforehand, using

pip install -r ci_tools/requirements-test.txt

Packaging

This project uses setuptools_scm to synchronise the version number. Therefore the following command should be used for development snapshots as well as official releases:

python setup.py egg_info bdist_wheel rotate -m.whl -k3

You may need to install requirements for setup beforehand, using

pip install -r ci_tools/requirements-setup.txt

Generating the documentation page

This project uses mkdocs to generate its documentation page. Therefore building a local copy of the doc page may be done using:

mkdocs build

You may need to install requirements for doc beforehand, using

pip install -r ci_tools/requirements-doc.txt

Generating the test reports

The following commands generate the html test report and the associated badge.

pytest --junitxml=junit.xml -v valid8/tests/
ant -f ci_tools/generate-junit-html.xml
python ci_tools/generate-junit-badge.py

PyPI Releasing memo

This project is now automatically deployed to PyPI when a tag is created. Anyway, for manual deployment we can use:

twine upload dist/* -r pypitest
twine upload dist/*

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

valid8-3.2.0.tar.gz (91.5 kB view details)

Uploaded Source

Built Distribution

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

valid8-3.2.0-py3-none-any.whl (63.2 kB view details)

Uploaded Python 3

File details

Details for the file valid8-3.2.0.tar.gz.

File metadata

  • Download URL: valid8-3.2.0.tar.gz
  • Upload date:
  • Size: 91.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for valid8-3.2.0.tar.gz
Algorithm Hash digest
SHA256 08c7e7ba3698bdd7ea5c761066a501d1e730c08f6b3ae2452ebc903ec5817e44
MD5 331a75732764e3a77b959edc988ca036
BLAKE2b-256 a9b433d2e3feea93cd212deb967bfd3843c1e627440e1eebd188ed4dcb47f14c

See more details on using hashes here.

File details

Details for the file valid8-3.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for valid8-3.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 9c74075f881c7bad5224e39afd43e9a9c711ad31d6416071b4b13a89b154a95d
MD5 a8d9d14d2b3a0c0251051ff53866ae51
BLAKE2b-256 013068c66230048db56ffb3d13008e2f9497532b13cf661e3f9e45242f908e17

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