CI run for rad:z3gqcJUoA1n9HaHKufZs5FCSGazv5

Radicle repository id rad:z3gqcJUoA1n9HaHKufZs5FCSGazv5

Table of Contents

Run log

At: 2026-03-03 22:42:33Z
After: 0.00 seconds
Program: ambient
Version: 0.12.0
Ambient starts
At: 2026-03-03 22:42:33Z
After: 0.00 seconds
tmpdir: /home/_rad/tmp
image_store: /home/_rad/ambient-images
projects: /dev/null
state: /home/_rad/ambient-state
rsync_target: null
rsync_target_base: null
rsync_target_map: null
dput_target: null
executor: /usr/bin/ambient-execute-plan
artifacts_max_size: 1 GB
cache_max_size: 30 GB
qemu:
  cpus: 2
  memory: 12 GB
  kvm_binary: /usr/bin/kvm
  ovmf_vars_file: /usr/share/ovmf/OVMF.fd
  ovmf_code_file: /usr/share/ovmf/OVMF.fd
uefi: false
lint: true
Ambient configuration
At: 2026-03-03 22:42:33Z
After: 0.06 seconds
Hoping for the best
Will run CI for project rad:z3gqcJUoA1n9HaHKufZs5FCSGazv5
At: 2026-03-03 22:42:33Z
After: 0.06 seconds
CargoFetch(
    CargoFetch,
)
Start action cargo_fetch
At: 2026-03-03 22:42:46Z
After: 12.89 seconds
  • cargo
  • --version
exit: 0
Stdout:
cargo 1.90.0 (840b83a10 2025-07-30)
OK: cargo --version
At: 2026-03-03 22:42:46Z
After: 12.89 seconds
  • cargo
  • clippy
  • --version
exit: 0
Stdout:
clippy 0.1.90 (1159e78c47 2025-09-14)
OK: cargo clippy --version
At: 2026-03-03 22:42:46Z
After: 12.89 seconds
  • rustc
  • --version
exit: 0
Stdout:
rustc 1.90.0 (1159e78c4 2025-09-14)
OK: rustc --version
At: 2026-03-03 22:42:46Z
After: 12.89 seconds
  • cargo
  • fetch
  • --locked
exit: 0
OK: cargo fetch --locked
At: 2026-03-03 22:42:34Z
After: 0.52 seconds
End action cargo_fetch
At: 2026-03-03 22:42:34Z
After: 0.52 seconds
Hopefully all is good.
Plan succeeded
At: 2026-03-03 22:42:39Z
After: 5.79 seconds
Program: ambient-execute-plan
Version: 0.12.0@626957c
Executor starts
At: 2026-03-03 22:42:39Z
After: 5.79 seconds
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_build
- action: cargo_test
- action: shell
  shell: |
    # Because of a (temporary) limitation in Ambient, we need to set
    # these variables manually. Once Ambient manages environment
    # variables better, these can be deleted.
    export CARGO_TARGET_DIR=/workspace/cache
    export CARGO_HOME=/workspace/deps
    export HOME=/root
    export PATH="/root/.cargo/bin:$PATH"
    export RUSTDOCFLAGS='-D warnings'

    cargo doc --workspace --no-deps --all-features
- action: shell
  shell: |
    # Because of a (temporary) limitation in Ambient, we need to set
    # these variables manually. Once Ambient manages environment
    # variables better, these can be deleted.
    export CARGO_TARGET_DIR=/workspace/cache
    export CARGO_HOME=/workspace/deps
    export HOME=/root
    export PATH="/root/.cargo/bin:$PATH"

    # These are based on debian/control.
    export DEBEMAIL=liw@liw.fi
    export DEBFULLNAME="Lars Wirzenius"

    # Clean up after tests and documentation building. The Debian
    # package building tools do not want changes outside the
    # `debian` directory, compared to what is committed to Git, from
    # which the "upstream tarball" is created.
    git reset --hard
    git clean -fdx
    git status --ignored

    # Update debian/changelog with a new version so that every run
    # creates a newer version. This avoids us having to update the
    # file manually for every CI run.
    V="$(dpkg-parsechangelog -SVersion | sed 's/-[^-]*$//')"
    T="$(date -u "+%Y%m%dT%H%M%S")"
    version="$V.ci$T-1"
    dch -v "$version" "CI build under Ambient."
    dch -r ''
