From 12756f1b8c67fdae93053c235c9e00486799199a Mon Sep 17 00:00:00 2001 From: Sebastian Holmin Date: Tue, 7 Jan 2025 12:07:00 +0100 Subject: [PATCH 1/2] Do not truncate `settings.json` --- test/test-runner/src/logging.rs | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) diff --git a/test/test-runner/src/logging.rs b/test/test-runner/src/logging.rs index 2fb893900278..efee58d52f21 100644 --- a/test/test-runner/src/logging.rs +++ b/test/test-runner/src/logging.rs @@ -78,7 +78,7 @@ async fn read_settings_file() -> Result { let mut settings_path = mullvad_paths::get_default_settings_dir() .map_err(|error| Error::Logs(format!("{}", error)))?; settings_path.push("settings.json"); - read_truncated(&settings_path) + read_truncated(&settings_path, None) .await .map_err(|error| Error::Logs(format!("{}: {}", settings_path.display(), error))) } @@ -91,7 +91,7 @@ async fn read_log_files() -> Result>, Error> { .map_err(|error| Error::Logs(format!("{}", error)))?; let mut log_files = Vec::new(); for path in paths { - let log_file = read_truncated(&path) + let log_file = read_truncated(&path, Some(TRUNCATE_LOG_FILE_LINES)) .await .map_err(|error| Error::Logs(format!("{}: {}", path.display(), error))) .map(|content| LogFile { @@ -123,17 +123,18 @@ async fn list_logs>(log_dir: T) -> Result, Error> { Ok(paths) } -async fn read_truncated>(path: T) -> io::Result { +async fn read_truncated>( + path: T, + truncate_lines: Option, +) -> io::Result { let mut output = vec![]; let reader = BufReader::new(File::open(path).await?); let mut lines = reader.lines(); while let Some(line) = lines.next_line().await? { output.push(line); } - if output.len() > TRUNCATE_LOG_FILE_LINES { - let drop_count = output.len() - TRUNCATE_LOG_FILE_LINES; - // not the most efficient - output.drain(0..drop_count); + if let Some(max_number_of_lines) = truncate_lines { + output.truncate(max_number_of_lines); } Ok(output.join("\n")) } From a88510aca8c2b45abb4e13443b31cd1944dc0d4a Mon Sep 17 00:00:00 2001 From: Sebastian Holmin Date: Tue, 7 Jan 2025 13:41:43 +0100 Subject: [PATCH 2/2] Add doc-string --- test/test-runner/src/logging.rs | 1 + 1 file changed, 1 insertion(+) diff --git a/test/test-runner/src/logging.rs b/test/test-runner/src/logging.rs index efee58d52f21..706ff2eed3ce 100644 --- a/test/test-runner/src/logging.rs +++ b/test/test-runner/src/logging.rs @@ -123,6 +123,7 @@ async fn list_logs>(log_dir: T) -> Result, Error> { Ok(paths) } +/// Read the contents of a file to string, optionally truncating the result by given amount of lines. async fn read_truncated>( path: T, truncate_lines: Option,