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.3.0.tar.gz (96.3 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.3.0-py3-none-any.whl (66.0 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for valid8-3.3.0.tar.gz
Algorithm Hash digest
SHA256 0638a7beaac9987052f6995d0145fad8a185841feb263cec0edc56937c1d9f3d
MD5 7133ea335909d6bc9c69362f5dec2ddd
BLAKE2b-256 4d4e7b168f9a58231e551646ae62337963c2d416a3be3fe4f5f564438162f8f1

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for valid8-3.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e3a5f6ef0c7be4e61d99f153359ed2240f6fee26f956faa0866970ce439ac495
MD5 b84d1d642ee2f695b98dd7f9fd79eeb1
BLAKE2b-256 fac4cca92ac8991e9d7615f13765ac3ebdf7dce6624caa36bddf9390a3e6e15a

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