User Journeys

Journeys are re-runnable prompts. Instead of creating a new agent from scratch every time, you define a journey once and run it repeatedly. Each run creates a new agent linked back to the journey, giving you a history of results for the same test over time.

Overview

A journey is an abstraction on top of the agent API. Where creating an agent is a one-off operation (one prompt, one run, one result), a journey lets you define a prompt once and run it as many times as you want. Each run creates a new agent that is linked back to the journey, so you build up a history of results for the same test over time.

This is the core mechanism for tracking the health of your application. If you have a journey called "checkout flow" and you run it after every deploy, you get a timeline of pass/fail results that tells you exactly when something broke and when it was fixed. The project health board aggregates this across all journeys in a project.

When you run a journey, the system resolves the persona and role (cascading from the run parameters, to the journey defaults, to the project defaults), renders the prompt, creates an agent, and queues it for execution.

Checkpoints

Checkpoints are a JSON array of named milestones that you expect the agent to reach during execution. Each checkpoint has a name and a description.

[ {"name": "login", "description": "Agent logged in successfully"}, {"name": "add_to_cart", "description": "Added item to cart"}, {"name": "checkout", "description": "Completed the checkout flow"} ]

Checkpoints are not evaluated during execution. The agent runs its agentic loop normally without any awareness of the checkpoints. After the agent completes, the full conversation trace is analyzed and each checkpoint is evaluated based on the evidence in the conversation. The result is a list of checkpoints that were hit and a list that were missed.

This design means checkpoints are purely observational. They do not alter the agent's behavior or cause early termination. They give you structured visibility into how far through a multi-step flow the agent got, which is especially useful when a journey fails partway through.

Success determination

Whether a journey run succeeded or failed is determined by a two-step process. First, the agent itself reports its own assessment when it finishes (success or failure with a summary). Second, a server-side verification step independently analyzes the full conversation trace and produces its own verdict.

If the agent and the server-side verification disagree, the server-side verdict wins. This means an agent cannot incorrectly report success if the evidence in the conversation shows otherwise, and vice versa. The final outcome is what you see in the API response and on the health board.

Persona and role resolution

When a journey is run, the persona and role are resolved using a cascading fallback. The system first checks if a persona or role was specified in the run parameters. If not, it falls back to the defaults set on the journey itself. If the journey has no defaults, it uses the project-level defaults.

This lets you set sensible defaults on the journey or project and override them on individual runs when needed. For example, you might have a journey that normally runs with a "Functional QA" role but occasionally run it with a "Power User" role to test a different interaction style.

POST /api/v1/journeys

Create a new user journey

Parameters

ParameterTypeInRequiredDescription
project_iduuidbodyYesID of the project this user journey belongs to
namestringbodyYesUser journey name
descriptionstringbodyNoUser journey description
prompt_templatestringbodyYesGo text/template prompt with {{.Variables}}
entry_urlstringbodyNoStarting URL for the user journey
checkpointsjsonbodyNoCheckpoint definitions for progress tracking
success_criteriajsonbodyNoCriteria to determine user journey success
sourcestringbodyNoOrigin of the user journey (e.g. 'discovery', 'manual')
importancestringbodyNoUser journey importance level (e.g. 'critical', 'high', 'medium', 'low')
file_pathsstring[]bodyNoPaths of tenant files to copy into the test run workspace when running this user journey

Status Codes

CodeDescription
201Journey created
400Validation error
401Unauthorized

Response Body

{
  "id": "770e8400-e29b-41d4-a716-446655440000",
  "tenant_id": "550e8400-e29b-41d4-a716-446655440000",
  "project_id": "660e8400-e29b-41d4-a716-446655440000",
  "name": "Checkout Flow",
  "description": "",
  "prompt_template": "Navigate to {{.EntryURL}} and complete checkout",
  "entry_url": "https://example.com",
  "checkpoints": [],
  "success_criteria": null,
  "file_paths": [],
  "created_at": "2025-01-15T10:30:00Z",
  "updated_at": "2025-01-15T10:30:00Z"
}
POST /api/v1/journeys
cURL
Response
GET /api/v1/journeys

List user journeys

Parameters

ParameterTypeInRequiredDescription
limitintegerqueryNoNumber of results to return (default: 20)
cursoruuidqueryNoCursor for pagination
project_iduuidqueryNoFilter by project ID (alias: project)

Status Codes

CodeDescription
200OK
401Unauthorized

Response Body

