#![deny(warnings, clippy::all)]
use std::env::VarError;
use std::process::Command;
use log::{info, LevelFilter};
use similar_asserts::assert_eq;
mod journal;
fn main() {
let env_name = "_TEST_LOG_TARGET";
let use_system_instance = std::env::var_os("GITHUB_ACTIONS").is_some();
match std::env::var(env_name) {
Ok(target) => {
use systemd_journal_logger::*;
JournalLog::new().unwrap().install().unwrap();
log::set_max_level(LevelFilter::Debug);
info!(
target: &target,
"connected_to_journal() -> {}",
connected_to_journal()
);
}
Err(VarError::NotUnicode(value)) => {
panic!("Value of ${} not unicode: {:?}", env_name, value);
}
Err(VarError::NotPresent) => {
let target = format!("journal_stream_{}", std::process::id());
let exe = std::env::current_exe().unwrap();
let status = if use_system_instance {
let mut cmd = Command::new("sudo");
cmd.arg("systemd-run");
cmd
} else {
let mut cmd = Command::new("systemd-run");
cmd.arg("--user");
cmd
}
.arg("--description=systemd-journal-logger integration test: journal_stream")
.arg(format!("--setenv={}={}", env_name, &target))
.arg("--wait")
.arg("--collect")
.arg(exe)
.status()
.unwrap();
assert!(status.success());
let journal = if use_system_instance {
journal::Journal::System
} else {
journal::Journal::User
};
let entries = journal::read(
journal,
vec![
format!("CODE_MODULE={}", module_path!()),
format!("TARGET={}", &target),
],
);
assert_eq!(entries.len(), 1);
assert_eq!(entries[0]["TARGET"], &target);
assert_eq!(entries[0]["MESSAGE"], "connected_to_journal() -> true");
}
}
}