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

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for surety-0.0.7.tar.gz
Algorithm Hash digest
SHA256 c117d6984f6bc1ff8099f8359ead4031fa23c56a0341141f67d5afcefd7aa5f4
MD5 14cd6d019c40f6101421ad24486eb6c4
BLAKE2b-256 b85c1b5fc6c2cf80439a75b5af155b00e06523f9dcd744e7c1af6fea0ec49317

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for surety-0.0.7-py3-none-any.whl
Algorithm Hash digest
SHA256 e1c04cfa6232553354325c25b0b345bbb900f28bb2db4602d8e24ed41e48f433
MD5 e0ac1cf7ac7b1a2b42f8f115bb4d29f3
BLAKE2b-256 108427f8fad6ec33c3d446eff4e17d232c5aa0d9bae415ec4cb836c2159dddeb

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