- action: deb
  packages: .
- 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
Runnable plan
At: 2026-03-03 22:42:39Z
After: 5.79 seconds
Mkdir(
    Mkdir {
        pathname: "/ci",
    },
)
Start action mkdir
At: 2026-03-03 22:42:39Z
After: 5.79 seconds
End action mkdir
At: 2026-03-03 22:42:39Z
After: 5.79 seconds
Mkdir(
    Mkdir {
        pathname: "/ci/artifacts",
    },
)
Start action mkdir
At: 2026-03-03 22:42:39Z
After: 5.79 seconds
End action mkdir
At: 2026-03-03 22:42:39Z
After: 5.79 seconds
TarExtract(
    TarExtract {
        archive: "/dev/vdc",
        directory: "/ci/src",
    },
)
Start action tar_extract
At: 2026-03-03 22:42:39Z
After: 5.90 seconds
End action tar_extract
At: 2026-03-03 22:42:39Z
After: 5.90 seconds
TarExtract(
    TarExtract {
        archive: "/dev/vdf",
        directory: "/ci/deps",
    },
)
Start action tar_extract
At: 2026-03-03 22:42:42Z
After: 8.40 seconds
End action tar_extract
At: 2026-03-03 22:42:42Z
After: 8.40 seconds
TarExtract(
    TarExtract {
        archive: "/dev/vde",
        directory: "/ci/cache",
    },
)
Start action tar_extract
At: 2026-03-03 22:42:42Z
After: 8.40 seconds
End action tar_extract
At: 2026-03-03 22:42:42Z
After: 8.41 seconds
Shell(
    Shell {
        shell: "ln -sf /ci /workspace",
    },
)
Start action shell
At: 2026-03-03 22:42:46Z
After: 12.89 seconds
  • bash
  • -c
  • set -xeuo pipefail ln -sf /ci /workspace
exit: 0
Stderr:
+ ln -sf /ci /workspace
OK: bash -c set -xeuo pipefail ln -sf /ci /workspace
At: 2026-03-03 22:42:42Z
After: 8.42 seconds
End action shell
At: 2026-03-03 22:42:42Z
After: 8.42 seconds
Shell(
    Shell {
        shell: "git config --global user.name 'Ambient CI'",
    },
)
Start action shell
At: 2026-03-03 22:42:46Z
After: 12.89 seconds
  • bash
  • -c
  • set -xeuo pipefail git config --global user.name 'Ambient CI'
exit: 0
Stderr:
+ git config --global user.name 'Ambient CI'
OK: bash -c set -xeuo pipefail git config --global user.name 'Ambient CI'
At: 2026-03-03 22:42:42Z
After: 8.42 seconds
End action shell
At: 2026-03-03 22:42:42Z
After: 8.42 seconds
Shell(
    Shell {
        shell: "git config --global user.email ambient@example.com",
    },
)
Start action shell
At: 2026-03-03 22:42:46Z
After: 12.89 seconds
  • bash
  • -c
  • set -xeuo pipefail git config --global user.email ambient@example.com
exit: 0
Stderr:
+ git config --global user.email ambient@example.com
OK: bash -c set -xeuo pipefail git config --global user.email ambient@example.com
At: 2026-03-03 22:42:42Z
After: 8.43 seconds
End action shell
At: 2026-03-03 22:42:42Z
After: 8.43 seconds
CargoFmt(
    CargoFmt,
)
Start action cargo_fmt
At: 2026-03-03 22:42:46Z
After: 12.89 seconds
  • cargo
  • --version
exit: 0
Stdout:
cargo 1.90.0 (840b83a10 2025-07-30)
OK: cargo --version
At: 2026-03-03 22:42:46Z
After: 12.89 seconds
  • cargo
  • clippy
  • --version
exit: 0
Stdout:
clippy 0.1.90 (1159e78c47 2025-09-14)
OK: cargo clippy --version
At: 2026-03-03 22:42:46Z
After: 12.89 seconds
  • rustc
  • --version
