1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-08 15:19:40 -05:00

fix(cli/bench): skip strace table border (#16310)

It crashes due to the table border output from `strace`,

```
% time     seconds  usecs/call     calls    errors syscall
------ ----------- ----------- --------- --------- ---------------- # this is skipped correctly
 61.27    6.012053         678      8860       637 futex
   0.00    0.000000           0         4           geteuid
------ ----------- ----------- --------- --------- ----------------  # this causes the crash
100.00   11.732230                 25552      1205 total

```

It's flaky because that line is not always skipped from the output, for
some reason that I've yet to find out.
This commit is contained in:
Marcos Casagrande 2022-10-16 21:37:42 +02:00 committed by GitHub
parent cf1be5e76f
commit 9fe508dfb9
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -2198,9 +2198,12 @@ pub fn parse_strace_output(output: &str) -> HashMap<String, StraceOutput> {
// Filter out non-relevant lines. See the error log at // Filter out non-relevant lines. See the error log at
// https://github.com/denoland/deno/pull/3715/checks?check_run_id=397365887 // https://github.com/denoland/deno/pull/3715/checks?check_run_id=397365887
// This is checked in testdata/strace_summary2.out // This is checked in testdata/strace_summary2.out
let mut lines = output let mut lines = output.lines().filter(|line| {
.lines() !line.is_empty()
.filter(|line| !line.is_empty() && !line.contains("detached ...")); && !line.contains("detached ...")
&& !line.contains("unfinished ...")
&& !line.contains("????")
});
let count = lines.clone().count(); let count = lines.clone().count();
if count < 4 { if count < 4 {
@ -2215,7 +2218,6 @@ pub fn parse_strace_output(output: &str) -> HashMap<String, StraceOutput> {
let syscall_fields = line.split_whitespace().collect::<Vec<_>>(); let syscall_fields = line.split_whitespace().collect::<Vec<_>>();
let len = syscall_fields.len(); let len = syscall_fields.len();
let syscall_name = syscall_fields.last().unwrap(); let syscall_name = syscall_fields.last().unwrap();
if (5..=6).contains(&len) { if (5..=6).contains(&len) {
summary.insert( summary.insert(
syscall_name.to_string(), syscall_name.to_string(),