Skip to main content
This page provides a complete, auto-generated reference for the Braintrust Python SDK. For usage guidance on important APIs, see the API Reference. Also see the Braintrust Python SDK on GitHub.

Requirements

  • Python 3.10 or higher

Installation

pip install braintrust

Functions

Eval

A function you can use to define an evaluator. This is a convenience wrapper around the Evaluator class.
name
str
The name of the evaluator. This corresponds to a project name in Braintrust.
data
EvalData[Input, Output]
Returns an iterator over the evaluation dataset. Each element of the iterator should be a EvalCase.
task
EvalTask[Input, Output]
Runs the evaluation task on a single input. The hooks object can be used to add metadata to the evaluation.
scores
Sequence[EvalScorer[Input, Output]]
A list of scorers to evaluate the results of the task. Each scorer can be a Scorer object or a function
experiment_name
str | None
(Optional) Experiment name. If not specified, a name will be generated automatically.
trial_count
int
The number of times to run the evaluator per input. This is useful for evaluating applications that
metadata
Metadata | None
(Optional) A dictionary with additional data about the test example, model outputs, or just about
is_public
bool
(Optional) Whether the experiment should be public. Defaults to false.
update
bool
reporter
ReporterDef[Input, Output, EvalReport] | None
(Optional) A reporter that takes an evaluator and its result and returns a report.
reporter.name
str
required
reporter.report_eval
Callable[[Evaluator[Input, Output], EvalResultWithSummary[Input, Output], bool, bool], EvalReport | Awaitable[EvalReport]]
required
reporter.report_run
Callable[[list[EvalReport], bool, bool], bool | Awaitable[bool]]
required
timeout
float | None
(Optional) The duration, in seconds, after which to time out the evaluation.
max_concurrency
int | None
project_id
str | None
(Optional) If specified, uses the given project ID instead of the evaluator’s name to identify the project.
base_experiment_name
str | None
An optional experiment name to use as a base. If specified, the new experiment will be
base_experiment_id
str | None
An optional experiment id to use as a base. If specified, the new experiment will be
git_metadata_settings
GitMetadataSettings | None
Optional settings for collecting git metadata. By default, will collect all git metadata fields allowed in org-level settings.
git_metadata_settings.collect
Literal['all', 'none', 'some']
required
git_metadata_settings.fields
NotRequired[Sequence[Literal['commit', 'branch', 'tag', 'dirty', 'author_name', 'author_email', 'commit_message', 'commit_time', 'git_diff']]]
repo_info
RepoInfo | None
Optionally explicitly specify the git metadata for this experiment. This takes precedence over git_metadata_settings if specified.
repo_info.commit
NotRequired[str | None]
repo_info.branch
NotRequired[str | None]
repo_info.tag
NotRequired[str | None]
repo_info.dirty
NotRequired[bool | None]
repo_info.author_name
NotRequired[str | None]
repo_info.author_email
NotRequired[str | None]
repo_info.commit_message
NotRequired[str | None]
repo_info.commit_time
NotRequired[str | None]
repo_info.git_diff
NotRequired[str | None]
error_score_handler
ErrorScoreHandler | None
Optionally supply a custom function to specifically handle score values when tasks or scoring functions have errored.
description
str | None
An optional description for the experiment.
summarize_scores
bool
Whether to summarize the scores of the experiment after it has run.
no_send_logs
bool
Do not send logs to Braintrust. When True, the evaluation runs locally
parameters
EvalParameters | None
A set of parameters that will be passed to the evaluator.
on_start
Callable[[ExperimentSummary], None] | None
An optional callback that will be called when the evaluation starts. It receives the
stream
Callable[[SSEProgressEvent], None] | None
A function that will be called with progress events, which can be used to
parent
str | None
If specified, instead of creating a new experiment object, the Eval() will populate
state
BraintrustState | None
Optional BraintrustState to use for the evaluation. If not specified, the global login state will be used.

Reporter

