rad:z3gqcJUoA1n9HaHKufZs5FCSGazv5 heartwoodf6225d6c41255a836e916474dde722542ec5539d
{
"request": "trigger",
"version": 1,
"event_type": "patch",
"repository": {
"id": "rad:z3gqcJUoA1n9HaHKufZs5FCSGazv5",
"name": "heartwood",
"description": "Radicle Heartwood Protocol & Stack",
"private": false,
"default_branch": "master",
"delegates": [
"did:key:z6MksFqXN3Yhqk8pTJdUGLwATkRfQvwZXPqR2qMEhbS9wzpT",
"did:key:z6MktaNvN1KVFMkSRAiN4qK5yvX1zuEEaseeX5sffhzPZRZW",
"did:key:z6MkireRatUThvd3qzfKht1S44wpm4FEWSSa4PRMTSQZ3voM",
"did:key:z6MkgFq6z5fkF2hioLLSNu1zP2qEL1aHXHZzGH1FLFGAnBGz",
"did:key:z6MkkPvBfjP4bQmco5Dm7UGsX2ruDBieEHi8n9DVJWX5sTEz"
]
},
"action": "Created",
"patch": {
"id": "66581a6b9fddfcf18cff6b2e5ba270eee3481f39",
"author": {
"id": "did:key:z6MkwGoyYxt6A2VE3fvZyH2rgiWdsXHBeV7jm7GSByS2aagA",
"alias": "ade"
},
"title": "rust/clippy: Lints for Defensive Programming",
"state": {
"status": "open",
"conflicts": []
},
"before": "02318f199c6f29a2eede1f282e1f9b99927d27ec",
"after": "f6225d6c41255a836e916474dde722542ec5539d",
"commits": [
"f6225d6c41255a836e916474dde722542ec5539d",
"b24fdf36a8fe8e7d2806db11aab9a66f9753d3d6",
"7b30081e018a808f00b4460314c01650c57cf797",
"b0795d324e1391d43d82bdb60941c5c047925723",
"e52b3e46bcff371b31233060e97ff49c313db00b",
"aa714bb8f480c0f0354300c5b36f7e4e7c5ac4cc",
"9280a9d93826eb73b6e4baf4ff11a3310dc866ce",
"77e1ce5595225a3e7d3cb904c4cecd01dcd643cf"
],
"target": "02318f199c6f29a2eede1f282e1f9b99927d27ec",
"labels": [],
"assignees": [],
"revisions": [
{
"id": "66581a6b9fddfcf18cff6b2e5ba270eee3481f39",
"author": {
"id": "did:key:z6MkwGoyYxt6A2VE3fvZyH2rgiWdsXHBeV7jm7GSByS2aagA",
"alias": "ade"
},
"description": "Fixes for [rust/clippy: Lints for Defensive Programming - 9584e6f](https://app.radicle.xyz/nodes/seed.radicle.garden/rad%3Az3gqcJUoA1n9HaHKufZs5FCSGazv5/issues/9584e6f07e21ede81f6f8f5e633eb751f0db5fe7). Added all suggested Clippy lints :).",
"base": "02318f199c6f29a2eede1f282e1f9b99927d27ec",
"oid": "f6225d6c41255a836e916474dde722542ec5539d",
"timestamp": 1768329235
}
]
}
}
{
"response": "triggered",
"run_id": {
"id": "1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c"
},
"info_url": "https://cci.rad.levitte.org//1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c.html"
}
Started at: 2026-01-13 19:34:13.154211+01: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/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/
╭────────────────────────────────────╮
│ heartwood │
│ Radicle Heartwood Protocol & Stack │
│ 131 issues · 16 patches │
╰────────────────────────────────────╯
Run `cd ./.` to go to the repository directory.
Exit code: 0
$ rad patch checkout 66581a6b9fddfcf18cff6b2e5ba270eee3481f39
✓ Switched to branch patch/66581a6 at revision 66581a6
✓ Branch patch/66581a6 setup to track rad/patches/66581a6b9fddfcf18cff6b2e5ba270eee3481f39
Exit code: 0
$ git config advice.detachedHead false
Exit code: 0
$ git checkout f6225d6c41255a836e916474dde722542ec5539d
HEAD is now at f6225d6c clippy: index slice inside tests
Exit code: 0
$ rad patch show 66581a6b9fddfcf18cff6b2e5ba270eee3481f39 -p
╭──────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────╮
│ Title rust/clippy: Lints for Defensive Programming │
│ Patch 66581a6b9fddfcf18cff6b2e5ba270eee3481f39 │
│ Author ade z6MkwGo…yS2aagA │
│ Head f6225d6c41255a836e916474dde722542ec5539d │
│ Base 02318f199c6f29a2eede1f282e1f9b99927d27ec │
│ Branches patch/66581a6 │
│ Commits ahead 8, behind 0 │
│ Status open │
│ │
│ Fixes for [rust/clippy: Lints for Defensive Programming - │
│ 9584e6f](https://app.radicle.xyz/nodes/seed.radicle.garden/rad%3Az3gqcJUoA1n9HaHKufZs5FCSGazv5/issues/9584e6f07e21ede81f6f8f5e633eb751f0db5fe7). │
│ Added all suggested Clippy lints :). │
├──────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ f6225d6 clippy: index slice inside tests │
│ b24fdf3 radicle-cli: remove dead code `parse_remote` │
│ 7b30081 clippy: must use candidate │
│ b0795d3 clippy: fn params excessive bools │
│ e52b3e4 clippy: index slicing │
│ aa714bb clippy: unneeded field pattern │
│ 9280a9d clippy: wildcard enum match arm │
│ 77e1ce5 clippy: fallible impl from │
├──────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┤
│ ● Revision 66581a6 @ f6225d6 by ade z6MkwGo…yS2aagA 19 seconds ago │
╰──────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────────╯
commit f6225d6c41255a836e916474dde722542ec5539d
Author: Adrian Duke <adrian.duke@gmail.com>
Date: Tue Jan 13 16:49:38 2026 +0000
clippy: index slice inside tests
diff --git a/crates/radicle-cli/tests/commands.rs b/crates/radicle-cli/tests/commands.rs
index ce8ca5262..b76a7812f 100644
--- a/crates/radicle-cli/tests/commands.rs
+++ b/crates/radicle-cli/tests/commands.rs
@@ -338,7 +338,7 @@ fn rad_config() {
let mut environment = Environment::new();
let alias = Alias::new("alice");
let profile = environment.profile_with(profile::Config {
- preferred_seeds: vec![RADICLE_NODE_BOOTSTRAP_IRIS.clone()[0].clone()],
+ preferred_seeds: vec![RADICLE_NODE_BOOTSTRAP_IRIS.clone().first().unwrap().clone()],
..profile::Config::new(alias)
});
let working = tempfile::tempdir().unwrap();
commit b24fdf36a8fe8e7d2806db11aab9a66f9753d3d6
Author: Adrian Duke <adrian.duke@gmail.com>
Date: Tue Jan 13 16:47:17 2026 +0000
radicle-cli: remove dead code `parse_remote`
diff --git a/crates/radicle-cli/src/git.rs b/crates/radicle-cli/src/git.rs
index b91f95f9a..7d6888432 100644
--- a/crates/radicle-cli/src/git.rs
+++ b/crates/radicle-cli/src/git.rs
@@ -345,14 +345,6 @@ pub fn check_version() -> Result<Version, anyhow::Error> {
Ok(git_version)
}
-/// Parse a remote refspec into a peer id and ref.
-pub fn parse_remote(refspec: &str) -> Option<(NodeId, &str)> {
- refspec
- .strip_prefix("refs/remotes/")
- .and_then(|s| s.split_once('/'))
- .and_then(|(peer, r)| NodeId::from_str(peer).ok().map(|p| (p, r)))
-}
-
pub fn add_tag(
repo: &Repository,
message: &str,
commit 7b30081e018a808f00b4460314c01650c57cf797
Author: Adrian Duke <adrian.duke@gmail.com>
Date: Tue Jan 13 16:46:21 2026 +0000
clippy: must use candidate
diff --git a/Cargo.toml b/Cargo.toml
index ca4b3eb47..e4a84362b 100644
--- a/Cargo.toml
+++ b/Cargo.toml
@@ -86,6 +86,7 @@ clippy.fallible_impl_from = "deny"
clippy.wildcard_enum_match_arm = "deny"
clippy.unneeded_field_pattern = "deny"
clippy.fn_params_excessive_bools = "deny"
+clippy.must_use_candidate = "deny"
[profile.container]
inherits = "release"
diff --git a/crates/radicle-cli/src/git.rs b/crates/radicle-cli/src/git.rs
index aa51aea02..b91f95f9a 100644
--- a/crates/radicle-cli/src/git.rs
+++ b/crates/radicle-cli/src/git.rs
@@ -43,6 +43,7 @@ pub struct Rev(String);
impl Rev {
/// Return the revision as a string.
+ #[must_use]
pub fn as_str(&self) -> &str {
&self.0
}
diff --git a/crates/radicle-cli/src/git/ddiff.rs b/crates/radicle-cli/src/git/ddiff.rs
index f005ffe72..7157beeef 100644
--- a/crates/radicle-cli/src/git/ddiff.rs
+++ b/crates/radicle-cli/src/git/ddiff.rs
@@ -382,6 +382,7 @@ impl DDiff {
}
/// Returns owned files in the diff.
+ #[must_use]
pub fn into_files(self) -> Vec<FileDDiff> {
self.files
}
diff --git a/crates/radicle-cli/src/git/unified_diff.rs b/crates/radicle-cli/src/git/unified_diff.rs
index a167bec50..3843d0eb8 100644
--- a/crates/radicle-cli/src/git/unified_diff.rs
+++ b/crates/radicle-cli/src/git/unified_diff.rs
@@ -33,6 +33,7 @@ impl Error {
Self::Syntax(msg.to_string())
}
+ #[must_use]
pub fn is_eof(&self) -> bool {
match self {
Self::UnexpectedEof => true,
@@ -137,12 +138,14 @@ impl TryFrom<&Hunk<Modification>> for HunkHeader {
}
impl HunkHeader {
+ #[must_use]
pub fn old_line_range(&self) -> std::ops::Range<u32> {
let start: u32 = self.old_line_no;
let end: u32 = self.old_line_no + self.old_size;
start..end + 1
}
+ #[must_use]
pub fn new_line_range(&self) -> std::ops::Range<u32> {
let start: u32 = self.new_line_no;
let end: u32 = self.new_line_no + self.new_size;
@@ -579,6 +582,7 @@ impl<'a> Writer<'a> {
Ok(())
}
+ #[must_use]
pub fn styled(mut self, value: bool) -> Self {
self.styled = value;
self
diff --git a/crates/radicle-cli/src/node.rs b/crates/radicle-cli/src/node.rs
index 518f4f98d..4db7efc35 100644
--- a/crates/radicle-cli/src/node.rs
+++ b/crates/radicle-cli/src/node.rs
@@ -25,12 +25,14 @@ pub struct SyncSettings {
impl SyncSettings {
/// Set sync timeout. Defaults to [`DEFAULT_SYNC_TIMEOUT`].
+ #[must_use]
pub fn timeout(mut self, timeout: time::Duration) -> Self {
self.timeout = timeout;
self
}
/// Set replicas.
+ #[must_use]
pub fn replicas(mut self, replicas: sync::ReplicationFactor) -> Self {
self.replicas = replicas;
self
@@ -44,6 +46,7 @@ impl SyncSettings {
/// Use profile to populate sync settings, by adding preferred seeds if no seeds are specified,
/// and removing the local node from the set.
+ #[must_use]
pub fn with_profile(mut self, profile: &Profile) -> Self {
// If no seeds were specified, add the preferred seeds.
if self.seeds.is_empty() {
diff --git a/crates/radicle-cli/src/terminal/cob.rs b/crates/radicle-cli/src/terminal/cob.rs
index 1f1b8be4b..7086c4c3a 100644
--- a/crates/radicle-cli/src/terminal/cob.rs
+++ b/crates/radicle-cli/src/terminal/cob.rs
@@ -51,6 +51,7 @@ pub mod migrate {
use super::MigrateSpinner;
/// Display migration progress via a spinner.
+ #[must_use]
pub fn spinner() -> MigrateSpinner {
MigrateSpinner::default()
}
diff --git a/crates/radicle-cli/src/terminal/format.rs b/crates/radicle-cli/src/terminal/format.rs
index 05440a022..2e026cd74 100644
--- a/crates/radicle-cli/src/terminal/format.rs
+++ b/crates/radicle-cli/src/terminal/format.rs
@@ -17,6 +17,7 @@ use radicle_term::element::Line;
use crate::terminal as term;
/// Format a node id to be more compact.
+#[must_use]
pub fn node_id_human_compact(node: &NodeId) -> Paint<String> {
let node = node.to_human();
let start = node.chars().take(7).collect::<String>();
@@ -26,10 +27,12 @@ pub fn node_id_human_compact(node: &NodeId) -> Paint<String> {
}
/// Format a node id.
+#[must_use]
pub fn node_id_human(node: &NodeId) -> Paint<String> {
Paint::new(node.to_human())
}
+#[must_use]
pub fn addr_compact(address: &Address) -> Paint<String> {
let host = match address.host() {
HostName::Ip(ip) => ip.to_string(),
@@ -72,17 +75,20 @@ pub fn command<D: fmt::Display>(cmd: D) -> Paint<String> {
}
/// Format a COB id.
+#[must_use]
pub fn cob(id: &ObjectId) -> Paint<String> {
Paint::new(format!("{:.7}", id.to_string()))
}
/// Format a DID.
+#[must_use]
pub fn did(did: &Did) -> Paint<String> {
let nid = did.as_key().to_human();
Paint::new(format!("{}…{}", &nid[..7], &nid[nid.len() - 7..]))
}
/// Format a Visibility.
+#[must_use]
pub fn visibility(v: &Visibility) -> Paint<&str> {
match v {
Visibility::Public => term::format::positive("public"),
@@ -91,6 +97,7 @@ pub fn visibility(v: &Visibility) -> Paint<&str> {
}
/// Format a policy.
+#[must_use]
pub fn policy(p: &Policy) -> Paint<String> {
match p {
Policy::Allow => term::format::positive(p.to_string()),
@@ -108,6 +115,7 @@ pub fn timestamp(time: impl Into<LocalTime>) -> Paint<String> {
Paint::new(fmt.convert(duration.into()))
}
+#[must_use]
pub fn bytes(size: usize) -> Paint<String> {
const KB: usize = 1024;
const MB: usize = 1024usize.pow(2);
@@ -125,6 +133,7 @@ pub fn bytes(size: usize) -> Paint<String> {
}
/// Format a ref update.
+#[must_use]
pub fn ref_update(update: &RefUpdate) -> Paint<&'static str> {
match update {
RefUpdate::Updated { .. } => term::format::tertiary("updated"),
@@ -134,6 +143,7 @@ pub fn ref_update(update: &RefUpdate) -> Paint<&'static str> {
}
}
+#[must_use]
pub fn ref_update_verbose(update: &RefUpdate) -> Paint<String> {
match update {
RefUpdate::Created { name, .. } => format!(
@@ -175,6 +185,7 @@ pub struct Identity<'a> {
}
impl<'a> Identity<'a> {
+ #[must_use]
pub fn new(profile: &'a Profile) -> Self {
Self {
profile,
@@ -183,11 +194,13 @@ impl<'a> Identity<'a> {
}
}
+ #[must_use]
pub fn short(mut self) -> Self {
self.short = true;
self
}
+ #[must_use]
pub fn styled(mut self) -> Self {
self.styled = true;
self
@@ -227,6 +240,7 @@ pub struct Author<'a> {
}
impl<'a> Author<'a> {
+ #[must_use]
pub fn new(nid: &'a NodeId, profile: &Profile, verbose: bool) -> Author<'a> {
let alias = profile.alias(nid);
@@ -238,10 +252,12 @@ impl<'a> Author<'a> {
}
}
+ #[must_use]
pub fn alias(&self) -> Option<term::Label> {
self.alias.as_ref().map(|a| a.to_string().into())
}
+ #[must_use]
pub fn you(&self) -> Option<term::Label> {
if self.you {
Some(term::format::primary("(you)").dim().italic().into())
@@ -256,6 +272,7 @@ impl<'a> Author<'a> {
/// * `(<did>, (you))` -- the `Author` is the local peer and has no alias
/// * `(<alias>, <did>)` -- the `Author` is another peer and has an alias
/// * `(<blank>, <did>)` -- the `Author` is another peer and has no alias
+ #[must_use]
pub fn labels(self) -> (term::Label, term::Label) {
let node_id = if self.verbose {
term::format::node_id_human(self.nid)
@@ -274,6 +291,7 @@ impl<'a> Author<'a> {
(alias, author)
}
+ #[must_use]
pub fn line(self) -> Line {
let (alias, author) = self.labels();
Line::spaced([alias, author])
@@ -283,6 +301,7 @@ impl<'a> Author<'a> {
/// HTML-related formatting.
pub mod html {
/// Comment a string with HTML comments.
+ #[must_use]
pub fn commented(s: &str) -> String {
format!("<!--\n{s}\n-->")
}
@@ -290,6 +309,7 @@ pub mod html {
/// Remove html style comments from a string.
///
/// The HTML comments must start at the beginning of a line and stop at the end.
+ #[must_use]
pub fn strip_comments(s: &str) -> String {
let ends_with_newline = s.ends_with('\n');
let mut is_comment = false;
@@ -323,6 +343,7 @@ pub mod issue {
use radicle::issue::{CloseReason, State};
/// Format issue state.
+ #[must_use]
pub fn state(s: &State) -> term::Paint<String> {
match s {
State::Open => term::format::positive(s.to_string()),
@@ -341,6 +362,7 @@ pub mod patch {
use super::*;
use radicle::patch::{State, Verdict};
+ #[must_use]
pub fn verdict(v: Option<Verdict>) -> term::Paint<String> {
match v {
Some(Verdict::Accept) => term::PREFIX_SUCCESS.into(),
@@ -350,6 +372,7 @@ pub mod patch {
}
/// Format patch state.
+ #[must_use]
pub fn state(s: &State) -> term::Paint<String> {
match s {
State::Draft => term::format::dim(s.to_string()),
@@ -366,6 +389,7 @@ pub mod identity {
use radicle::cob::identity::State;
/// Format identity revision state.
+ #[must_use]
pub fn state(s: &State) -> term::Paint<String> {
match s {
State::Active => term::format::tertiary(s.to_string()),
diff --git a/crates/radicle-cli/src/terminal/highlight.rs b/crates/radicle-cli/src/terminal/highlight.rs
index b62f9420b..e5f04ef49 100644
--- a/crates/radicle-cli/src/terminal/highlight.rs
+++ b/crates/radicle-cli/src/terminal/highlight.rs
@@ -59,6 +59,7 @@ impl Default for Theme {
impl Theme {
/// Get the named color.
+ #[must_use]
pub fn color(&self, color: &'static str) -> term::Color {
if let Some(c) = (self.color)(color) {
c
@@ -68,6 +69,7 @@ impl Theme {
}
/// Return the color of a syntax group.
+ #[must_use]
pub fn highlight(&self, group: &'static str) -> Option<term::Color> {
let color = match group {
"keyword" => self.color("red"),
diff --git a/crates/radicle-cli/src/terminal/io.rs b/crates/radicle-cli/src/terminal/io.rs
index 77c6cf2a4..e37d8b3d6 100644
--- a/crates/radicle-cli/src/terminal/io.rs
+++ b/crates/radicle-cli/src/terminal/io.rs
@@ -21,6 +21,7 @@ pub struct PassphraseValidator {
impl PassphraseValidator {
/// Create a new validator.
+ #[must_use]
pub fn new(keystore: Keystore) -> Self {
Self { keystore }
}
diff --git a/crates/radicle-cli/src/terminal/patch.rs b/crates/radicle-cli/src/terminal/patch.rs
index daf823a8b..5d5599ada 100644
--- a/crates/radicle-cli/src/terminal/patch.rs
+++ b/crates/radicle-cli/src/terminal/patch.rs
@@ -140,6 +140,7 @@ blank is also okay.
/// Combine the title and description fields to display to the user.
#[inline]
+#[must_use]
pub fn message(title: &str, description: &str) -> String {
format!("{title}\n\n{description}").trim().to_string()
}
diff --git a/crates/radicle-cli/src/terminal/upload_pack.rs b/crates/radicle-cli/src/terminal/upload_pack.rs
index 6e3db7bff..ab4cf0eb9 100644
--- a/crates/radicle-cli/src/terminal/upload_pack.rs
+++ b/crates/radicle-cli/src/terminal/upload_pack.rs
@@ -22,6 +22,7 @@ impl Default for UploadPack {
impl UploadPack {
/// Construct an empty set of spinners.
+ #[must_use]
pub fn new() -> Self {
Self {
remotes: BTreeSet::new(),
diff --git a/crates/radicle-core/src/repo.rs b/crates/radicle-core/src/repo.rs
index 0ef25438f..347ba18d8 100644
--- a/crates/radicle-core/src/repo.rs
+++ b/crates/radicle-core/src/repo.rs
@@ -47,6 +47,7 @@ impl RepoId {
///
/// Eg. `rad:z3XncAdkZjeK9mQS5Sdc4qhw98BUX`.
///
+ #[must_use]
pub fn urn(&self) -> String {
RAD_PREFIX.to_string() + &self.canonical()
}
@@ -65,6 +66,7 @@ impl RepoId {
///
/// Eg. `z3XncAdkZjeK9mQS5Sdc4qhw98BUX`.
///
+ #[must_use]
pub fn canonical(&self) -> String {
multibase::encode(multibase::Base::Base58Btc, AsRef::<[u8]>::as_ref(&self.0))
}
diff --git a/crates/radicle-localtime/src/lib.rs b/crates/radicle-localtime/src/lib.rs
index 53849a58e..3e92c041c 100644
--- a/crates/radicle-localtime/src/lib.rs
+++ b/crates/radicle-localtime/src/lib.rs
@@ -43,6 +43,7 @@ impl LocalTime {
}
/// Construct a local time from whole seconds since Epoch.
+ #[must_use = "constructor return new instances"]
pub const fn from_secs(secs: u64) -> Self {
Self {
millis: secs as u128 * 1000,
@@ -50,16 +51,19 @@ impl LocalTime {
}
/// Construct a local time from milliseconds since Epoch.
+ #[must_use = "constructor return new instances"]
pub const fn from_millis(millis: u128) -> Self {
Self { millis }
}
/// Return whole seconds since Epoch.
+ #[must_use = "returns a value but does not modify the time"]
pub fn as_secs(&self) -> u64 {
(self.millis / 1000).try_into().unwrap()
}
/// Return milliseconds since Epoch.
+ #[must_use = "returns a value but does not modify the time"]
pub fn as_millis(&self) -> u64 {
self.millis.try_into().unwrap()
}
@@ -69,6 +73,7 @@ impl LocalTime {
/// # Panics
///
/// This function will panic if `earlier` is later than `self`.
+ #[must_use = "returns the duration but does not modify the time"]
pub fn duration_since(&self, earlier: LocalTime) -> LocalDuration {
LocalDuration::from_millis(
self.millis
@@ -78,6 +83,7 @@ impl LocalTime {
}
/// Get the difference between two times.
+ #[must_use = "returns the difference but does not modify the time"]
pub fn diff(&self, other: LocalTime) -> LocalDuration {
if self > &other {
self.duration_since(other)
@@ -153,31 +159,37 @@ impl LocalDuration {
pub const MAX: LocalDuration = LocalDuration(u128::MAX);
/// Create a new duration from whole seconds.
+ #[must_use = "constructor return new instances"]
pub const fn from_secs(secs: u64) -> Self {
Self(secs as u128 * 1000)
}
/// Create a new duration from whole minutes.
+ #[must_use = "constructor return new instances"]
pub const fn from_mins(mins: u64) -> Self {
Self::from_secs(mins * 60)
}
/// Construct a new duration from milliseconds.
+ #[must_use = "constructor return new instances"]
pub const fn from_millis(millis: u128) -> Self {
Self(millis)
}
/// Return the number of minutes in this duration.
+ #[must_use = "returns a value but does not modify the duration"]
pub const fn as_mins(&self) -> u64 {
self.as_secs() / 60
}
/// Return the number of seconds in this duration.
+ #[must_use = "returns a value but does not modify the duration"]
pub const fn as_secs(&self) -> u64 {
(self.0 / 1000) as u64
}
/// Return the number of milliseconds in this duration.
+ #[must_use = "returns a value but does not modify the duration"]
pub const fn as_millis(&self) -> u128 {
self.0
}
commit b0795d324e1391d43d82bdb60941c5c047925723
Author: Adrian Duke <adrian.duke@gmail.com>
Date: Tue Jan 13 15:46:07 2026 +0000
clippy: fn params excessive bools
diff --git a/Cargo.toml b/Cargo.toml
index 2ec9106c5..ca4b3eb47 100644
--- a/Cargo.toml
+++ b/Cargo.toml
@@ -85,6 +85,7 @@ clippy.indexing_slicing = "deny"
clippy.fallible_impl_from = "deny"
clippy.wildcard_enum_match_arm = "deny"
clippy.unneeded_field_pattern = "deny"
+clippy.fn_params_excessive_bools = "deny"
[profile.container]
inherits = "release"
commit e52b3e46bcff371b31233060e97ff49c313db00b
Author: Adrian Duke <adrian.duke@gmail.com>
Date: Tue Jan 13 15:45:03 2026 +0000
clippy: index slicing
diff --git a/Cargo.toml b/Cargo.toml
index 29d418190..2ec9106c5 100644
--- a/Cargo.toml
+++ b/Cargo.toml
@@ -81,6 +81,7 @@ radicle-surf = "0.26.0"
[workspace.lints]
clippy.type_complexity = "allow"
clippy.enum_variant_names = "allow"
+clippy.indexing_slicing = "deny"
clippy.fallible_impl_from = "deny"
clippy.wildcard_enum_match_arm = "deny"
clippy.unneeded_field_pattern = "deny"
diff --git a/crates/radicle-cli/src/commands/cob/args.rs b/crates/radicle-cli/src/commands/cob/args.rs
index a7c315b7e..bd5f388bd 100644
--- a/crates/radicle-cli/src/commands/cob/args.rs
+++ b/crates/radicle-cli/src/commands/cob/args.rs
@@ -210,6 +210,7 @@ where
chunks.map(|chunk| {
// Slice accesses will not panic, guaranteed by `chunks_exact(2)`.
+ #[allow(clippy::indexing_slicing)]
Embed {
name: chunk[0].to_string(),
content: EmbedContent::from(T::from(chunk[1].clone())),
diff --git a/crates/radicle-cli/src/commands/id/args.rs b/crates/radicle-cli/src/commands/id/args.rs
index 05b802b7f..c123b0ef2 100644
--- a/crates/radicle-cli/src/commands/id/args.rs
+++ b/crates/radicle-cli/src/commands/id/args.rs
@@ -55,6 +55,7 @@ pub(super) fn parse_many_upserts(
chunks.map(|chunk| {
// Slice accesses will not panic, guaranteed by `chunks_exact(3)`.
+ #[allow(clippy::indexing_slicing)]
Ok(PayloadUpsert {
id: PayloadId::from_str(&chunk[0])?,
key: chunk[1].to_owned(),
diff --git a/crates/radicle-cli/src/git/pretty_diff.rs b/crates/radicle-cli/src/git/pretty_diff.rs
index a5319cfa8..dc306b93e 100644
--- a/crates/radicle-cli/src/git/pretty_diff.rs
+++ b/crates/radicle-cli/src/git/pretty_diff.rs
@@ -537,14 +537,14 @@ impl ToPretty for Modification {
match self {
Modification::Deletion(diff::Deletion { line, line_no }) => {
if let Some(lines) = &blobs.old.as_ref() {
- lines[*line_no as usize - 1].clone()
+ lines.get(*line_no as usize - 1).unwrap().clone()
} else {
term::Line::new(String::from_utf8_lossy(line.as_bytes()).as_ref())
}
}
Modification::Addition(diff::Addition { line, line_no }) => {
if let Some(lines) = &blobs.new.as_ref() {
- lines[*line_no as usize - 1].clone()
+ lines.get(*line_no as usize - 1).unwrap().clone()
} else {
term::Line::new(String::from_utf8_lossy(line.as_bytes()).as_ref())
}
@@ -554,7 +554,7 @@ impl ToPretty for Modification {
} => {
// Nb. we can check in the old or the new blob, we choose the new.
if let Some(lines) = &blobs.new.as_ref() {
- lines[*line_no_new as usize - 1].clone()
+ lines.get(*line_no_new as usize - 1).unwrap().clone()
} else {
term::Line::new(String::from_utf8_lossy(line.as_bytes()).as_ref())
}
diff --git a/crates/radicle-cli/src/terminal/highlight.rs b/crates/radicle-cli/src/terminal/highlight.rs
index 4e4045e70..b62f9420b 100644
--- a/crates/radicle-cli/src/terminal/highlight.rs
+++ b/crates/radicle-cli/src/terminal/highlight.rs
@@ -145,9 +145,11 @@ impl Builder {
}
}
ts::HighlightEvent::HighlightStart(h) => {
- let name = HIGHLIGHTS[h.0];
- let style =
- term::Style::default().fg(theme.highlight(name).unwrap_or_default());
+ let color = HIGHLIGHTS
+ .get(h.0)
+ .and_then(|name| theme.highlight(name))
+ .unwrap_or_default();
+ let style = term::Style::default().fg(color);
self.advance();
self.styles.push(style);
diff --git a/crates/radicle-cli/src/terminal/io.rs b/crates/radicle-cli/src/terminal/io.rs
index c3d470398..77c6cf2a4 100644
--- a/crates/radicle-cli/src/terminal/io.rs
+++ b/crates/radicle-cli/src/terminal/io.rs
@@ -78,7 +78,7 @@ pub fn comment_select(issue: &Issue) -> anyhow::Result<(&CommentId, &Comment)> {
(0..comments.len()).collect(),
)
.with_render_config(*CONFIG)
- .with_formatter(&|i| comments[i.index].1.body().to_owned())
+ .with_formatter(&|i| comments.get(i.index).unwrap().1.body().to_owned())
.prompt()?;
comments
commit aa714bb8f480c0f0354300c5b36f7e4e7c5ac4cc
Author: Adrian Duke <adrian.duke@gmail.com>
Date: Tue Jan 13 15:06:47 2026 +0000
clippy: unneeded field pattern
diff --git a/Cargo.toml b/Cargo.toml
index c95650396..29d418190 100644
--- a/Cargo.toml
+++ b/Cargo.toml
@@ -83,6 +83,7 @@ clippy.type_complexity = "allow"
clippy.enum_variant_names = "allow"
clippy.fallible_impl_from = "deny"
clippy.wildcard_enum_match_arm = "deny"
+clippy.unneeded_field_pattern = "deny"
[profile.container]
inherits = "release"
diff --git a/crates/radicle-cli/src/commands/cob.rs b/crates/radicle-cli/src/commands/cob.rs
index a565797c3..940414c55 100644
--- a/crates/radicle-cli/src/commands/cob.rs
+++ b/crates/radicle-cli/src/commands/cob.rs
@@ -150,7 +150,7 @@ pub fn run(args: Args, ctx: impl term::Context) -> anyhow::Result<()> {
repo,
objects,
type_name,
- format: _,
+ ..
} => {
let repo = storage.repository(repo)?;
if let Err(e) = show(objects, &repo, type_name.into(), &profile) {
@@ -167,7 +167,7 @@ pub fn run(args: Args, ctx: impl term::Context) -> anyhow::Result<()> {
type_name,
object,
operation,
- format: _,
+ ..
}) => {
let signer = &profile.signer()?;
let repo = storage.repository_mut(repo)?;
diff --git a/crates/radicle-cli/src/commands/follow.rs b/crates/radicle-cli/src/commands/follow.rs
index 851542c1f..aa214cd2e 100644
--- a/crates/radicle-cli/src/commands/follow.rs
+++ b/crates/radicle-cli/src/commands/follow.rs
@@ -14,12 +14,8 @@ pub fn run(args: Args, ctx: impl term::Context) -> anyhow::Result<()> {
let mut node = radicle::Node::new(profile.socket());
match Operation::from(args) {
- Operation::Follow {
- nid,
- alias,
- verbose: _,
- } => follow(nid, alias, &mut node, &profile)?,
- Operation::List { alias, verbose: _ } => following(&profile, alias)?,
+ Operation::Follow { nid, alias, .. } => follow(nid, alias, &mut node, &profile)?,
+ Operation::List { alias, .. } => following(&profile, alias)?,
}
Ok(())
commit 9280a9d93826eb73b6e4baf4ff11a3310dc866ce
Author: Adrian Duke <adrian.duke@gmail.com>
Date: Tue Jan 13 14:59:55 2026 +0000
clippy: wildcard enum match arm
diff --git a/Cargo.toml b/Cargo.toml
index 85057f3c8..c95650396 100644
--- a/Cargo.toml
+++ b/Cargo.toml
@@ -82,6 +82,7 @@ radicle-surf = "0.26.0"
clippy.type_complexity = "allow"
clippy.enum_variant_names = "allow"
clippy.fallible_impl_from = "deny"
+clippy.wildcard_enum_match_arm = "deny"
[profile.container]
inherits = "release"
diff --git a/crates/radicle-cli/src/commands/inbox.rs b/crates/radicle-cli/src/commands/inbox.rs
index 7dd3ddbc6..616e3382f 100644
--- a/crates/radicle-cli/src/commands/inbox.rs
+++ b/crates/radicle-cli/src/commands/inbox.rs
@@ -453,7 +453,8 @@ fn show(
.spawn()?
.wait()?;
}
- notification => {
+ notification @ NotificationKind::Cob { .. }
+ | notification @ NotificationKind::Unknown { .. } => {
term::json::to_pretty(¬ification, Path::new("notification.json"))?.print();
}
}
diff --git a/crates/radicle-cli/src/commands/issue/args.rs b/crates/radicle-cli/src/commands/issue/args.rs
index de04489e4..e89023f31 100644
--- a/crates/radicle-cli/src/commands/issue/args.rs
+++ b/crates/radicle-cli/src/commands/issue/args.rs
@@ -196,7 +196,7 @@ impl Command {
// Special handling for `--edit` will be removed in the future.
| Command::Edit { .. } => true,
Command::Comment(args) => !args.is_edit(),
- _ => false,
+ Command::Cache{..} | Command::Show { .. } | Command::List(_) => false,
}
}
}
diff --git a/crates/radicle-cli/src/commands/patch/review/builder.rs b/crates/radicle-cli/src/commands/patch/review/builder.rs
index 054273052..ba5c6b279 100644
--- a/crates/radicle-cli/src/commands/patch/review/builder.rs
+++ b/crates/radicle-cli/src/commands/patch/review/builder.rs
@@ -186,7 +186,10 @@ impl ReviewItem {
Self::FileAdded { hunk, .. } => hunk.as_ref(),
Self::FileDeleted { hunk, .. } => hunk.as_ref(),
Self::FileModified { hunk, .. } => hunk.as_ref(),
- _ => None,
+ Self::FileMoved { .. }
+ | Self::FileCopied { .. }
+ | Self::FileEofChanged { .. }
+ | Self::FileModeChanged { .. } => None,
}
}
@@ -277,7 +280,7 @@ impl ReviewItem {
EofNewLine::OldMissing => {
VStack::default().child(term::Label::new("`\\n` added at end-of-file"))
}
- _ => VStack::default(),
+ EofNewLine::BothMissing | EofNewLine::NoneMissing => VStack::default(),
},
Self::FileModeChanged { .. } => VStack::default(),
}
diff --git a/crates/radicle-cli/src/git/unified_diff.rs b/crates/radicle-cli/src/git/unified_diff.rs
index d37cdcbff..a167bec50 100644
--- a/crates/radicle-cli/src/git/unified_diff.rs
+++ b/crates/radicle-cli/src/git/unified_diff.rs
@@ -37,7 +37,7 @@ impl Error {
match self {
Self::UnexpectedEof => true,
Self::Io(e) => e.kind() == io::ErrorKind::UnexpectedEof,
- _ => false,
+ Self::Syntax(_) | Self::ParseInt(_) | Self::Utf8(_) => false,
}
}
}
diff --git a/crates/radicle-cli/src/node.rs b/crates/radicle-cli/src/node.rs
index 3212ecc6b..518f4f98d 100644
--- a/crates/radicle-cli/src/node.rs
+++ b/crates/radicle-cli/src/node.rs
@@ -87,7 +87,7 @@ impl SyncError {
fn is_connection_err(&self) -> bool {
match self {
Self::Node(e) => e.is_connection_err(),
- _ => false,
+ Self::Repository(_) | Self::AllSeedsTimedOut | Self::Target(_) => false,
}
}
}
diff --git a/crates/radicle-cli/src/terminal/cob.rs b/crates/radicle-cli/src/terminal/cob.rs
index d43f932cf..1f1b8be4b 100644
--- a/crates/radicle-cli/src/terminal/cob.rs
+++ b/crates/radicle-cli/src/terminal/cob.rs
@@ -102,6 +102,9 @@ where
/// Adds a hint to the COB out-of-date database error.
fn with_hint(e: profile::Error) -> anyhow::Error {
+ // There are many types that aren't `profile::Error::CobsCache`; specifying them all in an
+ // error path seems overly verbose with little value.
+ #[allow(clippy::wildcard_enum_match_arm)]
match e {
profile::Error::CobsCache(cob::cache::Error::OutOfDate) => {
anyhow::Error::from(terminal::args::Error::WithHint {
diff --git a/crates/radicle-core/src/repo.rs b/crates/radicle-core/src/repo.rs
index 82a637b63..0ef25438f 100644
--- a/crates/radicle-core/src/repo.rs
+++ b/crates/radicle-core/src/repo.rs
@@ -234,10 +234,12 @@ mod sqlite_impls {
code: None,
message: Some(e.to_string()),
}),
- _ => Err(Error {
- code: None,
- message: Some(format!("sql: invalid type `{:?}` for id", value.kind())),
- }),
+ Value::Binary(_) | Value::Float(_) | Value::Integer(_) | Value::Null => {
+ Err(Error {
+ code: None,
+ message: Some(format!("sql: invalid type `{:?}` for id", value.kind())),
+ })
+ }
}
}
}
commit 77e1ce5595225a3e7d3cb904c4cecd01dcd643cf
Author: Adrian Duke <adrian.duke@gmail.com>
Date: Tue Jan 13 14:27:41 2026 +0000
clippy: fallible impl from
diff --git a/Cargo.toml b/Cargo.toml
index cf07d16cf..85057f3c8 100644
--- a/Cargo.toml
+++ b/Cargo.toml
@@ -81,6 +81,7 @@ radicle-surf = "0.26.0"
[workspace.lints]
clippy.type_complexity = "allow"
clippy.enum_variant_names = "allow"
+clippy.fallible_impl_from = "deny"
[profile.container]
inherits = "release"
diff --git a/crates/radicle-cli/src/commands/patch/args.rs b/crates/radicle-cli/src/commands/patch/args.rs
index 1d0ac1560..83f4dcc5b 100644
--- a/crates/radicle-cli/src/commands/patch/args.rs
+++ b/crates/radicle-cli/src/commands/patch/args.rs
@@ -393,6 +393,9 @@ pub(super) enum CommentAction {
},
}
+// `emoji.unwrap()` is safe because an --emoji is required by --react and
+// --react requires --emoji in Clap. See CommentArts::react and CommentArgs::emoji.
+#[allow(clippy::fallible_impl_from)]
impl From<CommentArgs> for CommentAction {
fn from(
CommentArgs {
diff --git a/crates/radicle-localtime/src/lib.rs b/crates/radicle-localtime/src/lib.rs
index d61445766..53849a58e 100644
--- a/crates/radicle-localtime/src/lib.rs
+++ b/crates/radicle-localtime/src/lib.rs
@@ -3,7 +3,7 @@
//! Taken from <https://github.com/cloudhead/localtime>
use std::sync::atomic;
-use std::time::{SystemTime, UNIX_EPOCH};
+use std::time::{SystemTime, SystemTimeError, UNIX_EPOCH};
/// Local time.
///
@@ -30,7 +30,7 @@ impl LocalTime {
pub fn now() -> Self {
static LAST: atomic::AtomicU64 = atomic::AtomicU64::new(0);
- let now = Self::from(SystemTime::now()).as_secs();
+ let now = Self::try_from(SystemTime::now()).unwrap().as_secs();
let last = LAST.load(atomic::Ordering::SeqCst);
// If the current time is in the past, return the last recorded time instead.
@@ -95,11 +95,13 @@ impl LocalTime {
}
/// Convert a `SystemTime` into a local time.
-impl From<SystemTime> for LocalTime {
- fn from(system: SystemTime) -> Self {
- let millis = system.duration_since(UNIX_EPOCH).unwrap().as_millis();
+impl TryFrom<SystemTime> for LocalTime {
+ type Error = SystemTimeError;
- Self { millis }
+ fn try_from(system: SystemTime) -> Result<Self, Self::Error> {
+ system.duration_since(UNIX_EPOCH).map(|duration| Self {
+ millis: duration.as_millis(),
+ })
}
}
diff --git a/crates/radicle-node/src/main.rs b/crates/radicle-node/src/main.rs
index 9fcd4cc8e..03f221e1b 100644
--- a/crates/radicle-node/src/main.rs
+++ b/crates/radicle-node/src/main.rs
@@ -51,6 +51,9 @@ enum Logger {
Systemd,
}
+// Required for Mac and potentially Windows as clippy complains because of the OS specific
+// guard below.
+#[allow(clippy::derivable_impls)]
impl Default for Logger {
fn default() -> Self {
#[cfg(all(feature = "systemd", target_os = "linux"))]
diff --git a/crates/radicle-node/src/wire.rs b/crates/radicle-node/src/wire.rs
index 58ac544a6..241fe44f1 100644
--- a/crates/radicle-node/src/wire.rs
+++ b/crates/radicle-node/src/wire.rs
@@ -510,7 +510,8 @@ where
.sum();
self.metrics.worker_queue_size = self.worker.len();
- self.service.tick(SystemTime::now().into(), &self.metrics);
+ self.service
+ .tick(SystemTime::now().try_into().unwrap(), &self.metrics);
}
fn timer_reacted(&mut self) {
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 1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c -v /opt/radcis/ci.rad.levitte.org/cci/state/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/s:/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/s:ro -v /opt/radcis/ci.rad.levitte.org/cci/state/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w:/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w -w /1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w -v /opt/radcis/ci.rad.levitte.org/.radicle:/${id}/.radicle:ro -e RAD_HOME=/${id}/.radicle rust:trixie bash /1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/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 getrandom v0.3.3
Downloaded gix-ref v0.53.1
Downloaded colorchoice v1.0.0
Downloaded clap v4.5.44
Downloaded bloomy v1.2.0
Downloaded git-ref-format-macro v0.6.0
Downloaded lazy_static v1.5.0
Downloaded lock_api v0.4.14
Downloaded icu_provider v1.5.0
Downloaded itoa v1.0.11
Downloaded jobserver v0.1.31
Downloaded git-ref-format v0.6.0
Downloaded jsonschema v0.30.0
Downloaded litemap v0.7.5
Downloaded gix-hashtable v0.9.0
Downloaded gix-protocol v0.51.0
Downloaded gix-chunk v0.4.11
Downloaded env_filter v0.1.3
Downloaded inquire v0.7.5
Downloaded digest v0.10.7
Downloaded libgit2-sys v0.17.0+1.8.1
Downloaded pkcs1 v0.7.5
Downloaded inout v0.1.3
Downloaded fast-glob v0.3.3
Downloaded gix-commitgraph v0.29.0
Downloaded gix-path v0.10.20
Downloaded dyn-clone v1.0.17
Downloaded gix-refspec v0.31.0
Downloaded gix-fs v0.16.1
Downloaded indicatif v0.18.0
Downloaded litrs v0.4.1
Downloaded outref v0.5.2
Downloaded noise-framework v0.4.0
Downloaded memmap2 v0.9.8
Downloaded proc-macro-error-attr2 v2.0.0
Downloaded pin-project-lite v0.2.16
Downloaded quick-error v1.2.3
Downloaded nu-ansi-term v0.46.0
Downloaded indexmap v2.2.6
Downloaded proc-macro-error2 v2.0.1
Downloaded proc-macro2 v1.0.101
Downloaded memchr v2.7.2
Downloaded thiserror v2.0.17
Downloaded prodash v30.0.1
Downloaded mio v0.8.11
Downloaded tracing-core v0.1.34
Downloaded p521 v0.13.3
Downloaded git2 v0.19.0
Downloaded rustix v1.0.7
Downloaded sha1-checked v0.10.0
Downloaded unicode-display-width v0.3.0
Downloaded typeid v1.0.3
Downloaded toml_writer v1.0.2
Downloaded unicode-ident v1.0.12
Downloaded tinyvec v1.6.0
Downloaded version_check v0.9.4
Downloaded xattr v1.3.1
Downloaded zerofrom v0.1.6
Downloaded sharded-slab v0.1.7
Downloaded serde-untagged v0.1.7
Downloaded sval_json v2.14.1
Downloaded tracing-log v0.2.0
Downloaded serde_spanned v1.0.0
Downloaded utf16_iter v1.0.5
Downloaded rsa v0.9.6
Downloaded write16 v1.0.0
Downloaded toml v0.9.5
Downloaded zlib-rs v0.5.2
Downloaded uuid v1.16.0
Downloaded tracing v0.1.41
Downloaded yansi v0.5.1
Downloaded yoke v0.7.5
Downloaded sval_fmt v2.14.1
Downloaded zeroize v1.7.0
Downloaded tree-sitter-highlight v0.24.4
Downloaded regex-automata v0.1.10
Downloaded vsimd v0.8.0
Downloaded sval_dynamic v2.14.1
Downloaded shlex v1.3.0
Downloaded sval_ref v2.14.1
Downloaded tree-sitter-css v0.23.1
Downloaded shell-words v1.1.0
Downloaded signature v1.6.4
Downloaded same-file v1.0.6
Downloaded url v2.5.4
Downloaded unicode-width v0.1.11
Downloaded tree-sitter-c v0.23.2
Downloaded zerovec v0.10.4
Downloaded zerovec-derive v0.10.3
Downloaded zerocopy v0.7.35
Downloaded tree-sitter v0.24.4
Downloaded winnow v0.7.13
Downloaded tree-sitter-python v0.23.4
Downloaded tree-sitter-go v0.23.4
Downloaded vcpkg v0.2.15
Downloaded unicode-width v0.2.1
Downloaded rustix v0.38.34
Downloaded regex-syntax v0.6.29
Downloaded regex v1.11.1
Downloaded tree-sitter-rust v0.23.2
Downloaded tree-sitter-md v0.3.2
Downloaded regex-syntax v0.8.5
Downloaded libc v0.2.174
Downloaded tracing-subscriber v0.3.19
Downloaded tree-sitter-bash v0.23.3
Downloaded yoke-derive v0.7.5
Downloaded wait-timeout v0.2.1
Downloaded tree-sitter-ruby v0.23.1
Downloaded unicode-normalization v0.1.23
Downloaded tree-sitter-html v0.23.2
Downloaded serde_derive_internals v0.29.1
Downloaded rustc-demangle v0.1.26
Downloaded siphasher v0.3.11
Downloaded regex-automata v0.4.9
Downloaded similar v2.5.0
Downloaded serde_json v1.0.140
Downloaded schemars v1.0.4
Downloaded unicode-segmentation v1.11.0
Downloaded schemars_derive v1.0.4
Downloaded value-bag v1.11.1
Downloaded uuid-simd v0.8.0
Downloaded syn v2.0.106
Downloaded ssh-key v0.6.6
Downloaded signal-hook v0.3.18
Downloaded serde v1.0.219
Downloaded tree-sitter-typescript v0.23.2
Downloaded tokio v1.47.1
Downloaded writeable v0.5.5
Downloaded walkdir v2.5.0
Downloaded typenum v1.17.0
Downloaded thiserror-impl v1.0.69
Downloaded linux-raw-sys v0.4.13
Downloaded sval v2.14.1
Downloaded siphasher v1.0.1
Downloaded ryu v1.0.17
Downloaded sem_safe v0.2.0
Downloaded tree-sitter-json v0.24.8
Downloaded thiserror-impl v2.0.17
Downloaded systemd-journal-logger v2.2.2
Downloaded syn v1.0.109
Downloaded sval_nested v2.14.1
Downloaded salsa20 v0.10.2
Downloaded sha3 v0.10.8
Downloaded zerofrom-derive v0.1.6
Downloaded sval_serde v2.14.1
Downloaded scrypt v0.11.0
Downloaded sval_buffer v2.14.1
Downloaded signature v2.2.0
Downloaded signals_receipts v0.2.0
Downloaded scopeguard v1.2.0
Downloaded rusty-fork v0.3.1
Downloaded unit-prefix v0.5.1
Downloaded tree-sitter-toml-ng v0.6.0
Downloaded thread_local v1.1.9
Downloaded synstructure v0.13.1
Downloaded signal-hook-mio v0.2.4
Downloaded sha2 v0.10.8
Downloaded sha1 v0.10.6
Downloaded serde_fmt v1.0.3
Downloaded tar v0.4.40
Downloaded serde_derive v1.0.219
Downloaded rand v0.9.2
Downloaded proptest v1.9.0
Downloaded radicle-surf v0.26.0
Downloaded utf8parse v0.2.1
Downloaded sec1 v0.7.3
Downloaded signal-hook-registry v1.4.5
Downloaded value-bag-sval2 v1.11.1
Downloaded value-bag-serde1 v1.11.1
Downloaded utf8_iter v1.0.4
Downloaded universal-hash v0.5.1
Downloaded unarray v0.1.4
Downloaded socket2 v0.5.7
Downloaded structured-logger v1.0.4
Downloaded streaming-iterator v0.1.9
Downloaded rand_chacha v0.3.1
Downloaded rand v0.8.5
Downloaded portable-atomic v1.11.0
Downloaded test-log-macros v0.2.18
Downloaded tempfile v3.23.0
Downloaded spki v0.7.3
Downloaded socks5-client v0.4.1
Downloaded snapbox v0.4.17
Downloaded smallvec v1.15.1
Downloaded rand_chacha v0.9.0
Downloaded tree-sitter-language v0.1.2
Downloaded toml_datetime v0.7.0
Downloaded tinyvec_macros v0.1.1
Downloaded tinystr v0.7.6
Downloaded timeago v0.4.2
Downloaded thiserror v1.0.69
Downloaded test-log v0.2.18
Downloaded subtle v2.5.0
Downloaded strsim v0.11.1
Downloaded stable_deref_trait v1.2.0
Downloaded ssh-encoding v0.2.0
Downloaded ssh-cipher v0.2.0
Downloaded sqlite3-sys v0.15.2
Downloaded sqlite v0.32.0
Downloaded spin v0.9.8
Downloaded snapbox-macros v0.3.8
Downloaded rfc6979 v0.4.0
Downloaded referencing v0.30.0
Downloaded ref-cast-impl v1.0.24
Downloaded ref-cast v1.0.24
Downloaded rand_xorshift v0.4.0
Downloaded rand_core v0.6.4
Downloaded radicle-std-ext v0.2.0
Downloaded radicle-git-ext v0.11.0
Downloaded quote v1.0.41
Downloaded qcheck-macros v1.0.0
Downloaded qcheck v1.0.0
Downloaded primeorder v0.13.6
Downloaded pretty_assertions v1.4.0
Downloaded ppv-lite86 v0.2.17
Downloaded percent-encoding v2.3.1
Downloaded object v0.36.7
Downloaded rand_core v0.9.3
Downloaded polyval v0.6.2
Downloaded pkg-config v0.3.30
Downloaded p384 v0.13.0
Downloaded icu_properties_data v1.5.1
Downloaded aes-gcm v0.10.3
Downloaded num-bigint-dig v0.8.4
Downloaded itertools v0.14.0
Downloaded clap_builder v4.5.44
Downloaded aho-corasick v1.1.3
Downloaded cyphernet v0.5.2
Downloaded crossterm v0.29.0
Downloaded aes v0.8.4
Downloaded num-bigint v0.4.6
Downloaded miniz_oxide v0.8.8
Downloaded derive_more-impl v2.0.1
Downloaded derive_more v2.0.1
Downloaded bstr v1.12.0
Downloaded p256 v0.13.2
Downloaded fraction v0.15.3
Downloaded crossbeam-utils v0.8.19
Downloaded idna v1.0.3
Downloaded elliptic-curve v0.13.8
Downloaded pkcs8 v0.10.2
Downloaded num-traits v0.2.19
Downloaded hashbrown v0.14.3
Downloaded clap_derive v4.5.41
Downloaded amplify_num v0.5.2
Downloaded amplify_derive v4.0.0
Downloaded amplify v4.6.0
Downloaded parking_lot_core v0.9.12
Downloaded once_cell v1.21.3
Downloaded num-rational v0.4.2
Downloaded escargot v0.5.10
Downloaded ec25519 v0.1.0
Downloaded ascii v1.1.0
Downloaded libm v0.2.8
Downloaded jiff-static v0.2.15
Downloaded gix-transport v0.48.0
Downloaded ed25519 v1.5.3
Downloaded addr2line v0.24.2
Downloaded poly1305 v0.8.0
Downloaded phf v0.11.3
Downloaded pem-rfc7468 v0.7.0
Downloaded parking_lot v0.12.5
Downloaded os_info v3.12.0
Downloaded num-integer v0.1.46
Downloaded num-complex v0.4.6
Downloaded paste v1.0.15
Downloaded overload v0.1.1
Downloaded icu_normalizer_data v1.5.1
Downloaded phf_shared v0.11.3
Downloaded pbkdf2 v0.12.2
Downloaded num-cmp v0.1.0
Downloaded num v0.4.3
Downloaded normalize-line-endings v0.3.0
Downloaded newline-converter v0.3.0
Downloaded icu_locid v1.5.0
Downloaded mio v1.0.4
Downloaded faster-hex v0.10.0
Downloaded errno v0.3.13
Downloaded document-features v0.2.11
Downloaded data-encoding-macro-internal v0.1.12
Downloaded cypheraddr v0.4.0
Downloaded opaque-debug v0.3.1
Downloaded num-iter v0.1.45
Downloaded nonempty v0.9.0
Downloaded multibase v0.9.1
Downloaded lexopt v0.3.0
Downloaded hmac v0.12.1
Downloaded gix-features v0.43.1
Downloaded libz-rs-sys v0.5.2
Downloaded gix-url v0.32.0
Downloaded gix-revwalk v0.21.0
Downloaded fluent-uri v0.3.2
Downloaded flate2 v1.1.1
Downloaded displaydoc v0.2.5
Downloaded data-encoding v2.5.0
Downloaded cyphergraphy v0.3.0
Downloaded heapless v0.8.0
Downloaded dunce v1.0.5
Downloaded data-encoding-macro v0.1.14
Downloaded clap_lex v0.7.5
Downloaded cfg-if v1.0.0
Downloaded base-x v0.2.11
Downloaded aead v0.5.2
Downloaded ct-codecs v1.1.1
Downloaded crossbeam-channel v0.5.15
Downloaded cc v1.2.2
Downloaded adler2 v2.0.0
Downloaded home v0.5.9
Downloaded hash32 v0.3.1
Downloaded gix-validate v0.10.0
Downloaded gix-traverse v0.47.0
Downloaded gix-trace v0.1.13
Downloaded gix-sec v0.12.0
Downloaded gix-quote v0.6.0
Downloaded gix-hash v0.19.0
Downloaded gix-date v0.10.5
Downloaded gix-credentials v0.30.0
Downloaded gix-config-value v0.15.1
Downloaded gix-command v0.6.2
Downloaded gix-actor v0.35.4
Downloaded git-ref-format-core v0.6.0
Downloaded fxhash v0.2.1
Downloaded form_urlencoded v1.2.1
Downloaded ff v0.13.0
Downloaded fastrand v2.3.0
Downloaded fancy-regex v0.14.0
Downloaded equivalent v1.0.1
Downloaded env_logger v0.11.8
Downloaded emojis v0.6.4
Downloaded diff v0.1.13
Downloaded der v0.7.9
Downloaded ctr v0.9.2
Downloaded crypto-common v0.1.6
Downloaded crypto-bigint v0.5.5
Downloaded crc32fast v1.5.0
Downloaded convert_case v0.7.1
Downloaded const-oid v0.9.6
Downloaded colored v2.1.0
Downloaded clap_complete v4.5.60
Downloaded cipher v0.4.4
Downloaded chacha20poly1305 v0.10.1
Downloaded cbc v0.1.2
Downloaded bytesize v2.0.1
Downloaded bytes v1.10.1
Downloaded byteorder v1.5.0
Downloaded borrow-or-share v0.2.2
Downloaded blowfish v0.9.1
Downloaded block-padding v0.3.3
Downloaded bitflags v2.9.1
Downloaded bcrypt-pbkdf v0.10.0
Downloaded base64ct v1.6.0
Downloaded backtrace v0.3.75
Downloaded autocfg v1.2.0
Downloaded arc-swap v1.7.1
Downloaded anstyle-query v1.0.2
Downloaded anstyle-parse v0.2.3
Downloaded anstyle v1.0.11
Downloaded anstream v0.6.13
Downloaded amplify_syn v2.0.1
Downloaded ahash v0.8.11
Downloaded maybe-async v0.2.10
Downloaded matchers v0.1.0
Downloaded log v0.4.27
Downloaded keccak v0.1.5
Downloaded idna_adapter v1.2.0
Downloaded icu_provider_macros v1.5.0
Downloaded icu_locid_transform v1.5.0
Downloaded group v0.13.0
Downloaded gix-tempfile v18.0.0
Downloaded gix-lock v18.0.0
Downloaded erased-serde v0.4.6
Downloaded email_address v0.2.9
Downloaded either v1.11.0
Downloaded ecdsa v0.16.9
Downloaded cpufeatures v0.2.12
Downloaded chacha20 v0.9.1
Downloaded bytecount v0.6.8
Downloaded block-buffer v0.10.4
Downloaded bit-set v0.8.0
Downloaded base64 v0.22.1
Downloaded base64 v0.21.7
Downloaded base32 v0.4.0
Downloaded base16ct v0.2.0
Downloaded anyhow v1.0.82
Downloaded icu_collections v1.5.0
Downloaded gix-revision v0.35.0
Downloaded gix-pack v0.60.0
Downloaded crossterm v0.25.0
Downloaded console v0.16.0
Downloaded chrono v0.4.38
Downloaded bit-vec v0.8.0
Downloaded getrandom v0.2.15
Downloaded filetime v0.2.23
Downloaded bitflags v1.3.2
Downloaded icu_properties v1.5.1
Downloaded icu_normalizer v1.5.0
Downloaded icu_locid_transform_data v1.5.1
Downloaded iana-time-zone v0.1.60
Downloaded gix-prompt v0.11.1
Downloaded gix-odb v0.70.0
Downloaded gix-object v0.50.2
Downloaded hashbrown v0.15.5
Downloaded generic-array v0.14.7
Downloaded gix-diff v0.53.0
Downloaded gimli v0.31.1
Downloaded fnv v1.0.7
Downloaded heck v0.5.0
Downloaded human-panic v2.0.3
Downloaded gix-utils v0.3.0
Downloaded gix-shallow v0.5.0
Downloaded gix-packetline v0.19.1
Downloaded ghash v0.5.1
Downloaded jiff v0.2.15
Downloaded gix-negotiate v0.21.0
Downloaded linux-raw-sys v0.9.4
Downloaded sqlite3-src v0.5.1
Downloaded libz-sys v1.1.16
Compiling libc v0.2.174
Compiling proc-macro2 v1.0.101
Compiling quote v1.0.41
Compiling unicode-ident v1.0.12
Checking cfg-if v1.0.0
Compiling shlex v1.3.0
Compiling version_check v0.9.4
Checking memchr v2.7.2
Checking getrandom v0.2.15
Compiling jobserver v0.1.31
Compiling typenum v1.17.0
Compiling syn v2.0.106
Compiling generic-array v0.14.7
Compiling cc v1.2.2
Checking rand_core v0.6.4
Compiling serde v1.0.219
Checking regex-syntax v0.8.5
Checking crypto-common v0.1.6
Checking aho-corasick v1.1.3
Checking smallvec v1.15.1
Compiling thiserror v2.0.17
Checking subtle v2.5.0
Checking stable_deref_trait v1.2.0
Checking once_cell v1.21.3
Checking regex-automata v0.4.9
Checking cpufeatures v0.2.12
Checking fastrand v2.3.0
Compiling parking_lot_core v0.9.12
Checking scopeguard v1.2.0
Checking lock_api v0.4.14
Checking block-buffer v0.10.4
Checking parking_lot v0.12.5
Checking digest v0.10.7
Compiling crc32fast v1.5.0
Checking byteorder v1.5.0
Checking tinyvec_macros v0.1.1
Checking bitflags v2.9.1
Checking tinyvec v1.6.0
Compiling typeid v1.0.3
Checking gix-trace v0.1.13
Checking home v0.5.9
Compiling synstructure v0.13.1
Checking unicode-normalization v0.1.23
Checking gix-utils v0.3.0
Checking zlib-rs v0.5.2
Checking same-file v1.0.6
Checking walkdir v2.5.0
Checking bstr v1.12.0
Checking prodash v30.0.1
Checking itoa v1.0.11
Compiling getrandom v0.3.3
Compiling heapless v0.8.0
Compiling serde_derive v1.0.219
Compiling thiserror-impl v2.0.17
Compiling zerofrom-derive v0.1.6
Checking libz-rs-sys v0.5.2
Checking flate2 v1.1.1
Compiling yoke-derive v0.7.5
Checking zerofrom v0.1.6
Checking gix-validate v0.10.0
Compiling zerovec-derive v0.10.3
Checking yoke v0.7.5
Checking gix-path v0.10.20
Compiling displaydoc v0.2.5
Checking gix-features v0.43.1
Checking hash32 v0.3.1
Checking zeroize v1.7.0
Compiling pkg-config v0.3.30
Checking zerovec v0.10.4
Checking litemap v0.7.5
Compiling icu_locid_transform_data v1.5.1
Checking writeable v0.5.5
Compiling rustix v1.0.7
Checking faster-hex v0.10.0
Compiling icu_provider_macros v1.5.0
Checking linux-raw-sys v0.9.4
Checking tinystr v0.7.6
Checking icu_locid v1.5.0
Compiling icu_properties_data v1.5.1
Checking sha1 v0.10.6
Checking block-padding v0.3.3
Checking icu_provider v1.5.0
Compiling icu_normalizer_data v1.5.1
Checking inout v0.1.3
Checking sha1-checked v0.10.0
Checking icu_locid_transform v1.5.0
Checking icu_collections v1.5.0
Compiling syn v1.0.109
Checking icu_properties v1.5.1
Checking gix-hash v0.19.0
Checking cipher v0.4.4
Checking erased-serde v0.4.6
Checking serde_fmt v1.0.3
Checking utf16_iter v1.0.5
Checking write16 v1.0.0
Checking utf8_iter v1.0.4
Checking value-bag-serde1 v1.11.1
Checking value-bag v1.11.1
Checking log v0.4.27
Checking percent-encoding v2.3.1
Compiling thiserror v1.0.69
Checking icu_normalizer v1.5.0
Compiling thiserror-impl v1.0.69
Checking form_urlencoded v1.2.1
Checking sha2 v0.10.8
Checking idna_adapter v1.2.0
Checking idna v1.0.3
Compiling vcpkg v0.2.15
Checking url v2.5.4
Checking tempfile v3.23.0
Compiling libz-sys v1.1.16
Checking universal-hash v0.5.1
Compiling serde_json v1.0.140
Checking equivalent v1.0.1
Checking opaque-debug v0.3.1
Checking hashbrown v0.14.3
Checking ryu v1.0.17
Compiling autocfg v1.2.0
Compiling ref-cast v1.0.24
Compiling num-traits v0.2.19
Compiling amplify_syn v2.0.1
Checking indexmap v2.2.6
Compiling libgit2-sys v0.17.0+1.8.1
Compiling ref-cast-impl v1.0.24
Checking signature v1.6.4
Compiling amplify_derive v4.0.0
Checking ed25519 v1.5.3
Checking aead v0.5.2
Checking amplify_num v0.5.2
Checking ct-codecs v1.1.1
Checking ascii v1.1.0
Checking dyn-clone v1.0.17
Checking ec25519 v0.1.0
Checking git-ref-format-core v0.6.0
Checking amplify v4.6.0
Checking poly1305 v0.8.0
Checking chacha20 v0.9.1
Checking polyval v0.6.2
Compiling sqlite3-src v0.5.1
Checking cyphergraphy v0.3.0
Compiling serde_derive_internals v0.29.1
Checking hmac v0.12.1
Checking base64ct v1.6.0
Checking keccak v0.1.5
Checking pem-rfc7468 v0.7.0
Checking sha3 v0.10.8
Checking pbkdf2 v0.12.2
Checking ghash v0.5.1
Checking ctr v0.9.2
Checking aes v0.8.4
Compiling schemars_derive v1.0.4
Checking rand v0.8.5
Checking base32 v0.4.0
Compiling data-encoding v2.5.0
Checking schemars v1.0.4
Compiling data-encoding-macro-internal v0.1.12
Checking cypheraddr v0.4.0
Checking qcheck v1.0.0
Checking aes-gcm v0.10.3
Checking ssh-encoding v0.2.0
Checking chacha20poly1305 v0.10.1
Checking blowfish v0.9.1
Checking cbc v0.1.2
Checking ssh-cipher v0.2.0
Checking bcrypt-pbkdf v0.10.0
Checking data-encoding-macro v0.1.14
Checking noise-framework v0.4.0
Checking socks5-client v0.4.1
Compiling crossbeam-utils v0.8.19
Checking signature v2.2.0
Checking base-x v0.2.11
Checking ssh-key v0.6.6
Checking multibase v0.9.1
Checking cyphernet v0.5.2
Checking radicle-ssh v0.10.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-ssh)
Checking lazy_static v1.5.0
Checking jiff v0.2.15
Checking crossbeam-channel v0.5.15
Checking nonempty v0.9.0
Checking anstyle-query v1.0.2
Checking siphasher v1.0.1
Checking radicle-git-metadata v0.1.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-git-metadata)
Checking radicle-dag v0.10.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-dag)
Checking winnow v0.7.13
Checking hashbrown v0.15.5
Checking gix-date v0.10.5
Checking utf8parse v0.2.1
Checking anstyle-parse v0.2.3
Checking gix-actor v0.35.4
Checking gix-hashtable v0.9.0
Checking radicle-git-ref-format v0.1.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-git-ref-format)
Checking colorchoice v1.0.0
Checking anstyle v1.0.11
Checking iana-time-zone v0.1.60
Checking base64 v0.21.7
Checking chrono v0.4.38
Checking anstream v0.6.13
Checking gix-object v0.50.2
Checking colored v2.1.0
Checking radicle-localtime v0.1.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-localtime)
Checking serde-untagged v0.1.7
Checking bytesize v2.0.1
Checking memmap2 v0.9.8
Checking fast-glob v0.3.3
Checking tree-sitter-language v0.1.2
Checking dunce v1.0.5
Checking gix-chunk v0.4.11
Checking gix-fs v0.16.1
Checking gix-commitgraph v0.29.0
Checking gix-tempfile v18.0.0
Checking mio v1.0.4
Checking gix-revwalk v0.21.0
Checking gix-quote v0.6.0
Checking errno v0.3.13
Checking sem_safe v0.2.0
Checking shell-words v1.1.0
Checking either v1.11.0
Checking gix-command v0.6.2
Checking signals_receipts v0.2.0
Compiling object v0.36.7
Compiling signal-hook v0.3.18
Checking gix-lock v18.0.0
Checking gix-url v0.32.0
Checking gix-config-value v0.15.1
Checking gix-sec v0.12.0
Checking signal-hook-registry v1.4.5
Checking adler2 v2.0.0
Checking gimli v0.31.1
Compiling rustix v0.38.34
Checking miniz_oxide v0.8.8
Checking gix-prompt v0.11.1
Checking addr2line v0.24.2
Checking radicle-signals v0.11.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-signals)
Checking gix-traverse v0.47.0
Checking gix-revision v0.35.0
Checking gix-diff v0.53.0
Checking mio v0.8.11
Checking gix-packetline v0.19.1
Compiling tree-sitter v0.24.4
Compiling anyhow v1.0.82
Compiling linux-raw-sys v0.4.13
Compiling unicode-segmentation v1.11.0
Checking rustc-demangle v0.1.26
Checking backtrace v0.3.75
Compiling convert_case v0.7.1
Checking gix-transport v0.48.0
Checking signal-hook-mio v0.2.4
Checking gix-pack v0.60.0
Checking gix-refspec v0.31.0
Checking gix-credentials v0.30.0
Checking gix-shallow v0.5.0
Checking gix-ref v0.53.1
Checking gix-negotiate v0.21.0
Compiling maybe-async v0.2.10
Checking regex v1.11.1
Compiling proc-macro-error-attr2 v2.0.0
Checking arc-swap v1.7.1
Compiling portable-atomic v1.11.0
Checking gix-odb v0.70.0
Checking gix-protocol v0.51.0
Compiling proc-macro-error2 v2.0.1
Compiling xattr v1.3.1
Compiling derive_more-impl v2.0.1
Compiling filetime v0.2.23
Checking uuid v1.16.0
Compiling litrs v0.4.1
Checking bitflags v1.3.2
Checking unicode-width v0.2.1
Checking bytes v1.10.1
Compiling document-features v0.2.11
Checking console v0.16.0
Checking crossterm v0.25.0
Checking derive_more v2.0.1
Compiling tar v0.4.40
Compiling git-ref-format-macro v0.6.0
Checking newline-converter v0.3.0
Checking snapbox-macros v0.3.8
Checking salsa20 v0.10.2
Checking fxhash v0.2.1
Checking unit-prefix v0.5.1
Checking unicode-width v0.1.11
Checking similar v2.5.0
Checking streaming-iterator v0.1.9
Checking sqlite3-sys v0.15.2
Checking strsim v0.11.1
Compiling heck v0.5.0
Checking sqlite v0.32.0
Checking siphasher v0.3.11
Checking normalize-line-endings v0.3.0
Checking radicle-crypto v0.14.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-crypto)
Checking clap_lex v0.7.5
Checking snapbox v0.4.17
Checking clap_builder v4.5.44
Checking bloomy v1.2.0
Compiling clap_derive v4.5.41
Checking inquire v0.7.5
Checking indicatif v0.18.0
Compiling radicle-surf v0.26.0
Checking scrypt v0.11.0
Checking git-ref-format v0.6.0
Checking crossterm v0.29.0
Checking unicode-display-width v0.3.0
Checking systemd-journal-logger v2.2.2
Checking serde_spanned v1.0.0
Checking toml_datetime v0.7.0
Compiling tree-sitter-bash v0.23.3
Compiling tree-sitter-json v0.24.8
Compiling tree-sitter-c v0.23.2
Compiling tree-sitter-python v0.23.4
Compiling tree-sitter-rust v0.23.2
Compiling tree-sitter-ruby v0.23.1
Compiling tree-sitter-md v0.3.2
Compiling tree-sitter-go v0.23.4
Compiling tree-sitter-css v0.23.1
Compiling tree-sitter-typescript v0.23.2
Compiling tree-sitter-toml-ng v0.6.0
Compiling tree-sitter-html v0.23.2
Checking toml_writer v1.0.2
Checking pin-project-lite v0.2.16
Checking radicle-std-ext v0.2.0
Checking tokio v1.47.1
Checking toml v0.9.5
Checking clap v4.5.44
Checking os_info v3.12.0
Compiling radicle-node v0.16.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-node)
Checking yansi v0.5.1
Compiling radicle-cli v0.17.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-cli)
Checking diff v0.1.13
Checking pretty_assertions v1.4.0
Checking human-panic v2.0.3
Checking clap_complete v4.5.60
Checking structured-logger v1.0.4
Checking radicle-systemd v0.11.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-systemd)
Checking tree-sitter-highlight v0.24.4
Checking itertools v0.14.0
Checking num-integer v0.1.46
Compiling qcheck-macros v1.0.0
Checking socket2 v0.5.7
Checking lexopt v0.3.0
Compiling escargot v0.5.10
Checking timeago v0.4.2
Checking bit-vec v0.8.0
Checking bit-set v0.8.0
Checking num-bigint v0.4.6
Checking rand_core v0.9.3
Compiling ahash v0.8.11
Checking num-iter v0.1.45
Checking num-complex v0.4.6
Checking env_filter v0.1.3
Checking borrow-or-share v0.2.2
Checking zerocopy v0.7.35
Checking fluent-uri v0.3.2
Checking env_logger v0.11.8
Checking num-rational v0.4.2
Checking phf_shared v0.11.3
Compiling test-log-macros v0.2.18
Checking wait-timeout v0.2.1
Checking num v0.4.3
Checking fnv v1.0.7
Checking outref v0.5.2
Compiling radicle-remote-helper v0.14.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-remote-helper)
Checking quick-error v1.2.3
Checking ppv-lite86 v0.2.17
Checking vsimd v0.8.0
Compiling paste v1.0.15
Checking rand_chacha v0.9.0
Checking uuid-simd v0.8.0
Checking rusty-fork v0.3.1
Checking test-log v0.2.18
Checking fraction v0.15.3
Checking phf v0.11.3
Checking referencing v0.30.0
Checking rand v0.9.2
Checking rand_xorshift v0.4.0
Checking fancy-regex v0.14.0
Checking email_address v0.2.9
Checking base64 v0.22.1
Checking unarray v0.1.4
Checking num-cmp v0.1.0
Checking bytecount v0.6.8
Checking proptest v1.9.0
Checking emojis v0.6.4
Checking jsonschema v0.30.0
Checking git2 v0.19.0
Checking radicle-oid v0.1.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-oid)
Checking radicle-git-ext v0.11.0
Checking radicle-term v0.16.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-term)
Checking radicle-cob v0.17.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-cob)
Checking radicle-core v0.1.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-core)
Checking radicle v0.20.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle)
Checking radicle-fetch v0.16.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-fetch)
Checking radicle-cli-test v0.13.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-cli-test)
Checking radicle-schemars v0.6.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-schemars)
Checking radicle-protocol v0.4.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-protocol)
Finished `dev` profile [unoptimized + debuginfo] target(s) in 43.18s
+ cargo build --all-targets --workspace
Compiling libc v0.2.174
Compiling cfg-if v1.0.0
Compiling shlex v1.3.0
Compiling memchr v2.7.2
Compiling typenum v1.17.0
Compiling serde v1.0.219
Compiling generic-array v0.14.7
Compiling jobserver v0.1.31
Compiling getrandom v0.2.15
Compiling cc v1.2.2
Compiling rand_core v0.6.4
Compiling regex-syntax v0.8.5
Compiling crypto-common v0.1.6
Compiling aho-corasick v1.1.3
Compiling smallvec v1.15.1
Compiling thiserror v2.0.17
Compiling subtle v2.5.0
Compiling once_cell v1.21.3
Compiling stable_deref_trait v1.2.0
Compiling fastrand v2.3.0
Compiling cpufeatures v0.2.12
Compiling regex-automata v0.4.9
Compiling scopeguard v1.2.0
Compiling lock_api v0.4.14
Compiling parking_lot_core v0.9.12
Compiling block-buffer v0.10.4
Compiling bitflags v2.9.1
Compiling digest v0.10.7
Compiling parking_lot v0.12.5
Compiling tinyvec_macros v0.1.1
Compiling byteorder v1.5.0
Compiling tinyvec v1.6.0
Compiling crc32fast v1.5.0
Compiling gix-trace v0.1.13
Compiling typeid v1.0.3
Compiling home v0.5.9
Compiling erased-serde v0.4.6
Compiling serde_fmt v1.0.3
Compiling zlib-rs v0.5.2
Compiling unicode-normalization v0.1.23
Compiling value-bag-serde1 v1.11.1
Compiling same-file v1.0.6
Compiling walkdir v2.5.0
Compiling gix-utils v0.3.0
Compiling zerofrom v0.1.6
Compiling value-bag v1.11.1
Compiling prodash v30.0.1
Compiling bstr v1.12.0
Compiling itoa v1.0.11
Compiling log v0.4.27
Compiling gix-validate v0.10.0
Compiling yoke v0.7.5
Compiling gix-path v0.10.20
Compiling zerovec v0.10.4
Compiling hash32 v0.3.1
Compiling zeroize v1.7.0
Compiling heapless v0.8.0
Compiling tinystr v0.7.6
Compiling getrandom v0.3.3
Compiling litemap v0.7.5
Compiling writeable v0.5.5
Compiling libz-rs-sys v0.5.2
Compiling flate2 v1.1.1
Compiling icu_locid v1.5.0
Compiling gix-features v0.43.1
Compiling faster-hex v0.10.0
Compiling linux-raw-sys v0.9.4
Compiling icu_provider v1.5.0
Compiling icu_locid_transform_data v1.5.1
Compiling sha1 v0.10.6
Compiling block-padding v0.3.3
Compiling inout v0.1.3
Compiling icu_locid_transform v1.5.0
Compiling sha1-checked v0.10.0
Compiling icu_properties_data v1.5.1
Compiling icu_collections v1.5.0
Compiling gix-hash v0.19.0
Compiling rustix v1.0.7
Compiling icu_properties v1.5.1
Compiling cipher v0.4.4
Compiling icu_normalizer_data v1.5.1
Compiling utf16_iter v1.0.5
Compiling write16 v1.0.0
Compiling utf8_iter v1.0.4
Compiling percent-encoding v2.3.1
Compiling form_urlencoded v1.2.1
Compiling sha2 v0.10.8
Compiling libz-sys v1.1.16
Compiling thiserror v1.0.69
Compiling universal-hash v0.5.1
Compiling equivalent v1.0.1
Compiling hashbrown v0.14.3
Compiling opaque-debug v0.3.1
Compiling ryu v1.0.17
Compiling libgit2-sys v0.17.0+1.8.1
Compiling indexmap v2.2.6
Compiling icu_normalizer v1.5.0
Compiling idna_adapter v1.2.0
Compiling idna v1.0.3
Compiling serde_json v1.0.140
Compiling signature v1.6.4
Compiling tempfile v3.23.0
Compiling url v2.5.4
Compiling ed25519 v1.5.3
Compiling ref-cast v1.0.24
Compiling aead v0.5.2
Compiling amplify_num v0.5.2
Compiling ct-codecs v1.1.1
Compiling ascii v1.1.0
Compiling dyn-clone v1.0.17
Compiling ec25519 v0.1.0
Compiling num-traits v0.2.19
Compiling poly1305 v0.8.0
Compiling git-ref-format-core v0.6.0
Compiling amplify v4.6.0
Compiling chacha20 v0.9.1
Compiling polyval v0.6.2
Compiling sqlite3-src v0.5.1
Compiling cyphergraphy v0.3.0
Compiling hmac v0.12.1
Compiling keccak v0.1.5
Compiling base64ct v1.6.0
Compiling sha3 v0.10.8
Compiling pbkdf2 v0.12.2
Compiling pem-rfc7468 v0.7.0
Compiling ghash v0.5.1
Compiling ctr v0.9.2
Compiling aes v0.8.4
Compiling rand v0.8.5
Compiling base32 v0.4.0
Compiling qcheck v1.0.0
Compiling cypheraddr v0.4.0
Compiling aes-gcm v0.10.3
Compiling ssh-encoding v0.2.0
Compiling schemars v1.0.4
Compiling chacha20poly1305 v0.10.1
Compiling cbc v0.1.2
Compiling blowfish v0.9.1
Compiling data-encoding v2.5.0
Compiling data-encoding-macro v0.1.14
Compiling bcrypt-pbkdf v0.10.0
Compiling ssh-cipher v0.2.0
Compiling noise-framework v0.4.0
Compiling socks5-client v0.4.1
Compiling signature v2.2.0
Compiling base-x v0.2.11
Compiling multibase v0.9.1
Compiling ssh-key v0.6.6
Compiling cyphernet v0.5.2
Compiling radicle-ssh v0.10.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-ssh)
Compiling crossbeam-utils v0.8.19
Compiling crossbeam-channel v0.5.15
Compiling jiff v0.2.15
Compiling lazy_static v1.5.0
Compiling nonempty v0.9.0
Compiling anstyle-query v1.0.2
Compiling siphasher v1.0.1
Compiling radicle-dag v0.10.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-dag)
Compiling radicle-git-metadata v0.1.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-git-metadata)
Compiling winnow v0.7.13
Compiling hashbrown v0.15.5
Compiling utf8parse v0.2.1
Compiling anstyle-parse v0.2.3
Compiling gix-hashtable v0.9.0
Compiling radicle-git-ref-format v0.1.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-git-ref-format)
Compiling gix-date v0.10.5
Compiling gix-actor v0.35.4
Compiling base64 v0.21.7
Compiling colorchoice v1.0.0
Compiling anstyle v1.0.11
Compiling iana-time-zone v0.1.60
Compiling chrono v0.4.38
Compiling anstream v0.6.13
Compiling gix-object v0.50.2
Compiling colored v2.1.0
Compiling radicle-localtime v0.1.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-localtime)
Compiling serde-untagged v0.1.7
Compiling bytesize v2.0.1
Compiling memmap2 v0.9.8
Compiling tree-sitter-language v0.1.2
Compiling dunce v1.0.5
Compiling fast-glob v0.3.3
Compiling gix-chunk v0.4.11
Compiling gix-commitgraph v0.29.0
Compiling adler2 v2.0.0
Compiling gix-fs v0.16.1
Compiling gix-revwalk v0.21.0
Compiling gix-tempfile v18.0.0
Compiling mio v1.0.4
Compiling gix-quote v0.6.0
Compiling sem_safe v0.2.0
Compiling errno v0.3.13
Compiling shell-words v1.1.0
Compiling unicode-segmentation v1.11.0
Compiling either v1.11.0
Compiling gix-command v0.6.2
Compiling signals_receipts v0.2.0
Compiling gix-lock v18.0.0
Compiling gix-url v0.32.0
Compiling gix-config-value v0.15.1
Compiling gix-sec v0.12.0
Compiling signal-hook-registry v1.4.5
Compiling gimli v0.31.1
Compiling signal-hook v0.3.18
Compiling gix-prompt v0.11.1
Compiling object v0.36.7
Compiling addr2line v0.24.2
Compiling radicle-signals v0.11.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-signals)
Compiling gix-revision v0.35.0
Compiling gix-traverse v0.47.0
Compiling miniz_oxide v0.8.8
Compiling gix-diff v0.53.0
Compiling gix-packetline v0.19.1
Compiling mio v0.8.11
Compiling tree-sitter v0.24.4
Compiling rustc-demangle v0.1.26
Compiling rustix v0.38.34
Compiling backtrace v0.3.75
Compiling signal-hook-mio v0.2.4
Compiling gix-transport v0.48.0
Compiling sqlite3-sys v0.15.2
Compiling sqlite v0.32.0
Compiling radicle-crypto v0.14.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-crypto)
Compiling gix-pack v0.60.0
Compiling gix-refspec v0.31.0
Compiling gix-credentials v0.30.0
Compiling gix-ref v0.53.1
Compiling gix-shallow v0.5.0
Compiling convert_case v0.7.1
Compiling gix-negotiate v0.21.0
Compiling regex v1.11.1
Compiling arc-swap v1.7.1
Compiling gix-odb v0.70.0
Compiling gix-protocol v0.51.0
Compiling derive_more-impl v2.0.1
Compiling xattr v1.3.1
Compiling uuid v1.16.0
Compiling filetime v0.2.23
Compiling bitflags v1.3.2
Compiling unicode-width v0.2.1
Compiling bytes v1.10.1
Compiling console v0.16.0
Compiling crossterm v0.25.0
Compiling tar v0.4.40
Compiling git-ref-format-macro v0.6.0
Compiling derive_more v2.0.1
Compiling anyhow v1.0.82
Compiling portable-atomic v1.11.0
Compiling newline-converter v0.3.0
Compiling snapbox-macros v0.3.8
Compiling salsa20 v0.10.2
Compiling fxhash v0.2.1
Compiling siphasher v0.3.11
Compiling normalize-line-endings v0.3.0
Compiling unicode-width v0.1.11
Compiling streaming-iterator v0.1.9
Compiling strsim v0.11.1
Compiling unit-prefix v0.5.1
Compiling clap_lex v0.7.5
Compiling similar v2.5.0
Compiling clap_builder v4.5.44
Compiling snapbox v0.4.17
Compiling indicatif v0.18.0
Compiling inquire v0.7.5
Compiling bloomy v1.2.0
Compiling scrypt v0.11.0
Compiling radicle-surf v0.26.0
Compiling crossterm v0.29.0
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.0
Compiling serde_spanned v1.0.0
Compiling tree-sitter-md v0.3.2
Compiling tree-sitter-rust v0.23.2
Compiling tree-sitter-c v0.23.2
Compiling tree-sitter-typescript v0.23.2
Compiling tree-sitter-ruby v0.23.1
Compiling tree-sitter-bash v0.23.3
Compiling tree-sitter-json v0.24.8
Compiling tree-sitter-python v0.23.4
Compiling tree-sitter-html v0.23.2
Compiling tree-sitter-go v0.23.4
Compiling tree-sitter-css v0.23.1
Compiling tree-sitter-toml-ng v0.6.0
Compiling toml_writer v1.0.2
Compiling pin-project-lite v0.2.16
Compiling radicle-std-ext v0.2.0
Compiling tokio v1.47.1
Compiling toml v0.9.5
Compiling clap v4.5.44
Compiling os_info v3.12.0
Compiling yansi v0.5.1
Compiling radicle-node v0.16.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-node)
Compiling diff v0.1.13
Compiling radicle-cli v0.17.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-cli)
Compiling pretty_assertions v1.4.0
Compiling human-panic v2.0.3
Compiling clap_complete v4.5.60
Compiling structured-logger v1.0.4
Compiling radicle-systemd v0.11.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-systemd)
Compiling tree-sitter-highlight v0.24.4
Compiling itertools v0.14.0
Compiling num-integer v0.1.46
Compiling socket2 v0.5.7
Compiling timeago v0.4.2
Compiling lexopt v0.3.0
Compiling bit-vec v0.8.0
Compiling escargot v0.5.10
Compiling bit-set v0.8.0
Compiling num-bigint v0.4.6
Compiling rand_core v0.9.3
Compiling num-iter v0.1.45
Compiling num-complex v0.4.6
Compiling env_filter v0.1.3
Compiling num-rational v0.4.2
Compiling borrow-or-share v0.2.2
Compiling zerocopy v0.7.35
Compiling ahash v0.8.11
Compiling num v0.4.3
Compiling fluent-uri v0.3.2
Compiling env_logger v0.11.8
Compiling phf_shared v0.11.3
Compiling wait-timeout v0.2.1
Compiling quick-error v1.2.3
Compiling ppv-lite86 v0.2.17
Compiling outref v0.5.2
Compiling vsimd v0.8.0
Compiling radicle-remote-helper v0.14.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-remote-helper)
Compiling fnv v1.0.7
Compiling rusty-fork v0.3.1
Compiling uuid-simd v0.8.0
Compiling rand_chacha v0.9.0
Compiling test-log v0.2.18
Compiling referencing v0.30.0
Compiling phf v0.11.3
Compiling fraction v0.15.3
Compiling rand v0.9.2
Compiling rand_xorshift v0.4.0
Compiling fancy-regex v0.14.0
Compiling email_address v0.2.9
Compiling bytecount v0.6.8
Compiling num-cmp v0.1.0
Compiling base64 v0.22.1
Compiling unarray v0.1.4
Compiling proptest v1.9.0
Compiling jsonschema v0.30.0
Compiling git2 v0.19.0
Compiling emojis v0.6.4
Compiling radicle-oid v0.1.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-oid)
Compiling radicle-core v0.1.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-core)
Compiling radicle-cob v0.17.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-cob)
Compiling radicle-git-ext v0.11.0
Compiling radicle-term v0.16.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-term)
Compiling radicle v0.20.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle)
Compiling radicle-fetch v0.16.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-fetch)
Compiling radicle-protocol v0.4.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-protocol)
Compiling radicle-cli-test v0.13.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-cli-test)
Compiling radicle-schemars v0.6.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-schemars)
Finished `dev` profile [unoptimized + debuginfo] target(s) in 55.31s
+ cargo doc --workspace --no-deps --all-features
Checking regex-automata v0.4.9
Compiling syn v1.0.109
Checking idna v1.0.3
Compiling num-traits v0.2.19
Checking radicle-ssh v0.10.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-ssh)
Checking url v2.5.4
Checking git2 v0.19.0
Checking proptest v1.9.0
Checking bstr v1.12.0
Compiling amplify_syn v2.0.1
Checking gix-validate v0.10.0
Checking gix-path v0.10.20
Checking gix-features v0.43.1
Checking git-ref-format-core v0.6.0
Checking gix-hash v0.19.0
Compiling amplify_derive v4.0.0
Compiling data-encoding-macro-internal v0.1.12
Checking radicle-git-ref-format v0.1.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-git-ref-format)
Checking gix-date v0.10.5
Checking radicle-oid v0.1.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-oid)
Checking gix-actor v0.35.4
Checking gix-hashtable v0.9.0
Checking radicle-dag v0.10.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-dag)
Checking gix-object v0.50.2
Checking data-encoding-macro v0.1.14
Checking multibase v0.9.1
Checking radicle-git-metadata v0.1.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-git-metadata)
Checking chrono v0.4.38
Checking gix-commitgraph v0.29.0
Checking radicle-localtime v0.1.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-localtime)
Checking gix-fs v0.16.1
Checking gix-revwalk v0.21.0
Checking gix-tempfile v18.0.0
Checking gix-quote v0.6.0
Checking gix-command v0.6.2
Checking gix-url v0.32.0
Checking gix-lock v18.0.0
Checking gix-config-value v0.15.1
Checking radicle-signals v0.11.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-signals)
Checking gix-traverse v0.47.0
Checking amplify v4.6.0
Checking gix-prompt v0.11.1
Checking gix-revision v0.35.0
Checking gix-diff v0.53.0
Checking gix-packetline v0.19.1
Checking cyphergraphy v0.3.0
Checking regex v1.11.1
Checking gix-pack v0.60.0
Checking cypheraddr v0.4.0
Checking noise-framework v0.4.0
Checking tree-sitter v0.24.4
Checking socks5-client v0.4.1
Checking gix-transport v0.48.0
Checking cyphernet v0.5.2
Checking radicle-crypto v0.14.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-crypto)
Checking gix-refspec v0.31.0
Checking gix-credentials v0.30.0
Checking git-ref-format v0.6.0
Checking radicle-core v0.1.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-core)
Checking radicle-cob v0.17.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-cob)
Checking gix-ref v0.53.1
Checking gix-shallow v0.5.0
Checking gix-negotiate v0.21.0
Checking radicle-git-ext v0.11.0
Checking gix-odb v0.70.0
Checking uuid v1.16.0
Checking radicle v0.20.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle)
Compiling radicle-cli v0.17.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-cli)
Checking human-panic v2.0.3
Checking gix-protocol v0.51.0
Checking radicle-surf v0.26.0
Checking tree-sitter-toml-ng v0.6.0
Checking radicle-term v0.16.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-term)
Checking tree-sitter-highlight v0.24.4
Checking radicle-systemd v0.11.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-systemd)
Documenting radicle-systemd v0.11.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-systemd)
Documenting radicle v0.20.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle)
Documenting radicle-term v0.16.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-term)
Documenting radicle-core v0.1.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-core)
Documenting radicle-cob v0.17.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-cob)
Documenting radicle-crypto v0.14.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-crypto)
Documenting radicle-signals v0.11.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-signals)
Documenting radicle-oid v0.1.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-oid)
Documenting radicle-git-ref-format v0.1.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-git-ref-format)
Documenting radicle-localtime v0.1.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-localtime)
Documenting radicle-ssh v0.10.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-ssh)
Documenting radicle-dag v0.10.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-dag)
Documenting radicle-git-metadata v0.1.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-git-metadata)
Checking radicle-fetch v0.16.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-fetch)
Documenting radicle-cli v0.17.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-cli)
Documenting radicle-fetch v0.16.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-fetch)
Checking radicle-protocol v0.4.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-protocol)
Documenting radicle-protocol v0.4.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-protocol)
Documenting radicle-node v0.16.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-node)
Documenting radicle-cli-test v0.13.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-cli-test)
Documenting radicle-schemars v0.6.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-schemars)
Documenting radicle-remote-helper v0.14.0 (/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-remote-helper)
Finished `dev` profile [unoptimized + debuginfo] target(s) in 9.38s
Generated /1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/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.16s
Running unittests src/lib.rs (target/debug/deps/radicle-17353fb59e43dcb4)
running 236 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::common::test::test_color ... ok
test cob::common::test::test_emojis ... ok
test cob::cache::tests::test_check_version ... ok
test cob::common::test::test_title ... ok
test cob::cache::tests::test_migrate_to ... 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_reject_concurrent ... ok
test cob::identity::test::test_identity_remove_delegate_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::issue::test::test_invalid_actions ... ok
test cob::identity::test::test_identity_updates_concurrent_outdated ... ok
test cob::issue::test::test_invalid_cob ... ok
test cob::issue::test::test_invalid_tx ... ok
test cob::issue::test::test_concurrency ... ok
test cob::issue::test::test_invalid_tx_reference ... ok
test cob::issue::test::test_issue_all ... 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_comment ... ok
test cob::issue::test::test_issue_create_and_get ... ok
test cob::issue::test::test_issue_create_and_change_state ... 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_multilines ... 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_label ... ok
test cob::issue::test::test_issue_react ... ok
test cob::patch::cache::tests::test_find_by_revision ... ok
test cob::issue::test::test_issue_reply ... ok
test cob::patch::cache::tests::test_is_empty ... ok
test cob::patch::cache::tests::test_get ... ok
test cob::patch::cache::tests::test_list_by_status ... 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::test::test_patch_create_and_get ... ok
test cob::patch::cache::tests::test_list ... ok
test cob::patch::test::test_patch_discussion ... ok
test cob::patch::cache::tests::test_remove ... ok
test cob::patch::test::test_patch_merge ... ok
test cob::patch::cache::tests::test_counts ... 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_duplicate ... ok
test cob::patch::test::test_patch_review_edit ... 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_patch_review_edit_comment ... 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_until ... ok
test cob::stream::tests::test_all_from ... ok
test cob::patch::test::test_patch_review_revision_redact ... ok
test cob::stream::tests::test_from_until ... ok
test cob::stream::tests::test_regression_from_until ... ok
test cob::stream::tests::test_all_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_duplicate_comments ... ok
test cob::thread::tests::test_comment_redact_missing ... ok
test cob::thread::tests::test_edit_comment ... ok
test cob::thread::tests::test_redact_comment ... ok
test git::canonical::quorum::test::merge_base_commutative ... ok
test git::canonical::quorum::test::test_merge_bases ... ok
test cob::thread::tests::test_timeline ... 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 cob::patch::test::test_patch_update ... 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_canonical ... 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::rules::tests::test_rule_validate_failures ... ok
test identity::doc::test::test_canonical_doc ... ok
test identity::doc::test::test_canonical_example ... 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_max_delegates ... 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::partial ... 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 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_count ... ok
test node::routing::test::test_entries ... 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_and_remove ... ok
test node::routing::test::test_insert_duplicate ... ok
test node::routing::test::test_insert_existing_updated_time ... ok
test node::routing::test::test_len ... ok
test node::routing::test::test_prune ... 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::all_synced_nodes_are_preferred_seeds ... ok
test node::sync::announce::test::announcer_adapts_target_to_reach ... ok
test node::sync::announce::test::announcer_preferred_seeds_or_replica_factor ... ok
test node::sync::announce::test::announcer_reached_max_replication_target ... ok
test node::sync::announce::test::announcer_reached_min_replication_target ... ok
test git::canonical::tests::test_quorum_properties ... ok
test node::sync::announce::test::announcer_reached_preferred_seeds ... ok
test node::sync::announce::test::announcer_synced_with_unknown_node ... 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::construct_node_appears_in_multiple_input_sets ... ok
test node::sync::announce::test::cannot_construct_announcer ... ok
test node::sync::announce::test::construct_only_preferred_seeds_provided ... ok
test node::sync::announce::test::invariant_progress_should_match_state ... ok
test node::sync::announce::test::local_node_in_multiple_sets ... ok
test node::sync::announce::test::local_node_in_preferred_seeds ... ok
test node::sync::announce::test::local_node_in_unsynced_set ... 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::preferred_seeds_already_synced ... ok
test node::sync::announce::test::synced_with_local_node_is_ignored ... ok
test node::sync::announce::test::synced_with_same_node_multiple_times ... ok
test node::sync::announce::test::timed_out_after_reaching_success ... ok
test node::sync::fetch::test::all_nodes_are_candidates ... ok
test node::sync::fetch::test::all_nodes_are_fetchable ... ok
test node::sync::fetch::test::ignores_duplicates_and_local_node ... ok
test node::sync::fetch::test::preferred_seeds_target_returned_over_replicas ... ok
test node::sync::fetch::test::could_not_reach_target ... ok
test node::sync::fetch::test::reaches_target_of_max_replicas ... ok
test node::sync::fetch::test::reaches_target_of_preferred_seeds ... ok
test node::sync::test::ensure_replicas_construction ... ok
test node::sync::test::replicas_constrain_to ... 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 node::sync::fetch::test::reaches_target_of_replicas ... ok
test profile::test::canonicalize_home ... ok
test profile::test::test_config ... ok
test cob::thread::tests::prop_ordering ... ok
test rad::tests::test_checkout ... ok
test rad::tests::test_fork ... ok
test storage::git::tests::test_references_of ... ok
test rad::tests::test_init ... ok
test storage::git::tests::test_sign_refs ... 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::refs::tests::prop_canonical_roundtrip ... ok
test storage::git::tests::test_remote_refs ... 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 profile::config::test::schema ... ok
test storage::refs::tests::test_rid_verification ... ok
test identity::doc::test::prop_encode_decode ... ok
test result: ok. 236 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 1.77s
Running unittests src/lib.rs (target/debug/deps/radicle_cli-d2c4450d5febafa6)
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_url ... ok
test commands::clone::args::test::should_parse_rid_non_urn ... ok
test commands::cob::args::test::should_allow_log_json_format ... 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_show_json_format ... ok
test commands::cob::args::test::should_allow_update_json_format ... ok
test commands::cob::args::test::should_not_allow_show_pretty_format ... ok
test commands::cob::args::test::should_not_allow_update_pretty_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::init::args::test::should_not_parse_rid_url ... ok
test commands::id::args::test::should_parse_multiple_payloads ... ok
test commands::id::args::test::should_parse_single_payload ... ok
test commands::patch::review::builder::tests::test_review_comments_basic ... ok
test commands::init::args::test::should_parse_rid_non_urn ... ok
test commands::patch::review::builder::tests::test_review_comments_before ... ok
test commands::init::args::test::should_parse_rid_urn ... ok
test commands::inspect::test::test_tree ... 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_urn ... ok
test commands::publish::args::test::should_parse_rid_non_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 terminal::args::test::should_not_parse ... ok
test terminal::args::test::should_parse_nid ... 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_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-df8ebba3143147f5)
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-644825449840c903)
running 110 tests
test framework_home ... ok
test git_push_and_fetch ... ok
test git_push_amend ... ok
test git_push_canonical_annotated_tags ... ok
test git_push_canonical_lightweight_tags ... ok
test git_push_force_with_lease ... ok
test git_push_diverge ... ok
test rad_auth ... ok
test rad_auth_errors ... ok
test rad_block ... ok
test git_push_rollback ... ok
test rad_checkout ... ok
test git_tag ... ok
test git_push_converge ... ok
test rad_clone ... ok
test rad_clone_bare ... ok
test rad_clean ... ok
test rad_clone_connect ... ok
test rad_clone_all ... ok
test rad_clone_unknown ... ok
test rad_cob_log ... ok
test rad_cob_multiset ... ok
test rad_clone_directory ... ok
test rad_cob_migrate ... ok
test rad_clone_partial_fail ... ok
test rad_cob_operations ... ok
test rad_cob_show ... ok
test rad_cob_update_identity ... ok
test rad_cob_update ... ok
test rad_config ... ok
test rad_diff ... ok
test rad_help ... ok
test rad_id_collaboration ... ignored, slow
test rad_id ... ok
test rad_id_conflict ... ok
test rad_id_private ... ok
test rad_id_threshold ... ok
test rad_id_multi_delegate ... ok
test rad_id_unknown_field ... ok
test rad_id_update_delete_field ... ok
test rad_id_threshold_soft_fork ... ok
test rad_init ... ignored, part of many other tests
test rad_init_bare ... ok
test rad_init_detached_head ... ok
test rad_init_existing ... ok
test rad_init_existing_bare ... ok
test rad_init_no_git ... ok
test rad_init_no_seed ... ok
test rad_init_private ... ok
test rad_inbox ... ok
test rad_init_private_clone ... ok
test rad_fork ... ok
test rad_fetch ... ok
test rad_init_private_no_seed ... ok
test rad_init_private_clone_seed ... ok
test rad_init_sync_not_connected ... ok
test rad_init_private_seed ... ok
test rad_init_sync_preferred ... ok
test rad_init_with_existing_remote ... ok
test rad_inspect ... ok
test rad_issue ... ok
test rad_jj_bare ... ok
test rad_jj_colocated_patch ... ok
test rad_issue_list ... ok
test rad_key_mismatch ... ok
test rad_merge_no_ff ... ok
test rad_merge_after_update ... ok
test rad_merge_via_push ... ok
test rad_node_connect ... ok
test rad_node_connect_without_address ... ok
test rad_patch ... ok
test rad_node ... ok
test rad_patch_ahead_behind ... ok
test rad_patch_change_base ... ok
test rad_patch_checkout ... ok
test rad_patch_checkout_revision ... ok
test rad_patch_checkout_force ... ok
test rad_patch_detached_head ... ok
test rad_init_sync_timeout ... ok
test rad_patch_diff ... ok
test rad_init_sync_and_clone ... ok
test rad_patch_draft ... ok
test rad_patch_edit ... ok
test rad_patch_fetch_2 ... FAILED
test rad_patch_merge_draft ... ok
test rad_patch_fetch_1 ... ok
test rad_patch_delete ... ok
test rad_patch_revert_merge ... ok
test rad_patch_update ... ok
test rad_patch_via_push ... FAILED
test rad_patch_open_explore ... ok
test rad_publish ... ok
test rad_review_by_hunk ... ok
test rad_seed_and_follow ... ok
test rad_remote ... ok
test rad_seed_many ... ok
test rad_self ... ok
test rad_sync_without_node ... ok
test rad_unseed ... ok
test rad_push_and_pull_patches ... ok
test rad_warn_old_nodes ... ok
test rad_unseed_many ... ok
test rad_watch ... ok
test rad_sync ... ok
test test_clone_without_seeds ... ok
test test_cob_deletion ... ok
test test_cob_replication ... ok
test rad_workflow ... ok
test rad_patch_pull_update ... ok
test test_replication_via_seed ... ok
failures:
---- rad_patch_fetch_2 stdout ----
1768329430 test: Using PATH ["/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-cli/target/debug", "/usr/local/cargo/bin", "/usr/local/sbin", "/usr/local/bin", "/usr/sbin", "/usr/bin", "/sbin", "/bin", "/tmp/.tmpum1uCX/alice/work"]
1768329430 test: rad-init.md: Running `/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/target/debug/rad` with ["init", "--name", "heartwood", "--description", "Radicle Heartwood Protocol & Stack", "--no-confirm", "--public", "-v"] in `/tmp/.tmpum1uCX/alice/work`..
1768329431 test: rad-init.md: Running `/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/target/debug/rad` with ["init"] in `/tmp/.tmpum1uCX/alice/work`..
1768329431 test: rad-init.md: Running `/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/target/debug/rad` with ["ls"] in `/tmp/.tmpum1uCX/alice/work`..
1768329431 test: rad-init.md: Running `/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/target/debug/rad` with ["node", "inventory"] in `/tmp/.tmpum1uCX/alice/work`..
1768329431 test: Using PATH ["/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-cli/target/debug", "/usr/local/cargo/bin", "/usr/local/sbin", "/usr/local/bin", "/usr/sbin", "/usr/bin", "/sbin", "/bin", "/tmp/.tmpum1uCX/alice/work"]
1768329431 test: rad-patch-fetch-2.md: Running `git` with ["checkout", "-b", "alice/1", "-q"] in `/tmp/.tmpum1uCX/alice/work`..
1768329431 test: rad-patch-fetch-2.md: Running `git` with ["commit", "--allow-empty", "-m", "Changes #1", "-q"] in `/tmp/.tmpum1uCX/alice/work`..
1768329431 test: rad-patch-fetch-2.md: Running `git` with ["push", "rad", "-o", "patch.message=Changes", "HEAD:refs/patches"] in `/tmp/.tmpum1uCX/alice/work`..
1768329431 test: rad-patch-fetch-2.md: Running `git` with ["checkout", "master", "-q"] in `/tmp/.tmpum1uCX/alice/work`..
1768329431 test: rad-patch-fetch-2.md: Running `git` with ["branch", "-D", "alice/1", "-q"] in `/tmp/.tmpum1uCX/alice/work`..
1768329431 test: rad-patch-fetch-2.md: Running `git` with ["update-ref", "-d", "refs/remotes/rad/alice/1"] in `/tmp/.tmpum1uCX/alice/work`..
1768329431 test: rad-patch-fetch-2.md: Running `git` with ["update-ref", "-d", "refs/remotes/rad/patches/5e2dedcc5d515fcbc1cca483d3376609fe889bfb"] in `/tmp/.tmpum1uCX/alice/work`..
1768329431 test: rad-patch-fetch-2.md: Running `git` with ["gc", "--prune=now"] in `/tmp/.tmpum1uCX/alice/work`..
1768329431 test: rad-patch-fetch-2.md: Running `git` with ["branch", "-r"] in `/tmp/.tmpum1uCX/alice/work`..
1768329431 test: rad-patch-fetch-2.md: Running `git` with ["pull"] in `/tmp/.tmpum1uCX/alice/work`..
1768329431 test: rad-patch-fetch-2.md: Running `git` with ["branch", "-r"] in `/tmp/.tmpum1uCX/alice/work`..
thread 'rad_patch_fetch_2' panicked at crates/radicle-cli-test/src/lib.rs:503: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
---- rad_patch_via_push stdout ----
1768329432 test: Using PATH ["/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-cli/target/debug", "/usr/local/cargo/bin", "/usr/local/sbin", "/usr/local/bin", "/usr/sbin", "/usr/bin", "/sbin", "/bin", "/tmp/.tmptQ8YjA/alice/work"]
1768329432 test: rad-init.md: Running `/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/target/debug/rad` with ["init", "--name", "heartwood", "--description", "Radicle Heartwood Protocol & Stack", "--no-confirm", "--public", "-v"] in `/tmp/.tmptQ8YjA/alice/work`..
1768329432 test: rad-init.md: Running `/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/target/debug/rad` with ["init"] in `/tmp/.tmptQ8YjA/alice/work`..
1768329432 test: rad-init.md: Running `/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/target/debug/rad` with ["ls"] in `/tmp/.tmptQ8YjA/alice/work`..
1768329432 test: rad-init.md: Running `/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/target/debug/rad` with ["node", "inventory"] in `/tmp/.tmptQ8YjA/alice/work`..
1768329432 test: Using PATH ["/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/crates/radicle-cli/target/debug", "/usr/local/cargo/bin", "/usr/local/sbin", "/usr/local/bin", "/usr/sbin", "/usr/bin", "/sbin", "/bin", "/tmp/.tmptQ8YjA/alice/work"]
1768329432 test: rad-patch-via-push.md: Running `git` with ["checkout", "-b", "feature/1"] in `/tmp/.tmptQ8YjA/alice/work`..
1768329432 test: rad-patch-via-push.md: Running `git` with ["commit", "-a", "-m", "Add things", "-q", "--allow-empty"] in `/tmp/.tmptQ8YjA/alice/work`..
1768329432 test: rad-patch-via-push.md: Running `git` with ["push", "-o", "patch.message=Add things #1", "-o", "patch.message=See commits for details.", "rad", "HEAD:refs/patches"] in `/tmp/.tmptQ8YjA/alice/work`..
1768329432 test: rad-patch-via-push.md: Running `/1207e1ee-0fbf-48d3-b72c-f3c7d3e5d13c/w/target/debug/rad` with ["patch", "show", "6035d2f582afbe01ff23ea87528ae523d76875b6"] in `/tmp/.tmptQ8YjA/alice/work`..
1768329432 test: rad-patch-via-push.md: Running `git` with ["branch", "-vv"] in `/tmp/.tmptQ8YjA/alice/work`..
1768329432 test: rad-patch-via-push.md: Running `git` with ["status", "--short", "--branch"] in `/tmp/.tmptQ8YjA/alice/work`..
1768329432 test: rad-patch-via-push.md: Running `git` with ["fetch"] in `/tmp/.tmptQ8YjA/alice/work`..
1768329432 test: rad-patch-via-push.md: Running `git` with ["push"] in `/tmp/.tmptQ8YjA/alice/work`..
1768329432 test: rad-patch-via-push.md: Running `git` with ["show-ref"] in `/tmp/.tmptQ8YjA/alice/work`..
thread 'rad_patch_via_push' panicked at crates/radicle-cli-test/src/lib.rs:503: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:
rad_patch_fetch_2
rad_patch_via_push
test result: FAILED. 106 passed; 2 failed; 2 ignored; 0 measured; 0 filtered out; finished in 68.08s
error: test failed, to rerun pass `-p radicle-cli --test commands`
Running unittests src/lib.rs (target/debug/deps/radicle_cli_test-271eee1f80c41c0d)
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-84c4e41a69174119)
running 8 tests
test object::tests::test_serde ... ok
test tests::git::roundtrip ... ok
test tests::invalid_parse_refstr ... ok
test tests::git::list_cobs ... ok
test type_name::test::valid_typenames ... ok
test tests::git::update_cob ... ok
test tests::parse_refstr ... ok
test tests::git::traverse_cobs ... ok
test result: ok. 8 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
Running unittests src/lib.rs (target/debug/deps/radicle_core-ef9dfc09b2e6d61d)
running 2 tests
test repo::serde_impls::test::assert_prop_roundtrip_serde_json ... ok
test repo::test::assert_prop_roundtrip_parse ... ok
test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Running unittests src/lib.rs (target/debug/deps/radicle_crypto-2cdf91f3179b3527)
running 12 tests
test ssh::fmt::test::test_key ... ok
test ssh::fmt::test::test_fingerprint ... ok
test ssh::keystore::tests::test_init_no_passphrase ... ok
test ssh::test::test_agent_encoding_remove ... ok
test ssh::test::test_agent_encoding_sign ... ok
test ssh::test::prop_encode_decode_sk ... 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. 12 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.85s
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_dependencies ... ok
test tests::test_diamond ... ok
test tests::test_fold_diamond ... ok
test tests::test_complex ... ok
test tests::test_fold_multiple_roots ... ok
test tests::test_get ... 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_prune_1 ... ok
test tests::test_fold_reject ... ok
test tests::test_fold_sorting_1 ... ok
test tests::test_fold_sorting_2 ... ok
test tests::test_prune_2 ... ok
test tests::test_prune_by_sorting ... ok
test tests::test_remove ... 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-55beca16093fba7c)
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_git_metadata-ccdb6d430095148e)
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_git_ref_format-b808ac22aa3ddce7)
running 9 tests
test test::qualified ... ok
test test::component_invalid - should panic ... ok
test test::pattern ... ok
test test::qualified_invalid - should panic ... ok
test test::component ... 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 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-b324a722f6463902)
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-01418340137b57ac)
running 74 tests
test control::tests::test_control_socket ... ok
test fingerprint::tests::matching ... ok
test reactor::timer::tests::test_wake_exact ... ok
test reactor::timer::tests::test_next ... ok
test reactor::timer::tests::test_wake ... ok
test control::tests::test_seed_unseed ... ok
test tests::e2e::missing_default_branch ... ok
test tests::e2e::missing_delegate_default_branch ... ok
test tests::e2e::test_catchup_on_refs_announcements ... ok
test tests::e2e::test_background_foreground_fetch ... ok
test tests::e2e::test_channel_reader_limit ... 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_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_replication_invalid ... ok
test tests::e2e::test_inventory_sync_bridge ... ok
test tests::e2e::test_replication_ref_in_sigrefs ... ok
test tests::e2e::test_inventory_sync_ring ... ok
test tests::test_announcement_rebroadcast ... ok
test tests::e2e::test_inventory_sync_star ... 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_persistent_peer_connect ... ok
test tests::test_inventory_pruning ... ok
test tests::test_persistent_peer_reconnect_success ... ok
test tests::test_persistent_peer_reconnect_attempt ... ok
test tests::test_ping_response ... ok
test tests::test_queued_fetch_from_ann_same_rid ... ok
test tests::test_queued_fetch_from_command_same_rid ... ok
test tests::test_redundant_connect ... ok
test tests::test_queued_fetch_max_capacity ... ok
test tests::test_refs_announcement_followed ... ok
test tests::test_refs_announcement_fetch_trusted_no_inventory ... ok
test tests::test_refs_announcement_no_subscribe ... ok
test tests::test_refs_announcement_offline ... ok
test tests::test_refs_announcement_relay_private ... ok
test tests::test_refs_announcement_relay_public ... ok
test tests::test_refs_synced_event ... 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_seeding ... ok
test tests::prop_inventory_exchange_dense ... ok
test tests::test_announcement_message_amplification ... ok
test result: ok. 74 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 16.61s
Running unittests src/main.rs (target/debug/deps/radicle_node-5f2550719b5c8458)
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-d6586171c5e5bfc1)
running 10 tests
test fmt::test::fixture ... ok
test fmt::test::zero ... ok
test git2::test::zero ... ok
test fmt::test::git2 ... ok
test fmt::test::gix ... ok
test gix::test::zero ... ok
test str::test::fixture ... 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-be1e4f2918a857c6)
running 46 tests
test deserializer::test::test_decode_next ... ok
test deserializer::test::test_unparsed ... ok
test service::filter::test::compatible ... ok
test deserializer::test::prop_decode_next ... ok
test service::filter::test::test_parameters ... ok
test service::limiter::test::test_limitter_multi ... ok
test service::limiter::test::test_limitter_different_rates ... ok
test service::limiter::test::test_limitter_refill ... ok
test service::gossip::store::test::test_announced ... ok
test service::filter::test::test_sizes ... ok
test service::message::tests::test_inventory_limit ... ok
test wire::frame::test::test_encode_git_large ... ok
test wire::frame::test::test_stream_id ... ok
test service::message::tests::test_ref_remote_limit ... 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_signed_refs ... 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. 46 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 1.33s
Running unittests src/main.rs (target/debug/deps/git_remote_rad-403bd130a4109572)
running 0 tests
test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
Running unittests src/main.rs (target/debug/deps/radicle_schemars-3814598870a0c326)
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-bb66f1d798396f61)
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_ssh-ced840136c32d8e4)
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-36e3b0b1253d2879)
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-fac874e5460320c3)
running 21 tests
test ansi::tests::colors_disabled ... ok
test ansi::tests::colors_enabled ... ok
test cell::test::test_width ... ok
test element::test::test_spaced ... ok
test ansi::tests::wrapping ... ok
test element::test::test_width ... ok
test table::test::test_table ... ok
test element::test::test_truncate ... ok
test table::test::test_table_border ... ok
test table::test::test_table_truncate ... ok
test table::test::test_table_border_truncated ... ok
test table::test::test_table_border_maximized ... 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 ... ok
test vstack::test::test_vstack ... ok
test textarea::test::test_wrapping_code_block ... ok
test textarea::test::test_wrapping_fenced_block ... ok
test textarea::test::test_wrapping_paragraphs ... ok
test vstack::test::test_vstack_maximize ... ok
test result: ok. 21 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 2 tests
test crates/radicle-core/src/node.rs - node (line 5) ... FAILED
test crates/radicle-core/src/node.rs - node (line 9) ... FAILED
failures:
---- crates/radicle-core/src/node.rs - node (line 5) stdout ----
error: expected expression, found keyword `type`
--> crates/radicle-core/src/node.rs:6:45
|
3 | MULTIBASE(base58-btc, MULTICODEC(public-key-type, raw-public-key-bytes))
| ^^^^ expected expression
error[E0425]: cannot find value `base58` in this scope
--> crates/radicle-core/src/node.rs:6:11
|
3 | MULTIBASE(base58-btc, MULTICODEC(public-key-type, raw-public-key-bytes))
| ^^^^^^ not found in this scope
error[E0425]: cannot find value `btc` in this scope
--> crates/radicle-core/src/node.rs:6:18
|
3 | MULTIBASE(base58-btc, MULTICODEC(public-key-type, raw-public-key-bytes))
| ^^^ not found in this scope
error[E0425]: cannot find function, tuple struct or tuple variant `MULTIBASE` in this scope
--> crates/radicle-core/src/node.rs:6:1
|
3 | MULTIBASE(base58-btc, MULTICODEC(public-key-type, raw-public-key-bytes))
| ^^^^^^^^^ not found in this scope
error: aborting due to 4 previous errors
For more information about this error, try `rustc --explain E0425`.
Couldn't compile the test.
---- crates/radicle-core/src/node.rs - node (line 9) stdout ----
error[E0425]: cannot find value `z6MknSLrJoTcukLrE435hVNQT4JUhbvWLX4kUzqkEStBU8Vi` in this scope
--> crates/radicle-core/src/node.rs:10:1
|
3 | z6MknSLrJoTcukLrE435hVNQT4JUhbvWLX4kUzqkEStBU8Vi
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ not found in this scope
error: aborting due to 1 previous error
For more information about this error, try `rustc --explain E0425`.
Couldn't compile the test.
failures:
crates/radicle-core/src/node.rs - node (line 5)
crates/radicle-core/src/node.rs - node (line 9)
test result: FAILED. 0 passed; 2 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.04s
error: doctest failed, to rerun pass `-p radicle-core --doc`
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>::push (line 122) ... 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>::collect_from (line 30) ... 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.32s
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_ssh
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.13s
error: 2 targets failed:
`-p radicle-cli --test commands`
`-p radicle-core --doc`
Exit code: 101
{
"response": "finished",
"result": "failure"
}