[FIXES #922] properly check for -CURRENT in OpenBSD steps and pass the correct flags to the respective commands (#923)

* [FIXES #922] properly check for -CURRENT in openbsd steps and pass the correct flags

* un-break ctx.config().dry_run() on OpenBSD Step
This commit is contained in:
λP.(P izzy)
2024-10-13 19:29:51 -05:00
committed by GitHub
parent c36da89933
commit 8a7af2e14d

View File

@@ -3,20 +3,46 @@ use crate::execution_context::ExecutionContext;
use crate::terminal::print_separator; use crate::terminal::print_separator;
use crate::utils::{get_require_sudo_string, require_option}; use crate::utils::{get_require_sudo_string, require_option};
use color_eyre::eyre::Result; use color_eyre::eyre::Result;
use rust_i18n::t;
fn is_openbsd_current(ctx: &ExecutionContext) -> Result<bool> {
if ctx.config().dry_run() {
println!("Would check if OpenBSD is -current");
Ok(false) // Default to false for dry-run
} else {
let output = ctx.run_type().execute("uname").arg("-r").output_checked()?;
let version = String::from_utf8_lossy(&output.stdout);
Ok(version.trim().ends_with("-current"))
}
}
pub fn upgrade_openbsd(ctx: &ExecutionContext) -> Result<()> { pub fn upgrade_openbsd(ctx: &ExecutionContext) -> Result<()> {
let sudo = require_option(ctx.sudo().as_ref(), get_require_sudo_string())?; let sudo = require_option(ctx.sudo().as_ref(), get_require_sudo_string())?;
print_separator(t!("OpenBSD Update")); print_separator(t!("OpenBSD Update"));
ctx.run_type()
.execute(sudo) if ctx.config().dry_run() {
.args(["/usr/sbin/sysupgrade", "-n"]) println!("Would update the OpenBSD system");
.status_checked() return Ok(());
}
let mut args = vec!["/usr/sbin/sysupgrade", "-n"];
if is_openbsd_current(ctx)? {
args.push("-s");
}
ctx.run_type().execute(sudo).args(&args).status_checked()
} }
pub fn upgrade_packages(ctx: &ExecutionContext) -> Result<()> { pub fn upgrade_packages(ctx: &ExecutionContext) -> Result<()> {
let sudo = require_option(ctx.sudo().as_ref(), get_require_sudo_string())?; let sudo = require_option(ctx.sudo().as_ref(), get_require_sudo_string())?;
print_separator(t!("OpenBSD Packages")); print_separator(t!("OpenBSD Packages"));
if ctx.config().dry_run() {
println!("Would update OpenBSD packages");
return Ok(());
}
if ctx.config().cleanup() { if ctx.config().cleanup() {
ctx.run_type() ctx.run_type()
.execute(sudo) .execute(sudo)
@@ -24,10 +50,12 @@ pub fn upgrade_packages(ctx: &ExecutionContext) -> Result<()> {
.status_checked()?; .status_checked()?;
} }
ctx.run_type() let mut args = vec!["/usr/sbin/pkg_add", "-u"];
.execute(sudo) if is_openbsd_current(ctx)? {
.args(["/usr/sbin/pkg_add", "-u"]) args.push("-Dsnap");
.status_checked()?; }
ctx.run_type().execute(sudo).args(&args).status_checked()?;
Ok(()) Ok(())
} }