Skip to main content

A practical system for organizing validation rules.

Project description

pylidator

pylidator is a validation framework for Python projects.

Many business systems have complex validation rules. This library provides a method of organizing those rules for convenience and testability. A validator method is written for each rule (or group of rules), which simply returns a list of errors if any are found.

Validators

A validator method checks the validity of one or a closely-related group of assertions about a piece of data. They all look basically like this:

import pylidator

@pylidator.validator(of="child")
def child_is_valid(child):
    messages = []

    if child['age'] >= 18:
        messages.append({"age": "Child is too old."}

    if child['type'] != 'human':
        messages.append({"type": "Only humans allowed."}

    return messages

(Alternately, you can return just a dict of {field: message} items.)

Validating Something

Once you have authored some @pylidator.validator methods as above, you can use them! Try this:

import pylidator

objs = {
    'name': "Mrs. Teacher's Class",
    'children': [
        {'name': "Joe", 'age': 15, 'type': 'human'},
        {'name': "Sarah", 'age': 19, 'type': 'human'},
    ]
}

# Define a provider
def _provide_child(obj):
    for i, c in enumerate(obj['children']):
        yield c, {"description": "Child {}".format(i)}

providers = {"child": _provide_something}  # "child" matches the `of` argument of the `@pylidator.validator`.
ret = pylidator.validate(objs, {pylidator.ERROR: [some_values_are_valid]}, providers=providers)

child_is_valid will be invoked once per child, and any that return something truthy will show as an ERROR.

Function Reference

@pylidator.validator decorates any method that will be passed to pylidator.validate, and takes several optional parameters:

@pylidator.validator(of, requires=None, affects=None)

`of` specifies what provider the validator should use.   The `validate` call needs an item in `providers`
     that matches `of`.
`requires` (optional) can add additional context items, such as the current time or other services that can supply
     data or settings to the validator.  The requirement is fulfilled by passing `extra_context` to the `validate`
     call, containing any items that are used in a `requires`.
`affects` (optional) is simply passed through to results.  It can be used as guidance for UI/error reporting for
     helping to resolve any resultant errors.
pylidator.validate(
    obj, validators=None, providers=None, extra_context=None, field_name_mapper=None, 
    validation_type=None)

`obj` is the top-level object requiring validation.
`validators` is a dict of {level: list of `@pylidator.validator` objects}
`providers` is a dict of {of: func that takes obj and returns an iterable of some subobjects}
`extra_context` is a dict of other data that can be injected into `@pylidator.validator` with `requires`.
`field_name_mapper` is a string->string func that converts field names given in returned errors into verbose names.
`validation_type` is added as documentation into the error object.
`logging` If set to False, disables logging of validation results.
`why` String added to logging to identify the logpoint.

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

pylidator-1.1.6.tar.gz (12.6 kB view details)

Uploaded Source

Built Distribution

pylidator-1.1.6-py2.py3-none-any.whl (13.0 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file pylidator-1.1.6.tar.gz.

File metadata

  • Download URL: pylidator-1.1.6.tar.gz
  • Upload date:
  • Size: 12.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for pylidator-1.1.6.tar.gz
Algorithm Hash digest
SHA256 f0a0504d340f34e55b8617d632ee6184565001aa7693b7acf7dc99f09ec18640
MD5 6521266bc791639940f9dee0b02a6a33
BLAKE2b-256 fabca6b996dc0609b9c5abb4a1d8401e482df1c29c185d7f8e7c0e9a11649b99

See more details on using hashes here.

File details

Details for the file pylidator-1.1.6-py2.py3-none-any.whl.

File metadata

  • Download URL: pylidator-1.1.6-py2.py3-none-any.whl
  • Upload date:
  • Size: 13.0 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for pylidator-1.1.6-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 633b61f754e51f8a54c74ff2f183da0524d1fcf030d7f828fb99a02bdb6b8da5
MD5 c783b869df74ed1b65b92478efbb11fe
BLAKE2b-256 5d0d8617df7ef1b1c6b80637f366a0344f67c2a49f57e85c8690da9bcaad3024

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