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.12.tar.gz (291.5 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.12-py3-none-any.whl (18.8 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: surety-0.0.12.tar.gz
  • Upload date:
  • Size: 291.5 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.12.tar.gz
Algorithm Hash digest
SHA256 b91655dc3bbdb02e4dc8fa3d372684f0fe23d5397247bac0abd087459e8dc653
MD5 0ad8a73c705130c2bc91c2c459a43299
BLAKE2b-256 8279904123ce55bc7495c422bfd9e7a33d0e147b59519c62d0db9b031e37fe57

See more details on using hashes here.

File details

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

File metadata

  • Download URL: surety-0.0.12-py3-none-any.whl
  • Upload date:
  • Size: 18.8 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.12-py3-none-any.whl
Algorithm Hash digest
SHA256 9b8cd036a5f81a1632634552df9f0c7d08cf17fdc168e446ee387528ac7d9a72
MD5 23aa2658a2c6ca8f648cb4ac82c286ad
BLAKE2b-256 eeca8d3a8592a3aeafceb7a8eb3057748a1d0b64d14dc79cc34d374aaf413cc5

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