Skip to content

Commit

Permalink
Improve OpenBSD -CURRENT detection and Dry-run feedback
Browse files Browse the repository at this point in the history
This commit improves the -CURRENT detection by way of parsing /etc/motd
This change is more future-proof as when OpenBSD nears a stable release,
`uname` will temporarily report like -STABLE.

This commit *also* adds feedback if -CURRENT is found to make debugging
this feature easier with --dry-run, or, just a regular run as well.
  • Loading branch information
Izder456 committed Oct 16, 2024
1 parent a5df40e commit 44edea6
Showing 1 changed file with 21 additions and 4 deletions.
25 changes: 21 additions & 4 deletions src/steps/os/openbsd.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,30 +4,42 @@ use crate::terminal::print_separator;
use crate::utils::{get_require_sudo_string, require_option};
use color_eyre::eyre::Result;
use rust_i18n::t;
use std::fs;

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 motd_content = fs::read_to_string("/etc/motd")?;
let is_current = motd_content.contains("-current");

let version = String::from_utf8_lossy(&output.stdout);
Ok(version.trim().ends_with("-current"))
if is_current {
println!("OpenBSD system is running -current");
} else {
println!("OpenBSD system is not running -current");
}

Ok(is_current)
}
}

pub fn upgrade_openbsd(ctx: &ExecutionContext) -> Result<()> {
let sudo = require_option(ctx.sudo().as_ref(), get_require_sudo_string())?;
print_separator(t!("OpenBSD Update"));

let is_current = is_openbsd_current(ctx)?;

if ctx.config().dry_run() {
println!("Would update the OpenBSD system");
if is_current {
println!("Would use -s flag when upgrading system");
}
return Ok(());
}

let mut args = vec!["/usr/sbin/sysupgrade", "-n"];
if is_openbsd_current(ctx)? {
if is_current {
args.push("-s");
}

Expand All @@ -38,8 +50,13 @@ pub fn upgrade_packages(ctx: &ExecutionContext) -> Result<()> {
let sudo = require_option(ctx.sudo().as_ref(), get_require_sudo_string())?;
print_separator(t!("OpenBSD Packages"));

let is_current = is_openbsd_current(ctx)?;

if ctx.config().dry_run() {
println!("Would update OpenBSD packages");
if is_current {
println!("Would use -Dsnap flag when upgrading packages");
}
return Ok(());
}

Expand Down

0 comments on commit 44edea6

Please sign in to comment.