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",
    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",
    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",
    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",
)

# 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.dp1.us.honeyhive.ai
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

This version

1.0.1

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

Uploaded Python 3

File details

Details for the file honeyhive-1.0.1.tar.gz.

File metadata

  • Download URL: honeyhive-1.0.1.tar.gz
  • Upload date:
  • Size: 1.1 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.1.tar.gz
Algorithm Hash digest
SHA256 1505f435f43cf0fddd1bee597a04ff9ac818cc9b76874dca4842696e114a4799
MD5 82c2b13f5ffe808cacce814786b26f98
BLAKE2b-256 b15e62dd1f62c3025080692625bfabc2660b9e7f11aa8fe70fd942722991288e

See more details on using hashes here.

File details

Details for the file honeyhive-1.0.1-py3-none-any.whl.

File metadata

  • Download URL: honeyhive-1.0.1-py3-none-any.whl
  • Upload date:
  • Size: 411.5 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.1-py3-none-any.whl
Algorithm Hash digest
SHA256 b88fd6f2b47c52af081c5cf553a4c9be8d0dcb043efdeeebc37f163da87020a9
MD5 15d7388ca5bc314ebc3731440c809506
BLAKE2b-256 7487640bd1a3d352deaed17ec691be407d1a4bb36da1618c04aef5686d76f5b0

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