diff options
author | Evan Benn <evanbenn@chromium.org> | 2022-11-07 16:48:14 +1100 |
---|---|---|
committer | Edward O'Callaghan <quasisec@chromium.org> | 2022-11-17 04:28:20 +0000 |
commit | 4df64d93a063ddbfbf9d05f7059fe8386385132a (patch) | |
tree | 5cd0add9eef87af488bdff5079acfd5ee0466560 /util/flashrom_tester/src/logger.rs | |
parent | 065366dd278d5a2e220c9aa2667296580d414cab (diff) | |
download | flashrom-4df64d93a063ddbfbf9d05f7059fe8386385132a.tar.gz flashrom-4df64d93a063ddbfbf9d05f7059fe8386385132a.tar.bz2 flashrom-4df64d93a063ddbfbf9d05f7059fe8386385132a.zip |
flashrom_tester: Only print color when stdout isatty
Add the atty crate as a dependency. Print log and report in color only
when isatty is true.
BUG=b:246250254
BRANCH=None
TEST=ssh dut flashrom_tester # no color
TEST=ssh -t dut flashrom_tester # color
Change-Id: Ia3cc527fb98e53eda6773622340cf10764df2cba
Signed-off-by: Evan Benn <evanbenn@chromium.org>
Reviewed-on: https://review.coreboot.org/c/flashrom/+/69270
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Angel Pons <th3fanbus@gmail.com>
Reviewed-by: Edward O'Callaghan <quasisec@chromium.org>
Diffstat (limited to 'util/flashrom_tester/src/logger.rs')
-rw-r--r-- | util/flashrom_tester/src/logger.rs | 29 |
1 files changed, 18 insertions, 11 deletions
diff --git a/util/flashrom_tester/src/logger.rs b/util/flashrom_tester/src/logger.rs index 3c9b74b4..fb26bde4 100644 --- a/util/flashrom_tester/src/logger.rs +++ b/util/flashrom_tester/src/logger.rs @@ -41,6 +41,7 @@ use std::sync::Mutex; struct Logger<W: Write + Send> { level: log::LevelFilter, target: LogTarget<W>, + color: types::Color, } enum LogTarget<W> @@ -57,16 +58,14 @@ impl<W: Write + Send> log::Log for Logger<W> { } fn log(&self, record: &log::Record) { - fn log_internal<W: Write>(mut w: W, record: &log::Record) -> std::io::Result<()> { + 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, "{}{} ", types::MAGENTA, now)?; - write!( - w, - "{}[ {} ]{} ", - types::YELLOW, - record.level(), - types::RESET - )?; + write!(w, "{}{} ", color.magenta, now)?; + write!(w, "{}[ {} ]{} ", color.yellow, record.level(), color.reset)?; writeln!(w, "{}", record.args()) } @@ -75,11 +74,11 @@ impl<W: Write + Send> log::Log for Logger<W> { LogTarget::Terminal => { let stdout = std::io::stdout(); let mut lock = stdout.lock(); - log_internal(&mut lock, record) + log_internal(&mut lock, record, &self.color) } LogTarget::Write(ref mutex) => { let mut lock = mutex.lock().unwrap(); - log_internal(&mut *lock, record) + log_internal(&mut *lock, record, &self.color) } }; } @@ -97,6 +96,11 @@ pub fn init(to_file: Option<PathBuf>, debug: bool) { let mut logger = Logger { level: log::LevelFilter::Info, target: LogTarget::Terminal, + color: if atty::is(atty::Stream::Stdout) { + types::COLOR + } else { + types::NOCOLOR + }, }; if debug { @@ -106,6 +110,7 @@ pub fn init(to_file: Option<PathBuf>, debug: bool) { 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); @@ -115,6 +120,7 @@ pub fn init(to_file: Option<PathBuf>, debug: bool) { #[cfg(test)] mod tests { use super::{LogTarget, Logger}; + use flashrom_tester::types; use log::{Level, LevelFilter, Log, Record}; use std::sync::Mutex; @@ -125,6 +131,7 @@ mod tests { let logger = Logger { level: LevelFilter::Info, target: LogTarget::Write(lock), + color: types::COLOR, }; for record in records { |