Troubleshooting
Common AXP CLI failures and the current documented fixes.
This page covers failures that the current CLI can produce. For command syntax, compare against axp --help and the command-specific --help output.
axp: command not found after install
The installer writes the wrapper to ~/.fiveonefour/bin/axp by default. If that
directory is not already on PATH, the installer prints the export to add and,
for writable zsh or bash config directories, appends an installer-managed entry.
Open a new shell, reload your shell config, or add the path manually:
export PATH="$HOME/.fiveonefour/bin:$PATH"
axp --helpIf you installed with FIVEONEFOUR_HOME=<path>, use <path>/bin instead.
Install download fails
The installer requires curl and downloads the version manifest, binary,
checksum, and optional signature from https://download.514.ai with curl -fsSL.
If the manifest download fails, the script prints the failed manifest URL and
the underlying curl error.
Check that curl is installed and that your network, proxy, or firewall can
reach the download host:
curl -fsSL https://download.514.ai/stable/index.json >/dev/nullThen rerun the installer. If the binary or checksum download fails after the manifest succeeds, retry the install and keep the printed download URL for debugging.
Unsupported OS or architecture
The installer has prebuilt targets for:
- macOS arm64 and x86_64
- Linux arm64/aarch64 and x86_64/amd64
On any other uname -s and uname -m pair, it exits with unsupported platform: <os>/<arch>. Use one of the supported platforms for the hosted
installer.
Uninstall leaves a PATH entry
By default, uninstall removes the AXP wrapper and cached versions but leaves
shell startup files untouched. To remove exact installer-managed PATH entries
from ~/.zshrc, ~/.bashrc, ~/.bash_profile, and ~/.profile, pass
--remove-path:
bash <(curl -fsSL https://download.514.ai/uninstall.sh) --yes --remove-pathThe script only removes lines that exactly match the installer-managed
~/.fiveonefour/bin export, plus the adjacent # AXP CLI comment when present.
Remove custom PATH edits manually.
Uninstall skips the axp binary
The uninstall script only removes ~/.fiveonefour/bin/axp automatically when it
looks like the hosted installer wrapper. If that file is a custom binary,
symlink, or a Cargo-installed axp, uninstall prints that it was skipped.
Pass --force only when you intentionally want to remove that file anyway:
bash <(curl -fsSL https://download.514.ai/uninstall.sh) --yes --forceCargo-installed binaries outside ~/.fiveonefour/bin are not removed by the
hosted uninstall script.
Non-interactive uninstall fails
Interactive uninstall prompts before removing files. In a non-interactive shell,
the script refuses to continue unless you pass --yes:
bash <(curl -fsSL https://download.514.ai/uninstall.sh) --yesCombine it with other flags when needed, for example --yes --remove-path.
Preview uninstall changes
Use --dry-run to print what uninstall would remove or update without changing
files. Dry runs do not require confirmation and print Dry run: no files will be changed.
bash <(curl -fsSL https://download.514.ai/uninstall.sh) --dry-run --remove-pathNo command was provided
axp requires a subcommand. Running it with no command exits non-zero and prints usage.
axp --helpExperiment YAML does not validate
axp experiment validate <EXPERIMENT> prints Validated <EXPERIMENT> and a suggested axp run <EXPERIMENT> command on success. On schema failure, it prints one error line and exits non-zero. It may also print non-fatal warning[<rule>] lint messages to stderr while still exiting zero.
Common schema issues include:
schema_versionis not1.id, variant IDs, or test names are not kebab-case.name,flow.prompt,model, variant tags, or test scripts are empty.matrix.varianthas no entries.tests.applicationandtests.introspectionare both empty.limits.max_turns,limits.max_time_seconds, orlimits.max_cost_usdare zero or invalid.- The YAML contains an unknown field.
max_cost_usd must be a positive number. AXP aborts the agent when reported cumulative cost reaches that value; if the agent does not report cost during the run, AXP cannot stop on cost. max_time_seconds is enforced by AXP, and max_turns is passed to the agent where supported.
Run validation before starting containers:
axp experiment validate experiment.yamlIf you see warning[polls-for-file-in-setup], check any variant overrides.setup loop that waits for a /workspace/... path. Variants are isolated, so each variant must create or fetch its own setup files.
A run used the wrong variant set
axp run --variant <ID> only accepts IDs from matrix.variant. If a requested variant does not exist, the CLI prints the known variant IDs and exits with code 2.
Use a local dry run to inspect the planned variants without creating containers or making API calls:
axp local run experiment.yaml --resolve-variantsA run failed with setup_failed
A variant rolls up as setup_failed when its setup script exits non-zero — setup-checks, the agent, and tests never run. This is distinct from driver_error, which now means an actual harness/driver fault rather than a mundane setup bug.
The script's stdout + stderr (tail) is included in the axp run failure output, and the full output is saved to the variant's setup.log artifact (fetch it with axp download). A common cause is a missing command — e.g. installing docker.io without docker-cli, so a docker --version line exits 127.
Iterate on the setup script with a local run, which writes the same setup.log:
axp local run experiment.yaml--repeat 0 fails
--repeat must be at least 1.
axp run experiment.yaml --repeat 3A referenced secret can't be resolved
An axp://secrets/<slug> reference resolves from your org's secret store on both run paths. If the slug doesn't exist in the org (and, for local runs, no local source supplies the bound name), the run fails fast at preflight before any container starts.
Store the value, then re-run:
axp secrets set prod-gh # prompts for the value
axp secrets list # confirm the slug exists (values are never shown)For a local run you can also override the bound name from a local source instead of the store (lowest → highest precedence): auto-loaded ./.env, --env-file, host env, then --env:
echo "GITHUB_TOKEN=..." > .env # auto-loaded
axp local run experiment.yaml --env-file .env.local # explicit file
GITHUB_TOKEN=... axp local run experiment.yaml # host env
axp local run experiment.yaml --env GITHUB_TOKEN=... # highest precedenceA name must match ^[A-Z_][A-Z0-9_]*$. Harness-managed names cannot be used, including ANTHROPIC_API_KEY, ANTHROPIC_BASE_URL, OPENAI_API_KEY, OPENAI_BASE_URL, CURSOR_API_KEY, MODEL, MAX_TURNS, IS_SANDBOX, TRACEPARENT, and names starting with AXP_, CLAUDE_CODE_, CODEX_, CURSOR_, or OTEL_.
Anthropic API key is missing
axp run uses platform-supplied model access, so it needs no host model key. Local runs do: axp local run requires a model credential in the host environment for the selected agent — ANTHROPIC_API_KEY for Claude or OPENAI_API_KEY for Codex. These are harness-managed, so do not list them under environment_variables.
export ANTHROPIC_API_KEY=...
axp local run experiment.yamlexport OPENAI_API_KEY=...
axp local run codex-experiment.yamlIf you are using AXP-provided model access, make sure the CLI is logged in with axp auth login or has AXP_API_KEY set. You do not need to set Anthropic or OpenAI API keys for that run.
No runs are listed
axp list shows local runs from ./.axp/runs/ and, when signed in, remote platform runs. If no local runs exist in the current directory and no remote runs match, it prints an empty-list message.
Run a local experiment from the project directory that should own the results:
axp local run experiment.yaml
axp listaxp list shows no runs
Use axp list --local to check only ./.axp/runs/. If it is empty, run a local experiment first. Interrupted local runs are still listed with status partial. Inspect a run's artifacts directly under .axp/runs/<run-id>/, or query them with axp local query <run-id> "<SQL>".
To inspect platform results locally, download the run first:
axp download my-experiment-01HX...Docker image pull fails
axp local run pulls axp-base from Docker Hub (514labs/axp-base) on
first use. If the pull fails, check Docker is running and Docker Hub
is reachable; you can pre-pull manually:
docker pull 514labs/axp-base:latestUse axp local run --resolve-variants when you only want experiment validation without
touching containers. (Platform runs with axp run need no local Docker.)
axp run says you're not signed in
axp run submits to the platform, so it needs saved credentials. If you see an authentication error, sign in (or set AXP_API_KEY in CI):
axp auth login
axp auth whoamiTo run without the platform, use axp local run (Docker plus your own model key).
axp run and secrets
Platform runs support secrets: reference an org secret from environment_variables as axp://secrets/<slug> and dispatch resolves it server-side from your org's secret store. (Earlier releases rejected secret-bearing experiments at submit — that restriction is gone.) Store the value first with axp secrets set <slug>; a reference to a slug that doesn't exist in the org fails at submit. The deprecated secrets: field remains local-only.
See Runs and Environment and Auth.
Cancel a platform run
axp run prints a run id. Cancel queued or in-flight jobs with it:
axp cancel <run-request-id>Cancel only specific jobs with --run <run-id> (comma-separated); the default cancels every job in the request.
Not logged in for platform upload
axp upload requires credentials saved by axp auth login. If credentials are missing, run:
axp auth login
axp auth whoamiaxp auth whoami round-trips through the platform API and prints the resolved user and active org. Use axp auth orgs to list available orgs, and axp auth orgs --switch org_... to change the active CLI org.
The credentials file lives at ~/.fiveonefour/axp/credentials.toml. AXP_API_KEY can override the saved API key.
Upload target is wrong
Auth, upload, and download requests go to the AXP platform by default. If the AXP team gives you a different platform URL, set AXP_PLATFORM_URL:
AXP_PLATFORM_URL=https://platform.example.com axp upload my-experiment-01HX...Active org is wrong
Platform commands use the active CLI org by default. Check it with:
axp auth whoami
axp auth orgsSwitch the active org with:
axp auth orgs --switch org_...For a one-off upload or download without changing the active org, pass --org:
axp upload my-experiment-01HX... --org org_...
axp download my-experiment-01HX... --org org_...If a run exists in another org that your API key can access, the platform error includes this hint. If the run is not in an accessible org, the error does not reveal where it exists.
Run was already uploaded
If the server reports that a run already exists, pass --force to overwrite that upload:
axp upload my-experiment-01HX... --forceDownload destination already exists
axp download writes to .axp/downloads/<run-id>/ and refuses to replace an existing directory unless you pass --force:
axp download my-experiment-01HX... --forceLocal query derivation fails
Use axp local query to derive query files from a raw local run, or to read downloaded platform Parquet, and surface the conversion/query error:
axp local query <run-id> "SELECT * FROM runs LIMIT 1"If the run is not local, use axp list to find local runs or run axp download <run-id> before querying locally.