Skip to main content

HoneyHive Python SDK - LLM Observability and Evaluation Platform

Project description

HoneyHive Python SDK

A comprehensive Python SDK for HoneyHive, providing LLM observability, evaluation, and tracing capabilities with OpenTelemetry integration.

๐Ÿš€ Features

  • OpenTelemetry Integration - Full OTEL compliance with custom span processor and exporter
  • Automatic Session Management - Seamless session creation and management
  • Decorator Support - Easy-to-use @trace (unified sync/async), @atrace, and @trace_class decorators
  • Context Managers - start_span and enrich_span for manual span management
  • HTTP Instrumentation - Automatic HTTP request tracing
  • Baggage Support - Context propagation across service boundaries
  • Experiment Harness Integration - Automatic experiment tracking with MLflow, Weights & Biases, and Comet support
  • Real-time API Integration - Direct integration with HoneyHive backend services
  • Comprehensive Testing - Full test suite with 203 passing tests

๐Ÿ“ฆ Installation

Choose Your Instrumentor Type:

HoneyHive supports both OpenInference (lightweight) and OpenLLMetry (enhanced metrics) instrumentors.

Option A: OpenInference (Recommended for Beginners)

# Install with OpenAI integration (most common)
pip install honeyhive[openinference-openai]

# Install with Anthropic integration  
pip install honeyhive[openinference-anthropic]

# Install with Google AI integration
pip install honeyhive[openinference-google-ai]

# Install with multiple providers
pip install honeyhive[openinference-openai,openinference-anthropic,openinference-google-ai]

# Install all OpenInference integrations
pip install honeyhive[all-openinference]

Option B: OpenLLMetry (Enhanced Metrics)

# Install with OpenAI integration (enhanced metrics)
pip install honeyhive[traceloop-openai]

# Install with Anthropic integration  
pip install honeyhive[traceloop-anthropic]

# Install with Google AI integration
pip install honeyhive[traceloop-google-ai]

# Install with multiple providers
pip install honeyhive[traceloop-openai,traceloop-anthropic,traceloop-google-ai]

# Install all OpenLLMetry integrations
pip install honeyhive[all-traceloop]

Option C: Mix Both Types

# Strategic mixing based on your needs
pip install honeyhive[traceloop-openai,openinference-anthropic]

Basic Installation (manual instrumentor setup required):

pip install honeyhive

๐Ÿ“‹ Including in Your Project

For detailed guidance on including HoneyHive in your pyproject.toml, see our pyproject.toml Integration Guide.

๐Ÿ”ง Quick Start

Basic Usage

from honeyhive import HoneyHiveTracer, trace

# Initialize tracer
tracer = HoneyHiveTracer.init(
    api_key="your-api-key",
    project="your-project",
    source="production"
)

# Use unified decorator for automatic tracing (works with both sync and async)
@trace(event_type="demo", event_name="my_function")
def my_function():
    return "Hello, World!"

@trace(event_type="demo", event_name="my_async_function")
async def my_async_function():
    await asyncio.sleep(0.1)
    return "Hello, Async World!"

# Manual span management
with tracer.start_span("custom-operation"):
    # Your code here
    pass

# With HTTP tracing enabled (new simplified API)
tracer = HoneyHiveTracer.init(
    api_key="your-api-key",
    source="production",
    disable_http_tracing=False  # project derived from API key
)

Initialization

The HoneyHiveTracer.init() method is the recommended way to initialize the tracer:

from honeyhive import HoneyHiveTracer

# Standard initialization
tracer = HoneyHiveTracer.init(
    api_key="your-api-key",
    source="production"  # project derived from API key
)

# With custom server URL for self-hosted deployments
tracer = HoneyHiveTracer.init(
    api_key="your-api-key",
    source="production",
    server_url="https://custom-server.com"  # project derived from API key
)

Enhanced Features Available

from honeyhive import HoneyHiveTracer
from openinference.instrumentation.openai import OpenAIInstrumentor

# All features are available in the init method
tracer = HoneyHiveTracer.init(
    api_key="your-api-key",
    project="your-project",
    source="production",
    test_mode=True,  # Test mode support
    instrumentors=[OpenAIInstrumentor()],  # Auto-integration
    disable_http_tracing=True  # Performance control
)

