From 88b880b631c2b182786ca082c6b81a05c60bd044 Mon Sep 17 00:00:00 2001 From: Techassi Date: Fri, 7 Nov 2025 18:13:59 +0100 Subject: [PATCH 1/2] fix(boil): Set correct release version in container image metadata --- rust/boil/src/main.rs | 40 ++++++++++++++++++++++++++++++++++++++-- 1 file changed, 38 insertions(+), 2 deletions(-) diff --git a/rust/boil/src/main.rs b/rust/boil/src/main.rs index 189616ac7..4a7957455 100644 --- a/rust/boil/src/main.rs +++ b/rust/boil/src/main.rs @@ -71,8 +71,13 @@ impl VersionExt for Version { fn base_prerelease(&self) -> String { let mut base = self.base(); - base.push('-'); - base.push_str(&self.pre); + + // Well, that was a big doozy, ruined the whole release... + if !self.pre.is_empty() { + base.push('-'); + base.push_str(&self.pre); + } + base } } @@ -110,3 +115,34 @@ async fn main() -> Result<(), Error> { } } } + +#[cfg(test)] +mod tests { + use rstest::rstest; + + use super::*; + + #[rstest] + #[case("25.11.0-rc.1+arm64", "25.11.0-rc.1")] + #[case("25.11.0-rc.1", "25.11.0-rc.1")] + #[case("25.11.0-rc1", "25.11.0-rc1")] + #[case("0.0.0-dev", "0.0.0-dev")] + #[case("25.11.0", "25.11.0")] + #[case("0.0.0", "0.0.0")] + fn version_ext_base_prerelease(#[case] input: &str, #[case] expected: &str) { + let version: Version = input.parse().expect("must be a valid semantic version"); + assert_eq!(version.base_prerelease(), expected); + } + + #[rstest] + #[case("25.11.0-rc.1+arm64", "25.11.0")] + #[case("25.11.0-rc.1", "25.11.0")] + #[case("25.11.0-rc1", "25.11.0")] + #[case("0.0.0-dev", "0.0.0")] + #[case("25.11.0", "25.11.0")] + #[case("0.0.0", "0.0.0")] + fn version_ext_base(#[case] input: &str, #[case] expected: &str) { + let version: Version = input.parse().expect("must be a valid semantic version"); + assert_eq!(version.base(), expected); + } +} From 21975d4e965c631bd442fb8f3f04791324374aaf Mon Sep 17 00:00:00 2001 From: Techassi Date: Fri, 7 Nov 2025 18:19:59 +0100 Subject: [PATCH 2/2] chore: Use correct Rust toolchain for VS Code formatting --- .vscode/settings.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.vscode/settings.json b/.vscode/settings.json index b3ec3613b..a7bbec9c8 100644 --- a/.vscode/settings.json +++ b/.vscode/settings.json @@ -2,7 +2,7 @@ "rust-analyzer.rustfmt.overrideCommand": [ "rustfmt", // Keep in sync with across other repos like operator-rs and operator-templating - "+nightly-2025-05-26", + "+nightly-2025-10-23", "--edition", "2024", "--"