A function you can use to define a reporter. This is a convenience wrapper around the ReporterDef class.
name
str
The name of the reporter.
report_eval
Callable[[Evaluator[Input, Output], EvalResultWithSummary[Input, Output], bool, bool], EvalReport | Awaitable[EvalReport]]
return str(result.summary)
report_run
Callable[[list[EvalReport], bool, bool], bool | Awaitable[bool]]
return True

current_experiment

Returns the currently-active experiment (set by braintrust.init(...)). Returns None if no current experiment has been set.

current_logger

Returns the currently-active logger (set by braintrust.init_logger(...)). Returns None if no current logger has been set.

current_span

Return the currently-active span for logging (set by running a span under a context manager). If there is no active span, returns a no-op span object, which supports the same interface as spans but does no logging.

flush

Flush any pending rows to the server.

get_prompt_versions

Get the versions for a specific prompt.
project_id
str
The ID of the project to query
prompt_id
str
The ID of the prompt to get versions for

get_span_parent_object

Mainly for internal use. Return the parent object for starting a span in a global context. Applies precedence: current span > propagated parent string > experiment > logger.
parent
str | None
state
BraintrustState | None

init

Log in, and then initialize a new experiment in a specified project. If the project does not exist, it will be created.
project
str | None
The name of the project to create the experiment in. Must specify at least one of project or project_id.
experiment
str | None
The name of the experiment to create. If not specified, a name will be generated automatically.
description
str | None
(Optional) An optional description of the experiment.
dataset
Optional['Dataset']
(Optional) A dataset to associate with the experiment. The dataset must be initialized with braintrust.init_dataset before passing
open
bool
If the experiment already exists, open it in read-only mode. Throws an error if the experiment does not already exist.
base_experiment
str | None
An optional experiment name to use as a base. If specified, the new experiment will be summarized and compared to this experiment. Otherwise, it will pick an experiment by finding the closest ancestor on the default (e.g. main) branch.
is_public
bool
An optional parameter to control whether the experiment is publicly visible to anybody with the link or privately visible to only members of the organization. Defaults to private.
app_url
str | None
The URL of the Braintrust App. Defaults to https://www.braintrust.dev.
api_key
str | None
The API key to use. If the parameter is not specified, will try to use the BRAINTRUST_API_KEY environment variable. If no API
org_name
str | None
(Optional) The name of a specific organization to connect to. This is useful if you belong to multiple.
metadata
Metadata | None
(Optional) a dictionary with additional data about the test example, model outputs, or just about anything else that’s relevant, that you can use to help find and analyze examples later. For example, you could log the prompt, example’s id, or anything else that would be useful to slice/dice later. The values in metadata can be any JSON-serializable type, but its keys must be strings.
git_metadata_settings
GitMetadataSettings | None
(Optional) Settings for collecting git metadata. By default, will collect all git metadata fields allowed in org-level settings.
git_metadata_settings.collect
Literal['all', 'none', 'some']
required
git_metadata_settings.fields
NotRequired[Sequence[Literal['commit', 'branch', 'tag', 'dirty', 'author_name', 'author_email', 'commit_message', 'commit_time', 'git_diff']]]
set_current
bool
If true (the default), set the global current-experiment to the newly-created one.
update
bool | None
If the experiment already exists, continue logging to it. If it does not exist, creates the experiment with the specified arguments.
project_id
str | None
The id of the project to create the experiment in. This takes precedence over project if specified.
base_experiment_id
str | None
An optional experiment id to use as a base. If specified, the new experiment will be summarized and compared to this. This takes precedence over base_experiment if specified.
repo_info
RepoInfo | None
(Optional) Explicitly specify the git metadata for this experiment. This takes precedence over git_metadata_settings if specified.
repo_info.commit
NotRequired[str | None]
repo_info.branch
NotRequired[str | None]
repo_info.tag
NotRequired[str | None]
repo_info.dirty
NotRequired[bool | None]
repo_info.author_name
NotRequired[str | None]
repo_info.author_email
NotRequired[str | None]
repo_info.commit_message
NotRequired[str | None]
repo_info.commit_time
NotRequired[str | None]
repo_info.git_diff
NotRequired[str | None]
state
BraintrustState | None
(Optional) A BraintrustState object to use. If not specified, will use the global state. This is for advanced use only.

