2022-07-21 09:04:52 +00:00
|
|
|
#!/bin/sh
|
|
|
|
|
2022-12-29 12:47:25 +00:00
|
|
|
# This script runs tests before and after a PR and analyzes the results in
|
|
|
|
# order to highlight any difference in the set of tests skipped.
|
2022-07-26 08:10:07 +00:00
|
|
|
#
|
2022-12-29 12:47:25 +00:00
|
|
|
# It can be used to check the first testing criterion mentioned in strategy.md,
|
2022-07-26 08:10:07 +00:00
|
|
|
# end of section "Supporting builds with drivers without the software
|
2022-12-29 12:47:25 +00:00
|
|
|
# implementation", namely: the sets of tests skipped in the default config and
|
|
|
|
# the full config must be the same before and after the PR.
|
2022-07-26 08:10:07 +00:00
|
|
|
#
|
2022-12-29 13:02:05 +00:00
|
|
|
# USAGE:
|
|
|
|
# - First, commit any uncommited changes. (Also, see warning below.)
|
2023-01-23 11:51:52 +00:00
|
|
|
# - Then launch --> [SKIP_SSL_OPT=1] docs/architecture/psa-migration/outcome-analysis.sh
|
|
|
|
# - SKIP_SSL_OPT=1 can optionally be set to skip ssl-opt.sh tests
|
2022-12-29 13:02:05 +00:00
|
|
|
#
|
2022-07-26 08:10:07 +00:00
|
|
|
# WARNING: this script checks out a commit other than the head of the current
|
2022-07-27 18:37:12 +00:00
|
|
|
# branch; it checks out the current branch again when running successfully,
|
2022-07-26 08:10:07 +00:00
|
|
|
# but while the script is running, or if it terminates early in error, you
|
2022-07-27 18:37:12 +00:00
|
|
|
# should be aware that you might be at a different commit than expected.
|
2022-07-26 08:10:07 +00:00
|
|
|
#
|
2022-12-29 12:47:25 +00:00
|
|
|
# NOTE: you can comment out parts that don't need to be re-done when
|
2022-07-21 09:04:52 +00:00
|
|
|
# re-running this script (for example "get numbers before this PR").
|
|
|
|
|
|
|
|
set -eu
|
|
|
|
|
2022-12-29 13:02:05 +00:00
|
|
|
: ${SKIP_SSL_OPT:=0}
|
|
|
|
|
2022-07-21 09:04:52 +00:00
|
|
|
cleanup() {
|
|
|
|
make clean
|
|
|
|
git checkout -- include/mbedtls/mbedtls_config.h include/psa/crypto_config.h
|
|
|
|
}
|
|
|
|
|
|
|
|
record() {
|
|
|
|
export MBEDTLS_TEST_OUTCOME_FILE="$PWD/outcome-$1.csv"
|
|
|
|
rm -f $MBEDTLS_TEST_OUTCOME_FILE
|
2022-12-29 13:02:05 +00:00
|
|
|
|
2022-07-21 09:04:52 +00:00
|
|
|
make check
|
2022-12-29 13:02:05 +00:00
|
|
|
|
|
|
|
if [ $SKIP_SSL_OPT -eq 0 ]; then
|
|
|
|
make -C programs ssl/ssl_server2 ssl/ssl_client2 \
|
|
|
|
test/udp_proxy test/query_compile_time_config
|
|
|
|
tests/ssl-opt.sh
|
|
|
|
fi
|
2022-07-21 09:04:52 +00:00
|
|
|
}
|
|
|
|
|
2023-07-31 13:07:49 +00:00
|
|
|
# save current HEAD.
|
2023-07-31 14:47:07 +00:00
|
|
|
# Note: this can optionally be updated to
|
|
|
|
# HEAD=$(git branch --show-current)
|
|
|
|
# when using a Git version above 2.22
|
|
|
|
HEAD=$(git rev-parse --abbrev-ref HEAD)
|
2022-07-21 09:04:52 +00:00
|
|
|
|
2022-11-09 14:06:44 +00:00
|
|
|
# get the numbers before this PR for default and full
|
|
|
|
cleanup
|
|
|
|
git checkout $(git merge-base HEAD development)
|
2022-12-29 13:02:05 +00:00
|
|
|
|
2022-11-09 14:06:44 +00:00
|
|
|
record "before-default"
|
2022-07-21 09:04:52 +00:00
|
|
|
|
2022-11-09 14:06:44 +00:00
|
|
|
cleanup
|
2022-12-29 13:02:05 +00:00
|
|
|
|
2022-11-09 14:06:44 +00:00
|
|
|
scripts/config.py full
|
|
|
|
record "before-full"
|
2022-07-21 09:04:52 +00:00
|
|
|
|
2022-11-09 14:06:44 +00:00
|
|
|
# get the numbers now for default and full
|
2022-07-21 09:04:52 +00:00
|
|
|
cleanup
|
2022-11-09 14:06:44 +00:00
|
|
|
git checkout $HEAD
|
2022-12-29 13:02:05 +00:00
|
|
|
|
2022-11-09 14:06:44 +00:00
|
|
|
record "after-default"
|
2022-07-21 09:04:52 +00:00
|
|
|
|
|
|
|
cleanup
|
2022-12-29 13:02:05 +00:00
|
|
|
|
2022-11-09 14:06:44 +00:00
|
|
|
scripts/config.py full
|
|
|
|
record "after-full"
|
|
|
|
|
2022-12-29 13:02:05 +00:00
|
|
|
cleanup
|
|
|
|
|
2022-07-21 09:04:52 +00:00
|
|
|
# analysis
|
|
|
|
|
2022-10-12 08:57:31 +00:00
|
|
|
populate_suites () {
|
|
|
|
SUITES=''
|
|
|
|
make generated_files >/dev/null
|
|
|
|
data_files=$(cd tests/suites && echo *.data)
|
|
|
|
for data in $data_files; do
|
2022-12-29 13:02:05 +00:00
|
|
|
suite=${data%.data}
|
2022-12-29 12:47:25 +00:00
|
|
|
SUITES="$SUITES $suite"
|
2022-10-12 08:57:31 +00:00
|
|
|
done
|
|
|
|
make neat
|
2022-12-29 13:02:05 +00:00
|
|
|
|
|
|
|
if [ $SKIP_SSL_OPT -eq 0 ]; then
|
|
|
|
SUITES="$SUITES ssl-opt"
|
|
|
|
extra_files=$(cd tests/opt-testcases && echo *.sh)
|
|
|
|
for extra in $extra_files; do
|
|
|
|
suite=${extra%.sh}
|
|
|
|
SUITES="$SUITES $suite"
|
|
|
|
done
|
|
|
|
fi
|
2022-10-12 08:57:31 +00:00
|
|
|
}
|
|
|
|
|
2022-07-21 09:04:52 +00:00
|
|
|
compare_suite () {
|
|
|
|
ref="outcome-$1.csv"
|
|
|
|
new="outcome-$2.csv"
|
|
|
|
suite="$3"
|
|
|
|
|
2022-12-29 13:02:05 +00:00
|
|
|
pattern_suite=";$suite;"
|
2022-07-21 09:04:52 +00:00
|
|
|
total=$(grep -c "$pattern_suite" "$ref")
|
|
|
|
sed_cmd="s/^.*$pattern_suite\(.*\);SKIP.*/\1/p"
|
|
|
|
sed -n "$sed_cmd" "$ref" > skipped-ref
|
|
|
|
sed -n "$sed_cmd" "$new" > skipped-new
|
|
|
|
nb_ref=$(wc -l <skipped-ref)
|
|
|
|
nb_new=$(wc -l <skipped-new)
|
|
|
|
|
2022-12-29 13:02:05 +00:00
|
|
|
name=${suite#test_suite_}
|
|
|
|
printf "%40s: total %4d; skipped %4d -> %4d\n" \
|
|
|
|
$name $total $nb_ref $nb_new
|
2022-10-12 08:57:31 +00:00
|
|
|
if diff skipped-ref skipped-new | grep '^> '; then
|
|
|
|
ret=1
|
|
|
|
else
|
|
|
|
ret=0
|
|
|
|
fi
|
2022-07-21 09:04:52 +00:00
|
|
|
rm skipped-ref skipped-new
|
2022-10-12 08:57:31 +00:00
|
|
|
return $ret
|
2022-07-21 09:04:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
compare_builds () {
|
|
|
|
printf "\n*** Comparing $1 -> $2 ***\n"
|
2022-10-12 08:57:31 +00:00
|
|
|
failed=''
|
2022-07-21 09:04:52 +00:00
|
|
|
for suite in $SUITES; do
|
2022-10-12 08:57:31 +00:00
|
|
|
if compare_suite "$1" "$2" "$suite"; then :; else
|
|
|
|
failed="$failed $suite"
|
|
|
|
fi
|
2022-07-21 09:04:52 +00:00
|
|
|
done
|
2022-10-18 07:42:30 +00:00
|
|
|
if [ -z "$failed" ]; then
|
|
|
|
printf "No coverage gap found.\n"
|
|
|
|
else
|
|
|
|
printf "Suites with less coverage:%s\n" "$failed"
|
|
|
|
fi
|
2022-07-21 09:04:52 +00:00
|
|
|
}
|
|
|
|
|
2022-10-12 08:57:31 +00:00
|
|
|
populate_suites
|
2022-11-09 14:06:44 +00:00
|
|
|
compare_builds before-default after-default
|
|
|
|
compare_builds before-full after-full
|