Skip to main content

Python SDK for Tessera - Data contract coordination for warehouses

Project description

Tessera

Tessera Python SDK

Python SDK for Tessera - Data Contract Coordination

PyPI Python


Tessera coordinates data contracts between producers and consumers. Producers publish schemas, consumers register dependencies, and breaking changes require acknowledgment before deployment.

This SDK provides a Python client for the Tessera API.

Installation

pip install tessera-sdk

Or with uv:

uv add tessera-sdk

Quick Start

from tessera_sdk import TesseraClient

client = TesseraClient(base_url="http://localhost:8000")

# Create a team
team = client.teams.create(name="data-platform")

# Create an asset
asset = client.assets.create(
    fqn="warehouse.analytics.dim_customers",
    owner_team_id=team.id
)

# Publish a contract
result = client.assets.publish_contract(
    asset_id=asset.id,
    schema={
        "type": "object",
        "properties": {
            "id": {"type": "integer"},
            "name": {"type": "string"}
        }
    },
    version="1.0.0"
)

# Check impact before making changes
impact = client.assets.check_impact(
    asset_id=asset.id,
    proposed_schema={
        "type": "object",
        "properties": {
            "id": {"type": "string"},  # Changed type!
            "name": {"type": "string"}
        }
    }
)

if not impact.safe_to_publish:
    print(f"Breaking changes detected: {impact.breaking_changes}")

Features

  • Sync and async clients - Use TesseraClient or AsyncTesseraClient
  • Type-safe - Full Pydantic model support
  • Error handling - Typed exceptions for API errors
  • Flexible configuration - Environment variables or explicit config

Async Support

import asyncio
from tessera_sdk import AsyncTesseraClient

async def main():
    async with AsyncTesseraClient() as client:
        team = await client.teams.create(name="data-platform")
        print(f"Created team: {team.name}")

asyncio.run(main())

Airflow Integration

from airflow.decorators import task
from tessera_sdk import TesseraClient

@task
def validate_schema():
    client = TesseraClient()
    impact = client.assets.check_impact(
        asset_id="your-asset-id",
        proposed_schema=load_schema("./schema.json")
    )
    if not impact.safe_to_publish:
        raise ValueError(f"Breaking changes: {impact.breaking_changes}")

@task
def publish_contract():
    client = TesseraClient()
    client.assets.publish_contract(
        asset_id="your-asset-id",
        schema=load_schema("./schema.json"),
        version=get_version()
    )

API Reference

TesseraClient

The main client class with the following resources:

Resource Description
client.teams Team management
client.assets Asset and contract management
client.contracts Contract lookup and comparison
client.registrations Consumer registration
client.proposals Breaking change proposals

Configuration

# Explicit URL
client = TesseraClient(base_url="http://localhost:8000")

# Environment variable (TESSERA_URL)
client = TesseraClient()  # Uses TESSERA_URL or defaults to localhost:8000

# With authentication
client = TesseraClient(
    base_url="http://localhost:8000",
    api_key="your-api-key",
    timeout=30.0
)

Error Handling

from tessera_sdk import TesseraClient, NotFoundError, ValidationError

client = TesseraClient()

try:
    team = client.teams.get("non-existent-id")
except NotFoundError:
    print("Team not found")
except ValidationError as e:
    print(f"Validation error: {e.message}")

Requirements

  • Python 3.10+
  • httpx >= 0.25.0
  • pydantic >= 2.0.0

Related

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

tessera_sdk-0.1.0.tar.gz (445.9 kB view details)

Uploaded Source

Built Distribution

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

tessera_sdk-0.1.0-py3-none-any.whl (11.6 kB view details)

Uploaded Python 3

File details

Details for the file tessera_sdk-0.1.0.tar.gz.

File metadata

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

File hashes

Hashes for tessera_sdk-0.1.0.tar.gz
Algorithm Hash digest
SHA256 c36bbe43d2f05c934ea8c1d6826ad5a3a745739eb4c110bf81a4a2fb08298fd7
MD5 1ad1a22622150f0535db4c2219954dca
BLAKE2b-256 a6ae65068797148f76f00e35d0dde4dba25827ada4d486b952439f1865019c43

See more details on using hashes here.

Provenance

The following attestation bundles were made for tessera_sdk-0.1.0.tar.gz:

Publisher: publish.yml on ashita-ai/tessera-python

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

File details

Details for the file tessera_sdk-0.1.0-py3-none-any.whl.

File metadata

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

File hashes

Hashes for tessera_sdk-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 fa436565c9c025eb89e0d16d639068bbc229e536429912382c6d0b9db653c95f
MD5 c0a8c3ff579cb593409cd491bdf6046b
BLAKE2b-256 d02a997dee212d61e1f1e8a7ee15bdf06a485500ee2464d01e2f8756fc0b1c68

See more details on using hashes here.

Provenance

The following attestation bundles were made for tessera_sdk-0.1.0-py3-none-any.whl:

Publisher: publish.yml on ashita-ai/tessera-python

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