You can trace PydanticAI agent and tool calls in Weave using OpenTelemetry (OTEL). PydanticAI is a Python agent framework built by the Pydantic team to make it easy and type-safe to build production-grade applications with Generative AI. It uses OTEL for tracing all agent and tool calls. This guide shows you how to trace PydanticAI agent and tool calls using OTEL and visualize those traces in Weave. You’ll learn how to install the required dependencies, configure an OTEL tracer to send data to Weave, and instrument your PydanticAI agents and tools. You’ll also see how to enable tracing by default across all agents in your application.Documentation Index
Fetch the complete documentation index at: https://wb-21fd5541-feature-automate-reference-docs-generation.mintlify.app/llms.txt
Use this file to discover all available pages before exploring further.
Prerequisites
Before you begin, install the required OTEL dependencies:Configure OTEL tracing in Weave
To send traces from PydanticAI to Weave, configure OTEL with aTracerProvider and an OTLPSpanExporter. Set the exporter to the correct endpoint and HTTP headers for authentication and project identification.
Required configuration
- Endpoint:
https://trace.wandb.ai/otel/v1/traces - Headers:
Authorization: Basic auth using your W&B API keyproject_id: Your W&B entity/project name (e.g.,myteam/myproject)
Example set up
The following code snippet demonstrates how to configure an OTLP span exporter and tracer provider to send OTEL traces from a PydanticAI application to Weave.Trace PydanticAI Agents with OTEL
To trace your PydanticAI agents and send trace data to Weave, pass anInstrumentationSettings object configured with your tracer provider to the Agent constructor. This ensures that all agent and tool calls are traced according to your OTEL configuration.
The following example shows how to create a simple agent with tracing enabled. The key step is setting the instrument argument when initializing the agent:
Trace PydanticAI Tools with OTEL
Weave can trace any PydanticAI operations that are instrumented with OTEL, including both agent and tool calls. This means that when your agent invokes a tool (e.g. a function decorated with@agent.tool_plain), the entire interaction is captured and visualized in Weave, including tool inputs, outputs, and the model’s reasoning.
The following example shows how to create an agent with a system prompt and a tool. Tracing is enabled automatically for both the agent and the tool:
Both the agent call and the tool call are traced in Weave, allowing you to inspect the full reasoning and execution path of your application.
Instrument all agents by default
To apply OTEL tracing to all PydanticAI agents in your application, use theAgent.instrument_all() method. This sets a default InstrumentationSettings instance for any agent that doesn’t explicitly specify the instrument parameter.