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 — 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 types — Bool, 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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c117d6984f6bc1ff8099f8359ead4031fa23c56a0341141f67d5afcefd7aa5f4
|
|
| MD5 |
14cd6d019c40f6101421ad24486eb6c4
|
|
| BLAKE2b-256 |
b85c1b5fc6c2cf80439a75b5af155b00e06523f9dcd744e7c1af6fea0ec49317
|
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e1c04cfa6232553354325c25b0b345bbb900f28bb2db4602d8e24ed41e48f433
|
|
| MD5 |
e0ac1cf7ac7b1a2b42f8f115bb4d29f3
|
|
| BLAKE2b-256 |
108427f8fad6ec33c3d446eff4e17d232c5aa0d9bae415ec4cb836c2159dddeb
|