perf test: Add basic 'perf diff' test
There are some old bug reports on perf diff crashing: https://rhaas.blogspot.com/2012/06/perf-good-bad-ugly.html Happening across them I was prompted to add two very basic tests that will give some 'perf diff' coverage. Signed-off-by: Ian Rogers <irogers@google.com> Cc: Adrian Hunter <adrian.hunter@intel.com> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Athira Jajeev <atrajeev@linux.vnet.ibm.com> Cc: Ingo Molnar <mingo@redhat.com> Cc: Jiri Olsa <jolsa@kernel.org> Cc: Mark Rutland <mark.rutland@arm.com> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Peter Zijlstra <peterz@infradead.org> Link: https://lore.kernel.org/r/20231120190408.281826-1-irogers@google.com Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
This commit is contained in:
parent
a4320085a6
commit
144081ef78
101
tools/perf/tests/shell/diff.sh
Executable file
101
tools/perf/tests/shell/diff.sh
Executable file
@ -0,0 +1,101 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# perf diff tests
|
||||||
|
# SPDX-License-Identifier: GPL-2.0
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
err=0
|
||||||
|
perfdata1=$(mktemp /tmp/__perf_test.perf.data.XXXXX)
|
||||||
|
perfdata2=$(mktemp /tmp/__perf_test.perf.data.XXXXX)
|
||||||
|
perfdata3=$(mktemp /tmp/__perf_test.perf.data.XXXXX)
|
||||||
|
testprog="perf test -w thloop"
|
||||||
|
testsym="test_loop"
|
||||||
|
|
||||||
|
cleanup() {
|
||||||
|
rm -rf "${perfdata1}"
|
||||||
|
rm -rf "${perfdata1}".old
|
||||||
|
rm -rf "${perfdata2}"
|
||||||
|
rm -rf "${perfdata2}".old
|
||||||
|
rm -rf "${perfdata3}"
|
||||||
|
rm -rf "${perfdata3}".old
|
||||||
|
|
||||||
|
trap - EXIT TERM INT
|
||||||
|
}
|
||||||
|
|
||||||
|
trap_cleanup() {
|
||||||
|
cleanup
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
trap trap_cleanup EXIT TERM INT
|
||||||
|
|
||||||
|
make_data() {
|
||||||
|
file="$1"
|
||||||
|
if ! perf record -o "${file}" ${testprog} 2> /dev/null
|
||||||
|
then
|
||||||
|
echo "Workload record [Failed record]"
|
||||||
|
echo 1
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
if ! perf report -i "${file}" -q | grep -q "${testsym}"
|
||||||
|
then
|
||||||
|
echo "Workload record [Failed missing output]"
|
||||||
|
echo 1
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
echo 0
|
||||||
|
}
|
||||||
|
|
||||||
|
test_two_files() {
|
||||||
|
echo "Basic two file diff test"
|
||||||
|
err=$(make_data "${perfdata1}")
|
||||||
|
if [ $err != 0 ]
|
||||||
|
then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
err=$(make_data "${perfdata2}")
|
||||||
|
if [ $err != 0 ]
|
||||||
|
then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
if ! perf diff "${perfdata1}" "${perfdata2}" | grep -q "${testsym}"
|
||||||
|
then
|
||||||
|
echo "Basic two file diff test [Failed diff]"
|
||||||
|
err=1
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
echo "Basic two file diff test [Success]"
|
||||||
|
}
|
||||||
|
|
||||||
|
test_three_files() {
|
||||||
|
echo "Basic three file diff test"
|
||||||
|
err=$(make_data "${perfdata1}")
|
||||||
|
if [ $err != 0 ]
|
||||||
|
then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
err=$(make_data "${perfdata2}")
|
||||||
|
if [ $err != 0 ]
|
||||||
|
then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
err=$(make_data "${perfdata3}")
|
||||||
|
if [ $err != 0 ]
|
||||||
|
then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
if ! perf diff "${perfdata1}" "${perfdata2}" "${perfdata3}" | grep -q "${testsym}"
|
||||||
|
then
|
||||||
|
echo "Basic three file diff test [Failed diff]"
|
||||||
|
err=1
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
echo "Basic three file diff test [Success]"
|
||||||
|
}
|
||||||
|
|
||||||
|
test_two_files
|
||||||
|
test_three_files
|
||||||
|
|
||||||
|
cleanup
|
||||||
|
exit $err
|
Loading…
Reference in New Issue
Block a user