blob: 4294227fce0bf553e0fe696dfb539384cc605b50 [file] [log] [blame]
#!/usr/bin/env bash
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information regarding copyright ownership.
# The ASF licenses this file to You under the Apache License, Version 2.0
# (the "License"); you may not use this file except in compliance with
# the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# This bug system handles the output on the screen.
add_bugsystem console
CONSOLE_USE_BUILD_URL=false
## @description Print out the finished details on the console
## @audience private
## @stability evolving
## @replaceable no
## @param runresult
## @return 0 on success
## @return 1 on failure
function console_finalreport
{
declare result=$1
shift
declare i=0
declare ourstring
declare vote
declare subs
declare ela
declare comment
declare commentfile1="${PATCH_DIR}/comment.1"
declare commentfile2="${PATCH_DIR}/comment.2"
declare normaltop
declare line
declare seccoladj=0
declare spcfx=${PATCH_DIR}/spcl.txt
declare calctime
declare url
if [[ -n "${CONSOLE_REPORT_FILE}" ]]; then
exec 6>&1
exec >"${CONSOLE_REPORT_FILE}"
fi
if [[ ${result} == 0 ]]; then
if [[ ${ROBOT} == false ]]; then
if declare -f "${PROJECT_NAME}_console_success" >/dev/null; then
"${PROJECT_NAME}_console_success" > "${spcfx}"
else
{
printf "IF9fX18gICAgICAgICAgICAgICAgICAgICAgICAgICAgICBfIAovIF9fX3wg";
printf "XyAgIF8gIF9fXyBfX18gX19fICBfX18gX19ffCB8ClxfX18gXHwgfCB8IHwv";
printf "IF9fLyBfXy8gXyBcLyBfXy8gX198IHwKIF9fXykgfCB8X3wgfCAoX3wgKF98";
printf "ICBfXy9cX18gXF9fIFxffAp8X19fXy8gXF9fLF98XF9fX1xfX19cX19ffHxf";
printf "X18vX19fKF8pCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg";
printf "ICAK";
} > "${spcfx}"
fi
fi
printf '\n\n+1 overall\n\n'
else
if [[ ${ROBOT} == false ]]; then
if declare -f "${PROJECT_NAME}_console_failure" >/dev/null; then
"${PROJECT_NAME}_console_failure" > "${spcfx}"
else
{
printf "IF9fX19fICAgICBfIF8gICAgICAgICAgICAgICAgXyAKfCAgX19ffF8gXyhf";
printf "KSB8XyAgIF8gXyBfXyBfX198IHwKfCB8XyAvIF9gIHwgfCB8IHwgfCB8ICdf";
printf "Xy8gXyBcIHwKfCAgX3wgKF98IHwgfCB8IHxffCB8IHwgfCAgX18vX3wKfF98";
printf "ICBcX18sX3xffF98XF9fLF98X3wgIFxfX18oXykKICAgICAgICAgICAgICAg";
printf "ICAgICAgICAgICAgICAgICAK"
} > "${spcfx}"
fi
fi
printf '\n\n-1 overall\n\n'
fi
if [[ -f ${spcfx} ]]; then
if command -v base64 >/dev/null 2>&1; then
base64 --decode "${spcfx}" 2>/dev/null
elif command -v openssl >/dev/null 2>&1; then
openssl enc -A -d -base64 -in "${spcfx}" 2>/dev/null
fi
echo
echo
rm "${spcfx}"
fi
seccoladj=$(findlargest 2 "${TP_VOTE_TABLE[@]}")
if [[ ${seccoladj} -lt 10 ]]; then
seccoladj=10
fi
seccoladj=$((seccoladj + 2 ))
i=0
until [[ $i -eq ${#TP_HEADER[@]} ]]; do
printf '%s\n' "${TP_HEADER[${i}]}"
((i=i+1))
done
printf '| %s | %*s | %s | %s\n' "Vote" ${seccoladj} Subsystem Runtime "Comment"
echo "============================================================================"
i=0
until [[ $i -eq ${#TP_VOTE_TABLE[@]} ]]; do
ourstring=$(echo "${TP_VOTE_TABLE[${i}]}" | tr -s ' ')
vote=$(echo "${ourstring}" | cut -f2 -d\|)
subs=$(echo "${ourstring}" | cut -f3 -d\|)
ela=$(echo "${ourstring}" | cut -f4 -d\|)
calctime=$(clock_display "${ela}")
comment=$(echo "${ourstring}" | cut -f5 -d\|)
echo "${comment}" | fold -s -w $((78-seccoladj-22)) > "${commentfile1}"
normaltop=$(head -1 "${commentfile1}")
${SED} -e '1d' "${commentfile1}" > "${commentfile2}"
if [[ "${vote}" = "H" ]]; then
printf '| | %*s | |%-s\n' ${seccoladj} " " "${normaltop}"
else
printf '| %4s | %*s | %-10s |%-s\n' "${vote}" ${seccoladj} \
"${subs}" "${calctime}" "${normaltop}"
fi
while read -r line; do
printf '| | %*s | | %-s\n' ${seccoladj} " " "${line}"
done < "${commentfile2}"
((i=i+1))
rm "${commentfile2}" "${commentfile1}" 2>/dev/null
done
if [[ ${#TP_TEST_TABLE[@]} -gt 0 ]]; then
seccoladj=$(findlargest 1 "${TP_TEST_TABLE[@]}")
printf '\n\n%*s | Tests\n' "${seccoladj}" "Reason"
i=0
until [[ $i -eq ${#TP_TEST_TABLE[@]} ]]; do
ourstring=$(echo "${TP_TEST_TABLE[${i}]}" | tr -s ' ')
vote=$(echo "${ourstring}" | cut -f2 -d\|)
subs=$(echo "${ourstring}" | cut -f3 -d\|)
printf '%*s | %s\n' "${seccoladj}" "${vote}" "${subs}"
((i=i+1))
done
fi
printf '\n\n|| Subsystem || Report/Notes ||\n'
echo "============================================================================"
i=0
if [[ "${CONSOLE_USE_BUILD_URL}" = true ]]; then
url=$(get_artifact_url)
fi
if [[ -z "${url}" ]]; then
url=${PATCH_DIR}
fi
until [[ $i -eq ${#TP_FOOTER_TABLE[@]} ]]; do
comment=$(echo "${TP_FOOTER_TABLE[${i}]}" |
"${SED}" -e "s,@@BASE@@,${url},g")
printf '%s\n' "${comment}"
((i=i+1))
done
if [[ -n "${CONSOLE_REPORT_FILE}" ]]; then
exec 1>&6 6>&-
cat "${CONSOLE_REPORT_FILE}"
fi
}
## @description Give access to the brief report file in docker mode
## @audience private
## @stability evolving
## @replaceable no
function console_docker_support
{
if [[ -n "${CONSOLE_REPORT_FILE}" ]]; then
DOCKER_EXTRAARGS+=("-v" "${CONSOLE_REPORT_FILE}:${DOCKER_WORK_DIR}/console.txt")
USER_PARAMS+=("--console-report-file=${DOCKER_WORK_DIR}/console.txt")
fi
}