exit: 0
Stdout:
rustc 1.90.0 (1159e78c4 2025-09-14)
OK: rustc --version
At: 2026-03-03 22:42:46Z
After: 12.89 seconds
  • cargo
  • fmt
  • --check
exit: 1
Stdout:
Diff in /ci/src/crates/radicle-term/src/editor.rs:163:
                 .open("/dev/tty")?;
             process::Stdio::from(tty)
         } else if cfg!(windows) {
-            let tty = fs::OpenOptions::new()
-                .read(true)
-                .open("CONIN$")?;
+            let tty = fs::OpenOptions::new().read(true).open("CONIN$")?;
             process::Stdio::from(tty)
         } else {
             return Err(io::Error::new(
FAILED: cargo fmt --check
At: 2026-03-03 22:42:43Z
After: 9.88 seconds
Action failed
At: 2026-03-03 22:42:43Z
After: 9.88 seconds
Exit codd 1
Executor ends, failure
At: 2026-03-03 22:42:46Z
After: 12.89 seconds
    exit: 0
    QEMU OK

    Trigger message

    {
      "request": "trigger",
      "version": 1,
      "event_type": "patch",
      "repository": {
        "id": "rad:z3gqcJUoA1n9HaHKufZs5FCSGazv5",
        "name": "heartwood",
        "description": "Radicle Heartwood Protocol & Stack",
        "private": false,
        "default_branch": "master",
        "delegates": [
          "did:key:z6MksFqXN3Yhqk8pTJdUGLwATkRfQvwZXPqR2qMEhbS9wzpT",
          "did:key:z6MktaNvN1KVFMkSRAiN4qK5yvX1zuEEaseeX5sffhzPZRZW",
          "did:key:z6MkireRatUThvd3qzfKht1S44wpm4FEWSSa4PRMTSQZ3voM",
          "did:key:z6MkgFq6z5fkF2hioLLSNu1zP2qEL1aHXHZzGH1FLFGAnBGz",
          "did:key:z6MkkPvBfjP4bQmco5Dm7UGsX2ruDBieEHi8n9DVJWX5sTEz"
        ]
      },
      "action": "Created",
      "patch": {
        "id": "63be653fc7a7d5814bab9be32d9d5cc46f1d098f",
        "author": {
          "id": "did:key:z6Mkum88mKcX2sARx8R18RZUmAdakPFbXtdHzn8JNVEDqkxj",
          "alias": "justarandomgeek-trantor"
        },
        "title": "use `CONIN$` instead of `/dev/tty` on windows",
        "state": {
          "status": "open",
          "conflicts": []
        },
        "before": "e9245b630d728672d2b3d6ff9265fa4f1a86f13a",
        "after": "2641b7b6cec207790e4f7baf86391e0cc7f8d8d5",
        "commits": [
          "2641b7b6cec207790e4f7baf86391e0cc7f8d8d5"
        ],
        "target": "e9245b630d728672d2b3d6ff9265fa4f1a86f13a",
        "labels": [],
        "assignees": [],
        "revisions": [
          {
            "id": "63be653fc7a7d5814bab9be32d9d5cc46f1d098f",
            "author": {
              "id": "did:key:z6Mkum88mKcX2sARx8R18RZUmAdakPFbXtdHzn8JNVEDqkxj",
              "alias": "justarandomgeek-trantor"
            },
            "description": "This allows `git-remote-rad` to succesfully launch an editor on windows",
            "base": "e9245b630d728672d2b3d6ff9265fa4f1a86f13a",
            "oid": "2641b7b6cec207790e4f7baf86391e0cc7f8d8d5",
            "timestamp": 1772080013
          }
        ]
      }
    }

    Ambient stdout

    deprecated: the `cpus` field is replaced by `qemu.cpus`
    deprecated: the `memory` field is replaced by `qemu.memory`
    run CI for rad:z3gqcJUoA1n9HaHKufZs5FCSGazv5
    ERROR: CI run failed inside QEMU
    

    Ambient stderr

    <empty log>