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

Uploaded Python 3

File details

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

File metadata

  • Download URL: tessera_sdk-0.1.5.tar.gz
  • Upload date:
  • Size: 862.5 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.5.tar.gz
Algorithm Hash digest
SHA256 0b6ea6d87e66dd42754b9145d0bba39638e48053f187d84bef087cb0cc0d759c
MD5 ca9d557dd7cd37cc39eb8d80e55a4ddd
BLAKE2b-256 15e1a3a027f49eaa32509bea87859856d52b31711e558cfb36d501bdf40e6ac1

See more details on using hashes here.

Provenance

The following attestation bundles were made for tessera_sdk-0.1.5.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.5-py3-none-any.whl.

File metadata

  • Download URL: tessera_sdk-0.1.5-py3-none-any.whl
  • Upload date:
  • Size: 12.9 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.5-py3-none-any.whl
Algorithm Hash digest
SHA256 59a2f30f4392a6d90c88dfbfa717d77b1afe06f3345ade0ded46ca3c49e2cd81
MD5 34bb80b8b72cd8686765e6cd337425ff
BLAKE2b-256 c7d7a459349473c8bc2d1c384d361fa0758a9584eebdfd1aa3e5f155a4676f05

See more details on using hashes here.

Provenance

The following attestation bundles were made for tessera_sdk-0.1.5-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