test-all.sh: Rework use of directory argument

If a directory is specified, then check shader source files there.
Otherwise, use shader source files in the same directory as the test
script.

Enhance error checking and messages.

Change-Id: I6ea40e2a44128ba3ce103faaad5326b89bbf4ed7
Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/49841
Commit-Queue: David Neto <dneto@google.com>
Auto-Submit: David Neto <dneto@google.com>
Reviewed-by: Ben Clayton <bclayton@google.com>
diff --git a/test/test-all.sh b/test/test-all.sh
index fad05e9..ac79421 100755
--- a/test/test-all.sh
+++ b/test/test-all.sh
@@ -28,28 +28,35 @@
 
 TINT="$1"
 ONLY_FORMAT="$2"
-SUBDIR="$3"
+TARGETDIR="$3"
 
 function usage() {
-    echo "test-all.sh compiles with tint all the .wgsl files in the tint/test"
-    echo "directory, for each of the SPIR-V, MSL, HLSL and WGSL backends."
-    echo "Any errors are reported as test failures."
-    echo ""
-    echo "Usage: test-all.sh <path-to-tint-executable> [<only-format> [<subdir-with-more-samples>]]"
+    echo "test-all.sh uses tint to compile .wgsl and .spvasm files, reporting errors as test failures."
     echo
-    echo "<only-format> limits which output format is tested.  The default is all."
-    echo "       Possible values are: all, wgsl, spv, msl, hlsl"
+    echo "Usage: test-all.sh <path-to-tint-executable> [<only-format> [directory]]"
     echo
-    echo "<subdir-with-more-samples> specifies which directory has the sample files, relative to the script."
-    echo "       When not specified, check the .wgsl and .spvasm files in the script directory."
+    echo "<only-format> specifies which output format is tested."
+    echo "       Possible values are: all, wgsl, spv, msl, hlsl."
+    echo "       The default is 'all'."
+    echo
+    echo "[directory]   specifies which directory holds the source files"
+    echo "       The default is to use the script directory."
 }
 
+if [ -z "$TINT" ]; then
+    echo "error: missing argument: location of the 'tint' executable"
+    echo
+    usage
+    exit 1
+fi
 if [ ! -x "$TINT" ]; then
+    echo "error: invalid argument: location of the 'tint' executable"
+    echo
     usage
     exit 1
 fi
 
-if [ ! -z "$ONLY_FORMAT" ]; then
+if [ -n "$ONLY_FORMAT" ]; then
   case "${ONLY_FORMAT}" in
     all)
       ;;
@@ -78,25 +85,32 @@
       CHECK_HLSL=1
       ;;
     *)
+      echo "error: invalid format argument: $ONLY_FORMAT"
+      echo
       usage
       exit 1
   esac
 fi
 
-if [ ! -z "${SUBDIR}" ]; then
-  if [ ! -d "${SUBDIR}" ]; then
-    echo "error: ${SUBDIR} is not a directory"
-    exit 1
-  fi
-fi
-
-if [ ! -z "$4" ]; then
+if [ -n "$4" ]; then
   echo "error: Too many arguments"
+  echo
   usage
   exit 1
 fi
 
 SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}")" >/dev/null 2>&1 && pwd )"
+
+# If no subdirectory was specified, look in the script directory.
+if [ -z "${TARGETDIR}" ]; then
+  TARGETDIR="${SCRIPT_DIR}"
+fi
+
+if [ ! -d "${TARGETDIR}" ]; then
+    echo "error: ${TARGETDIR} is not a directory"
+    exit 1
+fi
+
 NUM_PASS=0
 NUM_SKIP=0
 NUM_FAIL=0
@@ -122,7 +136,8 @@
     local FORMAT=$2
     SKIP=
 
-    if [[ $SKIPPED == *"${FORMAT}:${TEST_FILE}"* ]]; then
+    TEST_FILE_WITHOUT_DIR=$(basename ${TEST_FILE})
+    if [[ $SKIPPED == *"${FORMAT}:${TEST_FILE_WITHOUT_DIR}"* ]]; then
         SKIP=1
     fi
 
@@ -133,7 +148,7 @@
         return
     fi
     set +e
-    "${TINT}" ${SCRIPT_DIR}/${TEST_FILE} --format ${FORMAT} -o /dev/null
+    "${TINT}" ${TEST_FILE} --format ${FORMAT} -o /dev/null
     if [ $? -eq 0 ]; then
         echo -e "${TEXT_GREEN}PASS${TEXT_DEFAULT}"
         NUM_PASS=$((${NUM_PASS}+1))
@@ -147,11 +162,6 @@
 # check_formats(TEST_FILE)
 function check_formats() {
     local TEST_FILE=$1
-    if [ -x realpath ]; then
-      TEST_FILE=$(realpath --relative-to="$SCRIPT_DIR" "$TEST_FILE")
-    else
-      TEST_FILE=$(echo -n "$TEST_FILE"| sed -e "s'${SCRIPT_DIR}/*''")
-    fi
     echo
     echo "Testing ${TEST_FILE}..."
     [ ${CHECK_WGSL} -eq 0 ] || check "${TEST_FILE}" wgsl
@@ -160,17 +170,10 @@
     [ ${CHECK_HLSL} -eq 0 ] || check "${TEST_FILE}" hlsl
 }
 
-if [ -z "${SUBDIR}" ]; then
-    for F in ${SCRIPT_DIR}/*.spvasm ${SCRIPT_DIR}/*.wgsl
-    do
-        check_formats "$F"
-    done
-else
-    for F in "${SCRIPT_DIR}/${SUBDIR}"/*;
-    do
-        check_formats "$F"
-    done
-fi
+for F in "${TARGETDIR}"/*.spvasm "${TARGETDIR}"/*.wgsl
+do
+    check_formats "$F"
+done
 
 if [ ${NUM_FAIL} -ne 0 ]; then
     echo