rad:z3gqcJUoA1n9HaHKufZs5FCSGazv5 heartwoodbe03d66ffa8654a095cf99d98ad4f529885f7e54
{
"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": "80369b810dd2e4742d5bd4ff1e7e960a7bf1d13e",
"author": {
"id": "did:key:z6MkkPvBfjP4bQmco5Dm7UGsX2ruDBieEHi8n9DVJWX5sTEz",
"alias": "lorenz"
},
"title": "Relax sqlite `synchronous` flag",
"state": {
"status": "open",
"conflicts": []
},
"before": "e9245b630d728672d2b3d6ff9265fa4f1a86f13a",
"after": "be03d66ffa8654a095cf99d98ad4f529885f7e54",
"commits": [
"be03d66ffa8654a095cf99d98ad4f529885f7e54",
"a55d7dffec01212912f31ff7bf18702a5b5b73d1",
"0c9fa5031fed01c37c21dcf3f7504a1da933a729",
"c0f0f15b73f08cdc33fd00166ac0acd9c686a158",
"3cbd1fc216f3748f528c9e949a41d552141e2bd8"
],
"target": "e9245b630d728672d2b3d6ff9265fa4f1a86f13a",
"labels": [],
"assignees": [],
"revisions": [
{
"id": "80369b810dd2e4742d5bd4ff1e7e960a7bf1d13e",
"author": {
"id": "did:key:z6MkkPvBfjP4bQmco5Dm7UGsX2ruDBieEHi8n9DVJWX5sTEz",
"alias": "lorenz"
},
"description": "According to the docs [1]: \n\n> WAL mode is safe from corruption with synchronous=NORMAL, and probably DELETE mode is safe too on modern filesystems. WAL mode is always consistent with synchronous=NORMAL, but WAL mode does lose durability. A transaction committed in WAL mode with synchronous=NORMAL might roll back following a power loss or system crash. Transactions are durable across application crashes regardless of the synchronous setting or journal mode.\n\nAlso: \n\n> You lose durability across power lose with synchronous NORMAL in WAL mode, but that is not important for most applications. Transactions are still atomic, consistent, and isolated, which are the most important characteristics in most use cases.\n\nThe tradeoff here is that SQLite will not aggressively fsync() after every transaction, so we should see less disk pressure. \n\n[1] - https://sqlite.org/wal.html",
"base": "b04f487b3ae2efcd23f52f8138abe32e73a718fd",
"oid": "00485a49e4164046381fdade76878cb74ba5b715",
"timestamp": 1771604372
},
{
"id": "5c635af3c0e148e4c9fb9bcb3ca01405e9a273a9",
"author": {
"id": "did:key:z6MkkPvBfjP4bQmco5Dm7UGsX2ruDBieEHi8n9DVJWX5sTEz",
"alias": "lorenz"
},
"description": "Rebased on 1.6.1",
"base": "4a5a51e6e550456c75d1a2182b0eafb9c3033ec0",
"oid": "406ea09e63659795098c646b2386eb1e28aac457",
"timestamp": 1771604770
},
{
"id": "34a7246c5063d37ca80a2d1d743ea15e155c019d",
"author": {
"id": "did:key:z6MkkPvBfjP4bQmco5Dm7UGsX2ruDBieEHi8n9DVJWX5sTEz",
"alias": "lorenz"
},
"description": "Rebased",
"base": "b04f487b3ae2efcd23f52f8138abe32e73a718fd",
"oid": "902649813f8658207f923fd7e19143e0d669f5a5",
"timestamp": 1771931763
},
{
"id": "264b5641d2ffabb82e887ace2d51c56f5eb4776b",
"author": {
"id": "did:key:z6MkkPvBfjP4bQmco5Dm7UGsX2ruDBieEHi8n9DVJWX5sTEz",
"alias": "lorenz"
},
"description": "",
"base": "b04f487b3ae2efcd23f52f8138abe32e73a718fd",
"oid": "f9b0590f35a6f81245a20c884993c77ad659b3ce",
"timestamp": 1771932199
},
{
"id": "0934766ec08a0f64d50d2827c5aa5b940f1b2fad",
"author": {
"id": "did:key:z6MkkPvBfjP4bQmco5Dm7UGsX2ruDBieEHi8n9DVJWX5sTEz",
"alias": "lorenz"
},
"description": "Makes sqlite PRAGMA flags configurable, maintaining the new defaults",
"base": "b04f487b3ae2efcd23f52f8138abe32e73a718fd",
"oid": "dc4368ccc04009f2fc0667dbabc5b28e9c029c81",
"timestamp": 1772105446
},
{
"id": "ff409ef4ecb29e89a329e179163acbe41fb8e88c",
"author": {
"id": "did:key:z6MkkPvBfjP4bQmco5Dm7UGsX2ruDBieEHi8n9DVJWX5sTEz",
"alias": "lorenz"
},
"description": "WIP",
"base": "b04f487b3ae2efcd23f52f8138abe32e73a718fd",
"oid": "6a541e549d0bfb59bc3d70a21a585f376ae93636",
"timestamp": 1772467264
},
{
"id": "16d9c605404a0d2cb6174b5af1ac01fd755518ac",
"author": {
"id": "did:key:z6MkkPvBfjP4bQmco5Dm7UGsX2ruDBieEHi8n9DVJWX5sTEz",
"alias": "lorenz"
},
"description": "Polish",
"base": "e9245b630d728672d2b3d6ff9265fa4f1a86f13a",
"oid": "be03d66ffa8654a095cf99d98ad4f529885f7e54",
"timestamp": 1772530729
}
]
}
}
{
"response": "triggered",
"run_id": {
"id": "addda884-6bf0-4e3d-a1c0-ac9e67000027"
},
"info_url": "https://cci.rad.levitte.org//addda884-6bf0-4e3d-a1c0-ac9e67000027.html"
}
Started at: 2026-03-03 10:39:15.987384+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/addda884-6bf0-4e3d-a1c0-ac9e67000027/w/
╭────────────────────────────────────╮
│ heartwood │
│ Radicle Heartwood Protocol & Stack │
│ 144 issues · 36 patches │
╰────────────────────────────────────╯
Run `cd ./.` to go to the repository directory.
Exit code: 0
$ rad patch checkout 80369b810dd2e4742d5bd4ff1e7e960a7bf1d13e
✓ Switched to branch patch/80369b8 at revision 0934766
✓ Branch patch/80369b8 setup to track rad/patches/80369b810dd2e4742d5bd4ff1e7e960a7bf1d13e
Exit code: 0
$ git config advice.detachedHead false
Exit code: 0
$ git checkout be03d66ffa8654a095cf99d98ad4f529885f7e54
HEAD is now at be03d66f radicle: Introduce `Profile::database_mut`
Exit code: 0
$ rad patch show 80369b810dd2e4742d5bd4ff1e7e960a7bf1d13e -p
╭──────────────────────────────────────────────────────────────────────────────────╮
│ Title Relax sqlite `synchronous` flag │
│ Patch 80369b810dd2e4742d5bd4ff1e7e960a7bf1d13e │
│ Author yorgos-laptop z6MkrnX…CPFSFS3 │
│ Head dc4368ccc04009f2fc0667dbabc5b28e9c029c81 │
│ Base b04f487b3ae2efcd23f52f8138abe32e73a718fd │
│ Branches patch/80369b8 │
│ Commits ahead 1, behind 1 │
│ Status open │
│ │
│ According to the docs [1]: │
│ │
│ > WAL mode is safe from corruption with synchronous=NORMAL, and probably DELETE │
│ mode is safe too on modern filesystems. WAL mode is always consistent with │
│ synchronous=NORMAL, but WAL mode does lose durability. A transaction committed │
│ in WAL mode with synchronous=NORMAL might roll back following a power loss or │
│ system crash. Transactions are durable across application crashes regardless of │
│ the synchronous setting or journal mode. │
│ │
│ Also: │
│ │
│ > You lose durability across power lose with synchronous NORMAL in WAL mode, but │
│ that is not important for most applications. Transactions are still atomic, │
│ consistent, and isolated, which are the most important characteristics in most │
│ use cases. │
│ │
│ The tradeoff here is that SQLite will not aggressively fsync() after every │
│ transaction, so we should see less disk pressure. │
│ │
│ [1] - https://sqlite.org/wal.html │
├──────────────────────────────────────────────────────────────────────────────────┤
│ dc4368c Make sqlite flags configurable, with NEW defaults │
├──────────────────────────────────────────────────────────────────────────────────┤
│ ● Revision 80369b8 @ 00485a4 by yorgos-laptop z6MkrnX…CPFSFS3 1 week ago │
│ ↑ Revision 5c635af @ 406ea09 by yorgos-laptop z6MkrnX…CPFSFS3 1 week ago │
│ ↑ Revision 34a7246 @ 9026498 by yorgos-laptop z6MkrnX…CPFSFS3 6 days ago │
│ ↑ Revision 264b564 @ f9b0590 by yorgos-laptop z6MkrnX…CPFSFS3 6 days ago │
│ ↑ Revision 0934766 @ dc4368c by yorgos-laptop z6MkrnX…CPFSFS3 4 days ago │
│ ↑ Revision ff409ef @ 6a541e5 by lorenz z6MkkPv…WX5sTEz 17 hours ago │
│ ↑ Revision 16d9c60 @ be03d66 by lorenz z6MkkPv…WX5sTEz 29 seconds ago │
╰──────────────────────────────────────────────────────────────────────────────────╯
commit dc4368ccc04009f2fc0667dbabc5b28e9c029c81
Author: Yorgos Saslis <yorgos.work@proton.me>
Date: Fri Feb 20 18:08:59 2026 +0200
Make sqlite flags configurable, with NEW defaults
The important change here, besides allowing node operators to configure
their sqlite `journal_mode` and `synchronous` flags, is that we relax
the default `synchronous` value from `FULL` to `NORMAL`.
With this change SQLite will not aggressively fsync() after every
transaction, so there is considerably less disk pressure as disk IO
can be batched.
In regard to the tradeoff, according to the docs [2]:
> WAL mode is safe from corruption with synchronous=NORMAL, and
probably DELETE mode is safe too on modern filesystems. WAL mode is
always consistent with synchronous=NORMAL, but WAL mode does lose
durability. A transaction committed in WAL mode with synchronous=NORMAL
might roll back following a power loss or system crash. Transactions
are durable across application crashes regardless of the synchronous
setting or journal mode.
Also:
> You lose durability across power lose with synchronous NORMAL in WAL
mode, but that is not important for most applications. Transactions
are still atomic, consistent, and isolated, which are the most
important characteristics in most use cases.
So, there is no risk to end up with a corrupt db, and in the extreme
cases of sudden power loss or system crash, some transaction may
*rollback*. Considering what radicle-node writes to its sqlite db, I
think that is an acceptable tradeoff.
[1] - https://sqlite.org/wal.html
[2] - https://sqlite.org/pragma.html#pragma_synchronous
Signed-off-by: Yorgos Saslis <yorgos.work@proton.me>
diff --git a/crates/radicle-cli/examples/rad-config.md b/crates/radicle-cli/examples/rad-config.md
index 6e208b20a..16f208410 100644
--- a/crates/radicle-cli/examples/rad-config.md
+++ b/crates/radicle-cli/examples/rad-config.md
@@ -52,6 +52,12 @@ $ rad config
"workers": 8,
"seedingPolicy": {
"default": "block"
+ },
+ "database": {
+ "sqlite": {
+ "journalMode": "WAL",
+ "synchronous": "NORMAL"
+ }
}
}
}
diff --git a/crates/radicle-node/src/runtime.rs b/crates/radicle-node/src/runtime.rs
index 0e2b86995..14487b293 100644
--- a/crates/radicle-node/src/runtime.rs
+++ b/crates/radicle-node/src/runtime.rs
@@ -177,7 +177,8 @@ impl Runtime {
log::info!(target: "node", "Opening node database..");
let db = home
.database_mut()?
- .journal_mode(node::db::JournalMode::default())?
+ .journal_mode(config.database.sqlite.journal_mode)?
+ .synchronous(config.database.sqlite.synchronous)?
.init(
&id,
announcement.features,
diff --git a/crates/radicle/src/node/config.rs b/crates/radicle/src/node/config.rs
index 1171db023..5147a6983 100644
--- a/crates/radicle/src/node/config.rs
+++ b/crates/radicle/src/node/config.rs
@@ -349,6 +349,37 @@ pub enum Relay {
Auto,
}
+/// Database configuration.
+#[derive(Debug, Default, Copy, Clone, Serialize, Deserialize)]
+#[serde(rename_all = "camelCase")]
+#[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))]
+pub struct DatabaseConfig {
+ /// SQLite configuration.
+ pub sqlite: SqliteConfig,
+}
+
+/// SQLite-specific database configuration.
+#[derive(Debug, Copy, Clone, Serialize, Deserialize)]
+#[serde(rename_all = "camelCase")]
+#[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))]
+pub struct SqliteConfig {
+ /// Journal mode. WAL is recommended for concurrent access.
+ #[serde(default)]
+ pub journal_mode: node::db::JournalMode,
+ /// Synchronous flag. Controls how often SQLite syncs to disk.
+ #[serde(default)]
+ pub synchronous: node::db::Synchronous,
+}
+
+impl Default for SqliteConfig {
+ fn default() -> Self {
+ Self {
+ journal_mode: node::db::JournalMode::WAL,
+ synchronous: node::db::Synchronous::NORMAL,
+ }
+ }
+}
+
/// Proxy configuration.
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(rename_all = "camelCase", tag = "mode")]
@@ -508,6 +539,9 @@ pub struct Config {
/// Default seeding policy.
#[serde(default)]
pub seeding_policy: DefaultSeedingPolicy,
+ /// Database configuration.
+ #[serde(default)]
+ pub database: DatabaseConfig,
/// Extra fields that aren't supported.
#[serde(flatten, skip_serializing)]
pub extra: json::Map<String, json::Value>,
@@ -544,6 +578,7 @@ impl Config {
workers: Workers::default(),
log: LogLevel::default(),
seeding_policy: DefaultSeedingPolicy::default(),
+ database: DatabaseConfig::default(),
extra: json::Map::default(),
secret: None,
}
@@ -828,4 +863,121 @@ mod test {
.unwrap()
);
}
+
+ #[test]
+ fn database_config_valid_combinations() {
+ use super::{node, Config};
+
+ let cases = [
+ // (journal_mode, synchronous, expected_journal, expected_sync, description)
+ (
+ None,
+ None,
+ node::db::JournalMode::WAL,
+ node::db::Synchronous::NORMAL,
+ "defaults",
+ ),
+ (
+ Some("wal"),
+ Some("NORMAL"),
+ node::db::JournalMode::WAL,
+ node::db::Synchronous::NORMAL,
+ "WAL+NORMAL (recommended)",
+ ),
+ (
+ Some("wal"),
+ Some("FULL"),
+ node::db::JournalMode::WAL,
+ node::db::Synchronous::FULL,
+ "WAL+FULL (max durability)",
+ ),
+ (
+ Some("wal"),
+ Some("OFF"),
+ node::db::JournalMode::WAL,
+ node::db::Synchronous::OFF,
+ "WAL+OFF (max performance)",
+ ),
+ (
+ Some("rollback"),
+ Some("FULL"),
+ node::db::JournalMode::DELETE,
+ node::db::Synchronous::FULL,
+ "DELETE+FULL",
+ ),
+ (
+ Some("rollback"),
+ Some("EXTRA"),
+ node::db::JournalMode::DELETE,
+ node::db::Synchronous::EXTRA,
+ "DELETE+EXTRA (max durability)",
+ ),
+ (
+ Some("WAL"),
+ Some("NORMAL"),
+ node::db::JournalMode::WAL,
+ node::db::Synchronous::NORMAL,
+ "WAL uppercase",
+ ),
+ (
+ Some("DELETE"),
+ Some("NORMAL"),
+ node::db::JournalMode::DELETE,
+ node::db::Synchronous::NORMAL,
+ "DELETE uppercase",
+ ),
+ ];
+
+ for (journal_mode, synchronous, expected_journal, expected_sync, description) in cases {
+ let mut json_value = json!({"alias": "example"});
+
+ if let (Some(jm), Some(sync)) = (journal_mode, synchronous) {
+ json_value["database"] = json!({
+ "sqlite": {
+ "journalMode": jm,
+ "synchronous": sync
+ }
+ });
+ }
+
+ let config: Config = serde_json::from_value(json_value)
+ .unwrap_or_else(|e| panic!("Failed to parse config for {description}: {e}"));
+
+ assert_eq!(
+ config.database.sqlite.journal_mode, expected_journal,
+ "journal_mode mismatch for {description}"
+ );
+ assert_eq!(
+ config.database.sqlite.synchronous, expected_sync,
+ "synchronous mismatch for {description}"
+ );
+ }
+ }
+
+ #[test]
+ fn database_config_rejects_invalid_values() {
+ use super::Config;
+
+ let invalid_cases = [
+ (Some("INVALID"), Some("NORMAL"), "invalid journal_mode"),
+ (Some("WAL"), Some("INVALID"), "invalid synchronous"),
+ (Some("WAL"), Some("normal"), "lowercase synchronous"),
+ (Some("Wal"), Some("NORMAL"), "mixed case journal_mode"),
+ ];
+
+ for (journal_mode, synchronous, description) in invalid_cases {
+ let mut json_value = json!({"alias": "example", "database": {"sqlite": {}}});
+ if let Some(jm) = journal_mode {
+ json_value["database"]["sqlite"]["journalMode"] = json!(jm);
+ }
+ if let Some(sync) = synchronous {
+ json_value["database"]["sqlite"]["synchronous"] = json!(sync);
+ }
+
+ assert!(
+ serde_json::from_value::<Config>(json_value).is_err(),
+ "Should reject {description}"
+ );
+ }
+ }
}
diff --git a/crates/radicle/src/node/db.rs b/crates/radicle/src/node/db.rs
index 423162525..3b482e243 100644
--- a/crates/radicle/src/node/db.rs
+++ b/crates/radicle/src/node/db.rs
@@ -50,16 +50,31 @@ pub enum Error {
}
/// Database journal mode.
-#[derive(Debug, Default, Copy, Clone, serde::Serialize, serde::Deserialize)]
-#[serde(rename_all = "camelCase")]
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq, serde::Serialize, serde::Deserialize)]
+#[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))]
pub enum JournalMode {
/// "WAL" mode. Good for concurrent reads & writes, but keeps some extra files around.
- #[serde(rename = "wal")]
+ #[serde(alias = "wal")]
#[default]
- WriteAheadLog,
+ WAL,
/// Default "rollback" mode. Certain writes may block reads.
#[serde(alias = "rollback")]
- Rollback,
+ DELETE,
+}
+
+/// SQLite synchronous flag value.
+#[derive(Debug, Default, Copy, Clone, PartialEq, Eq, serde::Serialize, serde::Deserialize)]
+#[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))]
+pub enum Synchronous {
+ /// OFF - No syncing at all. Fastest but least safe.
+ OFF,
+ /// NORMAL - Sync at critical moments. Good balance of safety and performance.
+ #[default]
+ NORMAL,
+ /// FULL - Sync at every critical moment. Safest but slowest.
+ FULL,
+ /// EXTRA - Like FULL with additional syncing.
+ EXTRA,
}
/// A file-backed database storing information about the network.
@@ -117,14 +132,15 @@ impl Database {
/// Set journal mode.
pub fn journal_mode(self, mode: JournalMode) -> Result<Self, Error> {
- match mode {
- JournalMode::Rollback => {
- self.db.execute("PRAGMA journal_mode = DELETE;")?;
- }
- JournalMode::WriteAheadLog => {
- self.db.execute("PRAGMA journal_mode = WAL;")?;
- }
- }
+ self.db
+ .execute(format!("PRAGMA journal_mode = {mode:?};"))?;
+ Ok(self)
+ }
+
+ /// Set synchronous flag.
+ pub fn synchronous(self, synchronous: Synchronous) -> Result<Self, Error> {
+ self.db
+ .execute(format!("PRAGMA synchronous = {synchronous:?};"))?;
Ok(self)
}
diff --git a/crates/radicle/src/profile.rs b/crates/radicle/src/profile.rs
index 79488aaa4..4dcfc6b27 100644
--- a/crates/radicle/src/profile.rs
+++ b/crates/radicle/src/profile.rs
@@ -253,7 +253,8 @@ impl Profile {
home.policies_mut()?;
home.notifications_mut()?;
home.database_mut()?
- .journal_mode(node::db::JournalMode::default())?
+ .journal_mode(config.node.database.sqlite.journal_mode)?
+ .synchronous(config.node.database.sqlite.synchronous)?
.init(
&public_key,
config.node.features(),
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 addda884-6bf0-4e3d-a1c0-ac9e67000027 -v /opt/radcis/ci.rad.levitte.org/cci/state/addda884-6bf0-4e3d-a1c0-ac9e67000027/s:/addda884-6bf0-4e3d-a1c0-ac9e67000027/s:ro -v /opt/radcis/ci.rad.levitte.org/cci/state/addda884-6bf0-4e3d-a1c0-ac9e67000027/w:/addda884-6bf0-4e3d-a1c0-ac9e67000027/w -w /addda884-6bf0-4e3d-a1c0-ac9e67000027/w -v /opt/radcis/ci.rad.levitte.org/.radicle:/${id}/.radicle:ro -e RAD_HOME=/${id}/.radicle rust:trixie bash /addda884-6bf0-4e3d-a1c0-ac9e67000027/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 backtrace v0.3.76
Downloaded base-x v0.2.11
Downloaded fluent-uri v0.3.2
Downloaded gix-transport v0.54.0
Downloaded litemap v0.7.5
Downloaded ff v0.13.0
Downloaded document-features v0.2.11
Downloaded ctr v0.9.2
Downloaded bytesize v2.0.1
Downloaded fast-glob v0.3.3
Downloaded crossterm v0.29.0
Downloaded gix-commitgraph v0.32.0
Downloaded gix-traverse v0.52.0
Downloaded gix-chunk v0.5.0
Downloaded hashbrown v0.14.3
Downloaded gix-shallow v0.8.1
Downloaded escargot v0.5.10
Downloaded gix-validate v0.11.0
Downloaded newline-converter v0.3.0
Downloaded idna_adapter v1.2.0
Downloaded env_logger v0.11.8
Downloaded human-panic v2.0.6
Downloaded multibase v0.9.1
Downloaded outref v0.5.2
Downloaded opaque-debug v0.3.1
Downloaded elliptic-curve v0.13.8
Downloaded num-integer v0.1.46
Downloaded nonempty v0.9.0
Downloaded phf_shared v0.11.3
Downloaded paste v1.0.15
Downloaded serde_derive_internals v0.29.1
Downloaded p256 v0.13.2
Downloaded pkg-config v0.3.30
Downloaded radicle-std-ext v0.2.0
Downloaded ref-cast v1.0.24
Downloaded signature v1.6.4
Downloaded rand_core v0.6.4
Downloaded salsa20 v0.10.2
Downloaded scopeguard v1.2.0
Downloaded jobserver v0.1.31
Downloaded scrypt v0.11.0
Downloaded gix-odb v0.75.0
Downloaded num-bigint-dig v0.8.4
Downloaded ssh-encoding v0.2.0
Downloaded serde-untagged v0.1.7
Downloaded ssh-cipher v0.2.0
Downloaded siphasher v0.3.11
Downloaded lexopt v0.3.0
Downloaded sqlite v0.32.0
Downloaded test-log v0.2.19
Downloaded serde_spanned v1.0.4
Downloaded snapbox-macros v0.3.8
Downloaded subtle v2.5.0
Downloaded serde_fmt v1.0.3
Downloaded sval_json v2.14.1
Downloaded thiserror v1.0.69
Downloaded test-log-macros v0.2.19
Downloaded structured-logger v1.0.4
Downloaded rand_chacha v0.3.1
Downloaded snapbox v0.4.17
Downloaded sval_fmt v2.14.1
Downloaded toml_writer v1.0.6+spec-1.1.0
Downloaded toml_datetime v0.7.5+spec-1.1.0
Downloaded timeago v0.4.2
Downloaded ssh-key v0.6.6
Downloaded zeroize v1.7.0
Downloaded value-bag-serde1 v1.11.1
Downloaded tracing-core v0.1.36
Downloaded tree-sitter-highlight v0.24.4
Downloaded yoke-derive v0.7.5
Downloaded value-bag-sval2 v1.11.1
Downloaded hmac v0.12.1
Downloaded wait-timeout v0.2.1
Downloaded rusty-fork v0.3.1
Downloaded zerovec-derive v0.10.3
Downloaded yoke v0.7.5
Downloaded yansi v0.5.1
Downloaded icu_properties v1.5.1
Downloaded walkdir v2.5.0
Downloaded typenum v1.17.0
Downloaded version_check v0.9.4
Downloaded uuid v1.20.0
Downloaded log v0.4.27
Downloaded icu_locid v1.5.0
Downloaded zerofrom-derive v0.1.6
Downloaded zerofrom v0.1.6
Downloaded synstructure v0.13.1
Downloaded write16 v1.0.0
Downloaded thread_local v1.1.9
Downloaded thiserror-impl v2.0.18
Downloaded object v0.37.3
Downloaded unicode-width v0.1.11
Downloaded zerovec v0.10.4
Downloaded tree-sitter v0.24.4
Downloaded zerocopy v0.7.35
Downloaded tree-sitter-css v0.23.1
Downloaded tracing-subscriber v0.3.22
Downloaded zlib-rs v0.6.0
Downloaded getrandom v0.3.3
Downloaded unicode-width v0.2.1
Downloaded jiff-static v0.2.20
Downloaded tree-sitter-md v0.3.2
Downloaded indexmap v2.2.6
Downloaded serde v1.0.228
Downloaded url v2.5.4
Downloaded tree-sitter-bash v0.23.3
Downloaded inquire v0.7.5
Downloaded tracing v0.1.44
Downloaded tree-sitter-go v0.23.4
Downloaded tree-sitter-ruby v0.23.1
Downloaded unicode-segmentation v1.11.0
Downloaded idna v1.0.3
Downloaded itertools v0.14.0
Downloaded unicode-normalization v0.1.23
Downloaded regex-automata v0.4.9
Downloaded mio v0.8.11
Downloaded winnow v0.7.14
Downloaded icu_properties_data v1.5.1
Downloaded vcpkg v0.2.15
Downloaded gimli v0.32.3
Downloaded proptest v1.9.0
Downloaded syn v2.0.106
Downloaded sha1-checked v0.10.0
Downloaded tree-sitter-rust v0.23.2
Downloaded git2 v0.20.4
Downloaded jsonschema v0.30.0
Downloaded libm v0.2.8
Downloaded tree-sitter-typescript v0.23.2
Downloaded hashbrown v0.16.1
Downloaded rustix v1.1.3
Downloaded gix-pack v0.65.0
Downloaded rand v0.9.2
Downloaded fraction v0.15.3
Downloaded icu_collections v1.5.0
Downloaded libc v0.2.182
Downloaded tree-sitter-c v0.23.2
Downloaded tempfile v3.25.0
Downloaded indicatif v0.18.0
Downloaded regex-syntax v0.8.5
Downloaded signal-hook v0.3.18
Downloaded sharded-slab v0.1.7
Downloaded gix-protocol v0.57.0
Downloaded flate2 v1.1.1
Downloaded xattr v1.3.1
Downloaded writeable v0.5.5
Downloaded jiff v0.2.20
Downloaded vsimd v0.8.0
Downloaded sysinfo v0.37.2
Downloaded syn v1.0.109
Downloaded tokio v1.47.1
Downloaded rustix v0.38.34
Downloaded linux-raw-sys v0.4.13
Downloaded icu_normalizer_data v1.5.1
Downloaded sha3 v0.10.8
Downloaded tree-sitter-python v0.23.4
Downloaded gix-ref v0.59.0
Downloaded shlex v1.3.0
Downloaded referencing v0.30.0
Downloaded rand_chacha v0.9.0
Downloaded thiserror-impl v1.0.69
Downloaded icu_locid_transform_data v1.5.1
Downloaded regex v1.11.1
Downloaded sha2 v0.10.8
Downloaded rustversion v1.0.20
Downloaded value-bag v1.11.1
Downloaded gix-object v0.56.0
Downloaded gix-object v0.55.0
Downloaded utf8_iter v1.0.4
Downloaded toml v0.9.12+spec-1.1.0
Downloaded tree-sitter-html v0.23.2
Downloaded serde_json v1.0.140
Downloaded gix-url v0.35.1
Downloaded utf8parse v0.2.2
Downloaded gix-path v0.11.1
Downloaded gix-features v0.46.1
Downloaded uuid-simd v0.8.0
Downloaded thiserror v2.0.18
Downloaded universal-hash v0.5.1
Downloaded unicode-display-width v0.3.0
Downloaded typeid v1.0.3
Downloaded gix-refspec v0.37.0
Downloaded gix-date v0.13.0
Downloaded utf16_iter v1.0.5
Downloaded unit-prefix v0.5.1
Downloaded unicode-ident v1.0.12
Downloaded unarray v0.1.4
Downloaded tree-sitter-toml-ng v0.6.0
Downloaded tree-sitter-language v0.1.2
Downloaded tree-sitter-json v0.24.8
Downloaded tracing-log v0.2.0
Downloaded tinyvec_macros v0.1.1
Downloaded systemd-journal-logger v2.2.2
Downloaded sval_ref v2.14.1
Downloaded portable-atomic v1.11.0
Downloaded icu_provider_macros v1.5.0
Downloaded gix-tempfile v21.0.1
Downloaded gix-date v0.14.0
Downloaded socket2 v0.5.7
Downloaded icu_provider v1.5.0
Downloaded icu_normalizer v1.5.0
Downloaded heapless v0.8.0
Downloaded tinystr v0.7.6
Downloaded sval v2.14.1
Downloaded libgit2-sys v0.18.3+1.9.2
Downloaded tinyvec v1.6.0
Downloaded tar v0.4.40
Downloaded sval_buffer v2.14.1
Downloaded spki v0.7.3
Downloaded similar v2.5.0
Downloaded serde_derive v1.0.228
Downloaded gix-fs v0.19.1
Downloaded smallvec v1.15.1
Downloaded signals_receipts v0.2.0
Downloaded serde_core v1.0.228
Downloaded linux-raw-sys v0.11.0
Downloaded radicle-surf v0.27.0
Downloaded p521 v0.13.3
Downloaded bloomy v1.2.0
Downloaded sval_serde v2.14.1
Downloaded sval_nested v2.14.1
Downloaded sval_dynamic v2.14.1
Downloaded strsim v0.11.1
Downloaded spin v0.9.8
Downloaded sqlite3-src v0.5.1
Downloaded num-complex v0.4.6
Downloaded gix-revision v0.41.0
Downloaded gix-packetline v0.21.1
Downloaded gix-negotiate v0.27.0
Downloaded gix-error v0.0.0
Downloaded sqlite3-sys v0.15.2
Downloaded streaming-iterator v0.1.9
Downloaded stable_deref_trait v1.2.0
Downloaded shell-words v1.1.0
Downloaded gix-lock v21.0.1
Downloaded gix-quote v0.6.2
Downloaded siphasher v1.0.1
Downloaded ref-cast-impl v1.0.24
Downloaded gix-trace v0.1.18
Downloaded socks5-client v0.4.1
Downloaded rsa v0.9.6
Downloaded rand v0.8.5
Downloaded gix-error v0.1.0
Downloaded generic-array v0.14.7
Downloaded gix-commitgraph v0.33.0
Downloaded signal-hook-registry v1.4.5
Downloaded sha1 v0.10.6
Downloaded rand_core v0.9.3
Downloaded prodash v31.0.0
Downloaded pretty_assertions v1.4.0
Downloaded signature v2.2.0
Downloaded signal-hook-mio v0.2.4
Downloaded schemars v1.0.4
Downloaded gix-chunk v0.6.0
Downloaded form_urlencoded v1.2.1
Downloaded p384 v0.13.0
Downloaded num v0.4.3
Downloaded gix-hashtable v0.12.0
Downloaded gix-command v0.7.1
Downloaded fnv v1.0.7
Downloaded sem_safe v0.2.0
Downloaded sec1 v0.7.3
Downloaded schemars_derive v1.0.4
Downloaded ryu v1.0.17
Downloaded rustc-demangle v0.1.26
Downloaded rfc6979 v0.4.0
Downloaded lazy_static v1.5.0
Downloaded gix-utils v0.3.1
Downloaded itoa v1.0.17
Downloaded chrono v0.4.38
Downloaded proc-macro2 v1.0.101
Downloaded qcheck-macros v1.0.0
Downloaded heck v0.5.0
Downloaded getrandom v0.2.15
Downloaded quote v1.0.41
Downloaded ppv-lite86 v0.2.17
Downloaded num-bigint v0.4.6
Downloaded memchr v2.7.2
Downloaded qcheck v1.0.0
Downloaded proc-macro-error-attr2 v2.0.0
Downloaded primeorder v0.13.6
Downloaded polyval v0.6.2
Downloaded keccak v0.1.6
Downloaded clap_builder v4.5.44
Downloaded same-file v1.0.6
Downloaded quick-error v1.2.3
Downloaded proc-macro-error2 v2.0.1
Downloaded poly1305 v0.8.0
Downloaded num-traits v0.2.19
Downloaded icu_locid_transform v1.5.0
Downloaded iana-time-zone v0.1.60
Downloaded gix-credentials v0.36.0
Downloaded rand_xorshift v0.4.0
Downloaded phf v0.11.3
Downloaded mio v1.0.4
Downloaded radicle-git-ext v0.12.0
Downloaded pkcs1 v0.7.5
Downloaded group v0.13.0
Downloaded git-ref-format-core v0.6.0
Downloaded pkcs8 v0.10.2
Downloaded pin-project-lite v0.2.16
Downloaded parking_lot_core v0.9.12
Downloaded hash32 v0.3.1
Downloaded gix-glob v0.24.0
Downloaded gix-actor v0.38.0
Downloaded num-rational v0.4.2
Downloaded gix-config-value v0.17.1
Downloaded cc v1.2.2
Downloaded percent-encoding v2.3.1
Downloaded pem-rfc7468 v0.7.0
Downloaded parking_lot v0.12.5
Downloaded maybe-async v0.2.10
Downloaded is_terminal_polyfill v1.70.2
Downloaded inout v0.1.3
Downloaded crypto-bigint v0.5.5
Downloaded pbkdf2 v0.12.2
Downloaded once_cell v1.21.3
Downloaded miniz_oxide v0.8.8
Downloaded fancy-regex v0.14.0
Downloaded nu-ansi-term v0.50.3
Downloaded normalize-line-endings v0.3.0
Downloaded lock_api v0.4.14
Downloaded gix-prompt v0.13.1
Downloaded derive_more-impl v2.0.1
Downloaded derive_more v2.0.1
Downloaded num-cmp v0.1.0
Downloaded noise-framework v0.4.0
Downloaded matchers v0.2.0
Downloaded num-iter v0.1.45
Downloaded clap v4.5.44
Downloaded memmap2 v0.9.8
Downloaded litrs v0.4.1
Downloaded der v0.7.9
Downloaded cyphernet v0.5.2
Downloaded crossbeam-utils v0.8.19
Downloaded colored v2.1.0
Downloaded gix-sec v0.13.1
Downloaded gix-revwalk v0.27.0
Downloaded gix-revwalk v0.26.0
Downloaded gix-hash v0.22.1
Downloaded git-ref-format v0.6.0
Downloaded crc32fast v1.5.0
Downloaded console v0.16.0
Downloaded clap_derive v4.5.41
Downloaded arc-swap v1.8.2
Downloaded env_filter v0.1.3
Downloaded anstyle v1.0.13
Downloaded data-encoding-macro v0.1.14
Downloaded cypheraddr v0.4.0
Downloaded chacha20poly1305 v0.10.1
Downloaded data-encoding v2.5.0
Downloaded cyphergraphy v0.3.0
Downloaded borrow-or-share v0.2.2
Downloaded block-padding v0.3.3
Downloaded block-buffer v0.10.4
Downloaded gix-diff v0.58.0
Downloaded fxhash v0.2.1
Downloaded faster-hex v0.10.0
Downloaded cpufeatures v0.2.12
Downloaded const-oid v0.9.6
Downloaded erased-serde v0.4.6
Downloaded either v1.11.0
Downloaded anstyle-parse v0.2.3
Downloaded git-ref-format-macro v0.6.0
Downloaded fastrand v2.3.0
Downloaded ec25519 v0.1.0
Downloaded dunce v1.0.5
Downloaded data-encoding-macro-internal v0.1.12
Downloaded gix-actor v0.39.0
Downloaded ghash v0.5.1
Downloaded dyn-clone v1.0.17
Downloaded crypto-common v0.1.6
Downloaded clap_complete v4.5.60
Downloaded chacha20 v0.9.1
Downloaded cbc v0.1.2
Downloaded bstr v1.12.0
Downloaded anstyle-query v1.0.2
Downloaded amplify_syn v2.0.1
Downloaded errno v0.3.13
Downloaded emojis v0.6.4
Downloaded email_address v0.2.9
Downloaded ed25519 v1.5.3
Downloaded displaydoc v0.2.5
Downloaded digest v0.10.7
Downloaded convert_case v0.7.1
Downloaded colorchoice v1.0.0
Downloaded clap_lex v0.7.5
Downloaded cfg-if v1.0.0
Downloaded crossbeam-channel v0.5.15
Downloaded bytes v1.11.1
Downloaded anyhow v1.0.82
Downloaded anstream v0.6.21
Downloaded amplify_num v0.5.2
Downloaded equivalent v1.0.1
Downloaded ecdsa v0.16.9
Downloaded ct-codecs v1.1.1
Downloaded crossterm v0.25.0
Downloaded cipher v0.4.4
Downloaded bytecount v0.6.8
Downloaded bitflags v1.3.2
Downloaded aho-corasick v1.1.3
Downloaded byteorder v1.5.0
Downloaded diff v0.1.13
Downloaded base16ct v0.2.0
Downloaded aes v0.8.4
Downloaded adler2 v2.0.0
Downloaded blowfish v0.9.1
Downloaded bit-vec v0.8.0
Downloaded amplify_derive v4.0.0
Downloaded filetime v0.2.23
Downloaded bitflags v2.9.1
Downloaded bit-set v0.8.0
Downloaded base64 v0.22.1
Downloaded ascii v1.1.0
Downloaded ahash v0.8.11
Downloaded aead v0.5.2
Downloaded base64ct v1.6.0
Downloaded base64 v0.21.7
Downloaded autocfg v1.2.0
Downloaded amplify v4.6.0
Downloaded aes-gcm v0.10.3
Downloaded bcrypt-pbkdf v0.10.0
Downloaded base32 v0.4.0
Downloaded addr2line v0.25.1
Downloaded libz-sys v1.1.16
Compiling libc v0.2.182
Compiling proc-macro2 v1.0.101
Compiling quote v1.0.41
Compiling unicode-ident v1.0.12
Checking cfg-if v1.0.0
Checking memchr v2.7.2
Compiling version_check v0.9.4
Compiling shlex v1.3.0
Checking regex-syntax v0.8.5
Compiling syn v2.0.106
Compiling jobserver v0.1.31
Checking getrandom v0.2.15
Compiling cc v1.2.2
Compiling typenum v1.17.0
Checking aho-corasick v1.1.3
Compiling generic-array v0.14.7
Checking regex-automata v0.4.9
Checking rand_core v0.6.4
Compiling serde_core v1.0.228
Checking crypto-common v0.1.6
Compiling serde v1.0.228
Checking smallvec v1.15.1
Checking subtle v2.5.0
Compiling thiserror v2.0.18
Checking cpufeatures v0.2.12
Checking fastrand v2.3.0
Checking stable_deref_trait v1.2.0
Compiling parking_lot_core v0.9.12
Checking scopeguard v1.2.0
Checking lock_api v0.4.14
Checking bstr v1.12.0
Checking block-buffer v0.10.4
Checking digest v0.10.7
Checking parking_lot v0.12.5
Checking tinyvec_macros v0.1.1
Checking byteorder v1.5.0
Checking tinyvec v1.6.0
Checking bitflags v2.9.1
Checking gix-trace v0.1.18
Compiling crc32fast v1.5.0
Checking gix-validate v0.11.0
Checking itoa v1.0.17
Compiling typeid v1.0.3
Checking same-file v1.0.6
Checking walkdir v2.5.0
Checking unicode-normalization v0.1.23
Checking prodash v31.0.0
Checking zlib-rs v0.6.0
Compiling serde_derive v1.0.228
Compiling thiserror-impl v2.0.18
Checking gix-utils v0.3.1
Compiling heapless v0.8.0
Checking hash32 v0.3.1
Compiling synstructure v0.13.1
Checking faster-hex v0.10.0
Compiling getrandom v0.3.3
Checking sha1 v0.10.6
Checking gix-path v0.11.1
Checking zeroize v1.7.0
Compiling zerofrom-derive v0.1.6
Compiling yoke-derive v0.7.5
Checking gix-features v0.46.1
Checking sha1-checked v0.10.0
Compiling rustix v1.1.3
Compiling pkg-config v0.3.30
Checking gix-hash v0.22.1
Checking zerofrom v0.1.6
Compiling zerovec-derive v0.10.3
Checking yoke v0.7.5
Checking linux-raw-sys v0.11.0
Compiling displaydoc v0.2.5
Checking block-padding v0.3.3
Checking once_cell v1.21.3
Checking erased-serde v0.4.6
Checking serde_fmt v1.0.3
Checking zerovec v0.10.4
Checking inout v0.1.3
Compiling syn v1.0.109
Checking value-bag-serde1 v1.11.1
Checking value-bag v1.11.1
Checking cipher v0.4.4
Checking log v0.4.27
Checking writeable v0.5.5
Checking litemap v0.7.5
Checking tinystr v0.7.6
Compiling icu_locid_transform_data v1.5.1
Checking icu_locid v1.5.0
Compiling icu_provider_macros v1.5.0
Checking percent-encoding v2.3.1
Compiling icu_properties_data v1.5.1
Checking icu_provider v1.5.0
Compiling icu_normalizer_data v1.5.1
Compiling thiserror v1.0.69
Checking icu_locid_transform v1.5.0
Checking icu_collections v1.5.0
Compiling thiserror-impl v1.0.69
Checking hashbrown v0.14.3
Checking equivalent v1.0.1
Compiling serde_json v1.0.140
Checking indexmap v2.2.6
Checking icu_properties v1.5.1
Checking sha2 v0.10.8
Checking utf16_iter v1.0.5
Compiling ref-cast v1.0.24
Checking write16 v1.0.0
Compiling vcpkg v0.2.15
Checking utf8_iter v1.0.4
Checking ryu v1.0.17
Compiling libz-sys v1.1.16
Checking tempfile v3.25.0
Compiling ref-cast-impl v1.0.24
Checking universal-hash v0.5.1
Checking icu_normalizer v1.5.0
Checking opaque-debug v0.3.1
Compiling autocfg v1.2.0
Checking dyn-clone v1.0.17
Compiling amplify_syn v2.0.1
Compiling num-traits v0.2.19
Checking idna_adapter v1.2.0
Compiling libgit2-sys v0.18.3+1.9.2
Checking signature v1.6.4
Checking idna v1.0.3
Checking ed25519 v1.5.3
Checking form_urlencoded v1.2.1
Compiling serde_derive_internals v0.29.1
Checking aead v0.5.2
Checking amplify_num v0.5.2
Compiling amplify_derive v4.0.0
Checking ct-codecs v1.1.1
Checking ascii v1.1.0
Checking ec25519 v0.1.0
Compiling schemars_derive v1.0.4
Checking url v2.5.4
Checking amplify v4.6.0
Checking git-ref-format-core v0.6.0
Checking poly1305 v0.8.0
Checking chacha20 v0.9.1
Checking cyphergraphy v0.3.0
Checking polyval v0.6.2
Checking schemars v1.0.4
Compiling sqlite3-src v0.5.1
Checking hmac v0.12.1
Checking base64ct v1.6.0
Checking keccak v0.1.6
Checking sha3 v0.10.8
Checking pem-rfc7468 v0.7.0
Checking pbkdf2 v0.12.2
Checking ghash v0.5.1
Checking ctr v0.9.2
Checking aes v0.8.4
Checking rand v0.8.5
Checking base32 v0.4.0
Compiling data-encoding v2.5.0
Checking qcheck v1.0.0
Checking cypheraddr v0.4.0
Compiling data-encoding-macro-internal v0.1.12
Checking aes-gcm v0.10.3
Checking ssh-encoding v0.2.0
Checking chacha20poly1305 v0.10.1
Checking cbc v0.1.2
Checking blowfish v0.9.1
Checking jiff v0.2.20
Checking data-encoding-macro v0.1.14
Checking bcrypt-pbkdf v0.10.0
Checking ssh-cipher v0.2.0
Checking noise-framework v0.4.0
Checking socks5-client v0.4.1
Checking base-x v0.2.11
Checking signature v2.2.0
Compiling crossbeam-utils v0.8.19
Checking ssh-key v0.6.6
Checking multibase v0.9.1
Checking cyphernet v0.5.2
Checking radicle-ssh v0.10.0 (/addda884-6bf0-4e3d-a1c0-ac9e67000027/w/crates/radicle-ssh)
Checking winnow v0.7.14
Checking crossbeam-channel v0.5.15
Checking hashbrown v0.16.1
Checking lazy_static v1.5.0
Checking gix-hashtable v0.12.0
Checking nonempty v0.9.0
Checking anstyle-query v1.0.2
Checking siphasher v1.0.1
Checking radicle-git-metadata v0.1.0 (/addda884-6bf0-4e3d-a1c0-ac9e67000027/w/crates/radicle-git-metadata)
Checking gix-error v0.1.0
Checking radicle-dag v0.10.0 (/addda884-6bf0-4e3d-a1c0-ac9e67000027/w/crates/radicle-dag)
Checking memmap2 v0.9.8
Checking utf8parse v0.2.2
Checking radicle-git-ref-format v0.1.0 (/addda884-6bf0-4e3d-a1c0-ac9e67000027/w/crates/radicle-git-ref-format)
Checking anstyle-parse v0.2.3
Checking iana-time-zone v0.1.60
Checking anstyle v1.0.13
Checking is_terminal_polyfill v1.70.2
Checking base64 v0.21.7
Checking colorchoice v1.0.0
Checking anstream v0.6.21
Checking chrono v0.4.38
Checking colored v2.1.0
Checking radicle-localtime v0.1.0 (/addda884-6bf0-4e3d-a1c0-ac9e67000027/w/crates/radicle-localtime)
Checking serde-untagged v0.1.7
Checking bytesize v2.0.1
Checking gix-error v0.0.0
Checking tree-sitter-language v0.1.2
Checking dunce v1.0.5
Checking fast-glob v0.3.3
Checking gix-date v0.14.0
Checking gix-date v0.13.0
Checking gix-actor v0.39.0
Checking gix-fs v0.19.1
Checking gix-object v0.56.0
Checking gix-tempfile v21.0.1
Checking gix-actor v0.38.0
Checking gix-chunk v0.6.0
Checking mio v1.0.4
Checking gix-quote v0.6.2
Checking gix-commitgraph v0.33.0
Checking gix-object v0.55.0
Checking gix-chunk v0.5.0
Checking 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.7.1
Checking signals_receipts v0.2.0
Checking gix-commitgraph v0.32.0
Checking gix-revwalk v0.27.0
Compiling signal-hook v0.3.18
Compiling object v0.37.3
Compiling rustversion v1.0.20
Checking gix-revwalk v0.26.0
Checking gix-lock v21.0.1
Checking gix-url v0.35.1
Checking gix-config-value v0.17.1
Checking gix-sec v0.13.1
Checking signal-hook-registry v1.4.5
Checking adler2 v2.0.0
Checking gimli v0.32.3
Compiling rustix v0.38.34
Checking miniz_oxide v0.8.8
Checking gix-prompt v0.13.1
Checking gix-traverse v0.52.0
Checking addr2line v0.25.1
Checking gix-revision v0.41.0
Checking radicle-signals v0.11.0 (/addda884-6bf0-4e3d-a1c0-ac9e67000027/w/crates/radicle-signals)
Checking gix-diff v0.58.0
Checking mio v0.8.11
Checking gix-glob v0.24.0
Checking gix-packetline v0.21.1
Compiling tree-sitter v0.24.4
Compiling unicode-segmentation v1.11.0
Checking rustc-demangle v0.1.26
Compiling linux-raw-sys v0.4.13
Compiling anyhow v1.0.82
Checking backtrace v0.3.76
Compiling convert_case v0.7.1
Checking gix-transport v0.54.0
Checking gix-refspec v0.37.0
Checking signal-hook-mio v0.2.4
Checking gix-pack v0.65.0
Checking arc-swap v1.8.2
Checking gix-credentials v0.36.0
Checking gix-shallow v0.8.1
Checking gix-ref v0.59.0
Checking gix-negotiate v0.27.0
Compiling maybe-async v0.2.10
Checking regex v1.11.1
Compiling proc-macro-error-attr2 v2.0.0
Compiling portable-atomic v1.11.0
Compiling proc-macro-error2 v2.0.1
Checking gix-protocol v0.57.0
Checking gix-odb v0.75.0
Compiling xattr v1.3.1
Compiling derive_more-impl v2.0.1
Compiling filetime v0.2.23
Checking uuid v1.20.0
Compiling litrs v0.4.1
Checking bytes v1.11.1
Checking bitflags v1.3.2
Checking unicode-width v0.2.1
Checking crossterm v0.25.0
Checking console v0.16.0
Compiling document-features v0.2.11
Checking derive_more v2.0.1
Compiling flate2 v1.1.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 strsim v0.11.1
Checking unit-prefix v0.5.1
Checking unicode-width v0.1.11
Compiling heck v0.5.0
Checking streaming-iterator v0.1.9
Checking similar v2.5.0
Checking normalize-line-endings v0.3.0
Checking siphasher v0.3.11
Checking clap_lex v0.7.5
Checking snapbox v0.4.17
Checking clap_builder v4.5.44
Checking sqlite3-sys v0.15.2
Checking sqlite v0.32.0
Checking bloomy v1.2.0
Checking radicle-crypto v0.15.0 (/addda884-6bf0-4e3d-a1c0-ac9e67000027/w/crates/radicle-crypto)
Compiling clap_derive v4.5.41
Checking inquire v0.7.5
Checking indicatif v0.18.0
Compiling radicle-surf v0.27.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 toml_datetime v0.7.5+spec-1.1.0
Checking serde_spanned v1.0.4
Compiling tree-sitter-md v0.3.2
Compiling tree-sitter-c v0.23.2
Compiling tree-sitter-go v0.23.4
Compiling tree-sitter-rust v0.23.2
Compiling tree-sitter-json v0.24.8
Compiling tree-sitter-toml-ng v0.6.0
Compiling tree-sitter-ruby v0.23.1
Compiling tree-sitter-python v0.23.4
Compiling tree-sitter-html v0.23.2
Compiling tree-sitter-css v0.23.1
Compiling tree-sitter-typescript v0.23.2
Compiling tree-sitter-bash v0.23.3
Checking pin-project-lite v0.2.16
Checking toml_writer v1.0.6+spec-1.1.0
Checking radicle-std-ext v0.2.0
Checking tokio v1.47.1
Checking toml v0.9.12+spec-1.1.0
Checking clap v4.5.44
Checking sysinfo v0.37.2
Checking yansi v0.5.1
Compiling radicle-node v0.17.0 (/addda884-6bf0-4e3d-a1c0-ac9e67000027/w/crates/radicle-node)
Compiling radicle-cli v0.18.0 (/addda884-6bf0-4e3d-a1c0-ac9e67000027/w/crates/radicle-cli)
Checking diff v0.1.13
Checking pretty_assertions v1.4.0
Checking human-panic v2.0.6
Checking clap_complete v4.5.60
Checking structured-logger v1.0.4
Checking radicle-systemd v0.12.0 (/addda884-6bf0-4e3d-a1c0-ac9e67000027/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 zerocopy v0.7.35
Checking borrow-or-share v0.2.2
Checking fluent-uri v0.3.2
Checking num-rational v0.4.2
Checking env_logger v0.11.8
Checking phf_shared v0.11.3
Checking num v0.4.3
Compiling test-log-macros v0.2.19
Checking wait-timeout v0.2.1
Compiling radicle-remote-helper v0.14.0 (/addda884-6bf0-4e3d-a1c0-ac9e67000027/w/crates/radicle-remote-helper)
Checking outref v0.5.2
Checking fnv v1.0.7
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 test-log v0.2.19
Checking rusty-fork v0.3.1
Checking fraction v0.15.3
Checking phf v0.11.3
Checking referencing v0.30.0
Checking rand_xorshift v0.4.0
Checking rand v0.9.2
Checking fancy-regex v0.14.0
Checking email_address v0.2.9
Checking unarray v0.1.4
Checking base64 v0.22.1
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 radicle-windows v0.1.0 (/addda884-6bf0-4e3d-a1c0-ac9e67000027/w/crates/radicle-windows)
Checking git2 v0.20.4
Checking radicle-oid v0.1.0 (/addda884-6bf0-4e3d-a1c0-ac9e67000027/w/crates/radicle-oid)
Checking radicle-git-ext v0.12.0
Checking radicle-term v0.17.0 (/addda884-6bf0-4e3d-a1c0-ac9e67000027/w/crates/radicle-term)
Checking radicle-cob v0.18.0 (/addda884-6bf0-4e3d-a1c0-ac9e67000027/w/crates/radicle-cob)
Checking radicle-core v0.1.0 (/addda884-6bf0-4e3d-a1c0-ac9e67000027/w/crates/radicle-core)
Checking radicle v0.21.0 (/addda884-6bf0-4e3d-a1c0-ac9e67000027/w/crates/radicle)
Checking radicle-fetch v0.17.0 (/addda884-6bf0-4e3d-a1c0-ac9e67000027/w/crates/radicle-fetch)
Checking radicle-cli-test v0.13.0 (/addda884-6bf0-4e3d-a1c0-ac9e67000027/w/crates/radicle-cli-test)
error: used `unwrap()` on a `Result` value
--> crates/radicle/src/node/config/sqlite.rs:151:34
|
151 | let config: Config = serde_json::from_value(config).unwrap();
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
= note: if this value is an `Err`, it will panic
= help: consider using `expect()` to provide a better panic message
= help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unwrap_used
= note: `-D clippy::unwrap-used` implied by `-D warnings`
= help: to override `-D warnings` add `#[allow(clippy::unwrap_used)]`
Checking radicle-protocol v0.5.0 (/addda884-6bf0-4e3d-a1c0-ac9e67000027/w/crates/radicle-protocol)
error: could not compile `radicle` (lib test) due to 1 previous error
warning: build failed, waiting for other jobs to finish...
Exit code: 101
{
"response": "finished",
"result": "failure"
}