init_dataset

Create a new dataset in a specified project. If the project does not exist, it will be created.
project
str | None
name
str | None
The name of the dataset to create. If not specified, a name will be generated automatically.
description
str | None
An optional description of the dataset.
version
str | int | None
An optional version of the dataset (to read). If not specified, the latest version will be used.
app_url
str | None
The URL of the Braintrust App. Defaults to https://www.braintrust.dev.
api_key
str | None
The API key to use. If the parameter is not specified, will try to use the BRAINTRUST_API_KEY environment variable. If no API
org_name
str | None
(Optional) The name of a specific organization to connect to. This is useful if you belong to multiple.
project_id
str | None
The id of the project to create the dataset in. This takes precedence over project if specified.
metadata
Metadata | None
(Optional) a dictionary with additional data about the dataset. The values in metadata can be any JSON-serializable type, but its keys must be strings.
use_output
bool
(Deprecated) If True, records will be fetched from this dataset in the legacy format, with the “expected” field renamed to “output”. This option will be removed in a future version of Braintrust.
_internal_btql
dict[str, Any] | None
(Internal) If specified, the dataset will be created with the given BTQL filters.
state
BraintrustState | None
(Internal) The Braintrust state to use. If not specified, will use the global state. For advanced use only.

init_experiment

Alias for init
args
Any
kwargs
Any

init_function

Creates a function that can be used as either a task or scorer in the Eval framework. When used as a task, it will invoke the specified Braintrust function with the input. When used as a scorer, it will invoke the function with the scorer arguments.
project_name
str
The name of the project containing the function.
slug
str
The slug of the function to invoke.
version
str | None
Optional version of the function to use. Defaults to latest.

init_logger

Create a new logger in a specified project. If the project does not exist, it will be created.
project
str | None
The name of the project to log into. If unspecified, will default to the Global project.
project_id
str | None
The id of the project to log into. This takes precedence over project if specified.
async_flush
bool
If true (the default), log events will be batched and sent asynchronously in a background thread. If false, log events will be sent synchronously. Set to false in serverless environments.
app_url
str | None
The URL of the Braintrust API. Defaults to https://www.braintrust.dev.
api_key
str | None
The API key to use. If the parameter is not specified, will try to use the BRAINTRUST_API_KEY environment variable. If no API
org_name
str | None
(Optional) The name of a specific organization to connect to. This is useful if you belong to multiple.
force_login
bool
Login again, even if you have already logged in (by default, the logger will not login if you are already logged in)
set_current
bool
If true (the default), set the global current-experiment to the newly-created one.
state
BraintrustState | None

invoke

Invoke a Braintrust function, returning a BraintrustStream or the value as a plain Python object.
function_id
str | None
The ID of the function to invoke.
version
str | None
The version of the function to invoke.
prompt_session_id
str | None
The ID of the prompt session to invoke the function from.
prompt_session_function_id
str | None
The ID of the function in the prompt session to invoke.
project_name
str | None
The name of the project containing the function to invoke.
project_id
str | None
The ID of the project to use for execution context (API keys, project defaults, etc.).
slug
str | None
The slug of the function to invoke.
global_function
str | None
The name of the global function to invoke.
function_type
FunctionTypeEnum | None
The type of the global function to invoke. If unspecified, defaults to ‘scorer’
input
Any
The input to the function. This will be logged as the input field in the span.
messages
list[Any] | None
Additional OpenAI-style messages to add to the prompt (only works for llm functions).
metadata
dict[str, Any] | None
Additional metadata to add to the span. This will be logged as the metadata field in the span.
tags
list[str] | None
Tags to add to the span. This will be logged as the tags field in the span.
parent
Exportable | str | None
The parent of the function. This can be an existing span, logger, or experiment, or
stream
bool
Whether to stream the function’s output. If True, the function will return a
mode
ModeType | None
The response shape of the function if returning tool calls. If “auto”, will return
strict
bool | None
Whether to use strict mode for the function. If true, the function will throw an
org_name
str | None
The name of the Braintrust organization to use.
api_key
str | None
The API key to use for authentication.
app_url
str | None
The URL of the Braintrust application.
force_login
bool
Whether to force a new login even if already logged in.

