3 # SPDX-License-Identifier: GPL-2.0
6 # test_basic of perf_probe test
7 # Author: Michael Petlan <mpetlan@redhat.com>
8 # Author: Masami Hiramatsu <masami.hiramatsu.pt@hitachi.com>
12 # This test tests basic functionality of perf probe command.
15 # include working environment
20 if ! check_kprobes_available
; then
28 if [ "$PARAM_GENERAL_HELP_TEXT_CHECK" = "y" ]; then
29 # test that a help message is shown and looks reasonable
30 $CMD_PERF probe
--help > $LOGS_DIR/basic_helpmsg.log
2> $LOGS_DIR/basic_helpmsg.err
33 ..
/common
/check_all_patterns_found.pl
"PERF-PROBE" "NAME" "SYNOPSIS" "DESCRIPTION" "OPTIONS" "PROBE\s+SYNTAX" "PROBE\s+ARGUMENT" "LINE\s+SYNTAX" < $LOGS_DIR/basic_helpmsg.log
35 ..
/common
/check_all_patterns_found.pl
"LAZY\s+MATCHING" "FILTER\s+PATTERN" "EXAMPLES" "SEE\s+ALSO" < $LOGS_DIR/basic_helpmsg.log
36 (( CHECK_EXIT_CODE
+= $?
))
37 ..
/common
/check_all_patterns_found.pl
"vmlinux" "module=" "source=" "verbose" "quiet" "add=" "del=" "list.*EVENT" "line=" "vars=" "externs" < $LOGS_DIR/basic_helpmsg.log
38 (( CHECK_EXIT_CODE
+= $?
))
39 ..
/common
/check_all_patterns_found.pl
"no-inlines" "funcs.*FILTER" "filter=FILTER" "force" "dry-run" "max-probes" "exec=" "demangle-kernel" < $LOGS_DIR/basic_helpmsg.log
40 (( CHECK_EXIT_CODE
+= $?
))
41 ..
/common
/check_no_patterns_found.pl
"No manual entry for" < $LOGS_DIR/basic_helpmsg.err
42 (( CHECK_EXIT_CODE
+= $?
))
44 print_results
$PERF_EXIT_CODE $CHECK_EXIT_CODE "help message"
45 (( TEST_RESULT
+= $?
))
47 print_testcase_skipped
"help message"
53 # without any args perf-probe should print usage
54 $CMD_PERF probe
2> $LOGS_DIR/basic_usage.log
> /dev
/null
56 ..
/common
/check_all_patterns_found.pl
"[Uu]sage" "perf probe" "verbose" "quiet" "add" "del" "force" "line" "vars" "externs" "range" < $LOGS_DIR/basic_usage.log
59 print_results
0 $CHECK_EXIT_CODE "usage message"
60 (( TEST_RESULT
+= $?
))
65 # '--quiet' should mute all output
66 $CMD_PERF probe
--quiet --add vfs_read
> $LOGS_DIR/basic_quiet01.log
2> $LOGS_DIR/basic_quiet01.err
68 $CMD_PERF probe
--quiet --del vfs_read
> $LOGS_DIR/basic_quiet03.log
2> $LOGS_DIR/basic_quiet02.err
69 (( PERF_EXIT_CODE
+= $?
))
71 test "`cat $LOGS_DIR/basic_quiet*log $LOGS_DIR/basic_quiet*err | wc -l`" -eq 0
74 print_results
$PERF_EXIT_CODE $CHECK_EXIT_CODE "quiet switch"
75 (( TEST_RESULT
+= $?
))
78 # print overall results
79 print_overall_results
"$TEST_RESULT"