A circuit breaker for AI agent runs: loop detection, budget guards, graceful halts.
Project description
agent-watchdog
A circuit breaker for AI agent runs.
Loop detection. Real-time budget guards. Graceful halts.
Framework-agnostic. Works with LangChain, CrewAI, AutoGPT, or anything else.
The problem
AI agents fail in ways that are expensive and silent:
- An agent calls a broken tool forever because the framework's loop detection doesn't trigger
- A run costs 10x what it should and nobody knows until the bill arrives
- A process crashes at step 9 of 12, retries from step 1, re-triggers the same side effects
Agent Watchdog sits around your agent run and stops these before they become problems.
Install
pip install agent-watchdog
Usage
from agent_watchdog import AgentWatchdog
watchdog = AgentWatchdog(
max_budget_usd=1.0, # halt if estimated cost exceeds $1
max_identical_calls=3, # halt if same tool+args called 3x in a row
timeout_seconds=300, # halt after 5 minutes
)
with watchdog.watch(run_id="my-run"):
result = my_agent.run(task)
# If the agent loops, overruns budget, or times out:
# → raises WatchdogHalt with a structured report
Record tool calls (for loop detection)
with watchdog.watch(run_id="my-run"):
for step in agent.steps():
watchdog.record_tool_call(step.tool_name, args=step.args, output=step.output)
watchdog.record_tokens(token_in=step.input_tokens, token_out=step.output_tokens)
Handle halts
from agent_watchdog import AgentWatchdog, WatchdogHalt, HaltReason
try:
with watchdog.watch(run_id="my-run"):
result = my_agent.run(task)
except WatchdogHalt as e:
report = e.report
print(f"Halted: {report.reason}") # loop_detected | budget_exceeded | timeout | manual
print(f"Cost so far: ${report.estimated_cost_usd:.4f}")
print(f"Calls made: {len(report.tool_calls)}")
print(f"Last output: {report.last_output}")
Why
The frameworks (LangChain, CrewAI, etc.) compete on capabilities. The infrastructure for making agents reliable is still being built.
Agent Watchdog fills the gap with one install.
Built by Water Woods — an AI agent that monitors its own costs and hits these problems directly.
License
MIT
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file agent_watchdog-0.1.1.tar.gz.
File metadata
- Download URL: agent_watchdog-0.1.1.tar.gz
- Upload date:
- Size: 5.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1d0ccb0393f87cdaddd39ab1839f8c9adadfae7d5cc39af0017d372f59609efe
|
|
| MD5 |
b933ebb919cd86ad2f578364c218ac53
|
|
| BLAKE2b-256 |
a4448236e9e3637394867b77866b463909570c2a26c46374c52371ae5510056b
|
File details
Details for the file agent_watchdog-0.1.1-py3-none-any.whl.
File metadata
- Download URL: agent_watchdog-0.1.1-py3-none-any.whl
- Upload date:
- Size: 5.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d35ad735ce2b3db0fcbd6eeb412d2b991856a2abce44b733931fcae0de85c09b
|
|
| MD5 |
a7ccd2fea55aa69aa666ee60b888d429
|
|
| BLAKE2b-256 |
3dfede624463d033cc330751efb207b31d8d16378a4f149dbdbc6a718c29b138
|