mirror of
https://github.com/aljazceru/goose.git
synced 2025-12-17 22:24:21 +01:00
Co-authored-by: Michael Neale <michael.neale@gmail.com> Co-authored-by: Wendy Tang <wendytang@squareup.com> Co-authored-by: Jarrod Sibbison <72240382+jsibbison-square@users.noreply.github.com> Co-authored-by: Alex Hancock <alex.hancock@example.com> Co-authored-by: Alex Hancock <alexhancock@block.xyz> Co-authored-by: Lifei Zhou <lifei@squareup.com> Co-authored-by: Wes <141185334+wesrblock@users.noreply.github.com> Co-authored-by: Max Novich <maksymstepanenko1990@gmail.com> Co-authored-by: Zaki Ali <zaki@squareup.com> Co-authored-by: Salman Mohammed <smohammed@squareup.com> Co-authored-by: Kalvin C <kalvinnchau@users.noreply.github.com> Co-authored-by: Alec Thomas <alec@swapoff.org> Co-authored-by: lily-de <119957291+lily-de@users.noreply.github.com> Co-authored-by: kalvinnchau <kalvin@block.xyz> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> Co-authored-by: Rizel Scarlett <rizel@squareup.com> Co-authored-by: bwrage <bwrage@squareup.com> Co-authored-by: Kalvin Chau <kalvin@squareup.com> Co-authored-by: Alice Hau <110418948+ahau-square@users.noreply.github.com> Co-authored-by: Alistair Gray <ajgray@stripe.com> Co-authored-by: Nahiyan Khan <nahiyan.khan@gmail.com> Co-authored-by: Alex Hancock <alexhancock@squareup.com> Co-authored-by: Nahiyan Khan <nahiyan@squareup.com> Co-authored-by: marcelle <1852848+laanak08@users.noreply.github.com> Co-authored-by: Yingjie He <yingjiehe@block.xyz> Co-authored-by: Yingjie He <yingjiehe@squareup.com> Co-authored-by: Lily Delalande <ldelalande@block.xyz> Co-authored-by: Adewale Abati <acekyd01@gmail.com> Co-authored-by: Ebony Louis <ebony774@gmail.com> Co-authored-by: Angie Jones <jones.angie@gmail.com> Co-authored-by: Ebony Louis <55366651+EbonyLouis@users.noreply.github.com>
35 lines
1.8 KiB
Markdown
35 lines
1.8 KiB
Markdown
---
|
|
title: Error Handling
|
|
---
|
|
# Error Handling in Goose
|
|
|
|
Error handling is a key performance-driving part of Goose. There are many ways that the non-determinism
|
|
in the LLM can introduce an error that it can in turn recover from. In a typical Goose session, it's expected for there
|
|
to be several agent errors that the model can see directly and correct, perhaps entirely behind the scenes.
|
|
|
|
## Traditional Errors
|
|
|
|
While the agent is operating, there can be intermittent issues in the network, availability of the
|
|
foundational model, etc. These are raised as errors in the agent API to the caller, who can decide
|
|
how to handle that. We generally handle these with [anyhow::Error][anyhow-error].
|
|
|
|
## Agent Errors
|
|
|
|
There are several types of errors where everything is working correctly, but the model generations
|
|
themselves are somehow causing errors. Things like generating an unknown tool name, incorrect parameters,
|
|
or a well formed tool call that results in an error in the tool itself. All of these can be surfaced to
|
|
the LLM to have it attempt to recover.
|
|
|
|
The error messages are in some ways prompting - they give instructions to the LLM on how it might go
|
|
about recovering. We handle these with [thiserror::Error][this-error] and carefully maintain a collection.
|
|
|
|
To cover all these cases, both `ToolUse` and `ToolResult` are typically passed through the API as part of a
|
|
`Result<T, AgentError>`. An error in a `ToolUse` will immediately become an error in a `ToolResult` and
|
|
passed back to the LLM. A valid `ToolUse` might still end up in an error `ToolResult`, which is also passed
|
|
back to the LLM.
|
|
|
|
The providers then handle translating the agent errors into the various API specs as valid messages.
|
|
|
|
|
|
[anyhow-error]: https://docs.rs/anyhow/latest/anyhow/
|
|
[this-error]: https://docs.rs/thiserror/latest/thiserror/ |