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:
parent
cf1be5e76f
commit
9fe508dfb9
1 changed files with 6 additions and 4 deletions
|
@ -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(),
|
||||||
|
|
Loading…
Reference in a new issue