{
  "journeys": [
    {
      "id": "770e8400-e29b-41d4-a716-446655440000",
      "tenant_id": "550e8400-e29b-41d4-a716-446655440000",
      "project_id": "660e8400-e29b-41d4-a716-446655440000",
      "name": "Checkout Flow",
      "description": "",
      "prompt_template": "Navigate to {{.EntryURL}} and complete checkout",
      "entry_url": "https://example.com",
      "checkpoints": [],
      "success_criteria": null,
      "file_paths": [],
      "created_at": "2025-01-15T10:30:00Z",
      "updated_at": "2025-01-15T10:30:00Z"
    }
  ],
  "next_cursor": "880e8400-e29b-41d4-a716-446655440000"
}
GET /api/v1/journeys
cURL
Response
GET /api/v1/journeys/{id}

Get user journey by ID

Parameters

ParameterTypeInRequiredDescription
iduuidpathYesUser journey ID

Status Codes

CodeDescription
200OK
400Invalid UUID
401Unauthorized
404Journey not found

Response Body

{
  "id": "770e8400-e29b-41d4-a716-446655440000",
  "tenant_id": "550e8400-e29b-41d4-a716-446655440000",
  "project_id": "660e8400-e29b-41d4-a716-446655440000",
  "name": "Checkout Flow",
  "description": "",
  "prompt_template": "Navigate to {{.EntryURL}} and complete checkout",
  "entry_url": "https://example.com",
  "checkpoints": [],
  "success_criteria": null,
  "file_paths": [],
  "created_at": "2025-01-15T10:30:00Z",
  "updated_at": "2025-01-15T10:30:00Z"
}
GET /api/v1/journeys/{id}
cURL
Response
PATCH /api/v1/journeys/{id}

Update a user journey

Parameters

ParameterTypeInRequiredDescription
iduuidpathYesUser journey ID
namestringbodyNoUser journey name
descriptionstringbodyNoUser journey description
prompt_templatestringbodyNoGo text/template prompt
entry_urlstringbodyNoStarting URL
checkpointsjsonbodyNoCheckpoint definitions
success_criteriajsonbodyNoSuccess criteria
sourcestringbodyNoOrigin of the user journey
importancestringbodyNoUser journey importance level
file_pathsstring[]bodyNoPaths of tenant files to copy into the test run workspace when running this user journey

Status Codes

CodeDescription
200Journey updated
400Validation error
401Unauthorized
404Journey not found

Response Body

{
  "id": "770e8400-e29b-41d4-a716-446655440000",
  "tenant_id": "550e8400-e29b-41d4-a716-446655440000",
  "project_id": "660e8400-e29b-41d4-a716-446655440000",
  "name": "Checkout Flow",
  "description": "",
  "prompt_template": "Navigate to {{.EntryURL}} and complete checkout",
  "entry_url": "https://example.com",
  "checkpoints": [],
  "success_criteria": null,
  "file_paths": [],
  "created_at": "2025-01-15T10:30:00Z",
  "updated_at": "2025-01-15T10:30:00Z"
}
PATCH /api/v1/journeys/{id}
cURL
Response
DELETE /api/v1/journeys/{id}

Delete a user journey

Parameters

ParameterTypeInRequiredDescription
iduuidpathYesUser journey ID

Status Codes

CodeDescription
204Journey deleted
400Invalid UUID
401Unauthorized
404Journey not found
DELETE /api/v1/journeys/{id}
cURL
Response
POST /api/v1/journeys/{id}/run

Run a user journey

Creates a new test run from the user journey template, rendering the prompt with the supplied variables. Files attached to the user journey are automatically copied into the test run workspace.

Parameters

ParameterTypeInRequiredDescription
iduuidpathYesUser journey ID
persona_iduuidbodyNoPersona for browser session (cookies, credentials, email)
role_iduuidbodyNoRole for prompt injection context
variablesobjectbodyNoTemplate variables to inject into prompt_template
modelstringbodyNoLLM model override for this run
max_iterationsintegerbodyNoMax iterations override for this run
browser_typestringbodyNoBrowser to use (default: chrome)
record_videobooleanbodyNoSave recordings for all runs. When false (default), only failed runs are saved. (default: false)

Status Codes

CodeDescription
201Agent created from journey
400Validation error or template rendering failed
401Unauthorized
404Journey not found

Response Body

{
  "id": "550e8400-e29b-41d4-a716-446655440000",
  "tenant_id": "660e8400-e29b-41d4-a716-446655440000",
  "project_id": "770e8400-e29b-41d4-a716-446655440000",
  "persona_id": "880e8400-e29b-41d4-a716-446655440000",
  "status": "pending",
  "prompt": "Navigate to https://example.com and complete checkout",
  "model": "gemini-2.5-flash",
  "browser_type": "chrome",
  "record_video": false,
  "agent_type": "direct",
  "messages": [],
  "iteration": 0,
  "max_iterations": 115,
  "tokens_used": 0,
  "journey_id": "990e8400-e29b-41d4-a716-446655440000",
  "source": "api",
  "created_at": "2025-01-15T10:30:00Z",
  "updated_at": "2025-01-15T10:30:00Z"
}
POST /api/v1/journeys/{id}/run
cURL
Response