Skip to main content

Validate JSON payloads against AsyncAPI specifications with detailed error reporting

Project description

AsyncAPI Payload Validator

PyPI version Python Support License

A Python tool for validating JSON message payloads against AsyncAPI specifications. Performs detailed JSON Schema validation including type checking, constraints, patterns, enums, and composition rules.

Features

  • Comprehensive validation - types, required fields, string length, patterns, enums, numeric constraints, oneOf/anyOf/allOf
  • Lenient type coercion - string numbers and booleans accepted where appropriate
  • AsyncAPI 2.x and 3.x - supports both specification versions
  • HTML reports - detailed reports with line-by-line source highlighting
  • Jinja2 templates - validate template structure before rendering
  • CI/CD ready - exit codes, GitHub Actions and GitLab CI examples

Installation

pip install asyncapi-payload-validator
Install from source
git clone https://github.com/ingka-group/asyncapi-payload-validator.git
cd asyncapi-payload-validator
pip install .

For development: pip install -e ".[dev]"

Quick Start

Command Line

# Basic validation
asyncapi-validate payload.json asyncapi-spec.yaml

# Generate HTML report
asyncapi-validate payload.json asyncapi-spec.yaml --html-report report.html

# Validate specific message by ID
asyncapi-validate payload.json asyncapi-spec.yaml --message-id UserSignedUp

# Validate Jinja2 template structure
asyncapi-validate template.json spec.yaml --render-jinja2

# Validate rendered template with context
asyncapi-validate template.json spec.yaml --render-jinja2 --jinja2-context context.json

Python Library

import json, yaml
from pathlib import Path
from asyncapi_payload_validator import validate_payload

payload = json.loads(Path('payload.json').read_text())
spec = yaml.safe_load(Path('asyncapi.yaml').read_text())

result = validate_payload(payload, spec)

if result['valid']:
    print("Validation passed!")
else:
    print(f"{result['summary']['total_violations']} violation(s)")
    for category, violations in result['violations'].items():
        for v in violations:
            print(f"  - {v}")

See Python API Reference for the full API, return value structure, and advanced usage.

Validation Rules

Icon Category Description
Extra Attributes Fields in payload not declared in schema
Type Mismatches Incorrect data types (with lenient coercion)
🚫 Missing Required Required fields absent from payload
↔️ Length Violations String minLength/maxLength constraints
#️⃣ Pattern Violations Regex pattern mismatches
Enum Violations Values not in allowed enum list
🔢 Numeric Violations min/max/multipleOf constraints
🧩 Composition Violations oneOf/anyOf/allOf rule failures

Exit Codes

Code Meaning
0 Validation passed
1 Validation failed (violations found)
2 Error (invalid arguments, file not found)
130 Cancelled by user (Ctrl+C)

Documentation

Guide Description
Examples and Output Output format, real-world examples, icon reference
Python API Programmatic usage, return structure, individual functions
CI/CD Integration GitHub Actions, GitLab CI examples
Advanced Features Jinja2 templates, type coercion, composition, troubleshooting

Contributing

Contributions are welcome! See CONTRIBUTING.md for guidelines.

License

MIT - see LICENCE.md for details.

Links

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

asyncapi_payload_validator-1.0.2.tar.gz (37.7 kB view details)

Uploaded Source

Built Distribution

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

asyncapi_payload_validator-1.0.2-py3-none-any.whl (32.2 kB view details)

Uploaded Python 3

File details

Details for the file asyncapi_payload_validator-1.0.2.tar.gz.

File metadata

File hashes

Hashes for asyncapi_payload_validator-1.0.2.tar.gz
Algorithm Hash digest
SHA256 b33c8fef8ad8ecfb280b881bb5ee49a1e3858675c844067a0685f221bb39e0e9
MD5 9fc778b00a5edbeda4e603a4bac22a25
BLAKE2b-256 ff90dc2db179dafdbf6c09000386affab400b93bb5f4de2ce272c7d06b151161

See more details on using hashes here.

Provenance

The following attestation bundles were made for asyncapi_payload_validator-1.0.2.tar.gz:

Publisher: pypi-publish.yml on ingka-group/asyncapi-payload-validator

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file asyncapi_payload_validator-1.0.2-py3-none-any.whl.

File metadata

File hashes

Hashes for asyncapi_payload_validator-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 cd97304f036549e425462dc340b3f05f2d100fd5fb3e00aea5b4a5c3996c776d
MD5 1a39d4ef9324473cc1f5ace272841a76
BLAKE2b-256 72c2345b27aa96a1d35323510bc215c1516848ca9dc17e93c59162d9bd52da62

See more details on using hashes here.

Provenance

The following attestation bundles were made for asyncapi_payload_validator-1.0.2-py3-none-any.whl:

Publisher: pypi-publish.yml on ingka-group/asyncapi-payload-validator

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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