load_prompt

Loads a prompt from the specified project.
project
str | None
The name of the project to load the prompt from. Must specify at least one of project or project_id.
slug
str | None
The slug of the prompt to load.
version
str | int | None
An optional version of the prompt (to read). If not specified, the latest version will be used.
project_id
str | None
The id of the project to load the prompt from. This takes precedence over project if specified.
id
str | None
The id of a specific prompt to load. If specified, this takes precedence over all other parameters (project, slug, version).
defaults
Mapping[str, Any] | None
(Optional) A dictionary of default values to use when rendering the prompt. Prompt values will override these defaults.
no_trace
bool
If true, do not include logging metadata for this prompt when build() is called.
environment
str | None
The environment to load the prompt from. Cannot be used together with version.
app_url
str | None
The URL of the Braintrust App. Defaults to https://www.braintrust.dev.
api_key
str | None
The API key to use. If the parameter is not specified, will try to use the BRAINTRUST_API_KEY environment variable. If no API
org_name
str | None
(Optional) The name of a specific organization to connect to. This is useful if you belong to multiple.

log

Log a single event to the current experiment. The event will be batched and uploaded behind the scenes.
event
Any

login

Log into Braintrust. This will prompt you for your API token, which you can find at https://www.braintrust.dev/app/token. This method is called automatically by init().
app_url
str | None
The URL of the Braintrust App. Defaults to https://www.braintrust.dev.
api_key
str | None
The API key to use. If the parameter is not specified, will try to use the BRAINTRUST_API_KEY environment variable. If no API
org_name
str | None
(Optional) The name of a specific organization to connect to. This is useful if you belong to multiple.
force_login
bool
Login again, even if you have already logged in (by default, this function will exit quickly if you have already logged in)

parent_context

Context manager to temporarily set the parent context for spans.
parent
str | None
The parent string to set during the context
state
BraintrustState | None
Optional BraintrustState to use. If not provided, uses the global state.

parse_stream

Parse a BraintrustStream into its final value.
stream
BraintrustStream
The BraintrustStream to parse.

patch_litellm

Patch LiteLLM to add Braintrust tracing. Format a permalink to the Braintrust application for viewing the span represented by the provided slug.
slug
str
The identifier generated from Span.export.
org_name
str | None
The org name to use. If not provided, the org name will be inferred from the global login state.
app_url
str | None
The app URL to use. If not provided, the app URL will be inferred from the global login state.

prettify_params

Clean up parameters by filtering out NOT_GIVEN values and serializing response_format.
params
dict[str, Any]

serialize_response_format

Serialize response format for logging.
response_format
Any

set_http_adapter

Specify a custom HTTP adapter to use for all network requests. This is useful for setting custom retry policies, timeouts, etc. Braintrust uses the requests library, so the adapter should be an instance of requests.adapters.HTTPAdapter. Alternatively, consider sub-classing our RetryRequestExceptionsAdapter to get automatic retries on network-related exceptions.
adapter
HTTPAdapter
The adapter to use.

set_masking_function

Set a global masking function that will be applied to all logged data before sending to Braintrust. The masking function will be applied after records are merged but before they are sent to the backend.
masking_function
Callable[[Any], Any] | None
A function that takes a JSON-serializable object and returns a masked version.

set_thread_pool_max_workers

Set the maximum number of threads to use for running evaluators. By default, this is the number of CPUs on the machine.
max_workers
Any

span_components_to_object_id

Utility function to resolve the object ID of a SpanComponentsV4 object. This function may trigger a login to braintrust if the object ID is encoded lazily.
components
SpanComponentsV4

