Tracing
Tracing records what your application does as spans you can inspect in Braintrust. The recommended way to capture AI calls is auto-instrumentation: use thetrace/contrib packages to instrument supported provider libraries, either at build time with Orchestrion or with runtime middleware (see Go SDK integrations). Tracing is built on OpenTelemetry, so you trace your own code with the standard OpenTelemetry API. The APIs below create the client, trace your own code, and link to your traces.
braintrust.New
Creates a Braintrust client and configures the OpenTelemetry pipeline that exports spans to Braintrust. Call it once on startup, passing your TracerProvider and any options.
#skip-compile
(*braintrust.Client, error).
braintrust.New reads BRAINTRUST_API_KEY from the environment. Configure the rest with functional options or environment variables (see Configuration).
Because tracing is built on OpenTelemetry, you trace your own application code with the standard OpenTelemetry API, and traced AI calls nest under your spans.
#skip-compile
Client.Permalink
Builds a Braintrust UI URL for a span, so you can link straight to a trace from your own logs or app.
#skip-compile
string.
Evaluations
An evaluation runs your task over a set of cases, scores each output, and logs the results to an experiment, which is how you measure quality and catch regressions as you change prompts or models. Create an evaluator withbraintrust.NewEvaluator, then call Run.
braintrust.NewEvaluator
Creates an evaluator for input type I and result type R, bound to a client. Call Run on it with the cases, task, and scorers to execute the evaluation and log an experiment.
#skip-compile
*eval.Evaluator[I, R]. Run returns (*eval.Result, error).
eval.Opts[I, R] fields:
Experiment(string, required): experiment name.Dataset(eval.Dataset[I, R], required): the cases to run. Build an in-memory one witheval.NewDataset(see Datasets).Task(eval.TaskFunc[I, R], required): the function under test. Wrap a plainfunc(ctx, input) (output, error)witheval.T.Scorers([]eval.Scorer[I, R]): scorers to apply to each case. ProvideScorers,Classifiers, or both.Classifiers([]eval.Classifier[I, R]): classifiers to apply to each case. ProvideScorers,Classifiers, or both.ProjectName(string): project to log to. Defaults to the client’s configured project.Tags([]string): tags to apply to the experiment.Metadata(eval.Metadata): metadata to attach to the experiment.Update(bool): append to an existing experiment with the same name. Defaults tofalse.Parallelism(int): number of goroutines. Defaults to1.TrialCount(int): number of times to run each case. Defaults to1.Quiet(bool): suppress result output. Defaults tofalse.
eval.NewScorer
Creates a scorer from a function. A scorer measures how good the task’s output is, returning one or more named scores per case.
#skip-compile
eval.Scorer[I, R]. The score function receives an eval.TaskResult[I, R] (with Input, Output, Expected, and Metadata) and returns eval.Scores. Use eval.S to build a single score.
eval.NewClassifier
Creates a classifier from a function. Use a classifier to categorize output instead of scoring it numerically.
#skip-compile
eval.Classifier[I, R].
Datasets
A dataset is the set of cases an evaluation runs against. Define cases inline in memory, or manage datasets in Braintrust through the API client.eval.NewDataset
Groups cases into an in-memory dataset you pass to Evaluator.Run, as an alternative to loading one from Braintrust.
#skip-compile
eval.Dataset[I, R].
Each eval.Case[I, R] has an Input and optional Expected, Tags, Metadata, and TrialCount.
Attachments
When your traces involve binary content like images or PDFs, log it as an attachment so it appears in Braintrust instead of as an opaque blob. When you trace AI calls, Braintrust automatically converts base64 attachments in provider messages into uploaded attachments, so you rarely need the APIs below for instrumented calls. Reach for them when you’re attaching binary content to a span yourself.attachment.From*
Creates an attachment from bytes, a file, or a URL.
#skip-compile
attachment.FromBytes(contentType string, data []byte)→*attachment.Attachment: from raw bytes.attachment.FromFile(contentType string, path string)→(*attachment.Attachment, error): reads a file.attachment.FromURL(url string)→(*attachment.Attachment, error): fetches a URL and uses the response content type.attachment.FromReader(contentType string, r io.Reader)→*attachment.Attachment: from anio.Reader.
API client
For direct access to the Braintrust REST API, use theapi package. Reach for it to manage projects, experiments, datasets, and functions programmatically, beyond what the higher-level APIs above cover.
api.NewClient
Creates a REST API client from an API key.
#skip-compile
*api.API.
Namespaces:
client.Projects(): project management.client.Experiments(): experiment management.client.Datasets(): dataset management. Methods includeCreate,Insert,InsertEvents,Delete,Fetch, andQuery.client.Functions(): function management, includingInvoke(ctx, functionID, input)to call a deployed function.
Configuration
Configure the client with functional options passed tobraintrust.New, or with environment variables.
#skip-compile
braintrust.WithAPIKey(apiKey string): API key. Defaults toBRAINTRUST_API_KEY.braintrust.WithAPIURL(apiURL string): Braintrust API URL.braintrust.WithAppURL(appURL string): Braintrust app URL, used for permalinks.braintrust.WithOrgName(orgName string): organization name, useful when credentials can access multiple orgs.braintrust.WithProject(projectName string): project that receives exported spans.braintrust.WithProjectID(projectID string): project ID. Takes precedence over the project name.braintrust.WithBlockingLogin(enabled bool): log in synchronously duringNewinstead of in the background.braintrust.WithExporter(exporter trace.SpanExporter): supply a custom span exporter. Intended for testing.braintrust.WithEnableTraceConsoleLog(enabled bool): print spans to the console.braintrust.WithFilterAISpans(enabled bool): export only AI-related spans.
Environment variables
BRAINTRUST_API_KEY(required): Braintrust API key.BRAINTRUST_API_URL: Braintrust API URL. Defaults tohttps://api.braintrust.dev.BRAINTRUST_APP_URL: Braintrust app URL, used for permalinks. Defaults tohttps://www.braintrust.dev.BRAINTRUST_DEFAULT_PROJECT: project that traced spans route to. Defaults todefault-go-project.BRAINTRUST_DEFAULT_PROJECT_ID: project UUID. Takes precedence over the project name.BRAINTRUST_ORG_NAME: organization name, useful when credentials can access multiple orgs.BRAINTRUST_OTEL_FILTER_AI_SPANS: set totrueto export only AI-related spans.BRAINTRUST_ENABLE_TRACE_CONSOLE_LOG: set totrueto print spans to the console.BRAINTRUST_BLOCKING_LOGIN: set totrueto log in synchronously at startup.