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.5.4.tar.gz (108.2 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.5.4-py3-none-any.whl (71.1 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for valid8-3.5.4.tar.gz
Algorithm Hash digest
SHA256 1290df2fbb479c0d2697e028c7c5ae1536a9e2c298bd8c3c9abd1a61a19ea860
MD5 fc18af7c9c68f8662109510c53ca2de6
BLAKE2b-256 95a119a82cf28d78d3149680a6be7dbe617d3cc051d4b9f83e750947d9a67a67

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for valid8-3.5.4-py3-none-any.whl
Algorithm Hash digest
SHA256 f9c98f1f927a01b46b565d3219f33082a2c7f27c50602e29d4170646e628e68f
MD5 0d50519f27a1925b076d300f32af5e0a
BLAKE2b-256 c154bd96505218f465b4907c090de9db1ded040395359c680db1b17e3fbc8015

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