Skip to main content

Surety — contract-driven testing framework for Python. Define schemas, generate realistic test data, and validate API, database, and UI interactions with reusable Python classes.

Project description

Surety
PyPI version Python versions Downloads Tests Documentation Status License

Surety — Contract-Driven Testing Framework for Python

Surety makes contract-based testing simple and readable.

The surety framework replaces scattered assertions with explicit schemas and contracts — Python classes that define expected data structures, generate realistic test data, and validate real responses deterministically.

A schema is a Dictionary subclass that defines the shape of data — fields, types, and constraints. A contract adds communication semantics on top of a schema — such as an API method and path, an event name, or a database table reference.

from surety import Dictionary, String, Int, Bool

class Customer(Dictionary):
    Id = Int(name='customer_id', min_val=1000, max_val=99999)
    Email = String(name='email')
    FirstName = String(name='first_name')
    Active = Bool(name='active')

customer = Customer()
print(customer.value)
# {'customer_id': 48271, 'email': 'jane.doe@example.com', 'first_name': 'Margaret', 'active': True}

Features

  • Schema-first — define expected data structures as reusable Python classes, not scattered assertions

  • Contracts — bind schemas to communication semantics (API endpoints, database tables, events)

  • Data generation — auto-generate realistic test data using Faker with 80+ providers

  • Transport-agnostic — the same schema validates API responses, database records, and UI state

  • Structured diffs — precise mismatch reporting with custom comparison rules (via surety-diff)

  • API testing — HTTP contracts, schema-based mocking, and request verification (via surety-api)

  • UI testing — Selenium-based browser automation with page objects (via surety-ui)

  • Database testing — PostgreSQL, MySQL, SQLite, and Cassandra support (via surety-db)

  • Field typesBool, Int, Float, Decimal, String, Uuid, DateTime, Enum, Array, and more

  • Extensible — create custom field types, comparison rules, and execution adapters

  • Python 3.7+ compatible

Install

pip install surety

Optional extensions:

pip install surety-diff      # Structured comparison engine
pip install surety-api       # HTTP API interaction and mocking
pip install surety-ui        # Browser-based UI testing with Selenium
pip install surety-db        # Database interaction layer
pip install surety-config    # YAML-based configuration

Quick Example

Define a schema, generate data, and validate:

from surety import Dictionary, String, Int, Array
from surety.diff import compare

# Define schemas
class Address(Dictionary):
    City = String(name='city')
    ZipCode = String(name='zip_code', fake_as='zipcode')

class Order(Dictionary):
    Id = Int(name='order_id')
    Status = String(name='status', default='pending')
    ShippingAddress = Address(name='shipping_address')

# Generate test data
order = Order()
print(order.value)
# {'order_id': 7312, 'status': 'pending', 'shipping_address': {'city': 'Portland', 'zip_code': '97201'}}

# Validate against actual response
compare(actual=api_response, expected=order.value)

Override specific values while keeping the rest auto-generated:

order = Order().with_values({
    Order.Id.name: 1,
    Order.ShippingAddress.name: {Address.City.name: 'Seattle'}
})

Use comparison rules for dynamic fields:

from surety.diff import compare
from surety.diff.rules import has_some_value, timestamp_equal_with_delta_3s

compare(
    actual=response,
    expected=order.value,
    rules={
        Order.Id.name: has_some_value,
        Order.CreatedAt.name: timestamp_equal_with_delta_3s
    }
)

Architecture

Surety separates three concerns:

Schemas

surety

Define data structures and generate test data

Contracts & Execution

surety-api, surety-db, surety-ui

Bind schemas to endpoints, tables, and pages; perform interactions

Validation

surety-diff

Compare actual data against schemas

Documentation

Full documentation: https://surety.readthedocs.io/

Issues

Report bugs and feature requests at the issue tracker.

License

MIT License. See LICENSE for details.

Copyright (c) 2026 Elena Kulgavaya.

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

surety-0.0.11.tar.gz (291.1 kB view details)

Uploaded Source

Built Distribution

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

surety-0.0.11-py3-none-any.whl (18.3 kB view details)

Uploaded Python 3

File details

Details for the file surety-0.0.11.tar.gz.

File metadata

  • Download URL: surety-0.0.11.tar.gz
  • Upload date:
  • Size: 291.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for surety-0.0.11.tar.gz
Algorithm Hash digest
SHA256 b7cf3a57e5024eb33b81bfa059e36131b7dab97e03031e173b187448a0f5f621
MD5 63a52d92b48fc7675baab5661261f68b
BLAKE2b-256 d15d590a443eaf67161be15f278dee05502786491621a989aa082a45926e9f9c

See more details on using hashes here.

File details

Details for the file surety-0.0.11-py3-none-any.whl.

File metadata

  • Download URL: surety-0.0.11-py3-none-any.whl
  • Upload date:
  • Size: 18.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for surety-0.0.11-py3-none-any.whl
Algorithm Hash digest
SHA256 72d4d560b4f8948e816bf53d8ed877aa24d0c8ec8ef2a3dc8a4c725c6fbbcb4b
MD5 1b95599a45e1da9be8799086f2a2ef3f
BLAKE2b-256 236df3d90f838e1a497dea49bebfb33eb031649759a0e7bd70e94d6437b5866d

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