start_span

Lower-level alternative to @traced for starting a span at the toplevel. It creates a span under the first active object (using the same precedence order as @traced), or if parent is specified, under the specified parent row, or returns a no-op span object.
name
str | None
type
SpanTypeAttribute | None
span_attributes
SpanAttributes | Mapping[str, Any] | None
span_attributes.name
NotRequired[str | None]
span_attributes.type
NotRequired[SpanType | None]
start_time
float | None
set_current
bool | None
parent
str | None
propagated_event
dict[str, Any] | None
state
BraintrustState | None
event
Any

summarize

Summarize the current experiment, including the scores (compared to the closest reference experiment) and metadata.
summarize_scores
bool
Whether to summarize the scores. If False, only the metadata will be returned.
comparison_experiment_id
str | None
The experiment to compare against. If None, the most recent experiment on the comparison_commit will be used.

traced

Decorator to trace the wrapped function when used without parentheses.
f
F

unpatch_litellm

Restore LiteLLM to its original state, removing Braintrust tracing.

update_span

Update a span using the output of span.export(). It is important that you only resume updating to a span once the original span has been fully written and flushed, since otherwise updates to the span may conflict with the original span.
exported
str
The output of span.export().
event
Any

wrap_anthropic

Wrap an Anthropic object (or AsyncAnthropic) to add tracing. If Braintrust is not configured, this is a no-op. If this is not an Anthropic object, this function is a no-op.
client
Any

wrap_litellm

Wrap the litellm module to add tracing. If Braintrust is not configured, nothing will be traced.
litellm_module
Any
The litellm module

wrap_openai

Wrap the openai module (pre v1) or OpenAI instance (post v1) to add tracing. If Braintrust is not configured, nothing will be traced. If this is not an OpenAI object, this function is a no-op.
openai
Any
The openai module or OpenAI object

Classes

AsyncResponseWrapper

Wrapper that properly preserves async context manager behavior for OpenAI responses. Methods __init__()

AsyncScorerLike

Protocol for asynchronous scorers that implement the eval_async interface. The framework will prefer this interface if available.

Attachment

Represents an attachment to be uploaded and the associated metadata. Methods __init__(), reference(), data(), upload(), debug_info()

BaseExperiment

Use this to specify that the dataset should actually be the data from a previous (base) experiment. If you do not specify a name, Braintrust will automatically figure out the best base experiment to use based on your git history (or fall back to timestamps). Properties
name
str | None

BraintrustConsoleChunk

A console chunk from a Braintrust stream. Properties
message
str
stream
Literal['stderr', 'stdout']
type
Literal['console']

BraintrustErrorChunk

An error chunk from a Braintrust stream. Properties
data
str
type
Literal['error']

BraintrustInvokeError

An error that occurs during a Braintrust stream.

BraintrustJsonChunk

A chunk of JSON data from a Braintrust stream. Properties
data
str
type
Literal['json_delta']

BraintrustProgressChunk

A progress chunk from a Braintrust stream. Properties
data
str
id
str
object_type
str
format
str
output_type
str
name
str
event
Literal['json_delta', 'text_delta', 'reasoning_delta']
type
Literal['progress']

BraintrustStream

A Braintrust stream. This is a wrapper around a generator of BraintrustStreamChunk, with utility methods to make them easy to log and convert into various formats. Methods __init__(), copy(), final_value()

BraintrustTextChunk

A chunk of text data from a Braintrust stream. Properties
data
str
type
Literal['text_delta']

CodeFunction

A generic callable, with metadata. Properties
project
'Project'
handler
Callable[..., Any]
name
str
slug
str
type_
str
description
str | None
parameters
Any
returns
Any
if_exists
IfExists | None
metadata
dict[str, Any] | None

CodePrompt

A prompt defined in code, with metadata. Properties
project
'Project'
name
str
slug
str
prompt
PromptData
tool_functions
list[CodeFunction | SavedFunctionId]
description
str | None
function_type
str | None
id
str | None
if_exists
IfExists | None
metadata
dict[str, Any] | None
Methods to_function_definition()

