Skip to main content

TeDS (Test-Driven Schema Development Tool) - CLI for verifying JSON Schema contracts using YAML test specifications

Project description

TeDS — Test‑Driven Schema Development Tool

TeDS (Test‑Driven Schema Development Tool) is a CLI to specify and test your JSON Schema contracts using YAML test specifications. Verify that your schemas accept what they should and reject what they must.

Why TeDS?

APIs live and die by their contracts. Most teams only test the "happy path" — but what about ensuring your schema actually rejects invalid data? TeDS fills this gap by testing both sides of your schema contract:

  • Positive cases: Schema accepts valid data (including examples)
  • Negative cases: Schema rejects invalid data (explicit invalid cases)
  • Contract clarity: Tests serve as living documentation
  • CI integration: Deterministic validation prevents regressions

Quick Start

Installation

# From PyPI (recommended)
pip install teds

# From source (development)
git clone https://github.com/yaccob/teds.git
cd teds
python3 -m venv .venv && . .venv/bin/activate
pip install -r requirements.txt

Basic Usage

# Verify a test specification
teds verify demo/sample_tests.yaml

# Generate tests from schema examples
teds generate demo/sample_schemas.yaml#/components/schemas

# Generate reports
teds verify demo/sample_tests.yaml --report default.html --output-level all

Core Concepts

Test Specifications

TeDS uses YAML files to define what should be valid or invalid for your schemas:

version: "1.0.0"
tests:
  schema.yaml#/User:
    valid:
      simple_user:
        description: Basic valid user
        payload:
          id: "12345"
          name: "Alice"
          email: "alice@example.com"
    invalid:
      missing_email:
        description: User without required email
        payload:
          id: "12345"
          name: "Alice"

Schema References

Point to specific schemas using JSON Pointer syntax:

  • schema.yaml#/User - Root level User schema
  • api.yaml#/components/schemas/User - OpenAPI style reference
  • definitions.yaml#/$defs/Address - JSON Schema 2020-12 style

Commands

Verify Test Specifications

# Basic verification
teds verify my_tests.yaml

# Filter output levels
teds verify my_tests.yaml --output-level error    # Only errors
teds verify my_tests.yaml --output-level warning  # Warnings and errors
teds verify my_tests.yaml --output-level all      # Everything

# Update test files in place
teds verify my_tests.yaml --in-place

# Generate reports
teds verify my_tests.yaml --report default.html
teds verify my_tests.yaml --report default.md
teds verify my_tests.yaml --report default.adoc

Generate Test Specifications

# Generate from schema root
teds generate schema.yaml

# Generate from specific path
teds generate api.yaml#/components/schemas

# Multiple targets
teds generate schema1.yaml schema2.yaml#/definitions

Reports

TeDS generates professional validation reports in multiple formats:

  • default.adoc - AsciiDoc with color-coded status and complete YAML payloads
  • default.html - HTML with responsive design and syntax highlighting
  • default.md - Markdown with emoji status indicators
  • summary.md - Compact summary with counts and references
  • summary.html - Simple HTML summary

Reports show complete test results with clean YAML formatting and clear message separation.

Exit Codes

  • 0 - Success (all tests passed)
  • 1 - Validation failures (some tests had ERROR results)
  • 2 - Hard failures (I/O errors, invalid testspec, schema resolution issues)

Tutorial

For a comprehensive step-by-step guide, see the complete tutorial.

Development

# Clone repository
git clone https://github.com/yaccob/teds.git
cd teds

# Setup
python3 -m venv .venv && . .venv/bin/activate
pip install -r requirements.txt

# Run tests
pytest -q

# Build
pip install hatch && hatch build

Security & Network Access

By default, TeDS only resolves local file references for security and reproducibility. Enable network access for remote $ref resolution:

teds verify spec.yaml --allow-network
teds generate schema.yaml --allow-network

Network access includes timeouts and size limits. Override via environment:

  • TEDS_NETWORK_TIMEOUT (seconds, default: 5)
  • TEDS_NETWORK_MAX_BYTES (bytes, default: 5MB)

Contributing

  • Use Conventional Commits (feat, fix, docs, etc.)
  • Keep changes focused and add tests under tests/
  • Run tests before submitting: pytest -q

License

[Add license information]

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

teds-0.8.0.tar.gz (225.2 kB view details)

Uploaded Source

Built Distribution

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

teds-0.8.0-py3-none-any.whl (42.7 kB view details)

Uploaded Python 3

File details

Details for the file teds-0.8.0.tar.gz.

File metadata

  • Download URL: teds-0.8.0.tar.gz
  • Upload date:
  • Size: 225.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for teds-0.8.0.tar.gz
Algorithm Hash digest
SHA256 e4c06d43ffeffa2b4a1090812e9ddb6a1860c97a9c2b5d76323281004fba1a1b
MD5 d542c51a4fcad68d2d0a5ac101b96ca9
BLAKE2b-256 ee93cfba4cd8548b14cfe49281abee275cb155d621fcdb3339d7b5dcfbe01f8d

See more details on using hashes here.

Provenance

The following attestation bundles were made for teds-0.8.0.tar.gz:

Publisher: release.yml on yaccob/teds

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

File details

Details for the file teds-0.8.0-py3-none-any.whl.

File metadata

  • Download URL: teds-0.8.0-py3-none-any.whl
  • Upload date:
  • Size: 42.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for teds-0.8.0-py3-none-any.whl
Algorithm Hash digest
SHA256 399399d6beafc6bb78671641d2b510e16e590ffe2f34f9009e942f12be40048c
MD5 f3b91f1a0d799740e24e8e96bf9bcb4c
BLAKE2b-256 b428d2ca1f4552408dda8e6f4b4c64d76d109dd122f7193a47ddb1f0df4ad9a2

See more details on using hashes here.

Provenance

The following attestation bundles were made for teds-0.8.0-py3-none-any.whl:

Publisher: release.yml on yaccob/teds

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