mirror of
https://review.coreboot.org/flashrom.git
synced 2025-04-27 23:22:37 +02:00
flashrom_tester: Remove --output log redirect option
Always print logs to stdout. User can redirect logs in the normal way if they wish. BUG=b:194245688 BRANCH=None TEST=clippy, unit Change-Id: I5eab8169644a16ba31b203e8607853c459f92978 Signed-off-by: Evan Benn <evanbenn@chromium.org> Reviewed-on: https://review.coreboot.org/c/flashrom/+/71773 Reviewed-by: Nikolai Artemiev <nartemiev@google.com> Reviewed-by: Peter Marheine <pmarheine@chromium.org> Reviewed-by: Edward O'Callaghan <quasisec@chromium.org> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
parent
06bcc26b1d
commit
eab04615ee
2
util/flashrom_tester/.cargo/config.toml
Normal file
2
util/flashrom_tester/.cargo/config.toml
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
[env]
|
||||||
|
RUST_TEST_THREADS = "1"
|
@ -30,6 +30,9 @@ sys-info = "0.9"
|
|||||||
[build-dependencies]
|
[build-dependencies]
|
||||||
built = { version = "0.5", features = ["chrono"] }
|
built = { version = "0.5", features = ["chrono"] }
|
||||||
|
|
||||||
|
[dev-dependencies]
|
||||||
|
gag = "1"
|
||||||
|
|
||||||
[features]
|
[features]
|
||||||
# Features required to build the CLI binary but not the library
|
# Features required to build the CLI binary but not the library
|
||||||
cli = ["chrono", "clap"]
|
cli = ["chrono", "clap"]
|
||||||
|
@ -35,67 +35,42 @@
|
|||||||
|
|
||||||
use flashrom_tester::types;
|
use flashrom_tester::types;
|
||||||
use std::io::Write;
|
use std::io::Write;
|
||||||
use std::path::PathBuf;
|
|
||||||
use std::sync::Mutex;
|
|
||||||
|
|
||||||
struct Logger<W: Write + Send> {
|
struct Logger {
|
||||||
level: log::LevelFilter,
|
level: log::LevelFilter,
|
||||||
target: LogTarget<W>,
|
|
||||||
color: types::Color,
|
color: types::Color,
|
||||||
}
|
}
|
||||||
|
|
||||||
enum LogTarget<W>
|
impl log::Log for Logger {
|
||||||
where
|
|
||||||
W: Write,
|
|
||||||
{
|
|
||||||
Terminal,
|
|
||||||
Write(Mutex<W>),
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<W: Write + Send> log::Log for Logger<W> {
|
|
||||||
fn enabled(&self, metadata: &log::Metadata) -> bool {
|
fn enabled(&self, metadata: &log::Metadata) -> bool {
|
||||||
metadata.level() <= self.level
|
metadata.level() <= self.level
|
||||||
}
|
}
|
||||||
|
|
||||||
fn log(&self, record: &log::Record) {
|
fn log(&self, record: &log::Record) {
|
||||||
fn log_internal<W: Write>(
|
|
||||||
mut w: W,
|
|
||||||
record: &log::Record,
|
|
||||||
color: &types::Color,
|
|
||||||
) -> std::io::Result<()> {
|
|
||||||
let now = chrono::Utc::now().to_rfc3339_opts(chrono::SecondsFormat::Micros, true);
|
|
||||||
write!(w, "{}{} ", color.magenta, now)?;
|
|
||||||
write!(w, "{}[ {} ]{} ", color.yellow, record.level(), color.reset)?;
|
|
||||||
writeln!(w, "{}", record.args())
|
|
||||||
}
|
|
||||||
|
|
||||||
// Write errors deliberately ignored
|
// Write errors deliberately ignored
|
||||||
let _ = match self.target {
|
|
||||||
LogTarget::Terminal => {
|
|
||||||
let stdout = std::io::stdout();
|
let stdout = std::io::stdout();
|
||||||
let mut lock = stdout.lock();
|
let mut lock = stdout.lock();
|
||||||
log_internal(&mut lock, record, &self.color)
|
let now = chrono::Utc::now().to_rfc3339_opts(chrono::SecondsFormat::Micros, true);
|
||||||
}
|
let _ = write!(lock, "{}{} ", self.color.magenta, now);
|
||||||
LogTarget::Write(ref mutex) => {
|
let _ = write!(
|
||||||
let mut lock = mutex.lock().unwrap();
|
lock,
|
||||||
log_internal(&mut *lock, record, &self.color)
|
"{}[ {} ]{} ",
|
||||||
}
|
self.color.yellow,
|
||||||
};
|
record.level(),
|
||||||
|
self.color.reset
|
||||||
|
);
|
||||||
|
let _ = writeln!(lock, "{}", record.args());
|
||||||
}
|
}
|
||||||
|
|
||||||
fn flush(&self) {
|
fn flush(&self) {
|
||||||
// Flush errors deliberately ignored
|
// Flush errors deliberately ignored
|
||||||
let _ = match self.target {
|
let _ = std::io::stdout().flush();
|
||||||
LogTarget::Terminal => std::io::stdout().flush(),
|
|
||||||
LogTarget::Write(ref w) => w.lock().unwrap().flush(),
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn init(to_file: Option<PathBuf>, debug: bool) {
|
pub fn init(debug: bool) {
|
||||||
let mut logger = Logger {
|
let mut logger = Logger {
|
||||||
level: log::LevelFilter::Info,
|
level: log::LevelFilter::Info,
|
||||||
target: LogTarget::Terminal,
|
|
||||||
color: if atty::is(atty::Stream::Stdout) {
|
color: if atty::is(atty::Stream::Stdout) {
|
||||||
types::COLOR
|
types::COLOR
|
||||||
} else {
|
} else {
|
||||||
@ -106,31 +81,23 @@ pub fn init(to_file: Option<PathBuf>, debug: bool) {
|
|||||||
if debug {
|
if debug {
|
||||||
logger.level = log::LevelFilter::Debug;
|
logger.level = log::LevelFilter::Debug;
|
||||||
}
|
}
|
||||||
if let Some(path) = to_file {
|
|
||||||
logger.target = LogTarget::Write(Mutex::new(
|
|
||||||
std::fs::File::create(path).expect("Unable to open log file for writing"),
|
|
||||||
));
|
|
||||||
logger.color = types::NOCOLOR;
|
|
||||||
}
|
|
||||||
|
|
||||||
log::set_max_level(logger.level);
|
log::set_max_level(logger.level);
|
||||||
log::set_boxed_logger(Box::new(logger)).unwrap();
|
log::set_boxed_logger(Box::new(logger)).unwrap();
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
use super::{LogTarget, Logger};
|
use std::io::Read;
|
||||||
|
|
||||||
|
use super::Logger;
|
||||||
use flashrom_tester::types;
|
use flashrom_tester::types;
|
||||||
use log::{Level, LevelFilter, Log, Record};
|
use log::{Level, LevelFilter, Log, Record};
|
||||||
use std::sync::Mutex;
|
|
||||||
|
|
||||||
fn run_records(records: &[Record]) -> String {
|
fn run_records(records: &[Record]) -> String {
|
||||||
let mut buf = Vec::<u8>::new();
|
let buf = gag::BufferRedirect::stdout().unwrap();
|
||||||
{
|
{
|
||||||
let lock = Mutex::new(&mut buf);
|
|
||||||
let logger = Logger {
|
let logger = Logger {
|
||||||
level: LevelFilter::Info,
|
level: LevelFilter::Info,
|
||||||
target: LogTarget::Write(lock),
|
|
||||||
color: types::COLOR,
|
color: types::COLOR,
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -140,7 +107,9 @@ mod tests {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
String::from_utf8(buf).unwrap()
|
let mut ret = String::new();
|
||||||
|
buf.into_inner().read_to_string(&mut ret).unwrap();
|
||||||
|
ret
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Log messages have the expected format
|
/// Log messages have the expected format
|
||||||
|
@ -41,7 +41,6 @@ mod logger;
|
|||||||
use clap::{App, Arg};
|
use clap::{App, Arg};
|
||||||
use flashrom::{FlashChip, Flashrom, FlashromCmd, FlashromLib};
|
use flashrom::{FlashChip, Flashrom, FlashromCmd, FlashromLib};
|
||||||
use flashrom_tester::{tester, tests};
|
use flashrom_tester::{tester, tests};
|
||||||
use std::path::PathBuf;
|
|
||||||
use std::sync::atomic::AtomicBool;
|
use std::sync::atomic::AtomicBool;
|
||||||
|
|
||||||
pub mod built_info {
|
pub mod built_info {
|
||||||
@ -91,13 +90,6 @@ fn main() {
|
|||||||
.long("print-layout")
|
.long("print-layout")
|
||||||
.help("Print the layout file's contents before running tests"),
|
.help("Print the layout file's contents before running tests"),
|
||||||
)
|
)
|
||||||
.arg(
|
|
||||||
Arg::with_name("log-file")
|
|
||||||
.short("o")
|
|
||||||
.long("log-file")
|
|
||||||
.takes_value(true)
|
|
||||||
.help("Write logs to a file rather than stdout"),
|
|
||||||
)
|
|
||||||
.arg(
|
.arg(
|
||||||
Arg::with_name("log_debug")
|
Arg::with_name("log_debug")
|
||||||
.short("d")
|
.short("d")
|
||||||
@ -121,10 +113,7 @@ fn main() {
|
|||||||
)
|
)
|
||||||
.get_matches();
|
.get_matches();
|
||||||
|
|
||||||
logger::init(
|
logger::init(matches.is_present("log_debug"));
|
||||||
matches.value_of_os("log-file").map(PathBuf::from),
|
|
||||||
matches.is_present("log_debug"),
|
|
||||||
);
|
|
||||||
debug!("Args parsed and logging initialized OK");
|
debug!("Args parsed and logging initialized OK");
|
||||||
|
|
||||||
debug!("Collecting crossystem info");
|
debug!("Collecting crossystem info");
|
||||||
|
Loading…
x
Reference in New Issue
Block a user