CompletionWrapper

Wrapper for LiteLLM completion functions with tracing support. Methods __init__(), completion()

DataSummary

Summary of a dataset’s data. Properties
new_records
int
total_records
int

Dataset

A dataset is a collection of records, such as model inputs and outputs, which represent data you can use to evaluate and fine-tune models. You can log production data to datasets, curate them with interesting examples, edit/delete records, and run evaluations against them. Methods __init__(), id(), name(), data(), project(), logging_state(), insert(), update(), delete(), summarize(), close(), flush()

DatasetSummary

Summary of a dataset’s scores and metadata. Properties
project_name
str
dataset_name
str
project_url
str
dataset_url
str
data_summary
DataSummary | None

EmbeddingWrapper

Wrapper for LiteLLM embedding functions. Methods __init__(), embedding()

EvalCase

An evaluation case. This is a single input to the evaluation task, along with an optional expected output, metadata, and tags. Properties
input
Input
expected
Output | None
metadata
Metadata | None
tags
Sequence[str] | None
id
str | None
created
str | None

EvalHooks

An object that can be used to add metadata to an evaluation. This is passed to the task function. Methods metadata(), expected(), span(), trial_index(), tags(), report_progress(), meta(), parameters()

EvalResult

The result of an evaluation. This includes the input, expected output, actual output, and metadata. Properties
input
Input
output
Output
scores
dict[str, float | None]
expected
Output | None
metadata
Metadata | None
tags
list[str] | None
error
Exception | None
exc_info
str | None

EvalScorerArgs

Arguments passed to an evaluator scorer. This includes the input, expected output, actual output, and metadata. Properties
input
Input
output
Output
expected
Output | None
metadata
Metadata | None

Evaluator

An evaluator is an abstraction that defines an evaluation dataset, a task to run on the dataset, and a set of scorers to evaluate the results of the task. Each method attribute can be synchronous or asynchronous (for optimal performance, it is recommended to provide asynchronous implementations). Properties
project_name
str
eval_name
str
data
EvalData[Input, Output]
task
EvalTask[Input, Output]
scores
list[EvalScorer[Input, Output]]
experiment_name
str | None
metadata
Metadata | None
trial_count
int
is_public
bool
update
bool
timeout
float | None
max_concurrency
int | None
project_id
str | None
base_experiment_name
str | None
base_experiment_id
str | None
git_metadata_settings
GitMetadataSettings | None
repo_info
RepoInfo | None
error_score_handler
ErrorScoreHandler | None
description
str | None
summarize_scores
bool
parameters
EvalParameters | None

Experiment

An experiment is a collection of logged events, such as model inputs and outputs, which represent a snapshot of your application at a particular point in time. An experiment is meant to capture more than just the model you use, and includes the data you use to test, pre- and post- processing code, comparison metrics (scores), and any other metadata you want to include. Methods __init__(), id(), name(), data(), project(), logging_state(), log(), log_feedback(), start_span(), update_span(), fetch_base_experiment(), summarize(), export(), close(), flush()

ExperimentSummary

Summary of an experiment’s scores and metadata. Properties
project_name
str
project_id
str | None
experiment_id
str | None
experiment_name
str
project_url
str | None
experiment_url
str | None
comparison_experiment_name
str | None
scores
dict[str, ScoreSummary]
metrics
dict[str, MetricSummary]

ExternalAttachment

Represents an attachment that resides in an external object store and the associated metadata. Methods __init__(), reference(), data(), upload(), debug_info()

JSONAttachment

A convenience class for creating attachments from JSON-serializable objects. Methods __init__()

LiteLLMWrapper

Main wrapper for the LiteLLM module. Methods __init__(), completion(), responses(), embedding(), moderation()

MetricSummary

Summary of a metric’s performance. Properties
name
str
metric
float | int
unit
str
improvements
int | None
regressions
int | None
diff
float | None

ModerationWrapper

Wrapper for LiteLLM moderation functions. Methods __init__(), moderation()

