coreboot-kgpe-d16/util/lint/lint-stable-019-header-files
Martin Roth f6ba75c736 util/lint/lint-stable-019-header-files: add test
Add a test to make sure that the linter fails correctly.

Signed-off-by: Martin Roth <gaumless@gmail.com>
Change-Id: I971951d4248dd10abe4c622025fdaf86e014c6cc
Reviewed-on: https://review.coreboot.org/c/coreboot/+/67351
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Elyes Haouas <ehaouas@noos.fr>
2022-09-06 17:58:57 +00:00

49 lines
1.4 KiB
Bash
Executable file

#!/usr/bin/env sh
#
# SPDX-License-Identifier: GPL-2.0-only
# DESCR: Check for auto-included headers
LC_ALL=C export LC_ALL
INCLUDED_DIRS='^src/'
EXCLUDED_FILES='src/include/kconfig.h'
HEADER_FILES="k\?config rules compiler"
TESTFILE1="src/lib/version.c"
TESTFILE2="src/lib/string.c"
TESTFILE3="src/lib/malloc.c"
TESTFILE4="src/lib/hardwaremain.c"
EXPECTED_FAILURES=4
# Configure to make sure tests fail
if [ "$1" = "--test" ]; then
sed -i.bak "s|^.*SPDX-License-Identifier.*|&\n\n#include <config.h>\n|" "${TESTFILE1}"
sed -i.bak "s|^.*SPDX-License-Identifier.*|&\n\n#include \"kconfig.h\"\n|" "${TESTFILE2}"
sed -i.bak "s|^.*SPDX-License-Identifier.*|&\n\n#include \"compiler.h\"\n|" "${TESTFILE3}"
sed -i.bak "s|^.*SPDX-License-Identifier.*|&\n\n#include <rules.h>\n|" "${TESTFILE4}"
echo "Expect ${EXPECTED_FAILURES} failures."
exit 0
elif [ "$1" = "--reset" ]; then
mv "${TESTFILE1}.bak" "${TESTFILE1}"
mv "${TESTFILE2}.bak" "${TESTFILE2}"
mv "${TESTFILE3}.bak" "${TESTFILE3}"
mv "${TESTFILE4}.bak" "${TESTFILE4}"
exit 0
fi
# Use git grep if the code is in a git repo, otherwise use grep.
if [ -n "$(command -v git)" ] && \
[ "$(git rev-parse --is-inside-work-tree 2>/dev/null)" = "true" ]
then
GREP_FILES="git grep -n"
else
GREP_FILES="grep -rn"
fi
for header in $HEADER_FILES; do
${GREP_FILES} "#[[:blank:]]*include[[:blank:]]\+[\"<][[:blank:]]*${header}\.h[[:blank:]]*[\">]" | \
grep "$INCLUDED_DIRS" | \
grep -v "$EXCLUDED_FILES"; \
done