diff --git a/tools/partest-ack b/tools/partest-ack index c88793c2b553..ab722e3b1c22 100755 --- a/tools/partest-ack +++ b/tools/partest-ack @@ -5,16 +5,17 @@ declare quiet failed update partest_debug declare cotouched since sortCommand declare -a ack_args partest_args scalac_args +declare -r standard_ack_args="--noenv -s --java --scala --type-add=scala:ext:flags,check --files-with-matches" partest_args=( --show-diff ) -base="$(cd "$(dirname "$0")"/.. && pwd)" +bindir="$(cd "$(dirname "$0")" && pwd)" +base="$bindir/.." cd "$base" || { echo "Could not change to base directory $base" && exit 1; } filesdir="test/files" sortCommand="sort -u" +partestPaths="$bindir/partest-paths" -# have to enumerate good test dirs since partest chokes and fails -# on continuations, bench, etc. tests -pathRegex="$filesdir/(pos|neg|jvm|run|scalap|presentation)/[^/.]+([.]scala)?\$" +[[ -x "$partestPaths" ]] || { echo "Cannot find partest-paths in $partestPaths" && exit 1; } [[ $# -gt 0 ]] || { cat <&2 "%% tests %-25s ... " "$description" - "$@" | asTestPaths | sort -u | countStdout | egrep -v '^[ ]*$' + "$@" | "$partestPaths" | countStdout | egrep -v '^[ ]*$' } allMatches() { diff --git a/tools/partest-paths b/tools/partest-paths new file mode 100755 index 000000000000..6ce403a04e32 --- /dev/null +++ b/tools/partest-paths @@ -0,0 +1,27 @@ +#!/bin/sh +# +# Given a list of files on stdin, translates them into a set +# of tests covering those files. That means paths which aren't +# part of a test are dropped and the rest are rewritten to the +# primary test path, with duplicates dropped. + +cd "$(dirname "$0")/.." + +# We have to enumerate good test dirs since partest chokes and fails +# on continuations, bench, etc. tests +pathRegex="test/files/(pos|neg|jvm|run|scalap|presentation)/[^/.]+([.]scala)?\$" + +# Echo the argument only if it matches our idea of a test and exists. +isPath () { [[ "$1" =~ $pathRegex ]] && [[ -e "$1" ]]; } + +# Filter stdin down to actual test paths. +asTestPaths() { + while read -r p; do + # Matched file at the standard test depth + p1="${p%.*}" && isPath "$p1.scala" && echo "$p1.scala" && continue + # Or, matched file may be in a test subdirectory, so strip the last path segment and check + p2="${p1%/*}" && isPath "$p2" && echo "$p2" && continue + done +} + +asTestPaths | sort -u