jerryscript/tools/runners/run-test-suite-test262.sh
crazy2be 9ab33e86d3 Add some progress printing to the test262 tests (#2559)
Previously, these would run for several minutes without printing
any progress. Now, at least print the number of tests executed.

JerryScript-DCO-1.0-Signed-off-by: crazy2be crazy1be@gmail.com
2018-10-15 08:22:29 +02:00

114 lines
3.4 KiB
Bash
Executable File

#!/bin/bash
# Copyright JS Foundation and other contributors, http://js.foundation
#
# Licensed 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.
ENGINE="$1"
PATH_TO_TEST262="$2"
OUTPUT_DIR=`dirname $ENGINE`
REPORT_PATH="${OUTPUT_DIR}/test262.report"
TIMEOUT="90s"
TIMEOUT_CMD=`which timeout`
if [ $? -ne 0 ]
then
TIMEOUT_CMD=`which gtimeout`
fi
if [ -z "${RUNTIME}" ]
then
COMMAND="${TIMEOUT_CMD} ${TIMEOUT} ${ENGINE}"
else
COMMAND="${TIMEOUT_CMD} ${TIMEOUT} ${RUNTIME} ${ENGINE}"
fi
if [ $# -lt 2 ]
then
echo "This script performs parallel test262 compliance testing of the specified engine."
echo ""
echo "Usage:"
echo " 1st parameter: JavaScript engine to be tested."
echo " 2nd parameter: path to the directory with official test262 testsuite."
echo ""
echo "Example:"
echo " ./run-test-suite-test262.sh <engine> <test262_dir>"
exit 1
fi
if [ ! -d "${PATH_TO_TEST262}/.git" ]
then
git clone https://github.com/tc39/test262.git -b es5-tests "${PATH_TO_TEST262}"
fi
rm -rf "${PATH_TO_TEST262}/test/suite/bestPractice"
rm -rf "${PATH_TO_TEST262}/test/suite/intl402"
# TODO: Enable these tests after daylight saving calculation is fixed.
rm -f "${PATH_TO_TEST262}/test/suite/ch15/15.9/15.9.3/S15.9.3.1_A5_T1.js"
rm -f "${PATH_TO_TEST262}/test/suite/ch15/15.9/15.9.3/S15.9.3.1_A5_T2.js"
rm -f "${PATH_TO_TEST262}/test/suite/ch15/15.9/15.9.3/S15.9.3.1_A5_T3.js"
rm -f "${PATH_TO_TEST262}/test/suite/ch15/15.9/15.9.3/S15.9.3.1_A5_T4.js"
rm -f "${PATH_TO_TEST262}/test/suite/ch15/15.9/15.9.3/S15.9.3.1_A5_T5.js"
rm -f "${PATH_TO_TEST262}/test/suite/ch15/15.9/15.9.3/S15.9.3.1_A5_T6.js"
echo "Starting test262 testing for ${ENGINE}. Running test262 may take a several minutes."
function progress_monitor() {
NUM_LINES_GOTTEN=0
(>&2 echo)
while read line
do
if [[ $((NUM_LINES_GOTTEN % 100)) == 0 ]]
then
(>&2 echo -ne "\rExecuted approx ${NUM_LINES_GOTTEN} tests...")
fi
echo "$line"
NUM_LINES_GOTTEN=$((NUM_LINES_GOTTEN + 1))
done
(>&2 echo)
(>&2 echo)
}
python2 "${PATH_TO_TEST262}"/tools/packaging/test262.py --command "${COMMAND}" \
--tests="${PATH_TO_TEST262}" --summary \
| progress_monitor > "${REPORT_PATH}"
TEST262_EXIT_CODE=$?
if [ $TEST262_EXIT_CODE -ne 0 ]
then
echo -e "\nFailed to run test2626\n"
echo "$0: see ${REPORT_PATH} for details about failures"
exit $TEST262_EXIT_CODE
fi
grep -A3 "=== Summary ===" "${REPORT_PATH}"
FAILURES=`sed -n '/Failed tests/,/^$/p' "${REPORT_PATH}"`
EXIT_CODE=0
if [ -n "$FAILURES" ]
then
echo -e "\n$FAILURES\n"
echo "$0: see ${REPORT_PATH} for details about failures"
EXIT_CODE=1
fi
FAILURES=`sed -n '/Expected to fail but passed/,/^$/p' "${REPORT_PATH}"`
if [ -n "$FAILURES" ]
then
echo -e "\n$FAILURES\n"
echo "$0: see ${REPORT_PATH} for details about failures"
EXIT_CODE=1
fi
exit $EXIT_CODE