NamedWrapper

Wrapper that preserves access to the original wrapped object’s attributes. Methods __init__()

Project

A handle to a Braintrust project. Methods __init__(), add_code_function(), add_prompt(), publish()

ProjectBuilder

Creates handles to Braintrust projects. Methods create()

Prompt

A prompt object consists of prompt text, a model, and model parameters (such as temperature), which can be used to generate completions or chat messages. The prompt object supports calling .build() which uses mustache templating to build the prompt with the given formatting options and returns a plain dictionary that includes the built prompt and arguments. The dictionary can be passed as kwargs to the OpenAI client or modified as you see fit. Methods __init__(), from_prompt_data(), id(), name(), slug(), prompt(), version(), options(), build()

PromptBuilder

Builder to create a prompt in Braintrust. Methods __init__(), create(), create(), create()

ReadonlyAttachment

A readonly alternative to Attachment, which can be used for fetching already-uploaded Attachments. Methods __init__(), data(), metadata(), status()

ReadonlyExperiment

A read-only view of an experiment, initialized by passing open=True to init(). Methods __init__(), id(), logging_state(), as_dataset()

RepoInfo

Information about the current HEAD of the repo. Properties
commit
str | None
branch
str | None
tag
str | None
dirty
bool | None
author_name
str | None
author_email
str | None
commit_message
str | None
commit_time
str | None
git_diff
str | None

ReporterDef

A reporter takes an evaluator and its result and returns a report. Properties
name
str
report_eval
Callable[[Evaluator[Input, Output], EvalResultWithSummary[Input, Output], bool, bool], EvalReport | Awaitable[EvalReport]]
report_run
Callable[[list[EvalReport], bool, bool], bool | Awaitable[bool]]

ResponsesWrapper

Wrapper for LiteLLM responses functions with tracing support. Methods __init__(), responses()

RetryRequestExceptionsAdapter

An HTTP adapter that automatically retries requests on connection exceptions. Methods __init__(), send()

SSEProgressEvent

A progress event that can be reported during task execution, specifically for SSE (Server-Sent Events) streams. This is a subclass of TaskProgressEvent with additional fields for SSE-specific metadata. Properties
id
str
object_type
str
origin
ObjectReference
name
str

ScoreSummary

Summary of a score’s performance. Properties
name
str
score
float
improvements
int | None
regressions
int | None
diff
float | None

ScorerBuilder

Builder to create a scorer in Braintrust. Methods __init__(), create(), create(), create(), create()

Span

A Span encapsulates logged data and metrics for a unit of work. This interface is shared by all span implementations. Methods id(), log(), log_feedback(), start_span(), export(), link(), permalink(), end(), flush(), close(), set_attributes(), set_current(), unset_current()

SpanIds

The three IDs that define a span’s position in the trace tree. Properties
span_id
str
root_span_id
str
span_parents
list[str] | None

SpanImpl

Primary implementation of the Span interface. See the Span interface for full details on each method. Properties
can_set_current
bool
Methods __init__(), id(), set_attributes(), log(), log_internal(), log_feedback(), start_span(), end(), export(), link(), permalink(), close(), flush(), set_current(), unset_current()

SpanScope

Scope for operating on a single span. Properties
type
Literal['span']
id
str
root_span_id
str

SyncScorerLike

Protocol for synchronous scorers that implement the callable interface. This is the most common interface and is used when no async version is available. Methods __call__()

TaskProgressEvent

Progress event that can be reported during task execution. Properties
format
FunctionFormat
output_type
FunctionOutputType
event
Literal['reasoning_delta', 'text_delta', 'json_delta', 'error', 'console', 'start', 'done', 'progress']
data
str

ToolBuilder

Builder to create a tool in Braintrust. Methods __init__(), create()

TraceScope

Scope for operating on an entire trace. Properties
type
Literal['trace']
root_span_id
str

TracedMessageStream

TracedMessageStream wraps both sync and async message streams. Obviously only one makes sense at a time Methods __init__()