2019-06-21 23:49:37 +08:00
#! /bin/bash
2020-01-22 13:31:22 +00:00
#
# Parses a results.tap file from SyTest output and a file containing test names (a test whitelist)
# and checks whether a test name that exists in the whitelist (that should pass), failed or not.
#
# An optional blacklist file can be added, also containing test names, where if a test name is
# present, the script will not error even if the test is in the whitelist file and failed
#
# For each of these files, lines starting with '#' are ignored.
#
# Usage ./show-expected-fail-tests.sh results.tap whitelist [blacklist]
2019-06-21 23:49:37 +08:00
results_file = $1
2020-01-22 13:31:22 +00:00
whitelist_file = $2
blacklist_file = $3
2019-06-25 18:50:19 +08:00
fail_build = 0
2020-01-22 13:31:22 +00:00
if [ $# -lt 2 ] ; then
echo " Usage: $0 results.tap whitelist [blacklist] "
exit 1
fi
2019-06-25 18:50:19 +08:00
if [ ! -f " $results_file " ] ; then
2020-01-22 13:31:22 +00:00
echo " ERROR: Specified results file ' ${ results_file } ' doesn't exist. "
2019-06-25 18:50:19 +08:00
fail_build = 1
fi
2020-01-22 13:31:22 +00:00
if [ ! -f " $whitelist_file " ] ; then
echo " ERROR: Specified test whitelist ' ${ whitelist_file } ' doesn't exist. "
2019-06-25 18:50:19 +08:00
fail_build = 1
fi
2020-01-22 13:31:22 +00:00
blacklisted_tests = ( )
# Check if a blacklist file was provided
if [ $# -eq 3 ] ; then
# Read test blacklist file
if [ ! -f " $blacklist_file " ] ; then
echo " ERROR: Specified test blacklist file ' ${ blacklist_file } ' doesn't exist. "
fail_build = 1
fi
# Read each line, ignoring those that start with '#'
blacklisted_tests = ""
search_non_comments = $( grep -v '^#' ${ blacklist_file } )
while read -r line ; do
# Record the blacklisted test name
blacklisted_tests += ( " ${ line } " )
done <<< " ${ search_non_comments } " # This allows us to edit blacklisted_tests in the while loop
fi
2019-06-25 18:50:19 +08:00
[ " $fail_build " = 0 ] || exit 1
2019-06-21 23:49:37 +08:00
passed_but_expected_fail = $( grep ' # TODO passed but expected fail' ${ results_file } | sed -E 's/^ok [0-9]+ (\(expected fail\) )?//' | sed -E 's/( \([0-9]+ subtests\))? # TODO passed but expected fail$//' )
tests_to_add = ""
2020-01-22 13:31:22 +00:00
already_in_whitelist = ""
2019-06-21 23:49:37 +08:00
2020-01-22 13:31:22 +00:00
while read -r test_name; do
# Ignore empty lines
[ " ${ test_name } " = "" ] && continue
2020-03-31 22:53:09 +08:00
grep " ^ ${ test_name } " " ${ whitelist_file } " > /dev/null 2>& 1
2019-06-21 23:49:37 +08:00
if [ " $? " != "0" ] ; then
2020-01-22 13:31:22 +00:00
# Check if this test name is blacklisted
if printf '%s\n' " ${ blacklisted_tests [@] } " | grep -q -P " ^ ${ test_name } $" ; then
# Don't notify about this test
continue
fi
# Append this test_name to the existing list
tests_to_add = " ${ tests_to_add } ${ test_name } \n "
2019-06-21 23:49:37 +08:00
fail_build = 1
else
2020-01-22 13:31:22 +00:00
already_in_whitelist = " ${ already_in_whitelist } ${ test_name } \n "
2019-06-21 23:49:37 +08:00
fi
done <<< " ${ passed_but_expected_fail } "
2020-02-14 13:07:14 +00:00
# TODO: Check that the same test doesn't exist in both the whitelist and blacklist
# TODO: Check that the same test doesn't appear twice in the whitelist|blacklist
# Trim test output strings
2020-05-04 14:48:49 +01:00
tests_to_add = $( IFS = $'\n' echo " ${ tests_to_add [*]%% '\n' } " )
already_in_whitelist = $( IFS = $'\n' echo " ${ already_in_whitelist [*]%% '\n' } " )
2020-02-14 13:07:14 +00:00
# Format output with markdown for buildkite annotation rendering purposes
if [ -n " ${ tests_to_add } " ] && [ -n " ${ already_in_whitelist } " ] ; then
echo "### 📜 SyTest Whitelist Maintenance"
fi
2019-06-21 23:49:37 +08:00
if [ -n " ${ tests_to_add } " ] ; then
2022-04-05 15:32:30 +02:00
echo " ::error::The following tests passed but are not present in \` $2 \`. Please append them to the file: "
echo "::group::Passing tests"
echo -e " ${ tests_to_add } "
echo "::endgroup::"
2019-06-21 23:49:37 +08:00
fi
2020-01-22 13:31:22 +00:00
if [ -n " ${ already_in_whitelist } " ] ; then
2022-04-05 15:32:30 +02:00
echo "::warning::Tests in the whitelist still marked as **expected fail**:"
echo "::group::Still marked as expected fail"
echo -e " ${ already_in_whitelist } "
echo "::endgroup::"
2019-06-21 23:49:37 +08:00
fi
exit ${ fail_build }