โœ… The init method now supports ALL constructor features!

OpenInference Integration

from honeyhive import HoneyHiveTracer
from openinference.instrumentation.openai import OpenAIInstrumentor

# Initialize tracer with OpenInference instrumentor (recommended pattern)
tracer = HoneyHiveTracer.init(
    api_key="your-api-key",
    project="your-project",
    source="production",
    instrumentors=[OpenAIInstrumentor()]  # Auto-integration
)

# OpenInference automatically traces OpenAI calls
import openai
response = openai.ChatCompletion.create(
    model="gpt-3.5-turbo",
    messages=[{"role": "user", "content": "Hello!"}]
)

Enriching Spans and Sessions

v1.0+ Recommended Pattern: Instance Methods

from honeyhive import HoneyHiveTracer

# Initialize tracer
tracer = HoneyHiveTracer.init(
    api_key="your-api-key",
    project="your-project"
)

# Use instance methods for enrichment (PRIMARY - Recommended)
@tracer.trace(event_type="tool")
def my_function(input_data):
    result = process_data(input_data)
    
    # โœ… Instance method (PRIMARY pattern in v1.0+)
    tracer.enrich_span(
        metadata={"input": input_data, "result": result},
        metrics={"processing_time_ms": 150}
    )
    
    return result

# Enrich session with user properties
tracer.enrich_session(
    user_properties={"user_id": "user-123", "plan": "premium"}
)

Legacy Pattern: Free Functions (Backward Compatibility)

For backward compatibility, the free function pattern from v0.2.x still works:

from honeyhive import trace, enrich_span, enrich_session

# Free functions with automatic tracer discovery (LEGACY)
@trace(event_type="tool")
def my_function(input_data):
    result = process_data(input_data)
    
    # Free function with auto-discovery (backward compatible)
    enrich_span(
        metadata={"input": input_data, "result": result},
        metrics={"processing_time_ms": 150}
    )
    
    return result

# Enrich session via free function
enrich_session(user_properties={"user_id": "user-123"})

โš ๏ธ Deprecation Notice: Free functions will be deprecated in v2.0. We recommend migrating to instance methods for new code.

Why Instance Methods?

  • โœ… Explicit tracer reference (no auto-discovery overhead)
  • โœ… Better multi-instance support (multiple tracers in same process)
  • โœ… Clearer code (explicit is better than implicit)
  • โœ… Future-proof (primary pattern going forward)

๐Ÿ—๏ธ Architecture

Core Components

src/honeyhive/
โ”œโ”€โ”€ api/                    # API client implementations
โ”‚   โ”œโ”€โ”€ client.py          # Main API client
โ”‚   โ”œโ”€โ”€ configurations.py  # Configuration management
โ”‚   โ”œโ”€โ”€ datapoints.py      # Data point operations
โ”‚   โ”œโ”€โ”€ datasets.py        # Dataset operations
โ”‚   โ”œโ”€โ”€ events.py          # Event management
โ”‚   โ”œโ”€โ”€ evaluations.py     # Evaluation operations
โ”‚   โ”œโ”€โ”€ metrics.py         # Metrics operations
โ”‚   โ”œโ”€โ”€ projects.py        # Project management
โ”‚   โ”œโ”€โ”€ session.py         # Session operations
โ”‚   โ””โ”€โ”€ tools.py           # Tool operations
โ”œโ”€โ”€ tracer/                 # OpenTelemetry integration
โ”‚   โ”œโ”€โ”€ otel_tracer.py     # Main tracer implementation
โ”‚   โ”œโ”€โ”€ span_processor.py  # Custom span processor
โ”‚   โ”œโ”€โ”€ span_exporter.py   # Custom span exporter
โ”‚   โ”œโ”€โ”€ decorators.py      # Tracing decorators
โ”‚   โ””โ”€โ”€ http_instrumentation.py # HTTP request tracing
โ”œโ”€โ”€ evaluation/             # Evaluation framework
โ”‚   โ””โ”€โ”€ evaluators.py      # Evaluation decorators
โ”œโ”€โ”€ models/                 # Pydantic models
โ”‚   โ””โ”€โ”€ generated.py       # Auto-generated from OpenAPI
โ””โ”€โ”€ utils/                  # Utility functions
    โ”œโ”€โ”€ config.py          # Configuration management
    โ”œโ”€โ”€ connection_pool.py # HTTP connection pooling
    โ”œโ”€โ”€ retry.py           # Retry mechanisms
    โ””โ”€โ”€ logger.py          # Logging utilities

