From b1ea7ed294af8edfd27526a1f32e311f77a2b1ce Mon Sep 17 00:00:00 2001 From: Thomas Levine <_@thomaslevine.com> Date: Wed, 2 Mar 2016 20:39:31 +0000 Subject: [PATCH] add more braces --- urchin | 135 +++++++++++++++++++++++++++++---------------------------- 1 file changed, 68 insertions(+), 67 deletions(-) diff --git a/urchin b/urchin index 09e61fa..4c6c097 100755 --- a/urchin +++ b/urchin @@ -280,8 +280,8 @@ report_outcome() { result=$(echo "${line}" | cut -f3) file_elapsed=$(echo "$line" | cut -f4) - prevdir=$currentdir - currentdir="$(dirname -- "$path")" + prevdir="${currentdir}" + currentdir="$(dirname -- "${path}")" # Number of files that have run, including this one n=$(($n + 1)) @@ -290,84 +290,84 @@ report_outcome() { eval "old_count=${result}s" eval "${result}s=$(($old_count+1))" - if $tap_format; then - if [ "$result" = not_ok ]; then + if "${tap_format}"; then + if [ "${result}" = not_ok ]; then not='not ' else not='' fi - if [ "$result" = skip ]; then + if [ "${result}" = skip ]; then skip='# SKIP' else skip='' fi - if test -z "$the_shell"; then + if test -z "${the_shell}"; then the_shell='File is not executable.' fi - echo "${not}ok $n - ${path} ($the_shell) ${skip}" - if $verbose || [ "$result" = not_ok ]; then + echo "${not}ok $n - ${path} (${the_shell}) ${skip}" + if "${verbose}" || [ "${result}" = not_ok ]; then echo '# ------------ Begin output ------------' - sed 's/^/# /' "$(stdout_file "$abspath" "$the_shell")" + sed 's/^/# /' "$(stdout_file "${abspath}" "${the_shell}")" echo '# ------------ End output ------------' fi - echo "# Previous test took $file_elapsed seconds." + echo "# Previous test took ${file_elapsed} seconds." else - if test "$prevdir" != "$currentdir"; then + if test "${prevdir}" != "${currentdir}"; then echo fi - if test "$prevpath" != "$path"; then - printf "$(dirname -- "$path")/\n> $(basename -- "$path")\n" + if test "${prevpath}" != "${path}"; then + printf "$(dirname -- "${path}")/\n> $(basename -- "${path}")\n" fi - case "$result" in + case "${result}" in ok) # On success, print a green '✓' printf '\033[32m✓ \033[0m' - echo "${the_shell} ($file_elapsed $(plural second $file_elapsed))" + echo "${the_shell} ("${file_elapsed}" $(plural second $file_elapsed))" ;; not_ok) # On not_ok, print a red '✗' printf '\033[31m✗ \033[0m' - echo "${the_shell} ($file_elapsed $(plural second $file_elapsed))" + echo "${the_shell} ("${file_elapsed}" $(plural second $file_elapsed))" ;; skip) - if test -z "$the_shell"; then + if test -z "${the_shell}"; then echo ' (File is not executable.)' else - echo " ${the_shell} ($file_elapsed $(plural second $file_elapsed))" + echo " ${the_shell} ("${file_elapsed}" $(plural second $file_elapsed))" fi ;; esac - if $verbose || test "$result" = not_ok; then - sed 's/^/ # /' "$(stdout_file "$abspath" "$the_shell")" + if "${verbose}" || test "${result}" = not_ok; then + sed 's/^/ # /' "$(stdout_file "${abspath}" "${the_shell}")" fi fi - prevpath="$path" - done < $sorted_log_file - rm $sorted_log_file + prevpath="${path}" + done < "${sorted_log_file}" + rm "${sorted_log_file}" - if $tap_format; then - echo "# Full test suite took $elapsed $(plural second $elapsed)." - echo 1..$n + if "${tap_format}"; then + echo "# Full test suite took ${elapsed} $(plural second ${elapsed})." + echo 1.."${n}" else echo - echo "Done, took $elapsed $(plural second $elapsed)." - printf '%s\n' "$oks $(plural test "$oks") passed." - printf '%s\n' "$skips $(plural test "$skips") skipped." + echo "Done, took ${elapsed} $(plural second ${elapsed})." + printf '%s\n' "${oks} $(plural test "${oks}") passed." + printf '%s\n' "${skips} $(plural test "${skips}") skipped." # If any tests are not ok, print the message in red. - if [ $not_oks -gt 0 ] ; then + if [ "${not_oks}" -gt 0 ] ; then printf '\033[31m' fi - printf '%s\n' "$not_oks $(plural test "$not_oks") failed." + printf '%s\n' "${not_oks} $(plural test "${not_oks}") failed." printf '\033[m\n' fi - test "$not_oks" -eq '0' + test "${not_oks}" -eq '0' } has_shebang_line() { - head -n 1 "$1" | grep -qE '^#!' + head -n 1 "${1}" | grep -qE '^#!' } USAGE="usage: $0 [] " @@ -375,12 +375,12 @@ USAGE="usage: $0 [] " urchin_help() { cat <&2 echo 'If this is really a problem, tell me, and I may fix it.' >&2 urchin_exit 11 @@ -447,43 +447,43 @@ validate_strings() { } cycle_shell=true -shell_list=$urchin_tmp/shell_list +shell_list="${urchin_tmp}"/shell_list run_in_series=false force=false exit_on_not_ok=false tap_format=false verbose=false -while [ $# -gt 0 ] +while [ "${#}" -gt 0 ] do - case "$1" in + case "${1}" in -b|--run-in-series) run_in_series=true;; -e|--exit-on-fail) exit_on_not_ok=true;; -f|--force) force=true;; -s|--shell) shift - shell_for_sh_tests=$1 + shell_for_sh_tests="${1}" - which "$shell_for_sh_tests" > /dev/null || { - echo "Cannot find specified shell: '$shell_for_sh_tests'" >&2 + which "${shell_for_sh_tests}" > /dev/null || { + echo "Cannot find specified shell: '${shell_for_sh_tests}'" >&2 urchin_help >&2 urchin_exit 11 } - validate_strings "$shell_for_sh_tests" 'Shell paths' - if echo "$shell_for_sh_tests" | grep \ > /dev/null; then + validate_strings "${shell_for_sh_tests}" 'Shell paths' + if echo "${shell_for_sh_tests}" | grep \ > /dev/null; then echo "Warning: It is best if shell paths contain no spaces so that you don't need to quote the TEST_SHELL variable." > /dev/stderr fi - echo "$shell_for_sh_tests" >> "$shell_list" + echo "${shell_for_sh_tests}" >> "${shell_list}" ;; -n|--disable-cycling) cycle_shell=false;; -t|--tap) tap_format=true;; - -T|--timeout) shift; urchin_timeout="$1" ;; + -T|--timeout) shift; urchin_timeout="${1}" ;; -v|--verbose) verbose=true;; -h|--help) urchin_help urchin_exit 0;; - --version) echo "$VERSION" + --version) echo "${VERSION}" urchin_exit;; -*) urchin_help >&2 urchin_exit 11;; @@ -492,13 +492,13 @@ you don't need to quote the TEST_SHELL variable." > /dev/stderr shift done -if ! $cycle_shell && test -f "$shell_list"; then +if ! "${cycle_shell}" && test -f "${shell_list}"; then echo "The -n/--disable-cycling and -s/--shell options clash with each other." >&2 urchin_exit 11 fi # If -s was not passed, use the available default shells. -if ! test -f "$shell_list"; then +if ! test -f "${shell_list}"; then if $cycle_shell; then for shell in $DEFAULT_SHELLS; do if which $shell > /dev/null; then @@ -511,43 +511,43 @@ if ! test -f "$shell_list"; then fi # Verify argument for main stuff -if [ "$#" != '1' ] || [ ! -e "$1" ]; then - if [ -n "$1" ] && [ ! -e "$1" ]; then - echo "No such file or directory: '$1'" >&2 +if [ "${#}" != '1' ] || [ ! -e "${1}" ]; then + if [ -n "${1}" ] && [ ! -e "${1}" ]; then + echo "No such file or directory: '${1}'" >&2 fi - echo "$USAGE" >&2 + echo "${USAGE}" >&2 urchin_exit 11 fi # Warn about strange sort commands weird_string='\n- c\n-- b\n--- c\n---- a\n' -if test $(printf "$weird_string" | sort | tr -d '[ \n-]') != cbca; then +if test $(printf "${weird_string}" | sort | tr -d '[ \n-]') != cbca; then echo 'Your version of sort sorts in dictionary order (-d) by default. Depending on how you name your tests, your Urchin output may look strange. If this is a problem, install BusyBox or BSD coreutils.' >&2 fi -if test -n "$urchin_timeout"; then +if test -n "${urchin_timeout}"; then # Choose the timeout command if timeout -t 0 true; then - TIMEOUT="timeout -t $urchin_timeout" + TIMEOUT="timeout -t ${urchin_timeout}" elif timeout 0 true; then - TIMEOUT="timeout $urchin_timeout" + TIMEOUT="timeout ${urchin_timeout}" else echo I couldn\'t figure out to use your version of timeout >&2 urchin_exit 1 fi fi -if $exit_on_not_ok && ! $run_in_series; then +if "${exit_on_not_ok}" && ! "${run_in_series}"; then echo 'You must also pass -b/--series in order to use -e/--exit-on-fail.' >&2 urchin_exit 11 fi # Run or present the Molly guard. -root="$(urchin_root "$1")" -if basename "$(fullpath "$root")" | - grep -i 'test' > /dev/null || $force; then +root="$(urchin_root "${1}")" +if basename "$(fullpath "${root}")" | + grep -i 'test' > /dev/null || "${force}"; then start=$(date +%s) @@ -555,11 +555,12 @@ if basename "$(fullpath "$root")" | # 2 urchin root # 3 Should we cycle shells? # 4 TEST_SHELL - recurse "$(fullpath "$1")" "$root" "$cycle_shell" "$TEST_SHELL" || : + recurse "$(fullpath "${1}")" "${root}" "${cycle_shell}" "${TEST_SHELL}" || : finish=$(date +%s) - report_outcome "$root" $tap_format $urchin_tmp/log $start $finish - urchin_exit $? + report_outcome "${root}" "${tap_format}" "${urchin_tmp}"/log "${start}" \ + "${finish}" + urchin_exit "${?}" else echo 'The root directory of the tests that you are running urchin on does not contain the word "test", so I am not running, @@ -567,4 +568,4 @@ in case that was an accident. Use the -f flag if you really want to run urchin on that directory.' >&2 exit_code=1 fi -urchin_exit $exit_code +urchin_exit "${exit_code}"