These raw log messages are meant to help Ambient developers figure out problems. You can ignore them.
{
"type": "executor_starts",
"name": "ambient-execute-plan",
"version": "0.14.0@c37ec71",
"timestamp": {
"secs_since_epoch": 1777388109,
"nanos_since_epoch": 550007256
},
"log_source": "Plan"
}{
"type": "runnable_plan",
"steps": [
{
"action": "mkdir",
"pathname": "/ci"
},
{
"action": "mkdir",
"pathname": "/ci/artifacts"
},
{
"action": "tar_extract",
"archive": "/dev/vdc",
"directory": "/ci/src"
},
{
"action": "tar_extract",
"archive": "/dev/vdf",
"directory": "/ci/deps"
},
{
"action": "tar_extract",
"archive": "/dev/vde",
"directory": "/ci/cache"
},
{
"action": "shell",
"shell": "ln -sf /ci /workspace"
},
{
"action": "shell",
"shell": "git config --global user.name 'Ambient CI'"
},
{
"action": "shell",
"shell": "git config --global user.email ambient@example.com"
},
{
"action": "cargo_fmt"
},
{
"action": "cargo_clippy"
},
{
"action": "cargo_test"
},
{
"action": "tar_create",
"archive": "/dev/vde",
"directory": "/ci/cache"
},
{
"action": "tar_create",
"archive": "/dev/vdd",
"directory": "/ci/artifacts"
}
],
"executor_drive": "/dev/vdb",
"source_drive": "/dev/vdc",
"artifact_drive": "/dev/vdd",
"cache_drive": "/dev/vde",
"deps_drive": "/dev/vdf",
"workspace_dir": "/ci",
"source_dir": "/ci/src",
"deps_dir": "/ci/deps",
"cache_dir": "/ci/cache",
"artifacts_dir": "/ci/artifacts",
"envs": {},
"timestamp": {
"secs_since_epoch": 1777388109,
"nanos_since_epoch": 550655197
},
"log_source": "Plan"
}{
"type": "execute_action",
"action": "mkdir",
"pathname": "/ci",
"timestamp": {
"secs_since_epoch": 1777388109,
"nanos_since_epoch": 550710741
},
"log_source": "Plan"
}{
"type": "action_succeeded",
"action": "mkdir",
"pathname": "/ci",
"timestamp": {
"secs_since_epoch": 1777388109,
"nanos_since_epoch": 551089679
},
"log_source": "Plan"
}{
"type": "execute_action",
"action": "mkdir",
"pathname": "/ci/artifacts",
"timestamp": {
"secs_since_epoch": 1777388109,
"nanos_since_epoch": 551157404
},
"log_source": "Plan"
}{
"type": "action_succeeded",
"action": "mkdir",
"pathname": "/ci/artifacts",
"timestamp": {
"secs_since_epoch": 1777388109,
"nanos_since_epoch": 551186098
},
"log_source": "Plan"
}{
"type": "execute_action",
"action": "tar_extract",
"archive": "/dev/vdc",
"directory": "/ci/src",
"timestamp": {
"secs_since_epoch": 1777388109,
"nanos_since_epoch": 551368868
},
"log_source": "Plan"
}{
"type": "action_succeeded",
"action": "tar_extract",
"archive": "/dev/vdc",
"directory": "/ci/src",
"timestamp": {
"secs_since_epoch": 1777388109,
"nanos_since_epoch": 580591229
},
"log_source": "Plan"
}{
"type": "execute_action",
"action": "tar_extract",
"archive": "/dev/vdf",
"directory": "/ci/deps",
"timestamp": {
"secs_since_epoch": 1777388109,
"nanos_since_epoch": 581027966
},
"log_source": "Plan"
}{
"type": "action_succeeded",
"action": "tar_extract",
"archive": "/dev/vdf",
"directory": "/ci/deps",
"timestamp": {
"secs_since_epoch": 1777388112,
"nanos_since_epoch": 263091893
},
"log_source": "Plan"
}{
"type": "execute_action",
"action": "tar_extract",
"archive": "/dev/vde",
"directory": "/ci/cache",
"timestamp": {
"secs_since_epoch": 1777388112,
"nanos_since_epoch": 263540412
},
"log_source": "Plan"
}{
"type": "action_succeeded",
"action": "tar_extract",
"archive": "/dev/vde",
"directory": "/ci/cache",
"timestamp": {
"secs_since_epoch": 1777388117,
"nanos_since_epoch": 319157005
},
"log_source": "Plan"
}{
"type": "execute_action",
"action": "shell",
"shell": "ln -sf /ci /workspace",
"timestamp": {
"secs_since_epoch": 1777388117,
"nanos_since_epoch": 321689785
},
"log_source": "Plan"
}{
"type": "start_program",
"argv": [
{
"Unix": [
98,
97,
115,
104
]
},
{
"Unix": [
45,
99
]
},
{
"Unix": [
115,
101,
116,
32,
45,
120,
101,
117,
111,
32,
112,
105,
112,
101,
102,
97,
105,
108,
10,
108,
110,
32,
45,
115,
102,
32,
47,
99,
105,
32,
47,
119,
111,
114,
107,
115,
112,
97,
99,
101,
10
]
}
],
"timestamp": {
"secs_since_epoch": 1777388117,
"nanos_since_epoch": 323923227
},
"log_source": "Plan"
}{
"type": "program_succeeded",
"exit_code": 0,
"stdout": "",
"stderr": "+ ln -sf /ci /workspace\n",
"timestamp": {
"secs_since_epoch": 1777388117,
"nanos_since_epoch": 331038089
},
"log_source": "Plan"
}{
"type": "action_succeeded",
"action": "shell",
"shell": "ln -sf /ci /workspace",
"timestamp": {
"secs_since_epoch": 1777388117,
"nanos_since_epoch": 333529993
},
"log_source": "Plan"
}{
"type": "execute_action",
"action": "shell",
"shell": "git config --global user.name 'Ambient CI'",
"timestamp": {
"secs_since_epoch": 1777388117,
"nanos_since_epoch": 335775389
},
"log_source": "Plan"
}{
"type": "start_program",
"argv": [
{
"Unix": [
98,
97,
115,
104
]
},
{
"Unix": [
45,
99
]
},
{
"Unix": [
115,
101,
116,
32,
45,
120,
101,
117,
111,
32,
112,
105,
112,
101,
102,
97,
105,
108,
10,
103,
105,
116,
32,
99,
111,
110,
102,
105,
103,
32,
45,
45,
103,
108,
111,
98,
97,
108,
32,
117,
115,
101,
114,
46,
110,
97,
109,
101,
32,
39,
65,
109,
98,
105,
101,
110,
116,
32,
67,
73,
39,
10
]
}
],
"timestamp": {
"secs_since_epoch": 1777388117,
"nanos_since_epoch": 338314269
},
"log_source": "Plan"
}{
"type": "program_succeeded",
"exit_code": 0,
"stdout": "",
"stderr": "+ git config --global user.name 'Ambient CI'\n",
"timestamp": {
"secs_since_epoch": 1777388117,
"nanos_since_epoch": 348971906
},
"log_source": "Plan"
}{
"type": "action_succeeded",
"action": "shell",
"shell": "git config --global user.name 'Ambient CI'",
"timestamp": {
"secs_since_epoch": 1777388117,
"nanos_since_epoch": 351784772
},
"log_source": "Plan"
}{
"type": "execute_action",
"action": "shell",
"shell": "git config --global user.email ambient@example.com",
"timestamp": {
"secs_since_epoch": 1777388117,
"nanos_since_epoch": 354602998
},
"log_source": "Plan"
}{
"type": "start_program",
"argv": [
{
"Unix": [
98,
97,
115,
104
]
},
{
"Unix": [
45,
99
]
},
{
"Unix": [
115,
101,
116,
32,
45,
120,
101,
117,
111,
32,
112,
105,
112,
101,
102,
97,
105,
108,
10,
103,
105,
116,
32,
99,
111,
110,
102,
105,
103,
32,
45,
45,
103,
108,
111,
98,
97,
108,
32,
117,
115,
101,
114,
46,
101,
109,
97,
105,
108,
32,
97,
109,
98,
105,
101,
110,
116,
64,
101,
120,
97,
109,
112,
108,
101,
46,
99,
111,
109,
10
]
}
],
"timestamp": {
"secs_since_epoch": 1777388117,
"nanos_since_epoch": 357234702
},
"log_source": "Plan"
}{
"type": "program_succeeded",
"exit_code": 0,
"stdout": "",
"stderr": "+ git config --global user.email ambient@example.com\n",
"timestamp": {
"secs_since_epoch": 1777388117,
"nanos_since_epoch": 365189821
},
"log_source": "Plan"
}{
"type": "action_succeeded",
"action": "shell",
"shell": "git config --global user.email ambient@example.com",
"timestamp": {
"secs_since_epoch": 1777388117,
"nanos_since_epoch": 368090363
},
"log_source": "Plan"
}{
"type": "execute_action",
"action": "cargo_fmt",
"timestamp": {
"secs_since_epoch": 1777388117,
"nanos_since_epoch": 370798055
},
"log_source": "Plan"
}{
"type": "start_program",
"argv": [
{
"Unix": [
99,
97,
114,
103,
111
]
},
{
"Unix": [
45,
45,
118,
101,
114,
115,
105,
111,
110
]
}
],
"timestamp": {
"secs_since_epoch": 1777388117,
"nanos_since_epoch": 372678857
},
"log_source": "Plan"
}{
"type": "program_succeeded",
"exit_code": 0,
"stdout": "cargo 1.94.0 (85eff7c80 2026-01-15)\n",
"stderr": "",
"timestamp": {
"secs_since_epoch": 1777388117,
"nanos_since_epoch": 431731279
},
"log_source": "Plan"
}{
"type": "start_program",
"argv": [
{
"Unix": [
99,
97,
114,
103,
111
]
},
{
"Unix": [
99,
108,
105,
112,
112,
121
]
},
{
"Unix": [
45,
45,
118,
101,
114,
115,
105,
111,
110
]
}
],
"timestamp": {
"secs_since_epoch": 1777388117,
"nanos_since_epoch": 434461293
},
"log_source": "Plan"
}{
"type": "program_succeeded",
"exit_code": 0,
"stdout": "clippy 0.1.94 (4a4ef493e3 2026-03-02)\n",
"stderr": "",
"timestamp": {
"secs_since_epoch": 1777388117,
"nanos_since_epoch": 539786107
},
"log_source": "Plan"
}{
"type": "start_program",
"argv": [
{
"Unix": [
114,
117,
115,
116,
99
]
},
{
"Unix": [
45,
45,
118,
101,
114,
115,
105,
111,
110
]
}
],
"timestamp": {
"secs_since_epoch": 1777388117,
"nanos_since_epoch": 542536640
},
"log_source": "Plan"
}{
"type": "program_succeeded",
"exit_code": 0,
"stdout": "rustc 1.94.0 (4a4ef493e 2026-03-02)\n",
"stderr": "",
"timestamp": {
"secs_since_epoch": 1777388117,
"nanos_since_epoch": 587254040
},
"log_source": "Plan"
}{
"type": "start_program",
"argv": [
{
"Unix": [
99,
97,
114,
103,
111
]
},
{
"Unix": [
102,
109,
116
]
},
{
"Unix": [
45,
45,
99,
104,
101,
99,
107
]
}
],
"timestamp": {
"secs_since_epoch": 1777388117,
"nanos_since_epoch": 589965556
},
"log_source": "Plan"
}{
"type": "program_failed",
"exit_code": 1,
"stdout": "Diff in /ci/src/src/bin/rad-artifact.rs:175:\n let signer = profile.signer().map_err(error::Signer)?;\n match loc.command {\n LocationCommand::Add(cmd) => {\n- location_add(\n- cmd,\n- args.no_input,\n- &mut releases,\n- &repo,\n- &profile,\n- &signer,\n- )?;\n+ location_add(cmd, args.no_input, &mut releases, &repo, &profile, &signer)?;\n }\n LocationCommand::Remove(cmd) => {\n- location_remove(\n- cmd,\n- args.no_input,\n- &mut releases,\n- &repo,\n- &profile,\n- &signer,\n- )?;\n+ location_remove(cmd, args.no_input, &mut releases, &repo, &profile, &signer)?;\n }\n }\n if !args.no_sync {\nDiff in /ci/src/src/bin/rad-artifact.rs:201:\n }\n Command::Attest(cmd) => {\n let signer = profile.signer().map_err(error::Signer)?;\n- attest_artifact(\n- cmd,\n- args.no_input,\n- &mut releases,\n- &repo,\n- &profile,\n- &signer,\n- )?;\n+ attest_artifact(cmd, args.no_input, &mut releases, &repo, &profile, &signer)?;\n if !args.no_sync {\n announce(&profile, repo.id)?;\n }\nDiff in /ci/src/src/bin/rad-artifact.rs:215:\n }\n Command::Redact(cmd) => {\n let signer = profile.signer().map_err(error::Signer)?;\n- redact_artifact(\n- cmd,\n- args.no_input,\n- &mut releases,\n- &repo,\n- &profile,\n- &signer,\n- )?;\n+ redact_artifact(cmd, args.no_input, &mut releases, &repo, &profile, &signer)?;\n if !args.no_sync {\n announce(&profile, repo.id)?;\n }\nDiff in /ci/src/src/bin/rad-artifact.rs:442:\n let (id, cid) = match (release, revision, cid) {\n (Some(_), _, Some(cid)) | (_, Some(_), Some(cid)) => {\n let id = resolve_target_release(\n- release,\n- revision,\n- releases,\n- repo,\n- &delegates,\n- no_input,\n- aliases,\n+ release, revision, releases, repo, &delegates, no_input, aliases,\n )?;\n (id, cid)\n }\nDiff in /ci/src/src/bin/rad-artifact.rs:494:\n let (id, cid) = match (release, revision, cid) {\n (Some(_), _, Some(cid)) | (_, Some(_), Some(cid)) => {\n let id = resolve_target_release(\n- release,\n- revision,\n- releases,\n- repo,\n- &delegates,\n- no_input,\n- aliases,\n+ release, revision, releases, repo, &delegates, no_input, aliases,\n )?;\n (id, cid)\n }\nDiff in /ci/src/src/bin/rad-artifact.rs:612:\n let id = parse_release_id(s, repo)?;\n let r = releases\n .get(&id)\n- .map_err(|err| error::Find::LookupId { release_id: id, err })?\n+ .map_err(|err| error::Find::LookupId {\n+ release_id: id,\n+ err,\n+ })?\n .ok_or(error::Find::NoReleaseId(id))?;\n vec![(id, r)]\n }\nDiff in /ci/src/src/bin/rad-artifact.rs:637:\n all_authors,\n local: Some(local),\n };\n- let shown =\n- display::Releases::new(candidates.into_iter(), aliases, filters, true, repo, repo);\n+ let shown = display::Releases::new(candidates.into_iter(), aliases, filters, true, repo, repo);\n if use_pretty(pretty, json) {\n print!(\"{}\", shown.pretty_detailed(pretty_style(verbose)));\n } else {\nDiff in /ci/src/src/bin/rad-artifact.rs:1016:\n repo: &Repository,\n aliases: &impl AliasStore,\n ) -> Result<ReleaseId, String> {\n- select_release(candidates, None, repo, aliases)?\n- .ok_or_else(|| \"no release selected\".into())\n+ select_release(candidates, None, repo, aliases)?.ok_or_else(|| \"no release selected\".into())\n }\n \n /// Show a multi-release picker. Returns `Some(id)` when the user\nDiff in /ci/src/src/bin/rad-artifact.rs:1304:\n name, commit_oid, ..\n } => {\n let short = &commit_oid.to_string()[..7];\n- let title =\n- display::CommitTitle::title(repo, commit_oid).unwrap_or_default();\n+ let title = display::CommitTitle::title(repo, commit_oid).unwrap_or_default();\n format!(\"{name} -> {short} {title}\")\n }\n Entry::Commit { oid } => {\nDiff in /ci/src/src/bin/rad-artifact.rs:1431:\n match releases.get(&id) {\n Ok(Some(_)) => Ok(id),\n Ok(None) => Err(error::Find::NoReleaseId(id).into()),\n- Err(err) => Err(error::Find::LookupId { release_id: id, err }.into()),\n+ Err(err) => Err(error::Find::LookupId {\n+ release_id: id,\n+ err,\n+ }\n+ .into()),\n }\n }\n (None, Some(rev)) => {\nDiff in /ci/src/src/bin/rad-artifact.rs:1459:\n /// `git revparse_single` accepts short OIDs, full OIDs, and any other\n /// ref name that points at the COB.\n fn parse_release_id(s: &str, repo: &Repository) -> Result<ReleaseId, error::Resolve> {\n- let object = repo.raw().revparse_single(s).map_err(|err| error::Resolve {\n- revision: s.to_owned(),\n- err,\n- })?;\n+ let object = repo\n+ .raw()\n+ .revparse_single(s)\n+ .map_err(|err| error::Resolve {\n+ revision: s.to_owned(),\n+ err,\n+ })?;\n Ok(cob::ObjectId::from(object.id()).into())\n }\n \nDiff in /ci/src/src/bin/rad-artifact.rs:1476:\n })?;\n if object.kind() == Some(ObjectType::Tag) {\n let tag_oid: Oid = object.id().into();\n- let peeled = object.peel(ObjectType::Commit).map_err(|err| error::Resolve {\n- revision: rev.to_owned(),\n- err,\n- })?;\n+ let peeled = object\n+ .peel(ObjectType::Commit)\n+ .map_err(|err| error::Resolve {\n+ revision: rev.to_owned(),\n+ err,\n+ })?;\n Ok(ResolvedRef {\n commit: peeled.id().into(),\n tag: Some(tag_oid),\nDiff in /ci/src/src/display.rs:646:\n \n if style.verbose {\n let label = |k: &str| pad_right(&style.dim(k), 14);\n- push_line(\n- &mut s,\n- format!(\" {}{}\", label(\"release\"), self.release_id),\n- );\n+ push_line(&mut s, format!(\" {}{}\", label(\"release\"), self.release_id));\n push_line(&mut s, format!(\" {}{}\", label(\"commit\"), self.oid));\n if let Some(tag_oid) = self.tag {\n push_line(&mut s, format!(\" {}{}\", label(\"tag\"), tag_oid));\nDiff in /ci/src/src/lib.rs:712:\n store: self,\n })\n }\n-\n }\n \n /// A `ReleaseMut` is a [`Release`] where the underlying `Release` can be\nDiff in /ci/src/src/lib.rs:972:\n \n /// Collect the delegate set for a Radicle storage repository for use\n /// with `find_unique_by_commit`.\n- fn delegates(\n- repo: &radicle::storage::git::Repository,\n- ) -> std::collections::BTreeSet<Did> {\n+ fn delegates(repo: &radicle::storage::git::Repository) -> std::collections::BTreeSet<Did> {\n use radicle::prelude::ReadRepository;\n repo.delegates().unwrap().into_iter().collect()\n }\nDiff in /ci/src/src/lib.rs:2002:\n node: _alice, repo, ..\n } = test::setup::NodeWithRepo::default();\n let test::setup::NodeWithRepo { node: bob, .. } = test::setup::NodeWithRepo::default();\n- let test::setup::NodeWithRepo { node: carol, .. } =\n- test::setup::NodeWithRepo::default();\n+ let test::setup::NodeWithRepo { node: carol, .. } = test::setup::NodeWithRepo::default();\n let oid = commit(&repo.backend, \"Test Commit\");\n let delegates = delegates(&repo);\n let mut releases = Releases::open(&*repo).unwrap();\n",
"stderr": "",
"timestamp": {
"secs_since_epoch": 1777388117,
"nanos_since_epoch": 800300630
},
"log_source": "Plan"
}{
"type": "action_failed",
"action": "cargo_fmt",
"timestamp": {
"secs_since_epoch": 1777388117,
"nanos_since_epoch": 916864252
},
"log_source": "Plan"
}{
"type": "executor_ends_in_failure",
"exit_code": 1,
"timestamp": {
"secs_since_epoch": 1777388117,
"nanos_since_epoch": 920102003
},
"log_source": "Plan"
}{
"request": "trigger",
"version": 1,
"event_type": "patch",
"repository": {
"id": "rad:z4VYyJ9KuwMNkXGQnmKuGPGKw3inv",
"name": "radicle-artifact",
"description": "A Radicle Collaborative Object (COB) for content-addressed release artifacts and their discovery locations",
"private": false,
"default_branch": "main",
"delegates": [
"did:key:z6MktwkohCx8aHZ1QCjVZUiLmX92oPZFxRiFZkbq32Tk5Tkm"
]
},
"action": "Updated",
"patch": {
"id": "8088114c6fb24aadf35c1be987cfc39851dec54d",
"author": {
"id": "did:key:z6MktwkohCx8aHZ1QCjVZUiLmX92oPZFxRiFZkbq32Tk5Tkm",
"alias": "2color"
},
"title": "feat(display): colorize and restructure list/show output",
"state": {
"status": "open",
"conflicts": []
},
"before": "c555a60e9b517decc083c30525ea62c0f5872458",
"after": "368c48202777d0e92b3a835ed3142d8082f0fc39",
"commits": [
"368c48202777d0e92b3a835ed3142d8082f0fc39",
"a4a11d1c9091b9a06551683a03720a3734fe493b",
"32597427255b8f82e4222618ce23d09d57a240af"
],
"target": "c555a60e9b517decc083c30525ea62c0f5872458",
"labels": [],
"assignees": [],
"revisions": [
{
"id": "8088114c6fb24aadf35c1be987cfc39851dec54d",
"author": {
"id": "did:key:z6MktwkohCx8aHZ1QCjVZUiLmX92oPZFxRiFZkbq32Tk5Tkm",
"alias": "2color"
},
"description": "- introduce display::Style for verbose + ANSI color knobs\n- detect color via TTY + NO_COLOR in rad-artifact\n- compact list: bullet header, badges (✓ attestations, ⊘ redactions),\n dim separator between releases, summary footer\n- detailed show: per-artifact labeled fields with grouped locations\n- table widths now ignore ANSI escapes via visible_width helper\n\nWhy: previous output crammed every release into the same column-aligned\ntable, making list and show indistinguishable and hard to scan; colors\nand a vertical layout for show let the reader find the field they need.\n\n\nfeat(display): clean up trailing whitespace, add render snapshot test\n\n- drop padding on standalone label lines (locations/attestations/redactions)\n so they don't emit trailing spaces\n- add a smoke test that renders a release in both compact and detailed\n styles; useful as an eyeball check via 'cargo test -- --nocapture'\n\nWhy: visual cleanliness matters in TTY output, and a runnable snapshot\nmakes future tweaks to the layout easy to validate locally.",
"base": "1af9b4fc79a1e5816b92292bab422287c2dc65a3",
"oid": "8593f8ba12d9877709ec9f3e5722582cf5d3a251",
"timestamp": 1777276634
},
{
"id": "96cfdcbb1685aad3f353512bc2e0b6fa204209a1",
"author": {
"id": "did:key:z6MktwkohCx8aHZ1QCjVZUiLmX92oPZFxRiFZkbq32Tk5Tkm",
"alias": "2color"
},
"description": "",
"base": "c555a60e9b517decc083c30525ea62c0f5872458",
"oid": "368c48202777d0e92b3a835ed3142d8082f0fc39",
"timestamp": 1777388086
}
]
}
}executor from config: /usr/bin/ambient-execute-plan executor from PATH: /usr/bin/ambient-execute-plan run CI for rad:z4VYyJ9KuwMNkXGQnmKuGPGKw3inv ERROR: CI run failed inside QEMU
<empty log>