mirror of
https://github.com/jerryscript-project/jerryscript.git
synced 2025-12-15 16:29:21 +00:00
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
114 lines
3.4 KiB
Bash
Executable File
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
|