Skip to main content

Anonymous datatype validation

Project description

Examples

>>> from datatype.validation import failures

>>> datatype = {'foo': [{'bar': 'int'}]}
>>> bad_value = {'foo': [{'bar': 'baz'}], 'bif': 'pow!'}

>>> failures(datatype, bad_value)
['foo[0].bar: expected int, got str', 'unexpected property "bif"']

Wildcard dictionary keys:

>>> datatype = {'_any_': ['int']}
>>> good_value = {'foo': [1, 2, 3], 'bar': [3, 4, 5]}

>>> failures(datatype, good_value)
[]

Datatype Definitions

Datatype definitions are represented with a small set of types that should be built-in for most languages.

Required types for proper validation:

  • int

  • float

  • string

  • boolean

  • dictionary (or anonymous object)

  • list (or array)

Specification

DEFINITION = PRIMITIVE | LIST | DICTIONARY | TUPLE
PRIMITIVE = ["nullable "] + ("int" | "str" | "float" | "bool")
DICTIONARY = (dictionary of) key: DICTIONARY-KEY, value: DEFINITION
DICTIONARY-KEY = (["optional "] + DICTIONARY-KEY-NAME) | "_any_"
DICTIONARY-KEY-NAME = [A-Za-z0-9_]+
LIST = (list of one) DEFINITION
TUPLE = (list of more than one) DEFINITION

Definition Examples (in python)

definition: "int"
example value: 5

definition: {"foo": "int"}
example value: {"foo": 5}

definition: [{"foo": ["bool"]}]
example value: [{"foo": [True, False]}, {"foo": [False, False]}]

definition: {"_any_": "int"}
example value: {"foo": 5, "bar": 7}

definition: ["int", "str"]
example value: [5, "foo"]

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

datatype-0.6.3.tar.gz (4.1 kB view details)

Uploaded Source

File details

Details for the file datatype-0.6.3.tar.gz.

File metadata

  • Download URL: datatype-0.6.3.tar.gz
  • Upload date:
  • Size: 4.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for datatype-0.6.3.tar.gz
Algorithm Hash digest
SHA256 b0db44123adabf7e6942405bcc5d3205505b771fc22f6c7feb04be135fac71fd
MD5 cf136ad1a2c7fba3be5d47bc37c1762c
BLAKE2b-256 ccb8f2e9a22bb8aca1bb9948fa2995afd294a993fec74189c5bc4c0b17ac4f1b

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