Key Design Principles

  1. Singleton Pattern - Single tracer instance per application
  2. Environment Configuration - Flexible configuration via environment variables
  3. Graceful Degradation - Fallback mechanisms for missing dependencies
  4. Test Isolation - Comprehensive test suite with proper isolation
  5. OpenTelemetry Compliance - Full OTEL standard compliance

โš™๏ธ Configuration

Environment Variables

Variable Description Default
HH_API_KEY HoneyHive API key Required
HH_API_URL API base URL https://api.honeyhive.ai
HH_PROJECT Project name default
HH_SOURCE Source environment production
HH_DISABLE_TRACING Disable tracing completely false
HH_DISABLE_HTTP_TRACING Disable HTTP request tracing false
HH_TEST_MODE Enable test mode false
HH_DEBUG_MODE Enable debug mode false
HH_VERBOSE Enable verbose API logging false
HH_OTLP_ENABLED Enable OTLP export true

Experiment Harness Variables

Variable Description Default
HH_EXPERIMENT_ID Unique experiment identifier None
HH_EXPERIMENT_NAME Human-readable experiment name None
HH_EXPERIMENT_VARIANT Experiment variant/treatment None
HH_EXPERIMENT_GROUP Experiment group/cohort None
HH_EXPERIMENT_METADATA JSON experiment metadata None

HTTP Client Configuration

Variable Description Default
HH_MAX_CONNECTIONS Maximum HTTP connections 100
HH_MAX_KEEPALIVE_CONNECTIONS Keepalive connections 20
HH_KEEPALIVE_EXPIRY Keepalive expiry (seconds) 30.0
HH_POOL_TIMEOUT Connection pool timeout 30.0
HH_RATE_LIMIT_CALLS Rate limit calls per window 1000
HH_RATE_LIMIT_WINDOW Rate limit window (seconds) 60.0
HH_HTTP_PROXY HTTP proxy URL None
HH_HTTPS_PROXY HTTPS proxy URL None
HH_NO_PROXY Proxy bypass list None
HH_VERIFY_SSL SSL verification true

๐Ÿค Contributing

Want to contribute to HoneyHive? See CONTRIBUTING.md for development setup and guidelines.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

honeyhive-1.0.0rc21.tar.gz (1.5 MB view details)

Uploaded Source

Built Distribution

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

honeyhive-1.0.0rc21-py3-none-any.whl (351.9 kB view details)

Uploaded Python 3

File details

Details for the file honeyhive-1.0.0rc21.tar.gz.

File metadata

  • Download URL: honeyhive-1.0.0rc21.tar.gz
  • Upload date:
  • Size: 1.5 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for honeyhive-1.0.0rc21.tar.gz
Algorithm Hash digest
SHA256 3561d58b082be0a1bdefe1d864c9e7f26516988d1ab484653f770a24b99cc699
MD5 d0af821b0f3ad86407b2652f7bb7c0c1
BLAKE2b-256 97586640f2f4183bcba00734442b2a5371f285ed548ca3ae7625bc2a35c31939

See more details on using hashes here.

File details

Details for the file honeyhive-1.0.0rc21-py3-none-any.whl.

File metadata

  • Download URL: honeyhive-1.0.0rc21-py3-none-any.whl
  • Upload date:
  • Size: 351.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for honeyhive-1.0.0rc21-py3-none-any.whl
Algorithm Hash digest
SHA256 1aef9186bc238a1c1ebae7041c36b9ada5d04d91ce2fe64a379e2323405f2457
MD5 33f5f229e737700d2762c3e13510bd5d
BLAKE2b-256 68d6b940ea20a5dff1ea9bdbd965f4ffacf822f1e8a6c877696ae498c9b31860

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