rad:z3gqcJUoA1n9HaHKufZs5FCSGazv5 heartwood188fa6a9303e214d5647996d8eff0bf59e58d8c5
{
"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": "Updated",
"patch": {
"id": "0fefd5bb5cf0550470a5b6c434f14215353d43e5",
"author": {
"id": "did:key:z6MkireRatUThvd3qzfKht1S44wpm4FEWSSa4PRMTSQZ3voM",
"alias": "fintohaps"
},
"title": "just: Introduce task manager for git hooks",
"state": {
"status": "open",
"conflicts": []
},
"before": "48551cde934370c0cf8a4127385d4a4a41c5ba4d",
"after": "188fa6a9303e214d5647996d8eff0bf59e58d8c5",
"commits": [
"188fa6a9303e214d5647996d8eff0bf59e58d8c5",
"90f018473377de796d865113960883c55baa55e4",
"bb8220af59c00916b7aed2133ec665da477acc34",
"5fa17a7159763a8dec89c80e41b8088945c87080",
"810c0eb495b3068caf6d0c45c9df32d3b1e82b3c",
"670d48b0f764213dcf3efe6c4dd082926cbebd5c",
"92f2ba48441d09481339900ea5e1f3a91cc1a2d1",
"5d9eeab871c183b385030ecbff2e4f951f0b67d2",
"090ef6028df73298a2306e774cec44e7282b166f",
"2528ac20035a83891582f23a4817ff847f4e1f36",
"4018cf0c1e6d86bb398f8296b2366c809fca4146",
"6a67d26c3a494d8735e8aa39f0db1a4ae5882c8a",
"ab8dc4c407e592e8c1e7a457de437814932202a1",
"6ae9b48c8f930dab1e7270bf4941b8117feb2cd7",
"5723bd95797c3c528f0014b811eb330e4bf269a6",
"53fd00dec66d06810bf9a73ef8619c4de2cc1e99",
"0a1601cce2dbed8ad1dd2ac0c041d678290b6757",
"74166c209ea2928e89401204c271703734f80f30",
"993b15d9370459178537cda9d49632633718a2b6",
"4fe34358719405df62f17b31449ab8356bd6e1b2",
"ba7911a1e4df9f9a47e03123f4b7f557bc43648d"
],
"target": "ac3eba09a111c09c3a6e4ce106520a3aaa1808b2",
"labels": [],
"assignees": [],
"revisions": [
{
"id": "0fefd5bb5cf0550470a5b6c434f14215353d43e5",
"author": {
"id": "did:key:z6MkireRatUThvd3qzfKht1S44wpm4FEWSSa4PRMTSQZ3voM",
"alias": "fintohaps"
},
"description": "As part of [discussions around task runners](https://radicle.zulipchat.com/#narrow/channel/369277-heartwood/topic/Common.20Project.20Commands/with/574591485) for Radicle, [`just`](https://just.systems/) became a candidate over `make` and a few others due to its focus solely on task running and no build system.\n\nThis patch introduces `just` as a git hook task runner and manager. We previously managed hooks with the `flake.nix` which is great for nix users but not the wider community.\n\nFurther discussion was had around `pre-commit` as the `flake.nix` could be converted to a `pre-commit` config, however it was decided this would prevent non-nix users from \ncontributing to the git hooks system easily.\n\nIn this patch we introduce a `justfile` with commands for all previous git hook checks from `flake.nix`.\n\nWe also introduce a `git-hook-template.sh` which is a thin shim over the `just` commands for each hook: `pre-commit`, `post-checkout`, `pre-push`.\nThe shim checks a set of 'sensitive' files against `master` and if there are changes, warns the users and has them explicitly consent to running hook commands.\nThis should provide a safety barrier for smuggled git hook overrides in large patches that may cause arbitrary code execution on reviewers machines.",
"base": "48551cde934370c0cf8a4127385d4a4a41c5ba4d",
"oid": "4018cf0c1e6d86bb398f8296b2366c809fca4146",
"timestamp": 1775669871
},
{
"id": "46c288d26f5b044bbfc1cfba68bc2473eb7bac44",
"author": {
"id": "did:key:z6MkireRatUThvd3qzfKht1S44wpm4FEWSSa4PRMTSQZ3voM",
"alias": "fintohaps"
},
"description": "",
"base": "48551cde934370c0cf8a4127385d4a4a41c5ba4d",
"oid": "090ef6028df73298a2306e774cec44e7282b166f",
"timestamp": 1775671569
},
{
"id": "3c472a836943d7d09252ce1881822ab0882dc2c2",
"author": {
"id": "did:key:z6MkireRatUThvd3qzfKht1S44wpm4FEWSSa4PRMTSQZ3voM",
"alias": "fintohaps"
},
"description": "",
"base": "48551cde934370c0cf8a4127385d4a4a41c5ba4d",
"oid": "92f2ba48441d09481339900ea5e1f3a91cc1a2d1",
"timestamp": 1775733919
},
{
"id": "f9cc5e42c9898a8077c51040f93471ba53a36261",
"author": {
"id": "did:key:z6MkireRatUThvd3qzfKht1S44wpm4FEWSSa4PRMTSQZ3voM",
"alias": "fintohaps"
},
"description": "REVIEW\n\nAdded review commits with a few improvements.\n\nAlso added `codespell` to the `flake.nix`.",
"base": "48551cde934370c0cf8a4127385d4a4a41c5ba4d",
"oid": "bca4164ef95ebb0f248c2a0aadfcfd3390d4e211",
"timestamp": 1776245287
},
{
"id": "ee0071ee2a218ceee5673c2d0d8ffc3e68ce40d1",
"author": {
"id": "did:key:z6MkireRatUThvd3qzfKht1S44wpm4FEWSSa4PRMTSQZ3voM",
"alias": "fintohaps"
},
"description": "just: Use full argument names for codespell\n\n\njust: Expand shellcheck glob to all shell scripts\n\n\njust: Check for file before removing in install-hooks\n\nThe `rm` command would fail if the hook did not exist.\nFirst check for existence and then remove.\n\n\njust: Add minimum version to CONTRIBUTING and HACKING",
"base": "48551cde934370c0cf8a4127385d4a4a41c5ba4d",
"oid": "bb8220af59c00916b7aed2133ec665da477acc34",
"timestamp": 1776250442
},
{
"id": "cda2789e6d07a78851291fde0feac8415665bca6",
"author": {
"id": "did:key:z6MkireRatUThvd3qzfKht1S44wpm4FEWSSa4PRMTSQZ3voM",
"alias": "fintohaps"
},
"description": "Changes:\n- Added confirmation via `bash`\n- Added back the change for `flake.nix`",
"base": "48551cde934370c0cf8a4127385d4a4a41c5ba4d",
"oid": "188fa6a9303e214d5647996d8eff0bf59e58d8c5",
"timestamp": 1776261523
}
]
}
}
{
"response": "triggered",
"run_id": {
"id": "861f49cc-f392-4113-8c11-c93a524f2c05"
},
"info_url": "https://cci.rad.levitte.org//861f49cc-f392-4113-8c11-c93a524f2c05.html"
}
Started at: 2026-04-15 15:58:52.178130+02:00
Commands:
$ rad clone rad:z3gqcJUoA1n9HaHKufZs5FCSGazv5 .
✓ Creating checkout in ./...
✓ Remote cloudhead@z6MksFqXN3Yhqk8pTJdUGLwATkRfQvwZXPqR2qMEhbS9wzpT added
✓ Remote-tracking branch cloudhead@z6MksFqXN3Yhqk8pTJdUGLwATkRfQvwZXPqR2qMEhbS9wzpT/master created for z6MksFqXN3Yhqk8pTJdUGLwATkRfQvwZXPqR2qMEhbS9wzpT
✓ Remote cloudhead@z6MktaNvN1KVFMkSRAiN4qK5yvX1zuEEaseeX5sffhzPZRZW added
✓ Remote-tracking branch cloudhead@z6MktaNvN1KVFMkSRAiN4qK5yvX1zuEEaseeX5sffhzPZRZW/master created for z6MktaNvN1KVFMkSRAiN4qK5yvX1zuEEaseeX5sffhzPZRZW
✓ Remote fintohaps@z6MkireRatUThvd3qzfKht1S44wpm4FEWSSa4PRMTSQZ3voM added
✓ Remote-tracking branch fintohaps@z6MkireRatUThvd3qzfKht1S44wpm4FEWSSa4PRMTSQZ3voM/master created for z6MkireRatUThvd3qzfKht1S44wpm4FEWSSa4PRMTSQZ3voM
✓ Remote erikli@z6MkgFq6z5fkF2hioLLSNu1zP2qEL1aHXHZzGH1FLFGAnBGz added
✓ Remote-tracking branch erikli@z6MkgFq6z5fkF2hioLLSNu1zP2qEL1aHXHZzGH1FLFGAnBGz/master created for z6MkgFq6z5fkF2hioLLSNu1zP2qEL1aHXHZzGH1FLFGAnBGz
✓ Remote lorenz@z6MkkPvBfjP4bQmco5Dm7UGsX2ruDBieEHi8n9DVJWX5sTEz added
✓ Remote-tracking branch lorenz@z6MkkPvBfjP4bQmco5Dm7UGsX2ruDBieEHi8n9DVJWX5sTEz/master created for z6MkkPvBfjP4bQmco5Dm7UGsX2ruDBieEHi8n9DVJWX5sTEz
✓ Repository successfully cloned under /opt/radcis/ci.rad.levitte.org/cci/state/861f49cc-f392-4113-8c11-c93a524f2c05/w/
╭────────────────────────────────────╮
│ heartwood │
│ Radicle Heartwood Protocol & Stack │
│ 154 issues · 41 patches │
╰────────────────────────────────────╯
Run `cd ./.` to go to the repository directory.
Exit code: 0
$ rad patch checkout 0fefd5bb5cf0550470a5b6c434f14215353d43e5
✓ Switched to branch patch/0fefd5b at revision ee0071e
✓ Branch patch/0fefd5b setup to track rad/patches/0fefd5bb5cf0550470a5b6c434f14215353d43e5
Exit code: 0
$ git config advice.detachedHead false
Exit code: 0
$ git checkout 188fa6a9303e214d5647996d8eff0bf59e58d8c5
HEAD is now at 188fa6a9 flake: Add codespell
Exit code: 0
$ rad patch show 0fefd5bb5cf0550470a5b6c434f14215353d43e5 -p
╭───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────╮
│ Title just: Introduce task manager for git hooks │
│ Patch 0fefd5bb5cf0550470a5b6c434f14215353d43e5 │
│ Author ade z6MkwGo…yS2aagA │
│ Head bb8220af59c00916b7aed2133ec665da477acc34 │
│ Base 48551cde934370c0cf8a4127385d4a4a41c5ba4d │
│ Branches patch/0fefd5b │
│ Commits ahead 19, behind 25 │
│ Status open │
│ │
│ As part of [discussions around task │
│ runners](https://radicle.zulipchat.com/#narrow/channel/369277-heartwood/topic/Common.20Project.20Commands/with/574591485) │
│ for Radicle, [`just`](https://just.systems/) became a candidate over `make` and │
│ a few others due to its focus solely on task running and no build system. │
│ │
│ This patch introduces `just` as a git hook task runner and manager. We │
│ previously managed hooks with the `flake.nix` which is great for nix users but │
│ not the wider community. │
│ │
│ Further discussion was had around `pre-commit` as the `flake.nix` could be │
│ converted to a `pre-commit` config, however it was decided this would prevent │
│ non-nix users from │
│ contributing to the git hooks system easily. │
│ │
│ In this patch we introduce a `justfile` with commands for all previous git hook │
│ checks from `flake.nix`. │
│ │
│ We also introduce a `git-hook-template.sh` which is a thin shim over the `just` │
│ commands for each hook: `pre-commit`, `post-checkout`, `pre-push`. │
│ The shim checks a set of 'sensitive' files against `master` and if there are │
│ changes, warns the users and has them explicitly consent to running hook │
│ commands. │
│ This should provide a safety barrier for smuggled git hook overrides in large │
│ patches that may cause arbitrary code execution on reviewers machines. │
├───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ bb8220a just: Add minimum version to CONTRIBUTING and HACKING │
│ 5fa17a7 just: Check for file before removing in install-hooks │
│ 810c0eb just: Expand shellcheck glob to all shell scripts │
│ 670d48b just: Use full argument names for codespell │
│ 92f2ba4 just: Remove existing hooks during install-hooks │
│ 5d9eeab just: Better doc comment for check-keywords │
│ 090ef60 hacking: Update docs with 'just' commands │
│ 2528ac2 contributing: Update docs with 'just' commands │
│ 4018cf0 git-hook-template: minor output formatting │
│ 6a67d26 just: Add post-checkout hook │
│ ab8dc4c just: Add check-hooks to confirm presence and integrity │
│ 6ae9b48 just: Introduce output formatting │
│ 5723bd9 just: Introduce pre-commit and pre-push installer │
│ 53fd00d just: Add groupings and parallel where possible │
│ 0a1601c just: Add pre-commit hook │
│ 74166c2 just: Add more pre-push tasks │
│ 993b15d just: Introduce justfile with pre-push hook cmds │
│ 4fe3435 codespell: Add 'ser' to word ignore │
│ ba7911a typos: Lint check failure writeable -> writable │
├───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ ● Revision 0fefd5b @ 4018cf0 by ade z6MkwGo…yS2aagA 6 days ago │
│ ↑ Revision 46c288d @ 090ef60 by ade z6MkwGo…yS2aagA 6 days ago │
│ └─ ⋄ reviewed by levitte z6Mku8h…Fo9XVAx 6 days ago │
│ ↑ Revision 3c472a8 @ 92f2ba4 by ade z6MkwGo…yS2aagA 6 days ago │
│ ↑ Revision f9cc5e4 @ bca4164 by fintohaps z6Mkire…SQZ3voM 4 hours ago │
│ ↑ Revision ee0071e @ bb8220a by ade z6MkwGo…yS2aagA 3 hours ago │
│ ↑ Revision cda2789 @ 188fa6a by fintohaps z6Mkire…SQZ3voM 11 seconds ago │
╰───────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────╯
commit bb8220af59c00916b7aed2133ec665da477acc34
Author: Adrian Duke <adrian.duke@gmail.com>
Date: Wed Apr 15 11:53:33 2026 +0100
just: Add minimum version to CONTRIBUTING and HACKING
diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md
index 73df9bdae..eb314a212 100644
--- a/CONTRIBUTING.md
+++ b/CONTRIBUTING.md
@@ -37,7 +37,7 @@ Patch formatting follows the same rules as commit formatting. See below.
### Git hooks & Task runner
-We use [`just`](https://just.systems/) as our task runner. You can see all available commands by running `just` or `just --list` in the repository root.
+We use [`just >= v1.49.0`](https://just.systems/) as our task runner. You can see all available commands by running `just` or `just --list` in the repository root.
If you are not using Nix (which sets up hooks automatically), you should install the local git hooks:
diff --git a/HACKING.md b/HACKING.md
index c3cb2f45c..7dedbc5c0 100644
--- a/HACKING.md
+++ b/HACKING.md
@@ -31,7 +31,7 @@ The repository is structured in *crates*, as follows:
## Task runner
-We use [`just`](https://just.systems/) to manage project tasks such as linting, formatting, and installing git hooks. To see a list of all available commands, run:
+We use [`just >= v1.49.0`](https://just.systems/) to manage project tasks such as linting, formatting, and installing git hooks. To see a list of all available commands, run:
$ just
commit 5fa17a7159763a8dec89c80e41b8088945c87080
Author: Fintan Halpenny <fintan.halpenny@gmail.com>
Date: Wed Apr 15 10:19:52 2026 +0100
just: Check for file before removing in install-hooks
The `rm` command would fail if the hook did not exist.
First check for existence and then remove.
diff --git a/justfile b/justfile
index 76db4ea68..0ee74e861 100644
--- a/justfile
+++ b/justfile
@@ -153,7 +153,9 @@ install-hooks:
#!/usr/bin/env bash
set -e
for hook in {{hooks}}; do
- rm ".git/hooks/$hook"
+ if [ -f ".git/hooks/$hook" ]; then
+ rm ".git/hooks/$hook"
+ fi
cp {{hook-script}} ".git/hooks/$hook"
chmod +x ".git/hooks/$hook"
done
commit 810c0eb495b3068caf6d0c45c9df32d3b1e82b3c
Author: Fintan Halpenny <fintan.halpenny@gmail.com>
Date: Wed Apr 15 10:19:52 2026 +0100
just: Expand shellcheck glob to all shell scripts
diff --git a/justfile b/justfile
index 1394f3e21..76db4ea68 100644
--- a/justfile
+++ b/justfile
@@ -74,7 +74,7 @@ check-spelling: (verify-tool "codespell")
[parallel]
check-scripts: (verify-tool "shellcheck")
@echo "{{CHECK}}Checking shell scripts...{{NORMAL}}"
- @shellcheck scripts/*.sh
+ @shellcheck **/*.sh
# Run checks for forbidden keywords
[group('pre-commit')]
commit 670d48b0f764213dcf3efe6c4dd082926cbebd5c
Author: Fintan Halpenny <fintan.halpenny@gmail.com>
Date: Wed Apr 15 10:19:52 2026 +0100
just: Use full argument names for codespell
diff --git a/justfile b/justfile
index eb983634b..1394f3e21 100644
--- a/justfile
+++ b/justfile
@@ -65,7 +65,7 @@ check-typos: (verify-tool "typos" "typos-cli")
[parallel]
check-spelling: (verify-tool "codespell")
@echo "{{CHECK}}Checking for code typos...{{NORMAL}}"
- @git ls-files -z | xargs -0 codespell -w
+ @git ls-files -z | xargs -0 codespell --write-changes --check-filenames
# Run shellcheck on all shell scripts
[group('pre-commit')]
commit 92f2ba48441d09481339900ea5e1f3a91cc1a2d1
Author: Adrian Duke <adrian.duke@gmail.com>
Date: Thu Apr 9 12:23:46 2026 +0100
just: Remove existing hooks during install-hooks
diff --git a/justfile b/justfile
index df5ec9302..eb983634b 100644
--- a/justfile
+++ b/justfile
@@ -153,6 +153,7 @@ install-hooks:
#!/usr/bin/env bash
set -e
for hook in {{hooks}}; do
+ rm ".git/hooks/$hook"
cp {{hook-script}} ".git/hooks/$hook"
chmod +x ".git/hooks/$hook"
done
commit 5d9eeab871c183b385030ecbff2e4f951f0b67d2
Author: Adrian Duke <adrian.duke@gmail.com>
Date: Thu Apr 9 12:23:13 2026 +0100
just: Better doc comment for check-keywords
diff --git a/justfile b/justfile
index 039aabd42..df5ec9302 100644
--- a/justfile
+++ b/justfile
@@ -76,7 +76,7 @@ check-scripts: (verify-tool "shellcheck")
@echo "{{CHECK}}Checking shell scripts...{{NORMAL}}"
@shellcheck scripts/*.sh
-# Replicate the custom grep checks from flake.nix
+# Run checks for forbidden keywords
[group('pre-commit')]
[group('pre-push')]
[group('check')]
commit 090ef6028df73298a2306e774cec44e7282b166f
Author: Adrian Duke <adrian.duke@gmail.com>
Date: Wed Apr 8 19:05:02 2026 +0100
hacking: Update docs with 'just' commands
diff --git a/HACKING.md b/HACKING.md
index a587c0c4d..c3cb2f45c 100644
--- a/HACKING.md
+++ b/HACKING.md
@@ -29,6 +29,16 @@ The repository is structured in *crates*, as follows:
* `radicle-term`: A generic terminal library used by the Radicle CLI.
* `radicle-tools`: Tools used to aid in the development of Radicle.
+## Task runner
+
+We use [`just`](https://just.systems/) to manage project tasks such as linting, formatting, and installing git hooks. To see a list of all available commands, run:
+
+ $ just
+
+If you are not using Nix, it is highly recommended to install the git hooks to automatically run checks before committing and pushing:
+
+ $ just install-hooks
+
## Running in debug mode
To run the services or the CLI in debug mode, use `cargo run -p <package>`.
commit 2528ac20035a83891582f23a4817ff847f4e1f36
Author: Adrian Duke <adrian.duke@gmail.com>
Date: Wed Apr 8 19:04:35 2026 +0100
contributing: Update docs with 'just' commands
diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md
index 393780a73..73df9bdae 100644
--- a/CONTRIBUTING.md
+++ b/CONTRIBUTING.md
@@ -35,15 +35,29 @@ simple guidelines.
Patch formatting follows the same rules as commit formatting. See below.
+### Git hooks & Task runner
+
+We use [`just`](https://just.systems/) as our task runner. You can see all available commands by running `just` or `just --list` in the repository root.
+
+If you are not using Nix (which sets up hooks automatically), you should install the local git hooks:
+
+ $ just install-hooks
+
+These hooks will run formatting, linting, and spelling checks on `pre-commit` and `pre-push`. For security, our hooks are copied rather than symlinked. If you check out a branch that modifies sensitive files (like `build.rs` or `justfile`), the hook will pause and ask for your confirmation before executing any code.
+
### Linting & formatting
Always check your code with the linter (`clippy`), by running:
- $ cargo clippy --workspace --tests
+ $ just lint-rust
+
+And make sure your code is formatted, using:
+
+ $ just format-rust
-And make sure your code is formatted with, using:
+You can also run the entire suite of pre-commit checks (which includes spelling and shell checks) with:
- $ cargo fmt
+ $ just pre-commit
Finally, ensure there is no trailing whitespace anywhere.
@@ -61,7 +75,7 @@ without effectively testing anything.
If you make documentation changes, you may want to check whether there are any
warnings or errors:
- $ cargo doc --workspace --all-features
+ $ just check-docs
### Code style
commit 4018cf0c1e6d86bb398f8296b2366c809fca4146
Author: Adrian Duke <adrian.duke@gmail.com>
Date: Wed Apr 8 18:28:34 2026 +0100
git-hook-template: minor output formatting
diff --git a/scripts/git-hook-template.sh b/scripts/git-hook-template.sh
index 4b6f93ec5..5b17cec0c 100644
--- a/scripts/git-hook-template.sh
+++ b/scripts/git-hook-template.sh
@@ -14,7 +14,7 @@ for file in "${SENSITIVE_FILES[@]}"; do
done
if [ ${#CHANGED_FILES[@]} -gt 0 ]; then
- echo "⚠️ WARNING: Sensitive files have been modified relative to $BASE_BRANCH."
+ echo "⚠️ WARNING: Sensitive files have been modified relative to $BASE_BRANCH."
echo "Executing these hooks may run arbitrary code from the modified files."
echo ""
@@ -28,7 +28,7 @@ if [ ${#CHANGED_FILES[@]} -gt 0 ]; then
# Read from /dev/tty because stdin is not attached to the terminal in git hooks.
exec < /dev/tty
- read -r -p "Do you want to continue executing the ${HOOK_NAME} hooks? [y/N] " response
+ read -r -p "⚠️ Do you want to continue executing the ${HOOK_NAME} hooks? [y/N] " response
case "$response" in
[yY][eE][sS]|[yY])
echo "Continuing with ${HOOK_NAME} hooks..."
@@ -42,14 +42,12 @@ fi
# Execute the appropriate just recipe based on the hook name
if [ "$HOOK_NAME" = "pre-commit" ]; then
- echo "Running pre-commit checks..."
just pre-commit
elif [ "$HOOK_NAME" = "pre-push" ]; then
- echo "Running pre-push checks..."
just pre-push
elif [ "$HOOK_NAME" = "post-checkout" ]; then
just post-checkout
else
- echo "Unknown hook: $HOOK_NAME"
+ echo "⚠️ Unknown hook: $HOOK_NAME"
exit 1
fi
commit 6a67d26c3a494d8735e8aa39f0db1a4ae5882c8a
Author: Adrian Duke <adrian.duke@gmail.com>
Date: Wed Apr 8 18:28:06 2026 +0100
just: Add post-checkout hook
diff --git a/justfile b/justfile
index 1a7b0b790..039aabd42 100644
--- a/justfile
+++ b/justfile
@@ -11,7 +11,9 @@ CHECK := "🔄 " + BOLD
default: check-hooks
@just --list
+# Run post-checkout checks
[group('hooks')]
+post-checkout:
# Run pre-commit checks
[group('hooks')]
diff --git a/scripts/git-hook-template.sh b/scripts/git-hook-template.sh
index 77077e76e..4b6f93ec5 100644
--- a/scripts/git-hook-template.sh
+++ b/scripts/git-hook-template.sh
@@ -47,6 +47,8 @@ if [ "$HOOK_NAME" = "pre-commit" ]; then
elif [ "$HOOK_NAME" = "pre-push" ]; then
echo "Running pre-push checks..."
just pre-push
+elif [ "$HOOK_NAME" = "post-checkout" ]; then
+ just post-checkout
else
echo "Unknown hook: $HOOK_NAME"
exit 1
commit ab8dc4c407e592e8c1e7a457de437814932202a1
Author: Adrian Duke <adrian.duke@gmail.com>
Date: Wed Apr 8 18:27:04 2026 +0100
just: Add check-hooks to confirm presence and integrity
diff --git a/justfile b/justfile
index 115f2e1ad..1a7b0b790 100644
--- a/justfile
+++ b/justfile
@@ -11,19 +11,7 @@ CHECK := "🔄 " + BOLD
default: check-hooks
@just --list
-# SECURITY: We COPY the hook template instead of symlinking it. This ensures that
-# checking out an untrusted patch won't overwrite your local git hooks. The copied
-# script also checks if sensitive files (like build.rs or justfile) were modified
-# in the patch and prompts for confirmation, preventing arbitrary code execution.
-#
-# Install git hooks
[group('hooks')]
-install-hooks:
- @cp scripts/git-hook-template.sh .git/hooks/pre-commit
- @chmod +x .git/hooks/pre-commit
- @cp scripts/git-hook-template.sh .git/hooks/pre-push
- @chmod +x .git/hooks/pre-push
- @echo "✅ pre-commit and pre-push hooks installed."
# Run pre-commit checks
[group('hooks')]
@@ -150,3 +138,57 @@ verify-tool tool package_name="":
echo "{{HINT}}Use your systems package manager to install '$PKG'.{{NORMAL}}"
exit 1
fi
+
+# SECURITY: We COPY the hook template instead of symlinking it. This ensures that
+# checking out an untrusted patch won't overwrite your local git hooks. The copied
+# script also checks if sensitive files (like build.rs or justfile) were modified
+# in the patch and prompts for confirmation, preventing arbitrary code execution.
+#
+# Install git hooks
+[group('hooks')]
+[confirm("Overwrite existing hooks '" + hooks + "'?")]
+install-hooks:
+ #!/usr/bin/env bash
+ set -e
+ for hook in {{hooks}}; do
+ cp {{hook-script}} ".git/hooks/$hook"
+ chmod +x ".git/hooks/$hook"
+ done
+ echo ""
+ echo "{{SUCCESS}}Hooks installed: {{hooks + NORMAL}}"
+
+# Check for missing or changed hooks
+[group('hooks')]
+check-hooks:
+ #!/usr/bin/env bash
+ set -e
+ TEMPLATE="{{hook-script}}"
+ OUTDATED=()
+ MISSING=0
+ TOTAL=0
+
+ for hook in {{hooks}}; do
+ TOTAL=$((TOTAL + 1))
+ if [ ! -f ".git/hooks/$hook" ]; then
+ MISSING=$((MISSING + 1))
+ OUTDATED+=("$hook")
+ elif ! cmp -s "$TEMPLATE" ".git/hooks/$hook"; then
+ OUTDATED+=("$hook")
+ fi
+ done
+
+ if [ "$MISSING" -eq "$TOTAL" ] && [ "$TOTAL" -gt 0 ]; then
+ echo ""
+ echo "{{HINT}}No git hooks are installed. Run 'just install-hooks' to install them.{{NORMAL}}"
+ echo ""
+ elif [ ${#OUTDATED[@]} -gt 0 ]; then
+ echo ""
+ echo "{{WARN}}WARNING: The following git hooks are missing or out of date:{{NORMAL}}"
+ echo ""
+ for hook in "${OUTDATED[@]}"; do
+ echo -e "\t$hook"
+ done
+ echo ""
+ echo "{{HINT}}Check them with 'diff scripts/git-hook-template.sh .git/hooks/<hook name>' then run 'just install-hooks'{{NORMAL}}"
+ echo ""
+ fi
commit 6ae9b48c8f930dab1e7270bf4941b8117feb2cd7
Author: Adrian Duke <adrian.duke@gmail.com>
Date: Wed Apr 8 18:25:48 2026 +0100
just: Introduce output formatting
diff --git a/justfile b/justfile
index b54aa64e7..115f2e1ad 100644
--- a/justfile
+++ b/justfile
@@ -1,4 +1,14 @@
-default:
+hooks := "pre-commit pre-push post-checkout"
+hook-script := "scripts/git-hook-template.sh"
+
+bold_underlined := BOLD + UNDERLINE
+WARN := "⚠️ " + YELLOW + bold_underlined
+SUCCESS := "✅ " + GREEN + bold_underlined
+ERROR := "❌ " + RED + bold_underlined
+HINT := "💡 " + BOLD
+CHECK := "🔄 " + BOLD
+
+default: check-hooks
@just --list
# SECURITY: We COPY the hook template instead of symlinking it. This ensures that
@@ -18,7 +28,9 @@ install-hooks:
# Run pre-commit checks
[group('hooks')]
pre-commit: format-rust check-rust check-docs check-typos check-spelling check-scripts check-keywords format-nix
- @echo "✅ pre-commit passed"
+ @echo ""
+ @echo "{{SUCCESS}}pre-commit passed!{{NORMAL}}"
+ @echo ""
# Format Rust code
[group('pre-commit')]
@@ -26,7 +38,7 @@ pre-commit: format-rust check-rust check-docs check-typos check-spelling check-s
[group('format')]
[parallel]
format-rust: (verify-tool "cargo")
- @echo "Cargo fmt..."
+ @echo "{{CHECK}}Cargo fmt...{{NORMAL}}"
@cargo fmt --all
# Run cargo check
@@ -35,7 +47,7 @@ format-rust: (verify-tool "cargo")
[group('check')]
[parallel]
check-rust:
- @echo "Cargo check..."
+ @echo "{{CHECK}}Cargo check...{{NORMAL}}"
@cargo check --workspace --all-targets --all-features
# Check documentation for warnings
@@ -44,7 +56,7 @@ check-rust:
[group('check')]
[parallel]
check-docs:
- @echo "Checking docs for warnings..."
+ @echo "{{CHECK}}Checking docs for warnings...{{NORMAL}}"
@RUSTDOCFLAGS="--deny warnings" cargo doc --workspace --all-features --no-deps
# Check for typos
@@ -53,7 +65,7 @@ check-docs:
[group('check')]
[parallel]
check-typos: (verify-tool "typos" "typos-cli")
- @echo "Checking for spelling typos..."
+ @echo "{{CHECK}}Checking for spelling typos...{{NORMAL}}"
@typos
# Run codespell
@@ -62,7 +74,7 @@ check-typos: (verify-tool "typos" "typos-cli")
[group('check')]
[parallel]
check-spelling: (verify-tool "codespell")
- @echo "Checking for code typos..."
+ @echo "{{CHECK}}Checking for code typos...{{NORMAL}}"
@git ls-files -z | xargs -0 codespell -w
# Run shellcheck on all shell scripts
@@ -71,7 +83,7 @@ check-spelling: (verify-tool "codespell")
[group('check')]
[parallel]
check-scripts: (verify-tool "shellcheck")
- @echo "Checking shell scripts..."
+ @echo "{{CHECK}}Checking shell scripts...{{NORMAL}}"
@shellcheck scripts/*.sh
# Replicate the custom grep checks from flake.nix
@@ -82,7 +94,7 @@ check-scripts: (verify-tool "shellcheck")
check-keywords: (verify-tool "rg" "ripgrep")
#!/usr/bin/env bash
set -e
- echo "Checking for forbidden words in staged files..."
+ echo "{{CHECK}}Checking for forbidden words in staged files...{{NORMAL}}"
# Get staged Rust files
STAGED_FILES=$(git diff --cached --name-only --diff-filter=ACMR | grep '\.rs$' || true)
@@ -114,12 +126,14 @@ format-nix:
# Run pre-push checks
[group('hooks')]
pre-push: format-rust check-rust check-keywords check-docs check-spelling check-scripts check-typos format-nix lint-rust
- @echo "✅ pre-push passed"
+ @echo ""
+ @echo "{{SUCCESS}}pre-push passed!{{NORMAL}}"
+ @echo ""
# Run Clippy lints
[group('pre-push')]
lint-rust: (verify-tool "cargo")
- @echo "Cargo clippy..."
+ @echo "{{CHECK}}Cargo clippy...{{NORMAL}}"
@cargo clippy --workspace --all-targets --all-features -- --deny warnings
# Check if required tools are in PATH.
@@ -132,7 +146,7 @@ verify-tool tool package_name="":
if [ -z "$PKG" ]; then
PKG="{{tool}}"
fi
- echo "❌ Missing required tool: {{tool}}"
- echo "💡 Use your systems package manager to install '$PKG'."
+ echo "{{ERROR}}Missing required tool: {{tool + NORMAL}}"
+ echo "{{HINT}}Use your systems package manager to install '$PKG'.{{NORMAL}}"
exit 1
fi
commit 5723bd95797c3c528f0014b811eb330e4bf269a6
Author: Adrian Duke <adrian.duke@gmail.com>
Date: Wed Apr 8 17:31:32 2026 +0100
just: Introduce pre-commit and pre-push installer
Copies the template script into the git hooks DIR to prevent a potential
attacker overwriting its contents. Also introduces a check before
running the hook against sensitive files from `master`, if there are
changes between the branch and `master`, asks user to confirm
continuation of hook execution.
diff --git a/justfile b/justfile
index 010b87a0f..b54aa64e7 100644
--- a/justfile
+++ b/justfile
@@ -1,6 +1,20 @@
default:
@just --list
+# SECURITY: We COPY the hook template instead of symlinking it. This ensures that
+# checking out an untrusted patch won't overwrite your local git hooks. The copied
+# script also checks if sensitive files (like build.rs or justfile) were modified
+# in the patch and prompts for confirmation, preventing arbitrary code execution.
+#
+# Install git hooks
+[group('hooks')]
+install-hooks:
+ @cp scripts/git-hook-template.sh .git/hooks/pre-commit
+ @chmod +x .git/hooks/pre-commit
+ @cp scripts/git-hook-template.sh .git/hooks/pre-push
+ @chmod +x .git/hooks/pre-push
+ @echo "✅ pre-commit and pre-push hooks installed."
+
# Run pre-commit checks
[group('hooks')]
pre-commit: format-rust check-rust check-docs check-typos check-spelling check-scripts check-keywords format-nix
diff --git a/scripts/git-hook-template.sh b/scripts/git-hook-template.sh
new file mode 100644
index 000000000..77077e76e
--- /dev/null
+++ b/scripts/git-hook-template.sh
@@ -0,0 +1,53 @@
+#!/usr/bin/env bash
+set -e
+
+HOOK_NAME=$(basename "$0")
+SENSITIVE_FILES=("justfile" "build.rs" "rust-toolchain.toml")
+CHANGED_FILES=()
+BASE_BRANCH="master"
+
+for file in "${SENSITIVE_FILES[@]}"; do
+ # Check if the file differs between the base branch and the current working tree
+ if git diff --name-only "$BASE_BRANCH" 2>/dev/null | grep -q "^${file}$"; then
+ CHANGED_FILES+=("$file")
+ fi
+done
+
+if [ ${#CHANGED_FILES[@]} -gt 0 ]; then
+ echo "⚠️ WARNING: Sensitive files have been modified relative to $BASE_BRANCH."
+ echo "Executing these hooks may run arbitrary code from the modified files."
+ echo ""
+
+ for file in "${CHANGED_FILES[@]}"; do
+ echo "--- Diff for $file ---"
+ git --no-pager diff "$BASE_BRANCH" -- "$file"
+ echo "------------------------"
+ done
+ echo ""
+
+ # Read from /dev/tty because stdin is not attached to the terminal in git hooks.
+ exec < /dev/tty
+
+ read -r -p "Do you want to continue executing the ${HOOK_NAME} hooks? [y/N] " response
+ case "$response" in
+ [yY][eE][sS]|[yY])
+ echo "Continuing with ${HOOK_NAME} hooks..."
+ ;;
+ *)
+ echo "Skipping ${HOOK_NAME} hooks."
+ exit 0
+ ;;
+ esac
+fi
+
+# Execute the appropriate just recipe based on the hook name
+if [ "$HOOK_NAME" = "pre-commit" ]; then
+ echo "Running pre-commit checks..."
+ just pre-commit
+elif [ "$HOOK_NAME" = "pre-push" ]; then
+ echo "Running pre-push checks..."
+ just pre-push
+else
+ echo "Unknown hook: $HOOK_NAME"
+ exit 1
+fi
commit 53fd00dec66d06810bf9a73ef8619c4de2cc1e99
Author: Adrian Duke <adrian.duke@gmail.com>
Date: Wed Apr 8 17:28:48 2026 +0100
just: Add groupings and parallel where possible
diff --git a/justfile b/justfile
index 9ef70e98d..010b87a0f 100644
--- a/justfile
+++ b/justfile
@@ -2,40 +2,69 @@ default:
@just --list
# Run pre-commit checks
+[group('hooks')]
pre-commit: format-rust check-rust check-docs check-typos check-spelling check-scripts check-keywords format-nix
@echo "✅ pre-commit passed"
# Format Rust code
+[group('pre-commit')]
+[group('pre-push')]
+[group('format')]
+[parallel]
format-rust: (verify-tool "cargo")
@echo "Cargo fmt..."
@cargo fmt --all
# Run cargo check
+[group('pre-commit')]
+[group('pre-push')]
+[group('check')]
+[parallel]
check-rust:
@echo "Cargo check..."
@cargo check --workspace --all-targets --all-features
# Check documentation for warnings
+[group('pre-commit')]
+[group('pre-push')]
+[group('check')]
+[parallel]
check-docs:
@echo "Checking docs for warnings..."
@RUSTDOCFLAGS="--deny warnings" cargo doc --workspace --all-features --no-deps
# Check for typos
+[group('pre-commit')]
+[group('pre-push')]
+[group('check')]
+[parallel]
check-typos: (verify-tool "typos" "typos-cli")
@echo "Checking for spelling typos..."
@typos
# Run codespell
+[group('pre-commit')]
+[group('pre-push')]
+[group('check')]
+[parallel]
check-spelling: (verify-tool "codespell")
@echo "Checking for code typos..."
@git ls-files -z | xargs -0 codespell -w
# Run shellcheck on all shell scripts
+[group('pre-commit')]
+[group('pre-push')]
+[group('check')]
+[parallel]
check-scripts: (verify-tool "shellcheck")
@echo "Checking shell scripts..."
@shellcheck scripts/*.sh
# Replicate the custom grep checks from flake.nix
+[group('pre-commit')]
+[group('pre-push')]
+[group('check')]
+[parallel]
check-keywords: (verify-tool "rg" "ripgrep")
#!/usr/bin/env bash
set -e
@@ -56,6 +85,10 @@ check-keywords: (verify-tool "rg" "ripgrep")
fi
# Format Nix files
+[group('pre-commit')]
+[group('pre-push')]
+[group('format')]
+[parallel]
format-nix:
#!/usr/bin/env bash
if command -v alejandra >/dev/null 2>&1; then
@@ -65,10 +98,12 @@ format-nix:
fi
# Run pre-push checks
+[group('hooks')]
pre-push: format-rust check-rust check-keywords check-docs check-spelling check-scripts check-typos format-nix lint-rust
@echo "✅ pre-push passed"
# Run Clippy lints
+[group('pre-push')]
lint-rust: (verify-tool "cargo")
@echo "Cargo clippy..."
@cargo clippy --workspace --all-targets --all-features -- --deny warnings
commit 0a1601cce2dbed8ad1dd2ac0c041d678290b6757
Author: Adrian Duke <adrian.duke@gmail.com>
Date: Wed Apr 8 17:28:00 2026 +0100
just: Add pre-commit hook
diff --git a/justfile b/justfile
index 3a9301c3f..9ef70e98d 100644
--- a/justfile
+++ b/justfile
@@ -1,6 +1,10 @@
default:
@just --list
+# Run pre-commit checks
+pre-commit: format-rust check-rust check-docs check-typos check-spelling check-scripts check-keywords format-nix
+ @echo "✅ pre-commit passed"
+
# Format Rust code
format-rust: (verify-tool "cargo")
@echo "Cargo fmt..."
commit 74166c209ea2928e89401204c271703734f80f30
Author: Adrian Duke <adrian.duke@gmail.com>
Date: Wed Apr 8 17:27:44 2026 +0100
just: Add more pre-push tasks
Migrating further pre-push checks from `flake.nix`
diff --git a/justfile b/justfile
index 5e5d42452..3a9301c3f 100644
--- a/justfile
+++ b/justfile
@@ -1,8 +1,67 @@
default:
@just --list
+# Format Rust code
+format-rust: (verify-tool "cargo")
+ @echo "Cargo fmt..."
+ @cargo fmt --all
+
+# Run cargo check
+check-rust:
+ @echo "Cargo check..."
+ @cargo check --workspace --all-targets --all-features
+
+# Check documentation for warnings
+check-docs:
+ @echo "Checking docs for warnings..."
+ @RUSTDOCFLAGS="--deny warnings" cargo doc --workspace --all-features --no-deps
+
+# Check for typos
+check-typos: (verify-tool "typos" "typos-cli")
+ @echo "Checking for spelling typos..."
+ @typos
+
+# Run codespell
+check-spelling: (verify-tool "codespell")
+ @echo "Checking for code typos..."
+ @git ls-files -z | xargs -0 codespell -w
+
+# Run shellcheck on all shell scripts
+check-scripts: (verify-tool "shellcheck")
+ @echo "Checking shell scripts..."
+ @shellcheck scripts/*.sh
+
+# Replicate the custom grep checks from flake.nix
+check-keywords: (verify-tool "rg" "ripgrep")
+ #!/usr/bin/env bash
+ set -e
+ echo "Checking for forbidden words in staged files..."
+
+ # Get staged Rust files
+ STAGED_FILES=$(git diff --cached --name-only --diff-filter=ACMR | grep '\.rs$' || true)
+
+ if [ -n "$STAGED_FILES" ]; then
+ ! echo "$STAGED_FILES" | xargs rg --context=3 --fixed-strings 'radicle.xyz'
+ ! echo "$STAGED_FILES" | xargs rg --context=3 --fixed-strings 'radicle.zulipchat.com'
+
+ # For `git2::` we need to exclude raw.rs
+ FILTERED_GIT2=$(echo "$STAGED_FILES" | grep '^crates/radicle/.*\.rs$' | grep -v 'crates/radicle/src/git/raw.rs' || true)
+ if [ -n "$FILTERED_GIT2" ]; then
+ ! echo "$FILTERED_GIT2" | xargs rg --context=3 --fixed-strings 'git2::'
+ fi
+ fi
+
+# Format Nix files
+format-nix:
+ #!/usr/bin/env bash
+ if command -v alejandra >/dev/null 2>&1; then
+ alejandra --check .
+ else
+ echo "⏭️ alejandra not found, skipping Nix formatting."
+ fi
+
# Run pre-push checks
-pre-push: lint-rust
+pre-push: format-rust check-rust check-keywords check-docs check-spelling check-scripts check-typos format-nix lint-rust
@echo "✅ pre-push passed"
# Run Clippy lints
commit 993b15d9370459178537cda9d49632633718a2b6
Author: Adrian Duke <adrian.duke@gmail.com>
Date: Wed Apr 8 17:14:20 2026 +0100
just: Introduce justfile with pre-push hook cmds
As part of migrating from `flake.nix` to a more universal task runner
that can manage git hooks too.
diff --git a/justfile b/justfile
new file mode 100644
index 000000000..5e5d42452
--- /dev/null
+++ b/justfile
@@ -0,0 +1,26 @@
+default:
+ @just --list
+
+# Run pre-push checks
+pre-push: lint-rust
+ @echo "✅ pre-push passed"
+
+# Run Clippy lints
+lint-rust: (verify-tool "cargo")
+ @echo "Cargo clippy..."
+ @cargo clippy --workspace --all-targets --all-features -- --deny warnings
+
+# Check if required tools are in PATH.
+[private]
+verify-tool tool package_name="":
+ #!/usr/bin/env bash
+ set -e
+ if ! command -v {{tool}} >/dev/null 2>&1; then
+ PKG="{{package_name}}"
+ if [ -z "$PKG" ]; then
+ PKG="{{tool}}"
+ fi
+ echo "❌ Missing required tool: {{tool}}"
+ echo "💡 Use your systems package manager to install '$PKG'."
+ exit 1
+ fi
commit 4fe34358719405df62f17b31449ab8356bd6e1b2
Author: Adrian Duke <adrian.duke@gmail.com>
Date: Wed Apr 8 15:27:22 2026 +0100
codespell: Add 'ser' to word ignore
codespell is misidentifying `::serde::ser` as `::serde::set`
diff --git a/.codespellrc b/.codespellrc
index 5940b8cd3..86c46f6ba 100644
--- a/.codespellrc
+++ b/.codespellrc
@@ -1,4 +1,4 @@
[codespell]
skip = .git*,*.lock,.codespellrc,target,.jj
check-hidden = true
-ignore-words-list = set,noes
+ignore-words-list = ser,set,noes
commit ba7911a1e4df9f9a47e03123f4b7f557bc43648d
Author: Adrian Duke <adrian.duke@gmail.com>
Date: Wed Apr 8 15:20:46 2026 +0100
typos: Lint check failure writeable -> writable
diff --git a/crates/radicle-cli/src/commands/issue/cache.rs b/crates/radicle-cli/src/commands/issue/cache.rs
index 4685c5801..f76fd7566 100644
--- a/crates/radicle-cli/src/commands/issue/cache.rs
+++ b/crates/radicle-cli/src/commands/issue/cache.rs
@@ -39,9 +39,9 @@ pub fn run(mode: CacheMode, profile: &Profile) -> anyhow::Result<()> {
fn cache(id: Option<IssueId>, repository: &Repository, profile: &Profile) -> anyhow::Result<()> {
let mut issues = {
- // NOTE: Since we require a cache that is writeable, on top of a store that
+ // NOTE: Since we require a cache that is writable, on top of a store that
// is read-only, we can neither use [`term::cob::issues_mut`] nor [`term::cob::issues`]
- // since these convenience functions pair a writeable cache with a writeable
+ // since these convenience functions pair a writable cache with a writable
// store, and respectively a read-only cache with a read-only store.
let db = profile.cobs_db_mut()?;
diff --git a/crates/radicle-cli/src/commands/patch/cache.rs b/crates/radicle-cli/src/commands/patch/cache.rs
index da979f221..4cb0078bd 100644
--- a/crates/radicle-cli/src/commands/patch/cache.rs
+++ b/crates/radicle-cli/src/commands/patch/cache.rs
@@ -39,9 +39,9 @@ pub fn run(mode: CacheMode, profile: &Profile) -> anyhow::Result<()> {
fn cache(id: Option<PatchId>, repository: &Repository, profile: &Profile) -> anyhow::Result<()> {
let mut patches = {
- // NOTE: Since we require a cache that is writeable, on top of a store that
+ // NOTE: Since we require a cache that is writable, on top of a store that
// is read-only, we can neither use [`term::cob::patches_mut`] nor [`term::cob::patches`]
- // since these convenience functions pair a writeable cache with a writeable
+ // since these convenience functions pair a writable cache with a writable
// store, and respectively a read-only cache with a read-only store.
let db = profile.cobs_db_mut()?;
Exit code: 0
shell: 'export RUSTDOCFLAGS=''-D warnings'' cargo --version rustc --version cargo fmt --check cargo clippy --all-targets --workspace -- --deny warnings cargo build --all-targets --workspace cargo doc --workspace --no-deps --all-features cargo test --workspace --no-fail-fast '
Commands:
$ podman run --name 861f49cc-f392-4113-8c11-c93a524f2c05 -v /opt/radcis/ci.rad.levitte.org/cci/state/861f49cc-f392-4113-8c11-c93a524f2c05/s:/861f49cc-f392-4113-8c11-c93a524f2c05/s:ro -v /opt/radcis/ci.rad.levitte.org/cci/state/861f49cc-f392-4113-8c11-c93a524f2c05/w:/861f49cc-f392-4113-8c11-c93a524f2c05/w -w /861f49cc-f392-4113-8c11-c93a524f2c05/w -v /opt/radcis/ci.rad.levitte.org/.radicle:/${id}/.radicle:ro -e RAD_HOME=/${id}/.radicle rust:trixie bash /861f49cc-f392-4113-8c11-c93a524f2c05/s/script.sh
+ export 'RUSTDOCFLAGS=-D warnings'
+ RUSTDOCFLAGS='-D warnings'
+ cargo --version
info: syncing channel updates for '1.90-x86_64-unknown-linux-gnu'
info: latest update on 2025-09-18, rust version 1.90.0 (1159e78c4 2025-09-14)
info: downloading component 'cargo'
info: downloading component 'clippy'
info: downloading component 'rust-docs'
info: downloading component 'rust-src'
info: downloading component 'rust-std'
info: downloading component 'rustc'
info: downloading component 'rustfmt'
info: installing component 'cargo'
info: installing component 'clippy'
info: installing component 'rust-docs'
info: installing component 'rust-src'
info: installing component 'rust-std'
info: installing component 'rustc'
info: installing component 'rustfmt'
cargo 1.90.0 (840b83a10 2025-07-30)
+ rustc --version
rustc 1.90.0 (1159e78c4 2025-09-14)
+ cargo fmt --check
+ cargo clippy --all-targets --workspace -- --deny warnings
Updating crates.io index
Downloading crates ...
Downloaded aes v0.8.4
Downloaded git-ref-format v0.6.0
Downloaded arc-swap v1.8.2
Downloaded gix-chunk v0.5.0
Downloaded lexopt v0.3.2
Downloaded aho-corasick v1.1.4
Downloaded icu_collections v2.1.1
Downloaded getrandom v0.3.4
Downloaded keccak v0.1.6
Downloaded itoa v1.0.17
Downloaded gix-sec v0.13.1
Downloaded once_cell v1.21.4
Downloaded iana-time-zone v0.1.65
Downloaded is_terminal_polyfill v1.70.2
Downloaded fnv v1.0.7
Downloaded gix-commitgraph v0.33.0
Downloaded heck v0.5.0
Downloaded data-encoding-macro v0.1.19
Downloaded borrow-or-share v0.2.4
Downloaded gix-error v0.1.0
Downloaded group v0.13.0
Downloaded fluent-uri v0.3.2
Downloaded num v0.4.3
Downloaded humantime v2.3.0
Downloaded potential_utf v0.1.4
Downloaded gix-utils v0.3.1
Downloaded inout v0.1.4
Downloaded gix-negotiate v0.27.0
Downloaded normalize-line-endings v0.3.0
Downloaded matchers v0.2.0
Downloaded opaque-debug v0.3.1
Downloaded multibase v0.9.2
Downloaded jobserver v0.1.34
Downloaded num-iter v0.1.45
Downloaded phf_shared v0.11.3
Downloaded proc-macro-error-attr2 v2.0.0
Downloaded pbkdf2 v0.12.2
Downloaded same-file v1.0.6
Downloaded scrypt v0.11.0
Downloaded quote v1.0.45
Downloaded ref-cast v1.0.25
Downloaded rand_xorshift v0.4.0
Downloaded serde_fmt v1.1.0
Downloaded qcheck v1.0.0
Downloaded rfc6979 v0.4.0
Downloaded signature v1.6.4
Downloaded schemars_derive v1.2.1
Downloaded shell-words v1.1.1
Downloaded siphasher v1.0.2
Downloaded polyval v0.6.2
Downloaded ssh-encoding v0.2.0
Downloaded sval_fmt v2.17.0
Downloaded gix-ref v0.59.0
Downloaded strsim v0.11.1
Downloaded fraction v0.15.3
Downloaded sval_ref v2.17.0
Downloaded gix-path v0.11.1
Downloaded test-log-macros v0.2.19
Downloaded spki v0.7.3
Downloaded streaming-iterator v0.1.9
Downloaded sqlite v0.37.0
Downloaded stable_deref_trait v1.2.1
Downloaded tinyvec_macros v0.1.1
Downloaded sval_nested v2.17.0
Downloaded structured-logger v1.0.5
Downloaded thiserror v1.0.69
Downloaded tree-sitter-language v0.1.7
Downloaded ryu v1.0.23
Downloaded universal-hash v0.5.1
Downloaded value-bag-sval2 v1.12.0
Downloaded serde_derive v1.0.228
Downloaded wait-timeout v0.2.1
Downloaded tree-sitter-toml-ng v0.6.0
Downloaded zerofrom v0.1.6
Downloaded xattr v1.6.1
Downloaded tree-sitter-highlight v0.24.7
Downloaded socket2 v0.5.10
Downloaded zerofrom-derive v0.1.6
Downloaded tree-sitter-css v0.23.2
Downloaded unicode-display-width v0.3.0
Downloaded serde v1.0.228
Downloaded walkdir v2.5.0
Downloaded zerovec-derive v0.11.2
Downloaded rand v0.8.5
Downloaded zeroize v1.8.2
Downloaded yoke v0.8.1
Downloaded value-bag v1.12.0
Downloaded writeable v0.6.2
Downloaded zmij v1.0.21
Downloaded unicode-ident v1.0.24
Downloaded uuid v1.22.0
Downloaded serde_core v1.0.228
Downloaded hashbrown v0.16.1
Downloaded yansi v1.0.1
Downloaded zerotrie v0.2.3
Downloaded ssh-key v0.6.7
Downloaded url v2.5.8
Downloaded tree-sitter-go v0.23.4
Downloaded unicode-segmentation v1.12.0
Downloaded unicode-normalization v0.1.25
Downloaded serde_json v1.0.149
Downloaded zerovec v0.11.5
Downloaded proptest v1.10.0
Downloaded tree-sitter-python v0.23.6
Downloaded winnow v0.7.15
Downloaded tracing-subscriber v0.3.23
Downloaded syn v1.0.109
Downloaded zlib-rs v0.6.3
Downloaded bstr v1.12.1
Downloaded unicode-width v0.2.2
Downloaded zerocopy v0.8.42
Downloaded tree-sitter-md v0.3.2
Downloaded object v0.37.3
Downloaded regex-syntax v0.8.10
Downloaded tree-sitter-rust v0.23.3
Downloaded rustix v1.1.4
Downloaded tree-sitter-bash v0.23.3
Downloaded tracing v0.1.44
Downloaded syn v2.0.117
Downloaded vcpkg v0.2.15
Downloaded tree-sitter-c v0.23.4
Downloaded bloomy v1.2.0
Downloaded tree-sitter-ruby v0.23.1
Downloaded sysinfo v0.37.2
Downloaded curve25519-dalek v4.1.3
Downloaded regex-automata v0.4.14
Downloaded tree-sitter v0.24.7
Downloaded chrono v0.4.44
Downloaded portable-atomic v1.13.1
Downloaded regex v1.12.3
Downloaded libc v0.2.183
Downloaded jiff v0.2.23
Downloaded radicle-surf v0.27.1
Downloaded p521 v0.13.3
Downloaded p384 v0.13.1
Downloaded libm v0.2.16
Downloaded clap_builder v4.6.0
Downloaded sha1-checked v0.10.0
Downloaded sha3 v0.10.8
Downloaded libz-sys v1.1.25
Downloaded tree-sitter-typescript v0.23.2
Downloaded tokio v1.50.0
Downloaded typenum v1.19.0
Downloaded rand v0.9.2
Downloaded num-bigint-dig v0.8.6
Downloaded sval v2.17.0
Downloaded tracing-core v0.1.36
Downloaded toml v0.9.12+spec-1.1.0
Downloaded schemars v1.2.1
Downloaded tinyvec v1.11.0
Downloaded signal-hook v0.3.18
Downloaded derive_more-impl v2.1.1
Downloaded vsimd v0.8.0
Downloaded value-bag-serde1 v1.12.0
Downloaded tar v0.4.45
Downloaded prodash v31.0.0
Downloaded memchr v2.8.0
Downloaded rsa v0.9.10
Downloaded num-bigint v0.4.6
Downloaded jsonschema v0.30.0
Downloaded yoke-derive v0.8.1
Downloaded version_check v0.9.5
Downloaded pretty_assertions v1.4.1
Downloaded tree-sitter-html v0.23.2
Downloaded tracing-log v0.2.0
Downloaded tempfile v3.27.0
Downloaded ssh-agent-lib v0.5.2
Downloaded spin v0.9.8
Downloaded cyphernet v0.5.2
Downloaded uuid-simd v0.8.0
Downloaded utf8parse v0.2.2
Downloaded utf8_iter v1.0.4
Downloaded unit-prefix v0.5.2
Downloaded unarray v0.1.4
Downloaded typeid v1.0.3
Downloaded snapbox v0.4.17
Downloaded similar v2.7.0
Downloaded itertools v0.14.0
Downloaded mio v1.1.1
Downloaded derive_more v2.1.1
Downloaded tree-sitter-json v0.24.8
Downloaded toml_writer v1.0.7+spec-1.1.0
Downloaded toml_datetime v0.7.5+spec-1.1.0
Downloaded tinystr v0.8.2
Downloaded timeago v0.4.2
Downloaded thread_local v1.1.9
Downloaded thiserror-impl v2.0.18
Downloaded thiserror-impl v1.0.69
Downloaded thiserror v2.0.18
Downloaded test-log v0.2.19
Downloaded systemd-journal-logger v2.2.2
Downloaded signals_receipts v0.2.5
Downloaded sharded-slab v0.1.7
Downloaded proc-macro2 v1.0.106
Downloaded clap v4.6.0
Downloaded libgit2-sys v0.18.3+1.9.2
Downloaded smallvec v1.15.1
Downloaded icu_locale_core v2.1.1
Downloaded synstructure v0.13.2
Downloaded sval_serde v2.17.0
Downloaded sqlite3-sys v0.18.0
Downloaded idna v1.1.0
Downloaded socks5-client v0.4.1
Downloaded crypto-bigint v0.5.5
Downloaded crossterm v0.29.0
Downloaded parking_lot v0.12.5
Downloaded icu_normalizer v2.1.1
Downloaded sval_buffer v2.17.0
Downloaded simd-adler32 v0.3.8
Downloaded signal-hook-registry v1.4.8
Downloaded parking_lot_core v0.9.12
Downloaded litrs v1.0.0
Downloaded jiff-static v0.2.23
Downloaded sval_json v2.17.0
Downloaded sval_dynamic v2.17.0
Downloaded ssh-cipher v0.2.0
Downloaded shlex v1.3.0
Downloaded sha2 v0.10.9
Downloaded serde_derive_internals v0.29.1
Downloaded serde-untagged v0.1.9
Downloaded sem_safe v0.2.1
Downloaded sec1 v0.7.3
Downloaded rusty-fork v0.3.1
Downloaded referencing v0.30.0
Downloaded rand_core v0.9.5
Downloaded pkg-config v0.3.32
Downloaded pkcs1 v0.7.5
Downloaded p256 v0.13.2
Downloaded num-traits v0.2.19
Downloaded num-complex v0.4.6
Downloaded miniz_oxide v0.8.9
Downloaded base64 v0.21.7
Downloaded emojis v0.6.4
Downloaded bytes v1.11.1
Downloaded pkcs8 v0.10.2
Downloaded pin-project-lite v0.2.17
Downloaded der v0.7.10
Downloaded gix-pack v0.65.0
Downloaded subtle v2.6.1
Downloaded snapbox-macros v0.3.10
Downloaded siphasher v0.3.11
Downloaded semver v1.0.27
Downloaded sqlite3-src v0.7.0
Downloaded icu_normalizer_data v2.1.1
Downloaded signature v2.2.0
Downloaded signal-hook-mio v0.2.5
Downloaded linux-raw-sys v0.12.1
Downloaded sha1 v0.10.6
Downloaded memmap2 v0.9.10
Downloaded serde_spanned v1.0.4
Downloaded rustversion v1.0.22
Downloaded litemap v0.8.1
Downloaded salsa20 v0.10.2
Downloaded primeorder v0.13.6
Downloaded ppv-lite86 v0.2.21
Downloaded pem-rfc7468 v0.7.0
Downloaded poly1305 v0.8.0
Downloaded scopeguard v1.2.0
Downloaded rustc-demangle v0.1.27
Downloaded proc-macro-error2 v2.0.1
Downloaded rand_chacha v0.9.0
Downloaded num-integer v0.1.46
Downloaded nu-ansi-term v0.50.3
Downloaded log v0.4.29
Downloaded secrecy v0.10.3
Downloaded rand_chacha v0.3.1
Downloaded qcheck-macros v1.0.0
Downloaded chacha20poly1305 v0.10.1
Downloaded rand_core v0.6.4
Downloaded radicle-std-ext v0.2.0
Downloaded radicle-git-ext v0.12.0
Downloaded pastey v0.2.1
Downloaded gix-date v0.13.0
Downloaded ed25519-dalek v2.2.0
Downloaded console v0.16.3
Downloaded phf v0.11.3
Downloaded percent-encoding v2.3.2
Downloaded lazy_static v1.5.0
Downloaded inquire v0.9.4
Downloaded gix-object v0.56.0
Downloaded outref v0.5.2
Downloaded num-rational v0.4.2
Downloaded hmac v0.12.1
Downloaded gix-features v0.46.1
Downloaded rustc_version v0.4.1
Downloaded ref-cast-impl v1.0.25
Downloaded quick-error v1.2.3
Downloaded maybe-async v0.2.10
Downloaded lock_api v0.4.14
Downloaded icu_properties v2.1.2
Downloaded crossbeam-channel v0.5.15
Downloaded cc v1.2.57
Downloaded noise-framework v0.4.0
Downloaded indexmap v2.13.0
Downloaded icu_provider v2.1.1
Downloaded elliptic-curve v0.13.8
Downloaded gix-credentials v0.36.0
Downloaded displaydoc v0.2.5
Downloaded digest v0.10.7
Downloaded gix-shallow v0.8.1
Downloaded num-cmp v0.1.0
Downloaded gix-refspec v0.37.0
Downloaded gix-packetline v0.21.1
Downloaded gix-fs v0.19.1
Downloaded indicatif v0.18.4
Downloaded gix-date v0.14.0
Downloaded generic-array v0.14.7
Downloaded gix-hash v0.22.1
Downloaded const-str v0.4.3
Downloaded chacha20 v0.9.1
Downloaded bit-vec v0.8.0
Downloaded crypto-common v0.1.7
Downloaded nonempty v0.9.0
Downloaded match-lookup v0.1.2
Downloaded idna_adapter v1.2.1
Downloaded git-ref-format-core v0.6.0
Downloaded gix-traverse v0.52.0
Downloaded gix-revwalk v0.27.0
Downloaded gix-protocol v0.57.0
Downloaded gix-odb v0.75.0
Downloaded gix-actor v0.39.0
Downloaded form_urlencoded v1.2.2
Downloaded clap_complete v4.6.0
Downloaded hash32 v0.3.1
Downloaded colored v2.2.0
Downloaded clap_derive v4.6.0
Downloaded cipher v0.4.4
Downloaded cyphergraphy v0.3.0
Downloaded base256emoji v1.0.2
Downloaded gix-object v0.55.0
Downloaded data-encoding-macro-internal v0.1.17
Downloaded base64ct v1.8.3
Downloaded cypheraddr v0.4.0
Downloaded ct-codecs v1.1.6
Downloaded base64 v0.22.1
Downloaded gix-trace v0.1.18
Downloaded gix-hashtable v0.12.0
Downloaded ed25519 v2.2.3
Downloaded const-oid v0.9.6
Downloaded gix-command v0.7.1
Downloaded gix-chunk v0.6.0
Downloaded block-buffer v0.10.4
Downloaded ecdsa v0.16.9
Downloaded colorchoice v1.0.5
Downloaded icu_properties_data v2.1.2
Downloaded gix-revwalk v0.26.0
Downloaded gix-config-value v0.17.1
Downloaded block-padding v0.3.3
Downloaded human-panic v2.0.6
Downloaded gix-revision v0.41.0
Downloaded gix-error v0.0.0
Downloaded gix-commitgraph v0.32.0
Downloaded crossbeam-utils v0.8.21
Downloaded convert_case v0.10.0
Downloaded bytesize v2.3.1
Downloaded gix-validate v0.11.0
Downloaded gix-tempfile v21.0.1
Downloaded gix-actor v0.38.0
Downloaded ff v0.13.1
Downloaded ctr v0.9.2
Downloaded cfg-if v1.0.4
Downloaded base-x v0.2.11
Downloaded gix-quote v0.6.2
Downloaded gix-diff v0.58.0
Downloaded flate2 v1.1.9
Downloaded env_filter v1.0.0
Downloaded ed25519 v1.5.3
Downloaded gix-url v0.35.2
Downloaded gix-glob v0.24.0
Downloaded ec25519 v0.1.0
Downloaded bytecount v0.6.9
Downloaded bitflags v2.11.0
Downloaded bcrypt-pbkdf v0.10.0
Downloaded autocfg v1.5.0
Downloaded gix-prompt v0.13.1
Downloaded gix-lock v21.0.1
Downloaded git2 v0.20.4
Downloaded gimli v0.32.3
Downloaded find-msvc-tools v0.1.9
Downloaded fancy-regex v0.14.0
Downloaded errno v0.3.14
Downloaded env_logger v0.11.9
Downloaded email_address v0.2.9
Downloaded dyn-clone v1.0.20
Downloaded dunce v1.0.5
Downloaded document-features v0.2.12
Downloaded data-encoding v2.10.0
Downloaded curve25519-dalek-derive v0.1.1
Downloaded crc32fast v1.5.0
Downloaded blowfish v0.9.1
Downloaded backtrace v0.3.76
Downloaded amplify_derive v4.0.1
Downloaded fastrand v2.3.0
Downloaded escargot v0.5.15
Downloaded either v1.15.0
Downloaded diff v0.1.13
Downloaded clap_lex v1.1.0
Downloaded byteorder v1.5.0
Downloaded bit-set v0.8.0
Downloaded base16ct v0.2.0
Downloaded anstream v1.0.0
Downloaded anstream v0.6.21
Downloaded heapless v0.8.0
Downloaded gix-transport v0.54.0
Downloaded git-ref-format-macro v0.6.0
Downloaded ghash v0.5.1
Downloaded getrandom v0.2.17
Downloaded filetime v0.2.27
Downloaded faster-hex v0.10.0
Downloaded equivalent v1.0.2
Downloaded cpufeatures v0.2.17
Downloaded cbc v0.1.2
Downloaded base32 v0.4.0
Downloaded fast-glob v0.3.3
Downloaded anyhow v1.0.102
Downloaded anstyle-parse v0.2.7
Downloaded amplify_num v0.5.3
Downloaded getrandom v0.4.2
Downloaded ascii v1.1.0
Downloaded anstyle-parse v1.0.0
Downloaded amplify_syn v2.0.1
Downloaded amplify v4.9.0
Downloaded ahash v0.8.12
Downloaded aes-gcm v0.10.3
Downloaded aead v0.5.2
Downloaded adler2 v2.0.1
Downloaded addr2line v0.25.1
Downloaded erased-serde v0.4.10
Downloaded anstyle-query v1.1.5
Downloaded anstyle v1.0.14
Compiling libc v0.2.183
Compiling proc-macro2 v1.0.106
Compiling quote v1.0.45
Compiling unicode-ident v1.0.24
Checking cfg-if v1.0.4
Checking zeroize v1.8.2
Compiling version_check v0.9.5
Compiling typenum v1.19.0
Compiling generic-array v0.14.7
Checking memchr v2.8.0
Compiling syn v2.0.117
Checking getrandom v0.2.17
Checking rand_core v0.6.4
Checking subtle v2.6.1
Compiling shlex v1.3.0
Checking crypto-common v0.1.7
Compiling find-msvc-tools v0.1.9
Checking regex-syntax v0.8.10
Checking aho-corasick v1.1.4
Compiling jobserver v0.1.34
Compiling cc v1.2.57
Checking const-oid v0.9.6
Checking smallvec v1.15.1
Compiling serde_core v1.0.228
Checking regex-automata v0.4.14
Checking block-buffer v0.10.4
Checking digest v0.10.7
Checking cpufeatures v0.2.17
Compiling thiserror v2.0.18
Checking stable_deref_trait v1.2.1
Checking fastrand v2.3.0
Compiling parking_lot_core v0.9.12
Checking scopeguard v1.2.0
Checking lock_api v0.4.14
Checking tinyvec_macros v0.1.1
Checking parking_lot v0.12.5
Checking tinyvec v1.11.0
Checking bstr v1.12.1
Checking bitflags v2.11.0
Checking gix-trace v0.1.18
Compiling crc32fast v1.5.0
Checking unicode-normalization v0.1.25
Checking gix-validate v0.11.0
Checking byteorder v1.5.0
Checking itoa v1.0.17
Compiling typeid v1.0.3
Checking gix-utils v0.3.1
Compiling erased-serde v0.4.10
Checking same-file v1.0.6
Checking hashbrown v0.16.1
Compiling serde v1.0.228
Compiling thiserror-impl v2.0.18
Compiling serde_derive v1.0.228
Checking walkdir v2.5.0
Checking prodash v31.0.0
Checking zlib-rs v0.6.3
Checking serde_fmt v1.1.0
Compiling heapless v0.8.0
Checking value-bag-serde1 v1.12.0
Checking hash32 v0.3.1
Compiling synstructure v0.13.2
Checking gix-path v0.11.1
Checking gix-features v0.46.1
Checking value-bag v1.12.0
Checking faster-hex v0.10.0
Compiling zerofrom-derive v0.1.6
Compiling yoke-derive v0.8.1
Checking log v0.4.29
Checking sha1 v0.10.6
Checking sha1-checked v0.10.0
Compiling rustix v1.1.4
Compiling pkg-config v0.3.32
Checking zerofrom v0.1.6
Checking yoke v0.8.1
Checking gix-hash v0.22.1
Compiling zerovec-derive v0.11.2
Checking block-padding v0.3.3
Checking linux-raw-sys v0.12.1
Compiling autocfg v1.5.0
Compiling zerocopy v0.8.42
Compiling libm v0.2.16
Compiling num-traits v0.2.19
Checking inout v0.1.4
Compiling displaydoc v0.2.5
Checking sha2 v0.10.9
Checking zerovec v0.11.5
Compiling getrandom v0.4.2
Checking cipher v0.4.4
Checking tinystr v0.8.2
Checking der v0.7.10
Checking once_cell v1.21.4
Checking writeable v0.6.2
Checking percent-encoding v2.3.2
Checking litemap v0.8.1
Checking zerotrie v0.2.3
Checking icu_locale_core v2.1.1
Checking potential_utf v0.1.4
Compiling thiserror v1.0.69
Compiling icu_properties_data v2.1.2
Compiling icu_normalizer_data v2.1.1
Compiling zmij v1.0.21
Compiling syn v1.0.109
Checking icu_provider v2.1.1
Checking icu_collections v2.1.1
Compiling thiserror-impl v1.0.69
Compiling serde_json v1.0.149
Checking equivalent v1.0.2
Checking indexmap v2.13.0
Checking ppv-lite86 v0.2.21
Checking num-integer v0.1.46
Checking hmac v0.12.1
Checking universal-hash v0.5.1
Compiling ref-cast v1.0.25
Checking opaque-debug v0.3.1
Compiling vcpkg v0.2.15
Compiling tree-sitter-language v0.1.7
Checking icu_properties v2.1.2
Checking icu_normalizer v2.1.1
Compiling libz-sys v1.1.25
Checking tempfile v3.27.0
Checking spki v0.7.3
Compiling ref-cast-impl v1.0.25
Checking signature v2.2.0
Checking ff v0.13.1
Checking spin v0.9.8
Checking base16ct v0.2.0
Checking lazy_static v1.5.0
Checking sec1 v0.7.3
Checking group v0.13.0
Checking idna_adapter v1.2.1
Checking rand_chacha v0.3.1
Checking crypto-bigint v0.5.5
Checking dyn-clone v1.0.20
Checking utf8_iter v1.0.4
Checking rand v0.8.5
Checking idna v1.1.0
Compiling amplify_syn v2.0.1
Checking num-iter v0.1.45
Compiling libgit2-sys v0.18.3+1.9.2
Checking aead v0.5.2
Checking signature v1.6.4
Compiling semver v1.0.27
Compiling amplify_derive v4.0.1
Checking elliptic-curve v0.13.8
Compiling rustc_version v0.4.1
Checking ed25519 v1.5.3
Checking poly1305 v0.8.0
Checking rfc6979 v0.4.0
Checking form_urlencoded v1.2.2
Checking chacha20 v0.9.1
Compiling serde_derive_internals v0.29.1
Checking ascii v1.1.0
Checking amplify_num v0.5.3
Checking ct-codecs v1.1.6
Checking ec25519 v0.1.0
Compiling schemars_derive v1.2.1
Checking url v2.5.8
Checking amplify v4.9.0
Checking ecdsa v0.16.9
Compiling curve25519-dalek v4.1.3
Checking primeorder v0.13.6
Checking git-ref-format-core v0.6.0
Checking polyval v0.6.2
Compiling num-bigint-dig v0.8.6
Checking base64ct v1.8.3
Checking ghash v0.5.1
Checking cyphergraphy v0.3.0
Checking pem-rfc7468 v0.7.0
Checking schemars v1.2.1
Checking pkcs8 v0.10.2
Checking pbkdf2 v0.12.2
Checking ctr v0.9.2
Checking aes v0.8.4
Compiling sqlite3-src v0.7.0
Compiling curve25519-dalek-derive v0.1.1
Checking keccak v0.1.6
Checking aes-gcm v0.10.3
Checking sha3 v0.10.8
Checking pkcs1 v0.7.5
Checking ssh-encoding v0.2.0
Checking ed25519 v2.2.3
Checking blowfish v0.9.1
Checking cbc v0.1.2
Checking base32 v0.4.0
Compiling data-encoding v2.10.0
Checking cypheraddr v0.4.0
Checking rsa v0.9.10
Compiling data-encoding-macro-internal v0.1.17
Checking ssh-cipher v0.2.0
Checking bcrypt-pbkdf v0.10.0
Checking ed25519-dalek v2.2.0
Checking p256 v0.13.2
Checking p521 v0.13.3
Checking p384 v0.13.1
Checking chacha20poly1305 v0.10.1
Checking qcheck v1.0.0
Compiling match-lookup v0.1.2
Checking jiff v0.2.23
Checking const-str v0.4.3
Checking data-encoding-macro v0.1.19
Checking base256emoji v1.0.2
Checking noise-framework v0.4.0
Checking ssh-key v0.6.7
Checking socks5-client v0.4.1
Checking secrecy v0.10.3
Checking base-x v0.2.11
Compiling crossbeam-utils v0.8.21
Checking multibase v0.9.2
Checking ssh-agent-lib v0.5.2
Checking cyphernet v0.5.2
Checking winnow v0.7.15
Checking crossbeam-channel v0.5.15
Checking anstyle-query v1.1.5
Checking utf8parse v0.2.2
Checking nonempty v0.9.0
Checking gix-hashtable v0.12.0
Checking siphasher v1.0.2
Checking radicle-git-metadata v0.2.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-git-metadata)
Checking gix-error v0.1.0
Checking radicle-dag v0.10.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-dag)
Checking memmap2 v0.9.10
Checking colorchoice v1.0.5
Checking anstyle v1.0.14
Checking is_terminal_polyfill v1.70.2
Checking radicle-git-ref-format v0.1.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-git-ref-format)
Checking base64 v0.21.7
Checking iana-time-zone v0.1.65
Checking chrono v0.4.44
Checking radicle-localtime v0.1.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-localtime)
Checking colored v2.2.0
Checking serde-untagged v0.1.9
Checking gix-error v0.0.0
Checking bytesize v2.3.1
Checking errno v0.3.14
Checking dunce v1.0.5
Checking fast-glob v0.3.3
Checking gix-date v0.14.0
Checking anstyle-parse v0.2.7
Checking gix-actor v0.39.0
Checking anstream v0.6.21
Checking gix-date v0.13.0
Checking gix-fs v0.19.1
Checking gix-actor v0.38.0
Checking gix-tempfile v21.0.1
Checking gix-object v0.56.0
Checking gix-chunk v0.6.0
Checking gix-quote v0.6.2
Checking gix-commitgraph v0.33.0
Checking gix-object v0.55.0
Checking gix-chunk v0.5.0
Checking mio v1.1.1
Checking sem_safe v0.2.1
Checking either v1.15.0
Checking shell-words v1.1.1
Checking gix-command v0.7.1
Checking signals_receipts v0.2.5
Checking gix-commitgraph v0.32.0
Checking gix-revwalk v0.27.0
Compiling rustversion v1.0.22
Compiling object v0.37.3
Checking gix-revwalk v0.26.0
Checking gix-lock v21.0.1
Checking gix-url v0.35.2
Checking gix-config-value v0.17.1
Checking gix-sec v0.13.1
Compiling signal-hook v0.3.18
Checking adler2 v2.0.1
Checking gimli v0.32.3
Compiling unicode-segmentation v1.12.0
Compiling convert_case v0.10.0
Checking miniz_oxide v0.8.9
Checking gix-prompt v0.13.1
Checking gix-traverse v0.52.0
Checking addr2line v0.25.1
Checking gix-revision v0.41.0
Checking radicle-signals v0.11.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-signals)
Checking gix-diff v0.58.0
Checking signal-hook-registry v1.4.8
Checking gix-packetline v0.21.1
Checking gix-glob v0.24.0
Compiling tree-sitter v0.24.7
Compiling anyhow v1.0.102
Checking rustc-demangle v0.1.27
Checking backtrace v0.3.76
Checking gix-refspec v0.37.0
Checking gix-transport v0.54.0
Checking gix-pack v0.65.0
Checking arc-swap v1.8.2
Checking gix-credentials v0.36.0
Compiling derive_more-impl v2.1.1
Checking gix-ref v0.59.0
Checking gix-shallow v0.8.1
Checking gix-negotiate v0.27.0
Compiling maybe-async v0.2.10
Checking regex v1.12.3
Compiling proc-macro-error-attr2 v2.0.0
Compiling litrs v1.0.0
Compiling simd-adler32 v0.3.8
Checking unicode-width v0.2.2
Compiling portable-atomic v1.13.1
Compiling getrandom v0.3.4
Compiling document-features v0.2.12
Compiling proc-macro-error2 v2.0.1
Checking gix-protocol v0.57.0
Checking derive_more v2.1.1
Checking gix-odb v0.75.0
Checking signal-hook-mio v0.2.5
Compiling xattr v1.6.1
Compiling filetime v0.2.27
Checking anstyle-parse v1.0.0
Checking uuid v1.22.0
Checking bytes v1.11.1
Checking anstream v1.0.0
Compiling flate2 v1.1.9
Compiling tar v0.4.45
Checking crossterm v0.29.0
Compiling git-ref-format-macro v0.6.0
Checking console v0.16.3
Checking snapbox-macros v0.3.10
Checking salsa20 v0.10.2
Checking clap_lex v1.1.0
Checking streaming-iterator v0.1.9
Checking unit-prefix v0.5.2
Checking strsim v0.11.1
Compiling heck v0.5.0
Checking similar v2.7.0
Checking siphasher v0.3.11
Checking normalize-line-endings v0.3.0
Checking bloomy v1.2.0
Checking snapbox v0.4.17
Compiling clap_derive v4.6.0
Checking clap_builder v4.6.0
Checking indicatif v0.18.4
Compiling radicle-surf v0.27.1
Checking scrypt v0.11.0
Checking git-ref-format v0.6.0
Checking inquire v0.9.4
Checking unicode-display-width v0.3.0
Checking systemd-journal-logger v2.2.2
Checking serde_spanned v1.0.4
Checking toml_datetime v0.7.5+spec-1.1.0
Checking sqlite3-sys v0.18.0
Compiling tree-sitter-c v0.23.4
Checking sqlite v0.37.0
Compiling tree-sitter-css v0.23.2
Compiling tree-sitter-toml-ng v0.6.0
Checking radicle-crypto v0.16.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-crypto)
Compiling tree-sitter-go v0.23.4
Compiling tree-sitter-rust v0.23.3
Compiling tree-sitter-bash v0.23.3
Compiling tree-sitter-python v0.23.6
Compiling tree-sitter-typescript v0.23.2
Compiling tree-sitter-json v0.24.8
Compiling tree-sitter-html v0.23.2
Compiling tree-sitter-ruby v0.23.1
Compiling tree-sitter-md v0.3.2
Checking toml_writer v1.0.7+spec-1.1.0
Checking pin-project-lite v0.2.17
Checking radicle-std-ext v0.2.0
Checking toml v0.9.12+spec-1.1.0
Checking tokio v1.50.0
Checking clap v4.6.0
Checking sysinfo v0.37.2
Checking yansi v1.0.1
Compiling radicle-node v0.19.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-node)
Checking diff v0.1.13
Compiling radicle-cli v0.20.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-cli)
Checking human-panic v2.0.6
Checking pretty_assertions v1.4.1
Checking clap_complete v4.6.0
Checking structured-logger v1.0.5
Checking radicle-systemd v0.12.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-systemd)
Checking tree-sitter-highlight v0.24.7
Checking itertools v0.14.0
Compiling qcheck-macros v1.0.0
Checking socket2 v0.5.10
Checking timeago v0.4.2
Checking lexopt v0.3.2
Compiling escargot v0.5.15
Checking humantime v2.3.0
Checking bit-vec v0.8.0
Checking bit-set v0.8.0
Checking rand_core v0.9.5
Checking num-bigint v0.4.6
Compiling ahash v0.8.12
Checking num-complex v0.4.6
Checking env_filter v1.0.0
Checking borrow-or-share v0.2.4
Checking fluent-uri v0.3.2
Checking env_logger v0.11.9
Checking phf_shared v0.11.3
Compiling test-log-macros v0.2.19
Checking wait-timeout v0.2.1
Checking outref v0.5.2
Checking num-rational v0.4.2
Checking vsimd v0.8.0
Checking fnv v1.0.7
Compiling radicle-remote-helper v0.16.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-remote-helper)
Checking num v0.4.3
Checking quick-error v1.2.3
Checking uuid-simd v0.8.0
Checking rusty-fork v0.3.1
Checking fraction v0.15.3
Checking test-log v0.2.19
Checking phf v0.11.3
Checking referencing v0.30.0
Checking rand_xorshift v0.4.0
Checking rand_chacha v0.9.0
Checking rand v0.9.2
Checking fancy-regex v0.14.0
Checking email_address v0.2.9
Checking unarray v0.1.4
Checking num-cmp v0.1.0
Checking base64 v0.22.1
Checking bytecount v0.6.9
Checking proptest v1.10.0
Checking emojis v0.6.4
Checking jsonschema v0.30.0
Compiling pastey v0.2.1
Checking radicle-windows v0.1.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-windows)
Checking git2 v0.20.4
Checking radicle-oid v0.1.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-oid)
Checking radicle-git-ext v0.12.0
Checking radicle-term v0.17.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-term)
Checking radicle-core v0.2.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-core)
Checking radicle-cob v0.19.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-cob)
Checking radicle v0.23.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle)
Checking radicle-fetch v0.19.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-fetch)
Checking radicle-cli-test v0.13.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-cli-test)
Checking radicle-schemars v0.7.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-schemars)
Checking radicle-protocol v0.7.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-protocol)
Finished `dev` profile [unoptimized + debuginfo] target(s) in 44.98s
+ cargo build --all-targets --workspace
Compiling libc v0.2.183
Compiling cfg-if v1.0.4
Compiling zeroize v1.8.2
Compiling typenum v1.19.0
Compiling memchr v2.8.0
Compiling subtle v2.6.1
Compiling shlex v1.3.0
Compiling regex-syntax v0.8.10
Compiling generic-array v0.14.7
Compiling aho-corasick v1.1.4
Compiling getrandom v0.2.17
Compiling rand_core v0.6.4
Compiling jobserver v0.1.34
Compiling crypto-common v0.1.7
Compiling cc v1.2.57
Compiling const-oid v0.9.6
Compiling smallvec v1.15.1
Compiling serde_core v1.0.228
Compiling regex-automata v0.4.14
Compiling block-buffer v0.10.4
Compiling digest v0.10.7
Compiling cpufeatures v0.2.17
Compiling stable_deref_trait v1.2.1
Compiling thiserror v2.0.18
Compiling fastrand v2.3.0
Compiling scopeguard v1.2.0
Compiling lock_api v0.4.14
Compiling parking_lot_core v0.9.12
Compiling bitflags v2.11.0
Compiling parking_lot v0.12.5
Compiling tinyvec_macros v0.1.1
Compiling tinyvec v1.11.0
Compiling gix-trace v0.1.18
Compiling byteorder v1.5.0
Compiling unicode-normalization v0.1.25
Compiling crc32fast v1.5.0
Compiling itoa v1.0.17
Compiling typeid v1.0.3
Compiling hashbrown v0.16.1
Compiling same-file v1.0.6
Compiling walkdir v2.5.0
Compiling gix-utils v0.3.1
Compiling erased-serde v0.4.10
Compiling prodash v31.0.0
Compiling zlib-rs v0.6.3
Compiling serde v1.0.228
Compiling bstr v1.12.1
Compiling serde_fmt v1.1.0
Compiling value-bag-serde1 v1.12.0
Compiling hash32 v0.3.1
Compiling heapless v0.8.0
Compiling gix-validate v0.11.0
Compiling value-bag v1.12.0
Compiling gix-path v0.11.1
Compiling log v0.4.29
Compiling faster-hex v0.10.0
Compiling zerofrom v0.1.6
Compiling sha1 v0.10.6
Compiling yoke v0.8.1
Compiling sha1-checked v0.10.0
Compiling block-padding v0.3.3
Compiling linux-raw-sys v0.12.1
Compiling zerovec v0.11.5
Compiling inout v0.1.4
Compiling sha2 v0.10.9
Compiling cipher v0.4.4
Compiling libm v0.2.16
Compiling gix-features v0.46.1
Compiling gix-hash v0.22.1
Compiling rustix v1.1.4
Compiling zerocopy v0.8.42
Compiling getrandom v0.4.2
Compiling tinystr v0.8.2
Compiling der v0.7.10
Compiling num-traits v0.2.19
Compiling percent-encoding v2.3.2
Compiling writeable v0.6.2
Compiling litemap v0.8.1
Compiling once_cell v1.21.4
Compiling icu_locale_core v2.1.1
Compiling zerotrie v0.2.3
Compiling potential_utf v0.1.4
Compiling icu_collections v2.1.1
Compiling icu_provider v2.1.1
Compiling equivalent v1.0.2
Compiling indexmap v2.13.0
Compiling zmij v1.0.21
Compiling icu_normalizer_data v2.1.1
Compiling icu_properties_data v2.1.2
Compiling num-integer v0.1.46
Compiling hmac v0.12.1
Compiling universal-hash v0.5.1
Compiling opaque-debug v0.3.1
Compiling libz-sys v1.1.25
Compiling thiserror v1.0.69
Compiling ppv-lite86 v0.2.21
Compiling serde_json v1.0.149
Compiling icu_properties v2.1.2
Compiling icu_normalizer v2.1.1
Compiling tempfile v3.27.0
Compiling spki v0.7.3
Compiling signature v2.2.0
Compiling ff v0.13.1
Compiling spin v0.9.8
Compiling base16ct v0.2.0
Compiling lazy_static v1.5.0
Compiling group v0.13.0
Compiling sec1 v0.7.3
Compiling idna_adapter v1.2.1
Compiling ref-cast v1.0.25
Compiling rand_chacha v0.3.1
Compiling crypto-bigint v0.5.5
Compiling dyn-clone v1.0.20
Compiling utf8_iter v1.0.4
Compiling rand v0.8.5
Compiling num-iter v0.1.45
Compiling idna v1.1.0
Compiling libgit2-sys v0.18.3+1.9.2
Compiling aead v0.5.2
Compiling signature v1.6.4
Compiling ed25519 v1.5.3
Compiling poly1305 v0.8.0
Compiling rfc6979 v0.4.0
Compiling form_urlencoded v1.2.2
Compiling elliptic-curve v0.13.8
Compiling chacha20 v0.9.1
Compiling amplify_num v0.5.3
Compiling ascii v1.1.0
Compiling ct-codecs v1.1.6
Compiling ec25519 v0.1.0
Compiling primeorder v0.13.6
Compiling ecdsa v0.16.9
Compiling url v2.5.8
Compiling git-ref-format-core v0.6.0
Compiling amplify v4.9.0
Compiling polyval v0.6.2
Compiling base64ct v1.8.3
Compiling cyphergraphy v0.3.0
Compiling ghash v0.5.1
Compiling pem-rfc7468 v0.7.0
Compiling schemars v1.2.1
Compiling pkcs8 v0.10.2
Compiling pbkdf2 v0.12.2
Compiling ctr v0.9.2
Compiling aes v0.8.4
Compiling sqlite3-src v0.7.0
Compiling keccak v0.1.6
Compiling sha3 v0.10.8
Compiling aes-gcm v0.10.3
Compiling curve25519-dalek v4.1.3
Compiling pkcs1 v0.7.5
Compiling ssh-encoding v0.2.0
Compiling num-bigint-dig v0.8.6
Compiling ed25519 v2.2.3
Compiling cbc v0.1.2
Compiling blowfish v0.9.1
Compiling base32 v0.4.0
Compiling cypheraddr v0.4.0
Compiling rsa v0.9.10
Compiling bcrypt-pbkdf v0.10.0
Compiling ssh-cipher v0.2.0
Compiling ed25519-dalek v2.2.0
Compiling p384 v0.13.1
Compiling p256 v0.13.2
Compiling p521 v0.13.3
Compiling chacha20poly1305 v0.10.1
Compiling qcheck v1.0.0
Compiling const-str v0.4.3
Compiling jiff v0.2.23
Compiling data-encoding v2.10.0
Compiling data-encoding-macro v0.1.19
Compiling base256emoji v1.0.2
Compiling ssh-key v0.6.7
Compiling noise-framework v0.4.0
Compiling socks5-client v0.4.1
Compiling secrecy v0.10.3
Compiling base-x v0.2.11
Compiling multibase v0.9.2
Compiling ssh-agent-lib v0.5.2
Compiling cyphernet v0.5.2
Compiling crossbeam-utils v0.8.21
Compiling winnow v0.7.15
Compiling crossbeam-channel v0.5.15
Compiling anstyle-query v1.1.5
Compiling utf8parse v0.2.2
Compiling gix-hashtable v0.12.0
Compiling nonempty v0.9.0
Compiling siphasher v1.0.2
Compiling gix-error v0.1.0
Compiling radicle-dag v0.10.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-dag)
Compiling radicle-git-metadata v0.2.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-git-metadata)
Compiling memmap2 v0.9.10
Compiling colorchoice v1.0.5
Compiling anstyle v1.0.14
Compiling is_terminal_polyfill v1.70.2
Compiling radicle-git-ref-format v0.1.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-git-ref-format)
Compiling iana-time-zone v0.1.65
Compiling base64 v0.21.7
Compiling chrono v0.4.44
Compiling radicle-localtime v0.1.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-localtime)
Compiling colored v2.2.0
Compiling tree-sitter-language v0.1.7
Compiling gix-error v0.0.0
Compiling serde-untagged v0.1.9
Compiling bytesize v2.3.1
Compiling errno v0.3.14
Compiling dunce v1.0.5
Compiling fast-glob v0.3.3
Compiling gix-date v0.14.0
Compiling anstyle-parse v0.2.7
Compiling adler2 v2.0.1
Compiling anstream v0.6.21
Compiling gix-actor v0.39.0
Compiling gix-date v0.13.0
Compiling gix-fs v0.19.1
Compiling gix-tempfile v21.0.1
Compiling gix-actor v0.38.0
Compiling gix-object v0.56.0
Compiling gix-chunk v0.6.0
Compiling gix-quote v0.6.2
Compiling gix-commitgraph v0.33.0
Compiling gix-object v0.55.0
Compiling gix-chunk v0.5.0
Compiling mio v1.1.1
Compiling sem_safe v0.2.1
Compiling shell-words v1.1.1
Compiling either v1.15.0
Compiling gix-command v0.7.1
Compiling signals_receipts v0.2.5
Compiling gix-commitgraph v0.32.0
Compiling gix-revwalk v0.27.0
Compiling unicode-segmentation v1.12.0
Compiling gix-revwalk v0.26.0
Compiling gix-lock v21.0.1
Compiling gix-url v0.35.2
Compiling gix-config-value v0.17.1
Compiling gix-sec v0.13.1
Compiling gimli v0.32.3
Compiling gix-prompt v0.13.1
Compiling gix-traverse v0.52.0
Compiling convert_case v0.10.0
Compiling object v0.37.3
Compiling addr2line v0.25.1
Compiling gix-revision v0.41.0
Compiling radicle-signals v0.11.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-signals)
Compiling gix-diff v0.58.0
Compiling miniz_oxide v0.8.9
Compiling signal-hook-registry v1.4.8
Compiling gix-glob v0.24.0
Compiling gix-packetline v0.21.1
Compiling tree-sitter v0.24.7
Compiling rustc-demangle v0.1.27
Compiling backtrace v0.3.76
Compiling gix-transport v0.54.0
Compiling gix-refspec v0.37.0
Compiling sqlite3-sys v0.18.0
Compiling sqlite v0.37.0
Compiling signal-hook v0.3.18
Compiling radicle-crypto v0.16.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-crypto)
Compiling gix-pack v0.65.0
Compiling arc-swap v1.8.2
Compiling derive_more-impl v2.1.1
Compiling gix-credentials v0.36.0
Compiling gix-ref v0.59.0
Compiling gix-shallow v0.8.1
Compiling gix-negotiate v0.27.0
Compiling regex v1.12.3
Compiling unicode-width v0.2.2
Compiling gix-protocol v0.57.0
Compiling gix-odb v0.75.0
Compiling derive_more v2.1.1
Compiling signal-hook-mio v0.2.5
Compiling xattr v1.6.1
Compiling anstyle-parse v1.0.0
Compiling uuid v1.22.0
Compiling filetime v0.2.27
Compiling bytes v1.11.1
Compiling tar v0.4.45
Compiling git-ref-format-macro v0.6.0
Compiling anstream v1.0.0
Compiling crossterm v0.29.0
Compiling flate2 v1.1.9
Compiling getrandom v0.3.4
Compiling portable-atomic v1.13.1
Compiling console v0.16.3
Compiling anyhow v1.0.102
Compiling snapbox-macros v0.3.10
Compiling salsa20 v0.10.2
Compiling siphasher v0.3.11
Compiling similar v2.7.0
Compiling streaming-iterator v0.1.9
Compiling normalize-line-endings v0.3.0
Compiling clap_lex v1.1.0
Compiling strsim v0.11.1
Compiling unit-prefix v0.5.2
Compiling snapbox v0.4.17
Compiling indicatif v0.18.4
Compiling clap_builder v4.6.0
Compiling bloomy v1.2.0
Compiling radicle-surf v0.27.1
Compiling scrypt v0.11.0
Compiling inquire v0.9.4
Compiling git-ref-format v0.6.0
Compiling unicode-display-width v0.3.0
Compiling systemd-journal-logger v2.2.2
Compiling toml_datetime v0.7.5+spec-1.1.0
Compiling serde_spanned v1.0.4
Compiling tree-sitter-html v0.23.2
Compiling tree-sitter-css v0.23.2
Compiling tree-sitter-bash v0.23.3
Compiling tree-sitter-typescript v0.23.2
Compiling tree-sitter-rust v0.23.3
Compiling tree-sitter-go v0.23.4
Compiling tree-sitter-md v0.3.2
Compiling tree-sitter-json v0.24.8
Compiling tree-sitter-ruby v0.23.1
Compiling tree-sitter-c v0.23.4
Compiling tree-sitter-python v0.23.6
Compiling tree-sitter-toml-ng v0.6.0
Compiling radicle-std-ext v0.2.0
Compiling pin-project-lite v0.2.17
Compiling toml_writer v1.0.7+spec-1.1.0
Compiling tokio v1.50.0
Compiling toml v0.9.12+spec-1.1.0
Compiling clap v4.6.0
Compiling sysinfo v0.37.2
Compiling radicle-cli v0.20.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-cli)
Compiling yansi v1.0.1
Compiling radicle-node v0.19.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-node)
Compiling diff v0.1.13
Compiling pretty_assertions v1.4.1
Compiling human-panic v2.0.6
Compiling clap_complete v4.6.0
Compiling structured-logger v1.0.5
Compiling radicle-systemd v0.12.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-systemd)
Compiling tree-sitter-highlight v0.24.7
Compiling itertools v0.14.0
Compiling socket2 v0.5.10
Compiling lexopt v0.3.2
Compiling timeago v0.4.2
Compiling humantime v2.3.0
Compiling bit-vec v0.8.0
Compiling bit-set v0.8.0
Compiling escargot v0.5.15
Compiling rand_core v0.9.5
Compiling num-bigint v0.4.6
Compiling num-complex v0.4.6
Compiling env_filter v1.0.0
Compiling borrow-or-share v0.2.4
Compiling fluent-uri v0.3.2
Compiling num-rational v0.4.2
Compiling env_logger v0.11.9
Compiling num v0.4.3
Compiling ahash v0.8.12
Compiling phf_shared v0.11.3
Compiling wait-timeout v0.2.1
Compiling fnv v1.0.7
Compiling outref v0.5.2
Compiling radicle-remote-helper v0.16.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-remote-helper)
Compiling vsimd v0.8.0
Compiling git2 v0.20.4
Compiling quick-error v1.2.3
Compiling rusty-fork v0.3.1
Compiling test-log v0.2.19
Compiling uuid-simd v0.8.0
Compiling phf v0.11.3
Compiling referencing v0.30.0
Compiling fraction v0.15.3
Compiling rand_chacha v0.9.0
Compiling rand v0.9.2
Compiling rand_xorshift v0.4.0
Compiling fancy-regex v0.14.0
Compiling email_address v0.2.9
Compiling base64 v0.22.1
Compiling num-cmp v0.1.0
Compiling bytecount v0.6.9
Compiling unarray v0.1.4
Compiling proptest v1.10.0
Compiling jsonschema v0.30.0
Compiling emojis v0.6.4
Compiling radicle-oid v0.1.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-oid)
Compiling radicle-core v0.2.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-core)
Compiling radicle-cob v0.19.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-cob)
Compiling radicle-git-ext v0.12.0
Compiling radicle v0.23.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle)
Compiling radicle-term v0.17.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-term)
Compiling radicle-windows v0.1.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-windows)
Compiling radicle-fetch v0.19.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-fetch)
Compiling radicle-protocol v0.7.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-protocol)
Compiling radicle-cli-test v0.13.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-cli-test)
Compiling radicle-schemars v0.7.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-schemars)
Finished `dev` profile [unoptimized + debuginfo] target(s) in 58.92s
+ cargo doc --workspace --no-deps --all-features
Checking regex-automata v0.4.14
Compiling num-traits v0.2.19
Compiling syn v1.0.109
Checking once_cell v1.21.4
Checking tempfile v3.27.0
Checking idna v1.1.0
Checking url v2.5.8
Checking num-integer v0.1.46
Checking git2 v0.20.4
Checking num-iter v0.1.45
Checking num-bigint-dig v0.8.6
Compiling amplify_syn v2.0.1
Checking bstr v1.12.1
Checking gix-validate v0.11.0
Checking git-ref-format-core v0.6.0
Checking gix-path v0.11.1
Compiling amplify_derive v4.0.1
Checking gix-features v0.46.1
Checking rsa v0.9.10
Checking gix-hash v0.22.1
Checking radicle-git-ref-format v0.1.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-git-ref-format)
Checking gix-hashtable v0.12.0
Checking ssh-key v0.6.7
Checking radicle-oid v0.1.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-oid)
Checking gix-error v0.1.0
Checking rusty-fork v0.3.1
Checking gix-error v0.0.0
Checking proptest v1.10.0
Checking radicle-dag v0.10.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-dag)
Checking radicle-git-metadata v0.2.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-git-metadata)
Checking gix-date v0.14.0
Checking ssh-agent-lib v0.5.2
Checking chrono v0.4.44
Checking radicle-localtime v0.1.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-localtime)
Checking amplify v4.9.0
Checking gix-actor v0.39.0
Checking gix-date v0.13.0
Checking cyphergraphy v0.3.0
Checking gix-fs v0.19.1
Checking cypheraddr v0.4.0
Checking noise-framework v0.4.0
Checking gix-tempfile v21.0.1
Checking gix-actor v0.38.0
Checking socks5-client v0.4.1
Checking gix-object v0.56.0
Checking gix-chunk v0.6.0
Checking cyphernet v0.5.2
Checking radicle-crypto v0.16.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-crypto)
Checking gix-quote v0.6.2
Checking gix-commitgraph v0.33.0
Checking gix-object v0.55.0
Checking gix-chunk v0.5.0
Checking radicle-cob v0.19.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-cob)
Checking radicle-core v0.2.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-core)
Checking gix-command v0.7.1
Checking gix-revwalk v0.27.0
Checking gix-commitgraph v0.32.0
Checking gix-lock v21.0.1
Checking gix-url v0.35.2
Checking radicle v0.23.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle)
Checking gix-config-value v0.17.1
Checking gix-revwalk v0.26.0
Checking gix-diff v0.58.0
Checking gix-prompt v0.13.1
Checking gix-traverse v0.52.0
Checking gix-revision v0.41.0
Checking radicle-signals v0.11.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-signals)
Checking gix-glob v0.24.0
Checking gix-packetline v0.21.1
Checking regex v1.12.3
Checking gix-refspec v0.37.0
Checking gix-transport v0.54.0
Checking tree-sitter v0.24.7
Checking gix-pack v0.65.0
Checking git-ref-format v0.6.0
Checking inquire v0.9.4
Checking gix-credentials v0.36.0
Checking gix-shallow v0.8.1
Checking gix-ref v0.59.0
Checking gix-negotiate v0.27.0
Checking radicle-git-ext v0.12.0
Checking gix-odb v0.75.0
Checking uuid v1.22.0
Compiling radicle-cli v0.20.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-cli)
Checking gix-protocol v0.57.0
Checking human-panic v2.0.6
Checking radicle-surf v0.27.1
Checking tree-sitter-toml-ng v0.6.0
Checking radicle-term v0.17.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-term)
Checking tree-sitter-highlight v0.24.7
Checking radicle-systemd v0.12.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-systemd)
Documenting radicle-systemd v0.12.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-systemd)
Documenting radicle-term v0.17.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-term)
Documenting radicle v0.23.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle)
Documenting radicle-signals v0.11.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-signals)
Documenting radicle-cob v0.19.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-cob)
Documenting radicle-core v0.2.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-core)
Documenting radicle-crypto v0.16.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-crypto)
Documenting radicle-oid v0.1.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-oid)
Documenting radicle-git-ref-format v0.1.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-git-ref-format)
Documenting radicle-localtime v0.1.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-localtime)
Documenting radicle-dag v0.10.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-dag)
Documenting radicle-git-metadata v0.2.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-git-metadata)
Documenting radicle-windows v0.1.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-windows)
Checking radicle-fetch v0.19.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-fetch)
Documenting radicle-cli v0.20.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-cli)
Documenting radicle-schemars v0.7.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-schemars)
Checking radicle-protocol v0.7.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-protocol)
Documenting radicle-protocol v0.7.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-protocol)
Documenting radicle-node v0.19.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-node)
Documenting radicle-fetch v0.19.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-fetch)
Documenting radicle-cli-test v0.13.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-cli-test)
Documenting radicle-remote-helper v0.16.0 (/861f49cc-f392-4113-8c11-c93a524f2c05/w/crates/radicle-remote-helper)
Finished `dev` profile [unoptimized + debuginfo] target(s) in 10.24s
Generated /861f49cc-f392-4113-8c11-c93a524f2c05/w/target/doc/radicle/index.html and 20 other files
+ cargo test --workspace --no-fail-fast
Finished `test` profile [unoptimized + debuginfo] target(s) in 0.20s
Running unittests src/lib.rs (target/debug/deps/radicle-1034629edcccc222)
running 323 tests
test canonical::formatter::test::ascii_control_characters ... ok
test canonical::formatter::test::securesystemslib_asserts ... ok
test canonical::formatter::test::ordered_nested_object ... ok
test cob::cache::migrations::_2::tests::test_patch_json_deserialization ... ok
test cob::cache::tests::test_check_version ... ok
test cob::common::test::test_color ... ok
test cob::common::test::test_title ... ok
test cob::cache::tests::test_migrate_to ... ok
test cob::common::test::test_emojis ... ok
test cob::cache::migrations::_2::tests::test_migration_2 ... ok
test cob::identity::test::prop_json_eq_str ... ok
test cob::identity::test::test_identity_redact_revision ... ok
test cob::identity::test::test_identity_remove_delegate_concurrent ... ok
test cob::identity::test::test_identity_reject_concurrent ... ok
test cob::identity::test::test_identity_update_rejected ... ok
test cob::identity::test::test_identity_updates ... ok
test cob::issue::cache::tests::test_counts ... ok
test cob::issue::cache::tests::test_get ... ok
test cob::issue::cache::tests::test_is_empty ... ok
test cob::issue::cache::tests::test_list ... ok
test cob::issue::cache::tests::test_list_by_status ... ok
test cob::issue::cache::tests::test_remove ... ok
test cob::identity::test::test_valid_identity ... ok
test cob::identity::test::test_identity_updates_concurrent ... ok
test cob::issue::test::test_embeds ... ok
test cob::issue::test::test_embeds_edit ... ok
test cob::identity::test::test_identity_updates_concurrent_outdated ... ok
test cob::issue::test::test_invalid_actions ... ok
test cob::issue::test::test_invalid_tx_reference ... ok
test cob::issue::test::test_invalid_tx ... ok
test cob::issue::test::test_concurrency ... ok
test cob::issue::test::test_invalid_cob ... ok
test cob::issue::test::test_issue_all ... ok
test cob::issue::test::test_issue_comment ... ok
test cob::issue::test::test_issue_create_and_assign ... ok
test cob::issue::test::test_issue_comment_redact ... ok
test cob::issue::test::test_issue_create_and_change_state ... ok
test cob::issue::test::test_issue_create_and_get ... ok
test cob::issue::test::test_issue_create_and_unassign ... ok
test cob::issue::test::test_issue_create_and_reassign ... ok
test cob::issue::test::test_issue_edit ... ok
test cob::issue::test::test_issue_edit_description ... ok
test cob::issue::test::test_issue_label ... ok
test cob::issue::test::test_issue_state_serde ... ok
test cob::issue::test::test_ordering ... ok
test cob::patch::actions::test::test_review_edit ... ok
test cob::issue::test::test_issue_multilines ... ok
test cob::issue::test::test_issue_react ... ok
test cob::patch::cache::tests::test_get ... ok
test cob::patch::cache::tests::test_is_empty ... ok
test cob::issue::test::test_issue_reply ... ok
test cob::patch::cache::tests::test_list ... ok
test cob::patch::cache::tests::test_remove ... ok
test cob::patch::encoding::review::test::test_review_deserialize_summary_migration_null_summary ... ok
test cob::patch::encoding::review::test::test_review_deserialize_summary_migration_with_summary ... ok
test cob::patch::encoding::review::test::test_review_deserialize_summary_migration_without_summary ... ok
test cob::patch::encoding::review::test::test_review_deserialize_summary_v2 ... ok
test cob::patch::encoding::review::test::test_review_summary ... ok
test cob::patch::test::test_json ... ok
test cob::patch::test::test_json_serialization ... ok
test cob::patch::cache::tests::test_counts ... ok
test cob::patch::test::test_patch_create_and_get ... ok
test cob::patch::cache::tests::test_list_by_status ... ok
test cob::patch::test::test_patch_discussion ... ok
test cob::patch::test::test_patch_merge ... ok
test cob::patch::test::test_patch_redact ... ok
test cob::patch::test::test_patch_review_comment ... ok
test cob::patch::test::test_patch_review ... ok
test cob::patch::test::test_patch_review_edit ... ok
test cob::patch::test::test_patch_review_duplicate ... ok
test cob::patch::test::test_patch_review_edit_comment ... ok
test cob::patch::test::test_patch_review_remove_summary ... ok
test cob::patch::test::test_reactions_json_serialization ... ok
test cob::patch::test::test_revision_edit_redact ... ok
test cob::patch::test::test_revision_reaction ... ok
test cob::patch::test::test_revision_review_merge_redacted ... ok
test cob::stream::tests::test_all_from ... ok
test cob::patch::test::test_patch_review_revision_redact ... ok
test cob::stream::tests::test_all_from_until ... ok
test cob::stream::tests::test_all_until ... ok
test cob::stream::tests::test_from_until ... ok
test cob::stream::tests::test_regression_from_until ... ok
test cob::thread::tests::test_comment_edit_missing ... ok
test cob::thread::tests::test_comment_edit_redacted ... ok
test cob::thread::tests::test_comment_redact_missing ... ok
test cob::thread::tests::test_duplicate_comments ... ok
test cob::thread::tests::test_edit_comment ... ok
test cob::thread::tests::test_redact_comment ... ok
test cob::thread::tests::test_timeline ... ok
test git::canonical::quorum::test::merge_base_commutative ... ok
test git::canonical::quorum::test::test_merge_bases ... ok
test cob::patch::test::test_patch_update ... ok
test git::canonical::rules::tests::test_deserialization ... ok
test git::canonical::rules::tests::test_deserialize_extensions ... ok
test git::canonical::rules::tests::test_order ... ok
test git::canonical::rules::tests::test_roundtrip ... ok
test git::canonical::rules::tests::test_canonical ... ok
test git::canonical::rules::tests::test_rule_validate_success ... ok
test git::canonical::rules::tests::test_special_branches ... ok
test git::canonical::tests::test_commit_quorum_fork_of_a_fork ... ok
test git::canonical::tests::test_commit_quorum_forked_merge_commits ... ok
test git::canonical::tests::test_commit_quorum_groups ... ok
test git::canonical::tests::test_commit_quorum_linear ... ok
test git::canonical::tests::test_commit_quorum_merges ... ok
test git::canonical::tests::test_commit_quorum_single ... ok
test git::canonical::tests::test_commit_quorum_three_way_fork ... ok
test git::canonical::tests::test_commit_quorum_two_way_fork ... ok
test git::canonical::tests::test_quorum_different_types ... ok
test git::canonical::rules::tests::test_rule_validate_failures ... ok
test git::canonical::tests::test_tag_quorum ... ok
test git::test::test_version_from_str ... ok
test git::test::test_version_ord ... ok
test identity::did::test::test_did_encode_decode ... ok
test identity::did::test::test_did_vectors ... ok
test git::canonical::tests::test_quorum_properties ... ok
test identity::doc::test::test_canonical_doc ... ok
test cob::patch::cache::tests::test_find_by_revision ... ok
test identity::doc::test::test_duplicate_dids ... ok
test identity::doc::test::test_future_version_error ... ok
test identity::doc::test::test_is_valid_version ... ok
test identity::doc::test::test_canonical_example ... ok
test identity::doc::test::test_not_found ... ok
test identity::doc::test::test_parse_version ... ok
test identity::doc::test::test_visibility_json ... ok
test identity::doc::update::test::test_can_update_crefs ... ok
test identity::doc::update::test::test_cannot_include_default_branch_rule ... ok
test identity::doc::update::test::test_default_branch_rule_exists_after_verification ... ok
test identity::project::test::test_project_name ... ok
test node::address::store::test::test_alias ... ok
test node::address::store::test::test_disconnected ... ok
test node::address::store::test::test_disconnected_ban ... ok
test node::address::store::test::test_empty ... ok
test node::address::store::test::test_entries ... ok
test node::address::store::test::test_get_none ... ok
test node::address::store::test::test_insert_and_get ... ok
test node::address::store::test::test_insert_and_remove ... ok
test node::address::store::test::test_insert_and_update ... ok
test node::address::store::test::test_insert_duplicate ... ok
test node::address::store::test::test_node_aliases ... ok
test node::address::store::test::test_remove_nothing ... ok
test node::command::test::command_result ... ok
test node::config::test::deserialize_migrating_scope ... ok
test node::config::test::fetch_level_min ... ok
test node::config::test::onion_absent ... ok
test node::config::test::onion_null ... ok
test node::config::test::partial ... ok
test node::config::test::regression_ipv6_address_brackets ... ok
test node::config::test::regression_ipv6_address_no_brackets ... ok
test node::config::test::serialize_migrating_scope ... ok
test node::db::config::test::database_config_valid_combinations ... ok
test node::db::config::test::invalid ... ok
test node::db::test::migration_8::all_ipv6_formatted_dns_addresses_are_retyped ... ok
test node::db::test::migration_8::dns_address_starting_with_bracket_but_missing_closing_bracket_colon_is_unaffected ... ok
test node::db::test::migration_8::dns_address_with_bracket_not_at_start_is_unaffected ... ok
test node::db::test::migration_8::ipv4_address_is_unaffected ... ok
test node::db::test::migration_8::ipv6_formatted_dns_address_is_deleted_when_correct_ipv6_row_already_exists ... ok
test node::db::test::migration_8::ipv6_formatted_dns_address_is_retyped_to_ipv6 ... ok
test node::db::test::migration_8::migration_applies_to_all_nodes ... ok
test node::db::test::migration_8::plain_dns_hostname_without_brackets_is_unaffected ... ok
test node::db::test::migration_8::retype_preserves_address_metadata ... ok
test node::db::test::test_version ... ok
test node::features::test::test_operations ... ok
test node::notifications::store::test::test_branch_notifications ... ok
test node::notifications::store::test::test_clear ... ok
test node::notifications::store::test::test_cob_notifications ... ok
test node::notifications::store::test::test_counts_by_repo ... ok
test node::notifications::store::test::test_duplicate_notifications ... ok
test node::notifications::store::test::test_notification_status ... ok
test node::policy::store::test::test_follow_and_unfollow_node ... ok
test node::policy::store::test::test_node_aliases ... ok
test node::policy::store::test::test_node_policies ... ok
test node::policy::store::test::test_node_policy ... ok
test node::policy::store::test::test_repo_policies ... ok
test node::policy::store::test::test_repo_policy ... ok
test node::policy::store::test::test_seed_and_unseed_repo ... ok
test identity::doc::test::test_max_delegates ... ok
test node::policy::store::test::test_update_alias ... ok
test node::policy::store::test::test_update_scope ... ok
test node::refs::store::test::test_count ... ok
test node::refs::store::test::test_set_and_delete ... ok
test node::refs::store::test::test_set_and_get ... ok
test node::routing::test::test_entries ... ok
test node::routing::test::test_count ... ok
test node::routing::test::test_insert_and_get ... ok
test node::routing::test::test_insert_and_get_resources ... ok
test node::routing::test::test_insert_duplicate ... ok
test node::routing::test::test_insert_existing_updated_time ... ok
test node::routing::test::test_insert_and_remove ... ok
test node::routing::test::test_len ... ok
test cob::thread::tests::prop_ordering ... ok
test node::routing::test::test_remove_many ... ok
test node::routing::test::test_remove_redundant ... ok
test node::routing::test::test_update_existing_multi ... ok
test node::sync::announce::test::announcer_adapts_target_to_reach ... ok
test node::sync::announce::test::all_synced_nodes_are_preferred_seeds ... ok
test node::routing::test::test_prune ... ok
test node::sync::announce::test::announcer_reached_max_replication_target ... ok
test node::sync::announce::test::announcer_preferred_seeds_or_replica_factor ... ok
test node::sync::announce::test::announcer_reached_min_replication_target ... ok
test node::sync::announce::test::announcer_reached_preferred_seeds ... ok
test node::sync::announce::test::announcer_with_replication_factor_zero_and_preferred_seeds ... ok
test node::sync::announce::test::announcer_timed_out ... ok
test node::sync::announce::test::announcer_synced_with_unknown_node ... ok
test node::sync::announce::test::construct_only_preferred_seeds_provided ... ok
test node::sync::announce::test::construct_node_appears_in_multiple_input_sets ... ok
test node::sync::announce::test::cannot_construct_announcer ... ok
test node::sync::announce::test::invariant_progress_should_match_state ... ok
test node::sync::announce::test::local_node_in_preferred_seeds ... ok
test node::sync::announce::test::local_node_in_multiple_sets ... ok
test node::sync::announce::test::local_node_in_synced_set ... ok
test node::sync::announce::test::local_node_only_in_all_sets_results_in_no_seeds_error ... ok
test node::sync::announce::test::local_node_in_unsynced_set ... ok
test node::sync::announce::test::synced_with_local_node_is_ignored ... ok
test node::sync::announce::test::preferred_seeds_already_synced ... ok
test node::sync::announce::test::timed_out_after_reaching_success ... ok
test node::sync::announce::test::synced_with_same_node_multiple_times ... ok
test node::sync::fetch::test::all_nodes_are_candidates ... ok
test node::sync::fetch::test::ignores_duplicates_and_local_node ... ok
test node::sync::fetch::test::could_not_reach_target ... ok
test node::sync::fetch::test::all_nodes_are_fetchable ... ok
test node::sync::fetch::test::reaches_target_of_max_replicas ... ok
test node::sync::fetch::test::preferred_seeds_target_returned_over_replicas ... ok
test node::sync::test::ensure_replicas_construction ... ok
test node::sync::test::replicas_constrain_to ... ok
test node::sync::fetch::test::reaches_target_of_preferred_seeds ... ok
test node::test::test_address ... ok
test node::test::test_alias ... ok
test node::test::test_command_result ... ok
test node::test::test_user_agent ... ok
test node::timestamp::tests::test_timestamp_max ... ok
test profile::test::canonicalize_home ... ok
test profile::test::test_config ... ok
test node::sync::fetch::test::reaches_target_of_replicas ... ok
test rad::tests::test_fork ... ok
test rad::tests::test_checkout ... ok
test rad::tests::test_init ... ok
test storage::git::tests::test_references_of ... ok
test storage::git::transport::local::url::test::test_url_parse ... ok
test storage::git::transport::local::url::test::test_url_to_string ... ok
test storage::git::transport::remote::url::test::test_url_parse ... ok
test storage::git::tests::test_sign_refs ... ok
test profile::config::test::schema ... ok
test storage::refs::sigrefs::read::test::commit_reader::identity_root_error ... ok
test storage::refs::sigrefs::read::test::commit_reader::missing_commit ... ok
test storage::refs::sigrefs::read::test::commit_reader::read_ok ... ok
test storage::refs::sigrefs::read::test::commit_reader::too_many_parents ... ok
test storage::refs::sigrefs::read::test::commit_reader::tree_error ... ok
test storage::refs::sigrefs::read::test::identity_root_reader::doc_blob_error ... ok
test storage::refs::sigrefs::read::test::identity_root_reader::missing_identity ... ok
test storage::refs::sigrefs::read::test::identity_root_reader::read_ok_none ... ok
test storage::refs::sigrefs::read::test::identity_root_reader::read_ok_some ... ok
test storage::refs::sigrefs::read::test::resolve_tip::find_reference_error ... ok
test storage::refs::sigrefs::read::test::resolve_tip::missing_sigrefs ... ok
test storage::refs::sigrefs::read::test::resolve_tip::resolve_tip_ok ... ok
test storage::refs::sigrefs::read::test::signed_refs_reader::detect_parent::root_without_parent ... ok
test storage::refs::sigrefs::read::test::signed_refs_reader::detect_parent::root_without_root ... ok
test storage::refs::sigrefs::read::test::signed_refs_reader::downgrade::parent ... ok
test storage::refs::sigrefs::read::test::signed_refs_reader::downgrade::restore ... ok
test storage::refs::sigrefs::read::test::signed_refs_reader::downgrade::root ... ok
test storage::refs::sigrefs::read::test::signed_refs_reader::downgrade::root_with_parent ... ok
test storage::refs::sigrefs::read::test::signed_refs_reader::head_commit_error ... ok
test storage::refs::sigrefs::read::test::signed_refs_reader::head_verify_mismatched_identity_error ... ok
test storage::refs::sigrefs::read::test::signed_refs_reader::head_verify_signature_error ... ok
test storage::refs::sigrefs::read::test::signed_refs_reader::invalid_parent ... ok
test storage::refs::sigrefs::read::test::signed_refs_reader::read_ok_no_parent ... ok
test storage::refs::sigrefs::read::test::signed_refs_reader::read_ok_parent ... ok
test storage::refs::sigrefs::read::test::signed_refs_reader::read_ok_root ... ok
test storage::refs::sigrefs::read::test::signed_refs_reader::replay::alternating ... ok
test storage::refs::sigrefs::read::test::signed_refs_reader::replay::chain ... ok
test storage::refs::sigrefs::read::test::signed_refs_reader::replay::multiple ... ok
test storage::refs::sigrefs::read::test::signed_refs_reader::replay::root_at_head ... ok
test storage::refs::sigrefs::read::test::signed_refs_reader::single_commit ... ok
test storage::refs::sigrefs::read::test::signed_refs_reader::two_commits ... ok
test storage::refs::sigrefs::read::test::signed_refs_reader::walk_commit_error ... ok
test storage::refs::sigrefs::read::test::signed_refs_reader::walk_verify_error ... ok
test storage::refs::sigrefs::read::test::tree_reader::missing_both ... ok
test storage::refs::sigrefs::read::test::tree_reader::missing_refs ... ok
test storage::refs::sigrefs::read::test::tree_reader::missing_signature ... ok
test storage::refs::sigrefs::read::test::tree_reader::parse_refs_error ... ok
test storage::refs::sigrefs::read::test::tree_reader::parse_signature_error ... ok
test storage::refs::sigrefs::read::test::tree_reader::read_ok ... ok
test storage::refs::sigrefs::read::test::tree_reader::read_refs_error ... ok
test storage::refs::sigrefs::read::test::tree_reader::read_signature_error ... ok
test storage::refs::sigrefs::write::test::commit_writer::tree_error ... ok
test storage::refs::sigrefs::write::test::commit_writer::write_commit_error ... ok
test storage::refs::sigrefs::write::test::commit_writer::write_empty_refs ... ok
test storage::refs::sigrefs::write::test::commit_writer::write_root_ok ... ok
test storage::refs::sigrefs::write::test::commit_writer::write_with_parent_ok ... ok
test storage::refs::sigrefs::write::test::head_reader::no_head ... ok
test storage::refs::sigrefs::write::test::head_reader::read_ok ... ok
test storage::refs::sigrefs::write::test::head_reader::reference_error ... ok
test storage::refs::sigrefs::write::test::head_reader::refs_blob_error ... ok
test storage::refs::sigrefs::write::test::head_reader::refs_blob_missing ... ok
test storage::refs::sigrefs::write::test::head_reader::refs_parse_error ... ok
test storage::refs::sigrefs::write::test::head_reader::signature_blob_error ... ok
test storage::refs::sigrefs::write::test::head_reader::signature_blob_missing ... ok
test storage::refs::sigrefs::write::test::head_reader::signature_parse_error ... ok
test storage::refs::sigrefs::write::test::signed_refs_writer::commit_error ... ok
test storage::refs::sigrefs::write::test::signed_refs_writer::head_error ... ok
test storage::refs::sigrefs::write::test::signed_refs_writer::never_write_rad_sigrefs ... ok
test storage::refs::sigrefs::write::test::signed_refs_writer::reference_error ... ok
test storage::refs::sigrefs::write::test::signed_refs_writer::unchanged ... ok
test storage::refs::sigrefs::write::test::signed_refs_writer::unchanged_force_writes_new_commit ... ok
test storage::refs::sigrefs::write::test::signed_refs_writer::write_empty_refs ... ok
test storage::refs::sigrefs::write::test::signed_refs_writer::write_root_ok ... ok
test storage::refs::sigrefs::write::test::signed_refs_writer::write_with_parent_ok ... ok
test storage::refs::sigrefs::write::test::tree_writer::sign_error ... ok
test storage::refs::sigrefs::write::test::tree_writer::write_ok ... ok
test storage::refs::sigrefs::write::test::tree_writer::write_tree_error ... ok
test storage::refs::tests::prop_canonical_roundtrip ... ok
test storage::refs::tests::test_rid_verification ... ok
test storage::tests::test_storage ... ok
test test::assert::test::assert_with_message ... ok
test test::assert::test::test_assert_no_move ... ok
test test::assert::test::test_assert_panic_0 - should panic ... ok
test test::assert::test::test_assert_panic_1 - should panic ... ok
test test::assert::test::test_assert_panic_2 - should panic ... ok
test test::assert::test::test_assert_succeed ... ok
test test::assert::test::test_panic_message ... ok
test version::test::test_version ... ok
test storage::refs::sigrefs::property::idempotent ... ok
test identity::doc::test::prop_encode_decode ... ok
test storage::refs::sigrefs::property::roundtrip ... ok
test result: ok. 323 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 3.38s
Running unittests src/lib.rs (target/debug/deps/radicle_cli-f88c627dc09e436f)
running 46 tests
test commands::block::args::test::should_not_parse ... ok
test commands::block::args::test::should_parse_nid ... ok
test commands::block::args::test::should_parse_rid ... ok
test commands::clone::args::test::should_parse_rid_non_urn ... ok
test commands::clone::args::test::should_parse_rid_url ... ok
test commands::clone::args::test::should_parse_rid_urn ... ok
test commands::cob::args::test::should_allow_log_pretty_format ... ok
test commands::cob::args::test::should_allow_log_json_format ... ok
test commands::cob::args::test::should_not_allow_show_pretty_format ... ok
test commands::cob::args::test::should_allow_show_json_format ... ok
test commands::cob::args::test::should_not_allow_update_pretty_format ... ok
test commands::cob::args::test::should_allow_update_json_format ... ok
test commands::fork::args::test::should_not_parse_rid_url ... ok
test commands::fork::args::test::should_parse_rid_non_urn ... ok
test commands::fork::args::test::should_parse_rid_urn ... ok
test commands::id::args::test::should_not_parse_into_payload - should panic ... ok
test commands::id::args::test::should_not_clobber_payload_args ... ok
test commands::id::args::test::should_not_parse_single_payload ... ok
test commands::id::args::test::should_parse_into_payload ... ok
test commands::id::args::test::should_not_parse_single_payloads ... ok
test commands::id::args::test::should_parse_single_payload ... ok
test commands::id::args::test::should_parse_multiple_payloads ... ok
test commands::init::args::test::should_not_parse_rid_url ... ok
test commands::init::args::test::should_parse_rid_urn ... ok
test commands::init::args::test::should_parse_rid_non_urn ... ok
test commands::inspect::test::test_tree ... ok
test commands::patch::review::builder::tests::test_review_comments_before ... ok
test commands::patch::review::builder::tests::test_review_comments_basic ... ok
test commands::patch::review::builder::tests::test_review_comments_multiline ... ok
test commands::patch::review::builder::tests::test_review_comments_split_hunk ... ok
test commands::publish::args::test::should_not_parse_rid_url ... ok
test commands::publish::args::test::should_parse_rid_non_urn ... ok
test commands::publish::args::test::should_parse_rid_urn ... ok
test git::pretty_diff::test::test_pretty ... ignored
test git::ddiff::tests::diff_encode_decode_ddiff_hunk ... ok
test git::unified_diff::test::test_diff_content_encode_decode_content ... ok
test commands::watch::args::test::should_parse_ref_str ... ok
test git::unified_diff::test::test_diff_encode_decode_diff ... ok
test terminal::args::test::should_not_parse ... ok
test terminal::args::test::should_parse_nid ... ok
test terminal::args::test::should_parse_rid ... ok
test terminal::format::test::test_bytes ... ok
test terminal::format::test::test_strip_comments ... ok
test terminal::patch::test::test_edit_display_message ... ok
test terminal::patch::test::test_create_display_message ... ok
test terminal::patch::test::test_update_display_message ... ok
test result: ok. 45 passed; 0 failed; 1 ignored; 0 measured; 0 filtered out; finished in 0.01s
Running unittests src/main.rs (target/debug/deps/rad-8443661264181606)
running 0 tests
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Running tests/commands.rs (target/debug/deps/commands-980d3acf3e9a8617)
running 115 tests
test commands::clone::rad_clone_bare ... ok
test commands::clone::rad_clone ... ok
test commands::checkout::rad_checkout ... ok
test commands::clone::rad_clone_all ... ok
test commands::clone::rad_clone_scope ... ok
test commands::clone::rad_clone_unknown ... ok
test commands::clone::rad_clone_directory ... ok
test commands::clone::rad_clone_connect ... ok
test commands::clone::rad_clone_partial_fail ... ok
test commands::cob::rad_cob_multiset ... ok
test commands::clone::test_clone_without_seeds ... ok
test commands::cob::rad_cob_log ... ok
test commands::cob::rad_cob_operations ... ok
test commands::cob::rad_cob_migrate ... ok
test commands::cob::rad_cob_show ... ok
test commands::cob::rad_cob_update_identity ... ok
test commands::cob::rad_cob_update ... ok
test commands::cob::test_cob_deletion ... ok
test commands::cob::test_cob_replication ... ok
test commands::git::git_push_amend ... ok
test commands::git::git_push_and_fetch ... ok
test commands::git::git_push_canonical_annotated_tags ... ok
test commands::git::git_push_canonical_lightweight_tags ... ok
test commands::git::git_push_force_with_lease ... ok
test commands::git::git_push_diverge ... ok
test commands::id::rad_id ... ok
test commands::id::rad_id_collaboration ... ignored, slow
test commands::git::git_push_converge ... ok
test commands::git::git_push_rollback ... ok
test commands::git::git_tag ... ok
test commands::id::rad_id_private ... ok
test commands::id::rad_id_threshold_soft_fork ... ok
test commands::id::rad_id_conflict ... ok
test commands::id::rad_id_threshold ... ok
test commands::id::rad_id_unknown_field ... ok
test commands::id::rad_id_update_delete_field ... ok
test commands::init::rad_init ... ignored, part of many other tests
test commands::id::rad_id_unauthorized_delegate ... ok
test commands::init::rad_init_detached_head ... ok
test commands::init::rad_init_bare ... ok
test commands::id::rad_id_multi_delegate ... ok
test commands::init::rad_init_no_git ... ok
test commands::init::rad_init_existing ... ok
test commands::init::rad_init_existing_bare ... ok
test commands::init::rad_init_no_seed ... ok
test commands::init::rad_init_private ... ok
test commands::init::rad_init_private_no_seed ... ok
test commands::init::rad_init_private_clone ... ok
test commands::init::rad_init_private_clone_seed ... ok
test commands::inbox::rad_inbox ... ok
test commands::init::rad_init_private_seed ... ok
test commands::init::rad_init_sync_not_connected ... ok
test commands::init::rad_init_with_existing_remote ... ok
test commands::init::rad_init_sync_preferred ... ok
test commands::init::rad_publish ... ok
test commands::issue::rad_issue ... ok
test commands::jj::rad_jj_bare ... ok
test commands::jj::rad_jj_colocated_patch ... ok
test commands::issue::rad_issue_list ... ok
test commands::node::rad_node_connect ... ok
test commands::node::rad_node_connect_without_address ... ok
test commands::patch::rad_merge_after_update ... ok
test commands::node::rad_node ... ok
test commands::patch::rad_merge_no_ff ... ok
test commands::patch::rad_merge_via_push ... ok
test commands::patch::rad_patch_ahead_behind ... ok
test commands::patch::rad_patch ... ok
test commands::patch::rad_patch_change_base ... ok
test commands::patch::rad_patch_checkout ... ok
test commands::init::rad_init_sync_and_clone ... ok
test commands::init::rad_init_sync_timeout ... ok
test commands::patch::rad_patch_checkout_revision ... ok
test commands::patch::rad_patch_detached_head ... ok
test commands::patch::rad_patch_diff ... ok
test commands::patch::rad_patch_checkout_force ... ok
test commands::patch::rad_patch_draft ... ok
test commands::patch::rad_patch_fetch_2 ... FAILED
test commands::patch::rad_patch_edit ... ok
test commands::patch::rad_patch_fetch_1 ... ok
test commands::patch::rad_patch_merge_draft ... ok
test commands::patch::rad_patch_delete ... ok
test commands::patch::rad_patch_revert_merge ... ok
test commands::patch::rad_patch_update ... ok
test commands::patch::rad_patch_open_explore ... ok
test commands::patch::rad_patch_via_push ... FAILED
test commands::policy::rad_block ... ok
test commands::policy::rad_seed_and_follow ... ok
test commands::patch::rad_review_by_hunk ... ok
test commands::policy::rad_seed_policy_allow_no_scope ... ok
test commands::policy::rad_seed_scope ... ok
test commands::policy::rad_unseed ... ok
test commands::policy::rad_seed_many ... ok
test commands::policy::rad_unseed_many ... ok
test commands::patch::rad_push_and_pull_patches ... ok
test commands::remote::rad_remote ... ok
test commands::sync::rad_sync_without_node ... ok
test commands::sync::rad_sync ... ok
test commands::utility::framework_home ... ok
test commands::utility::rad_auth ... ok
test commands::utility::rad_auth_errors ... ok
test commands::utility::rad_clean ... ok
test commands::patch::rad_patch_pull_update ... ok
test commands::utility::rad_diff ... ok
test commands::utility::rad_config ... ok
test commands::utility::rad_help ... ok
test commands::utility::rad_inspect ... ok
test commands::utility::rad_key_mismatch ... ok
test commands::utility::rad_self ... ok
test commands::utility::rad_warn_old_nodes ... ok
test commands::sync::rad_fetch ... ok
test commands::watch::rad_watch ... ok
test rad_remote ... ok
test commands::sync::test_replication_via_seed ... ok
test commands::workflow::rad_workflow ... ok
test commands::utility::rad_fork ... ok
failures:
---- commands::patch::rad_patch_fetch_2 stdout ----
1776261725 test: rad-init:6: `rad init --name heartwood --description Radicle Heartwood Protocol & Stack --no-confirm --public -v` @ /tmp/.tmpvv7m6o/alice/work
1776261725 test: rad-init:28: `rad init` @ /tmp/.tmpvv7m6o/alice/work
1776261725 test: rad-init:35: `rad ls` @ /tmp/.tmpvv7m6o/alice/work
1776261725 test: rad-init:46: `rad node inventory` @ /tmp/.tmpvv7m6o/alice/work
1776261725 test: rad-patch-fetch-2:6: `git checkout -b alice/1 -q` @ /tmp/.tmpvv7m6o/alice/work
1776261725 test: rad-patch-fetch-2:7: `git commit --allow-empty -m Changes #1 -q` @ /tmp/.tmpvv7m6o/alice/work
1776261725 test: rad-patch-fetch-2:8: `git push rad -o patch.message=Changes HEAD:refs/patches` @ /tmp/.tmpvv7m6o/alice/work
1776261726 test: rad-patch-fetch-2:12: `git checkout master -q` @ /tmp/.tmpvv7m6o/alice/work
1776261726 test: rad-patch-fetch-2:13: `git branch -D alice/1 -q` @ /tmp/.tmpvv7m6o/alice/work
1776261726 test: rad-patch-fetch-2:14: `git update-ref -d refs/remotes/rad/alice/1` @ /tmp/.tmpvv7m6o/alice/work
1776261726 test: rad-patch-fetch-2:15: `git update-ref -d refs/remotes/rad/patches/5e2dedcc5d515fcbc1cca483d3376609fe889bfb` @ /tmp/.tmpvv7m6o/alice/work
1776261726 test: rad-patch-fetch-2:16: `git gc --prune=now` @ /tmp/.tmpvv7m6o/alice/work
1776261726 test: rad-patch-fetch-2:17: `git branch -r` @ /tmp/.tmpvv7m6o/alice/work
1776261726 test: rad-patch-fetch-2:22: `git pull` @ /tmp/.tmpvv7m6o/alice/work
1776261726 test: rad-patch-fetch-2:24: `git branch -r` @ /tmp/.tmpvv7m6o/alice/work
thread 'commands::patch::rad_patch_fetch_2' panicked at crates/radicle-cli-test/src/lib.rs:502:36:
--- Expected
++++ actual: stdout
1 - rad/HEAD -> rad/master
2 1 | rad/master
3 2 | rad/patches/5e2dedcc5d515fcbc1cca483d3376609fe889bfb
Exit status: 0
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace
---- commands::patch::rad_patch_via_push stdout ----
1776261727 test: rad-init:6: `rad init --name heartwood --description Radicle Heartwood Protocol & Stack --no-confirm --public -v` @ /tmp/.tmp7rSxfY/alice/work
1776261727 test: rad-init:28: `rad init` @ /tmp/.tmp7rSxfY/alice/work
1776261727 test: rad-init:35: `rad ls` @ /tmp/.tmp7rSxfY/alice/work
1776261727 test: rad-init:46: `rad node inventory` @ /tmp/.tmp7rSxfY/alice/work
1776261727 test: rad-patch-via-push:7: `git checkout -b feature/1` @ /tmp/.tmp7rSxfY/alice/work
1776261727 test: rad-patch-via-push:9: `git commit -a -m Add things -q --allow-empty` @ /tmp/.tmp7rSxfY/alice/work
1776261727 test: rad-patch-via-push:10: `git push -o patch.message=Add things #1 -o patch.message=See commits for details. rad HEAD:refs/patches` @ /tmp/.tmp7rSxfY/alice/work
1776261727 test: rad-patch-via-push:22: `rad patch show 6035d2f582afbe01ff23ea87528ae523d76875b6` @ /tmp/.tmp7rSxfY/alice/work
1776261727 test: rad-patch-via-push:45: `git branch -vv` @ /tmp/.tmp7rSxfY/alice/work
1776261727 test: rad-patch-via-push:53: `git status --short --branch` @ /tmp/.tmp7rSxfY/alice/work
1776261727 test: rad-patch-via-push:55: `git fetch` @ /tmp/.tmp7rSxfY/alice/work
1776261727 test: rad-patch-via-push:56: `git push` @ /tmp/.tmp7rSxfY/alice/work
1776261727 test: rad-patch-via-push:62: `git show-ref` @ /tmp/.tmp7rSxfY/alice/work
thread 'commands::patch::rad_patch_via_push' panicked at crates/radicle-cli-test/src/lib.rs:502:36:
--- Expected
++++ actual: stdout
1 1 | 42d894a83c9c356552a57af09ccdbd5587a99045 refs/heads/feature/1
2 2 | f2de534b5e81d7c6e2dcaf58c3dd91573c0a0354 refs/heads/master
3 - f2de534b5e81d7c6e2dcaf58c3dd91573c0a0354 refs/remotes/rad/HEAD
4 3 | f2de534b5e81d7c6e2dcaf58c3dd91573c0a0354 refs/remotes/rad/master
5 4 | 42d894a83c9c356552a57af09ccdbd5587a99045 refs/remotes/rad/patches/6035d2f582afbe01ff23ea87528ae523d76875b6
Exit status: 0
failures:
commands::patch::rad_patch_fetch_2
commands::patch::rad_patch_via_push
test result: FAILED. 111 passed; 2 failed; 2 ignored; 0 measured; 0 filtered out; finished in 73.98s
error: test failed, to rerun pass `-p radicle-cli --test commands`
Running unittests src/lib.rs (target/debug/deps/radicle_cli_test-bd3e3c4dcb1548d6)
running 3 tests
test tests::test_parse ... ok
test tests::test_run ... ok
test tests::test_example_spaced_brackets ... ok
test result: ok. 3 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Running unittests src/lib.rs (target/debug/deps/radicle_cob-6fe139a7978b5280)
running 9 tests
test object::tests::test_serde ... ok
test tests::git::roundtrip ... ok
test tests::git::list_cobs ... ok
test tests::git::traverse_cobs ... ok
test type_name::test::invalid_typenames ... ok
test tests::invalid_parse_refstr ... ok
test type_name::test::valid_typenames ... ok
test tests::parse_refstr ... ok
test tests::git::update_cob ... ok
test result: ok. 9 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
Running unittests src/lib.rs (target/debug/deps/radicle_core-e6bfed2c189a2d2c)
running 4 tests
test repo::test::valid ... ok
test repo::test::invalid ... ok
test repo::test::assert_prop_roundtrip_parse ... ok
test repo::serde_impls::test::assert_prop_roundtrip_serde_json ... ok
test result: ok. 4 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
Running unittests src/lib.rs (target/debug/deps/radicle_crypto-99d51a8f68c92ad6)
running 11 tests
test ssh::agent::test::test_agent_encoding_remove ... ok
test ssh::agent::test::test_agent_encoding_sign ... ok
test ssh::fmt::test::test_fingerprint ... ok
test ssh::fmt::test::test_key ... ok
test ssh::keystore::tests::test_init_no_passphrase ... ok
test tests::prop_encode_decode ... ok
test tests::test_e25519_dh ... ok
test tests::test_encode_decode ... ok
test tests::prop_key_equality ... ok
test ssh::keystore::tests::test_signer ... ok
test ssh::keystore::tests::test_init_passphrase ... ok
test result: ok. 11 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.83s
Running unittests src/lib.rs (target/debug/deps/radicle_dag-05f7457e7194a495)
running 20 tests
test tests::test_contains ... ok
test tests::test_cycle ... ok
test tests::test_diamond ... ok
test tests::test_fold_multiple_roots ... ok
test tests::test_fold_diamond ... ok
test tests::test_dependencies ... ok
test tests::test_fold_sorting_1 ... ok
test tests::test_fold_reject ... ok
test tests::test_get ... ok
test tests::test_fold_sorting_2 ... ok
test tests::test_is_empty ... ok
test tests::test_len ... ok
test tests::test_merge_1 ... ok
test tests::test_merge_2 ... ok
test tests::test_complex ... ok
test tests::test_prune_1 ... ok
test tests::test_remove ... ok
test tests::test_prune_2 ... ok
test tests::test_prune_by_sorting ... ok
test tests::test_siblings ... ok
test result: ok. 20 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Running unittests src/lib.rs (target/debug/deps/radicle_fetch-d6686b91a80123f8)
running 1 test
test stage::test::valid_refspecs ... ok
test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Running unittests src/lib.rs (target/debug/deps/radicle_git_metadata-7266929c438027dc)
running 24 tests
test commit::parse::test::error::invalid_author ... ok
test commit::parse::test::error::invalid_committer ... ok
test commit::parse::test::error::invalid_format_continuation_without_preceding_header ... ok
test commit::parse::test::error::invalid_tree ... ok
test commit::parse::test::error::missing_author ... ok
test commit::parse::test::error::missing_header_body_separator ... ok
test commit::parse::test::error::missing_tree_empty_header ... ok
test commit::parse::test::error::invalid_parent ... ok
test commit::parse::test::error::missing_committer ... ok
test commit::parse::test::error::missing_tree_wrong_first_line ... ok
test commit::parse::test::success::commit_gpgsig_is_preserved_and_strip_removes_it ... ok
test commit::parse::test::success::commit_last_paragraph_kept_in_message_when_not_all_trailers ... ok
test commit::parse::test::success::commit_with_multiline_gpgsig ... ok
test commit::parse::test::success::commit_with_single_parent ... ok
test commit::parse::test::success::commit_with_trailers ... ok
test commit::parse::test::success::merge_commit ... ok
test commit::parse::test::unit::body_last_paragraph_not_trailers_stays_in_message ... ok
test commit::parse::test::success::roundtrip ... ok
test commit::parse::test::success::commit_with_extra_headers ... ok
test commit::parse::test::success::root_commit ... ok
test commit::parse::test::unit::body_no_paragraph_separator_means_no_trailers ... ok
test commit::parse::test::unit::trailers_accepts_empty_input ... ok
test commit::parse::test::unit::trailers_rejects_line_without_separator ... ok
test commit::parse::test::unit::trailers_rejects_invalid_token_chars ... ok
test result: ok. 24 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Running unittests src/lib.rs (target/debug/deps/radicle_git_ref_format-b95a9bd0637298c8)
running 9 tests
test test::component ... ok
test test::component_invalid - should panic ... ok
test test::pattern ... ok
test test::qualified_pattern ... ok
test test::qualified_pattern_invalid - should panic ... ok
test test::refname ... ok
test test::refname_invalid - should panic ... ok
test test::qualified ... ok
test test::qualified_invalid - should panic ... ok
test result: ok. 9 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Running unittests src/lib.rs (target/debug/deps/radicle_localtime-9ecb37b1e50cb4e3)
running 1 test
test serde_impls::test::test_localtime ... ok
test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Running unittests src/lib.rs (target/debug/deps/radicle_node-a19843acdcc94364)
running 79 tests
test reactor::timer::tests::test_next ... ok
test control::tests::test_control_socket ... ok
test reactor::timer::tests::test_wake ... ok
test reactor::timer::tests::test_wake_exact ... ok
test control::tests::test_seed_unseed ... ok
test fingerprint::tests::matching ... ok
test tests::e2e::missing_default_branch ... ok
test tests::e2e::fetch_does_not_contain_rad_sigrefs_parent ... ok
test tests::e2e::missing_delegate_default_branch ... ok
test tests::e2e::test_background_foreground_fetch ... ok
test tests::e2e::test_block_prevents_connection ... ok
test tests::e2e::test_block_active_connection ... ok
test tests::e2e::test_block_prevents_fetch ... ok
test tests::e2e::test_channel_reader_limit ... ok
test tests::e2e::test_catchup_on_refs_announcements ... ok
test tests::e2e::test_clone ... ok
test tests::e2e::test_dont_fetch_owned_refs ... ok
test tests::e2e::test_connection_crossing ... ok
test tests::e2e::test_fetch_followed_remotes ... ok
test tests::e2e::test_concurrent_fetches ... ok
test tests::e2e::test_fetch_preserve_owned_refs ... ok
test tests::e2e::test_fetch_unseeded ... ok
test tests::e2e::test_fetch_up_to_date ... ok
test tests::e2e::test_inventory_sync_basic ... ok
test tests::e2e::test_fetch_emits_canonical_ref_update ... ok
test tests::e2e::test_large_fetch ... ok
test tests::e2e::test_migrated_clone ... ok
test tests::e2e::test_missing_remote ... ok
test tests::e2e::test_multiple_offline_inits ... ok
test tests::e2e::test_non_fastforward_identity_doc ... ok
test tests::e2e::test_non_fastforward_sigrefs ... ok
test tests::e2e::test_outdated_delegate_sigrefs ... ok
test tests::e2e::test_outdated_sigrefs ... ok
test tests::e2e::test_replication ... ok
test tests::e2e::test_inventory_sync_bridge ... ok
test tests::e2e::test_replication_invalid ... ok
test tests::e2e::test_inventory_sync_ring ... ok
test tests::e2e::test_replication_ref_in_sigrefs ... ok
test tests::e2e::test_inventory_sync_star ... ok
test tests::test_announcement_rebroadcast ... ok
test tests::test_announcement_rebroadcast_duplicates ... ok
test tests::test_announcement_rebroadcast_timestamp_filtered ... ok
test tests::test_connection_kept_alive ... ok
test tests::test_announcement_relay ... ok
test tests::test_disconnecting_unresponsive_peer ... ok
test tests::test_fetch_missing_inventory_on_gossip ... ok
test tests::test_fetch_missing_inventory_on_schedule ... ok
test tests::test_inbound_connection ... ok
test tests::test_inventory_decode ... ok
test tests::test_init_and_seed ... ok
test tests::test_inventory_relay ... ok
test tests::test_inventory_relay_bad_timestamp ... ok
test tests::test_inventory_sync ... ok
test tests::test_maintain_connections ... ok
test tests::test_maintain_connections_failed_attempt ... ok
test tests::test_maintain_connections_transient ... ok
test tests::test_outbound_connection ... ok
test tests::test_inventory_pruning ... ok
test tests::test_persistent_peer_connect ... ok
test tests::test_persistent_peer_reconnect_attempt ... ok
test tests::test_persistent_peer_reconnect_success ... ok
test tests::test_ping_response ... ok
test tests::test_queued_fetch_from_ann_same_rid ... ok
test tests::test_queued_fetch_max_capacity ... ok
test tests::test_queued_fetch_from_command_same_rid ... ok
test tests::test_redundant_connect ... ok
test tests::test_refs_announcement_fetch_trusted_no_inventory ... ok
test tests::test_refs_announcement_followed ... ok
test tests::test_refs_announcement_no_subscribe ... ok
test tests::test_refs_announcement_offline ... ok
test tests::test_announcement_message_amplification ... ok
test tests::prop_inventory_exchange_dense ... ok
test tests::test_refs_announcement_relay_private ... ok
test tests::test_seed_repo_subscribe ... ok
test wire::test::test_inventory_ann_with_extension ... ok
test wire::test::test_pong_message_with_extension ... ok
test tests::test_refs_announcement_relay_public ... ok
test tests::test_seeding ... ok
test tests::test_refs_synced_event ... ok
test result: ok. 79 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 14.97s
Running unittests src/main.rs (target/debug/deps/radicle_node-91030754a726535d)
running 0 tests
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Running unittests src/lib.rs (target/debug/deps/radicle_oid-32b41d88203b7116)
running 10 tests
test fmt::test::fixture ... ok
test fmt::test::git2 ... ok
test git2::test::zero ... ok
test gix::test::zero ... ok
test fmt::test::zero ... ok
test str::test::fixture ... ok
test fmt::test::gix ... ok
test str::test::zero ... ok
test str::test::git2_roundtrip ... ok
test str::test::gix_roundrip ... ok
test result: ok. 10 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Running unittests src/lib.rs (target/debug/deps/radicle_protocol-8abd9fe24a797cf4)
running 99 tests
test deserializer::test::test_decode_next ... ok
test deserializer::test::test_unparsed ... ok
test deserializer::test::prop_decode_next ... ok
test fetcher::service::tests::test_fetch_coalescing_different_refs ... ok
test fetcher::test::queue::properties::capacity::bounded ... ok
test fetcher::test::queue::properties::capacity::rejection ... ok
test fetcher::test::queue::properties::dequeue::empty_queue_returns_none ... ok
test fetcher::test::queue::properties::dequeue::enables_reenqueue ... ok
test fetcher::test::queue::properties::capacity::capacity_reached_returns_same_item ... ok
test fetcher::test::queue::properties::dequeue::drained_queue_returns_none ... ok
test fetcher::test::queue::properties::capacity::restored_after_dequeue ... ok
test fetcher::test::queue::properties::fifo::interleaved_operations ... ok
test fetcher::test::queue::properties::fifo::ordering ... ok
test fetcher::test::queue::properties::equality::reflexive ... ok
test fetcher::test::queue::properties::equality::symmetric ... ok
test fetcher::test::queue::properties::merge::different_rid_accepted ... ok
test fetcher::test::queue::properties::merge::combines_refs ... ok
test fetcher::test::queue::properties::merge::longer_timeout_preserved ... ok
test fetcher::test::queue::properties::equality::transitive ... ok
test fetcher::test::queue::properties::merge::succeed_when_at_capacity ... ok
test fetcher::test::queue::unit::capacity_takes_precedence_over_merge_for_new_items ... ok
test fetcher::test::queue::unit::empty_refs_items_can_be_equal ... ok
test fetcher::test::queue::unit::max_timeout_accepted ... ok
test fetcher::test::queue::properties::merge::does_not_increase_queue_length ... ok
test fetcher::test::queue::unit::merge_preserves_position_in_queue ... ok
test fetcher::test::queue::unit::zero_timeout_accepted ... ok
test fetcher::test::state::command::cancel::non_existent_returns_unexpected ... ok
test fetcher::test::state::command::cancel::cancellation_is_isolated ... ok
test fetcher::test::state::command::cancel::ongoing_and_queued ... ok
test fetcher::test::state::command::cancel::single_ongoing ... ok
test fetcher::test::state::command::fetch::fetch_after_previous_completed ... ok
test fetcher::test::state::command::fetch::fetch_at_capacity_enqueues ... ok
test fetcher::test::state::command::fetch::fetch_different_repo_same_node_within_capacity ... ok
test fetcher::test::state::command::fetch::fetch_duplicate_returns_already_fetching ... ok
test fetcher::test::state::command::fetch::fetch_queue_merge_empty_refs_fetches_all ... ok
test fetcher::test::state::command::fetch::fetch_queue_merge_takes_longer_timeout ... ok
test fetcher::test::state::command::fetch::fetch_queue_merges_already_queued ... ok
test fetcher::test::state::command::fetch::fetch_queue_rejected_capacity_reached ... ok
test fetcher::test::state::command::fetch::fetch_same_repo_different_nodes_queues_second ... ok
test fetcher::test::state::command::fetch::fetch_start_first_fetch_for_node ... ok
test fetcher::test::state::command::fetch::fetch_same_repo_different_refs_enqueues ... ok
test fetcher::test::queue::properties::merge::empty_refs_fetches_all ... ok
test fetcher::test::state::command::fetched::complete_single_ongoing ... ok
test fetcher::test::state::command::fetched::complete_one_of_multiple ... ok
test fetcher::test::state::command::fetched::non_existent_returns_not_found ... ok
test fetcher::test::state::concurrent::fetched_then_cancel ... ok
test fetcher::test::state::command::fetched::complete_then_dequeue_fifo ... ok
test fetcher::test::state::concurrent::interleaved_operations ... ok
test fetcher::test::state::config::min_queue_size ... ok
test fetcher::test::state::dequeue::empty_queue_returns_none ... ok
test fetcher::test::state::dequeue::cannot_dequeue_while_node_at_capacity ... ok
test fetcher::test::state::dequeue::maintains_fifo_order ... ok
test fetcher::test::state::invariant::queue_integrity_after_merge ... ok
test fetcher::test::state::multinode::independent_queues ... ok
test service::filter::test::compatible ... ok
test service::filter::test::test_parameters ... ok
test service::filter::test::test_sizes ... ok
test service::gossip::store::test::test_announced ... ok
test service::limiter::test::test_limiter_different_rates ... ok
test service::limiter::test::test_limiter_multi ... ok
test service::limiter::test::test_limiter_refill ... ok
test fetcher::test::queue::properties::merge::same_rid_merges_anywhere_in_queue ... ok
test fetcher::test::state::config::high_concurrency ... ok
test service::message::tests::test_inventory_limit ... ok
test service::message::tests::test_ref_remote_limit ... ok
test wire::frame::test::test_encode_git_large ... ok
test wire::frame::test::test_stream_id ... ok
test fetcher::test::state::multinode::high_count ... ok
test wire::message::tests::prop_roundtrip_address ... ok
test service::message::tests::prop_refs_announcement_signing ... ok
test wire::message::tests::prop_zero_bytes_encode_decode ... ok
test wire::message::tests::test_inv_ann_max_size ... ok
test wire::message::tests::test_node_ann_max_size ... ok
test wire::message::tests::test_ping_encode_size_overflow - should panic ... ok
test wire::message::tests::test_pingpong_encode_max_size ... ok
test wire::message::tests::test_pong_encode_size_overflow - should panic ... ok
test wire::message::tests::prop_roundtrip_message ... ok
test wire::tests::prop_oid ... ok
test wire::tests::prop_roundtrip_filter ... ok
test wire::tests::prop_roundtrip_publickey ... ok
test wire::tests::prop_roundtrip_refs ... ok
test wire::tests::prop_roundtrip_repoid ... ok
test wire::tests::prop_roundtrip_tuple ... ok
test wire::tests::prop_roundtrip_u16 ... ok
test wire::tests::prop_roundtrip_u32 ... ok
test wire::tests::prop_roundtrip_u64 ... ok
test wire::tests::prop_roundtrip_vec ... ok
test wire::tests::prop_signature ... ok
test wire::tests::prop_string ... ok
test wire::tests::test_alias ... ok
test wire::tests::test_bounded_vec_limit ... ok
test wire::tests::test_filter_invalid ... ok
test wire::tests::test_string ... ok
test wire::varint::test::prop_roundtrip_varint ... ok
test wire::varint::test::test_encode_overflow - should panic ... ok
test wire::varint::test::test_encoding ... ok
test wire::message::tests::test_refs_ann_max_size ... ok
test wire::message::tests::prop_message_decoder ... ok
test service::message::tests::test_node_announcement_validate ... ok
test result: ok. 99 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 1.62s
Running unittests src/main.rs (target/debug/deps/git_remote_rad-742be4fde4d7f3e8)
running 12 tests
test protocol::tests::test_capabilities ... ok
test protocol::tests::test_empty ... ok
test protocol::tests::test_fetch ... ok
test protocol::tests::test_fetch_whitespace ... ok
test protocol::tests::test_list ... ok
test protocol::tests::test_list_for_push ... ok
test protocol::tests::test_option ... ok
test protocol::tests::test_option_whitespace_preservation ... ok
test protocol::tests::test_push ... ok
test protocol::tests::test_push_force ... ok
test protocol::tests::test_push_delete ... ok
test protocol::tests::test_invalid ... ok
test result: ok. 12 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Running unittests src/main.rs (target/debug/deps/radicle_schemars-a1f957f3728f7d57)
running 0 tests
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Running unittests src/lib.rs (target/debug/deps/radicle_signals-edd60ee35e85748c)
running 0 tests
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Running unittests src/lib.rs (target/debug/deps/radicle_systemd-d0fb15a14ac3d4e9)
running 0 tests
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Running unittests src/lib.rs (target/debug/deps/radicle_term-51db4123a6bc434a)
running 21 tests
test ansi::tests::colors_disabled ... ok
test cell::test::test_width ... ok
test ansi::tests::colors_enabled ... ok
test ansi::tests::wrapping ... ok
test element::test::test_spaced ... ok
test element::test::test_width ... ok
test element::test::test_truncate ... ok
test table::test::test_table_border_maximized ... ok
test table::test::test_table ... ok
test table::test::test_table_border_truncated ... ok
test table::test::test_table_border ... ok
test table::test::test_table_truncate ... ok
test table::test::test_table_unicode ... ok
test table::test::test_truncate ... ok
test table::test::test_table_unicode_truncate ... ok
test textarea::test::test_wrapping_code_block ... ok
test textarea::test::test_wrapping_fenced_block ... ok
test textarea::test::test_wrapping ... ok
test vstack::test::test_vstack_maximize ... ok
test vstack::test::test_vstack ... ok
test textarea::test::test_wrapping_paragraphs ... ok
test result: ok. 21 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Running unittests src/lib.rs (target/debug/deps/radicle_windows-2c067555aa9e0165)
running 0 tests
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Doc-tests radicle
running 1 test
test crates/radicle/src/cob/patch/encoding/review.rs - cob::patch::encoding::review::Review (line 23) ... ignored
test result: ok. 0 passed; 0 failed; 1 ignored; 0 measured; 0 filtered out; finished in 0.00s
Doc-tests radicle_cli
running 0 tests
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Doc-tests radicle_cli_test
running 0 tests
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Doc-tests radicle_cob
running 1 test
test crates/radicle-cob/src/backend/stable.rs - backend::stable::with_advanced_timestamp (line 56) ... ignored
test result: ok. 0 passed; 0 failed; 1 ignored; 0 measured; 0 filtered out; finished in 0.00s
Doc-tests radicle_core
running 0 tests
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Doc-tests radicle_crypto
running 0 tests
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Doc-tests radicle_dag
running 0 tests
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Doc-tests radicle_fetch
running 0 tests
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Doc-tests radicle_git_metadata
running 0 tests
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Doc-tests radicle_git_ref_format
running 0 tests
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Doc-tests radicle_localtime
running 0 tests
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Doc-tests radicle_node
running 0 tests
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Doc-tests radicle_oid
running 0 tests
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Doc-tests radicle_protocol
running 6 tests
test crates/radicle-protocol/src/bounded.rs - bounded::BoundedVec<T,N>::collect_from (line 30) ... ok
test crates/radicle-protocol/src/bounded.rs - bounded::BoundedVec<T,N>::truncate (line 50) ... ok
test crates/radicle-protocol/src/bounded.rs - bounded::BoundedVec<T,N>::max (line 96) ... ok
test crates/radicle-protocol/src/bounded.rs - bounded::BoundedVec<T,N>::push (line 122) ... ok
test crates/radicle-protocol/src/bounded.rs - bounded::BoundedVec<T,N>::unbound (line 149) ... ok
test crates/radicle-protocol/src/bounded.rs - bounded::BoundedVec<T,N>::with_capacity (line 66) ... ok
test result: ok. 6 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Doc-tests radicle_signals
running 0 tests
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Doc-tests radicle_systemd
running 0 tests
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Doc-tests radicle_term
running 1 test
test crates/radicle-term/src/table.rs - table (line 4) ... ok
test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Doc-tests radicle_windows
running 0 tests
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
error: 1 target failed:
`-p radicle-cli --test commands`
Exit code: 101
{
"response": "finished",
"result": "failure"
}