2 # perf script task-analyzer tests
3 # SPDX-License-Identifier: GPL-2.0
5 tmpdir
=$
(mktemp
-d /tmp
/perf-script-task-analyzer-XXXXX
)
8 # set PERF_EXEC_PATH to find scripts in the source directory
9 perfdir
=$
(dirname "$0")/..
/..
10 if [ -e "$perfdir/scripts/python/Perf-Trace-Util" ]; then
11 export PERF_EXEC_PATH
=$perfdir
14 # Disable lsan to avoid warnings about python memory leaks.
15 export ASAN_OPTIONS
=detect_leaks
=0
30 trap trap_cleanup
exit term int
36 echo "FAIL: \"$2\" Error message: \"$3\""
43 report
1 "invocation of $1 command failed"
49 if [ "$?" != 0 ]; then
50 report
1 "$3" "Failed to find required string:'${1}'."
56 # check if perf is compiled with libtraceevent support
57 skip_no_probe_record_support
() {
58 perf check feature
-q libtraceevent
&& return 0
63 # 1s should be sufficient to catch at least some switches
64 perf record
-e sched
:sched_switch
-a -- sleep 1 > /dev
/null
2>&1
65 # check if perf data file got created in above step.
66 if [ ! -e "perf.data" ]; then
67 printf "FAIL: perf record failed to create \"perf.data\" \n"
72 # check standard inkvokation with no arguments
74 out
="$tmpdir/perf.out"
75 perf
script report task-analyzer
> "$out"
76 check_exec_0
"perf script report task-analyzer"
77 find_str_or_fail
"Comm" "$out" "${FUNCNAME[0]}"
81 out
="$tmpdir/perf.out"
82 perf
script report task-analyzer
--ns --rename-comms-by-tids 0:random
> "$out"
83 check_exec_0
"perf script report task-analyzer --ns --rename-comms-by-tids 0:random"
84 find_str_or_fail
"Comm" "$out" "${FUNCNAME[0]}"
87 test_ms_filtertasks_highlight
(){
88 out
="$tmpdir/perf.out"
89 perf
script report task-analyzer
--ms --filter-tasks perf
--highlight-tasks perf \
91 check_exec_0
"perf script report task-analyzer --ms --filter-tasks perf --highlight-tasks perf"
92 find_str_or_fail
"Comm" "$out" "${FUNCNAME[0]}"
95 test_extended_times_timelimit_limittasks
() {
96 out
="$tmpdir/perf.out"
97 perf
script report task-analyzer
--extended-times --time-limit :99999 \
98 --limit-to-tasks perf
> "$out"
99 check_exec_0
"perf script report task-analyzer --extended-times --time-limit :99999 --limit-to-tasks perf"
100 find_str_or_fail
"Out-Out" "$out" "${FUNCNAME[0]}"
104 out
="$tmpdir/perf.out"
105 perf
script report task-analyzer
--summary > "$out"
106 check_exec_0
"perf script report task-analyzer --summary"
107 find_str_or_fail
"Summary" "$out" "${FUNCNAME[0]}"
110 test_summaryextended
() {
111 out
="$tmpdir/perf.out"
112 perf
script report task-analyzer
--summary-extended > "$out"
113 check_exec_0
"perf script report task-analyzer --summary-extended"
114 find_str_or_fail
"Inter Task Times" "$out" "${FUNCNAME[0]}"
118 out
="$tmpdir/perf.out"
119 perf
script report task-analyzer
--summary-only > "$out"
120 check_exec_0
"perf script report task-analyzer --summary-only"
121 find_str_or_fail
"Summary" "$out" "${FUNCNAME[0]}"
124 test_extended_times_summary_ns
() {
125 out
="$tmpdir/perf.out"
126 perf
script report task-analyzer
--extended-times --summary --ns > "$out"
127 check_exec_0
"perf script report task-analyzer --extended-times --summary --ns"
128 find_str_or_fail
"Out-Out" "$out" "${FUNCNAME[0]}"
129 find_str_or_fail
"Summary" "$out" "${FUNCNAME[0]}"
133 perf
script report task-analyzer
--csv csv
> /dev
/null
134 check_exec_0
"perf script report task-analyzer --csv csv"
135 find_str_or_fail
"Comm;" csv
"${FUNCNAME[0]}"
138 test_csv_extended_times
() {
139 perf
script report task-analyzer
--csv csv
--extended-times > /dev
/null
140 check_exec_0
"perf script report task-analyzer --csv csv --extended-times"
141 find_str_or_fail
"Out-Out;" csv
"${FUNCNAME[0]}"
145 perf
script report task-analyzer
--csv-summary csvsummary
> /dev
/null
146 check_exec_0
"perf script report task-analyzer --csv-summary csvsummary"
147 find_str_or_fail
"Comm;" csvsummary
"${FUNCNAME[0]}"
150 test_csvsummary_extended
() {
151 perf
script report task-analyzer
--csv-summary csvsummary
--summary-extended \
153 check_exec_0
"perf script report task-analyzer --csv-summary csvsummary --summary-extended"
154 find_str_or_fail
"Out-Out;" csvsummary
"${FUNCNAME[0]}"
157 skip_no_probe_record_support
159 if [ $err -ne 0 ]; then
160 echo "WARN: Skipping tests. No libtraceevent support"
167 test_ms_filtertasks_highlight
168 test_extended_times_timelimit_limittasks
172 test_extended_times_summary_ns
175 test_csv_extended_times
176 test_csvsummary_extended