1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/dist/tools/ci/github_annotate.sh

105 lines
2.6 KiB
Bash

# Copyright 2020 Martine S. Lenders <m.lenders@fu-berlin.sh>
#
# This file is subject to the terms and conditions of the GNU Lesser
# General Public License v2.1. See the file LICENSE in the top level
# directory for more details.
LOG=cat
LOGFILE=
OUTFILE=github_annotate_outfile.log
ECHO_ESC=echo
if ps -p $$ | grep -q '\<bash\>'; then
# workaround when included in bash to escape newlines and carriage returns
# properly in _escape
ECHO_ESC='echo -e'
fi
github_annotate_setup() {
if [ -n "${GITHUB_RUN_ID}" ]; then
LOGFILE=run-${GITHUB_RUN_ID}.log
LOG="tee -a ${LOGFILE}"
fi
}
github_annotate_is_on() {
test -n "${LOGFILE}"
return $?
}
_escape() {
# see https://stackoverflow.com/a/1252191/11921757
${ECHO_ESC} "$1" | sed -e ':a' -e 'N' -e '$!ba' \
-e 's/%/%25/g' -e 's/\r/%0D/g' -e 's/\n/%0A/g'
}
_github_annotate() {
MESSAGE="$(_escape "${1}")"
LEVEL="${2:-error}"
OPTS="${3:-}"
echo "::${LEVEL} ${OPTS}::${DETAILS}" >> ${OUTFILE}
}
github_annotate_error() {
if [ -n "${GITHUB_RUN_ID}" ]; then
FILENAME="${1}"
LINENUM="${2}"
DETAILS="${3}"
_github_annotate "${DETAILS}" error "file=${FILENAME},line=${LINENUM}"
fi
}
github_annotate_error_no_file() {
if [ -n "${GITHUB_RUN_ID}" ]; then
DETAILS="${1}"
_github_annotate "${DETAILS}" error
fi
}
github_annotate_warning() {
if [ -n "${GITHUB_RUN_ID}" ]; then
FILENAME="${1}"
LINENUM="${2}"
DETAILS="$(_escape "${3}")"
_github_annotate "${DETAILS}" warning "file=${FILENAME},line=${LINENUM}"
fi
}
github_annotate_warning_no_file() {
if [ -n "${GITHUB_RUN_ID}" ]; then
DETAILS="${1}"
_github_annotate "${DETAILS}" warning
fi
}
github_annotate_parse_log_default() {
ANNOTATE_FUNC="${1:-github_annotate_error}"
if github_annotate_is_on; then
PATTERN='^.\+:[0-9]\+:'
grep "${PATTERN}" "${LOGFILE}" | while read line; do
FILENAME=$(echo "${line}" | cut -d: -f1)
LINENUM=$(echo "${line}" | cut -d: -f2)
DETAILS=$(echo "${line}" | cut -d: -f3- |
sed -e 's/^[ \t]*//' -e 's/[ \t]*$//')
${ANNOTATE_FUNC} "${FILENAME}" "${LINENUM}" "${DETAILS}"
done
fi
}
github_annotate_teardown() {
if [ -n "${LOGFILE}" ]; then
rm -f ${LOGFILE}
LOGFILE=
fi
}
github_annotate_report_last_run() {
if [ -n "${GITHUB_RUN_ID}" -a -f "${OUTFILE}" ]; then
# de-duplicate errors
sort -u ${OUTFILE} >&2
fi
rm -f ${OUTFILE}
}