From 171627ab6fe880c3e24733f08c519835cb860ac1 Mon Sep 17 00:00:00 2001 From: Graham Percival Date: Wed, 11 Oct 2023 19:46:43 -0700 Subject: [PATCH] tests: use "local" variables POSIX sh does not include local variables [1], so we're switching to the convention of using: _func_var_name for local function variable names, so that we always have distinct names. This does lead to rather verbose variable names, but this is an acceptable trade-off in order to have correct program behaviour. [1] Adding "local" to POSIX was discussed, but rejected, in: https://www.austingroupbugs.net/view.php?id=767 It's possible to get "local variables" by abusing eval, but those solutions don't look appealing. --- tests/shared_test_functions.sh | 123 ++++++++++--------- tests/shared_valgrind_functions.sh | 183 +++++++++++++++-------------- 2 files changed, 159 insertions(+), 147 deletions(-) diff --git a/tests/shared_test_functions.sh b/tests/shared_test_functions.sh index 89191c5f..d4a12924 100644 --- a/tests/shared_test_functions.sh +++ b/tests/shared_test_functions.sh @@ -96,8 +96,8 @@ _prepdir() { ## find_system (cmd, args): # Look for ${cmd} in the ${PATH}, and ensure that it supports ${args}. find_system() { - cmd=$1 - cmd_with_args="$1 ${2:-}" + _find_system_cmd=$1 + _find_system_cmd_with_args="$1 ${2:-}" # Sanity check. if [ "$#" -gt "2" ]; then @@ -106,26 +106,28 @@ find_system() { fi # Look for ${cmd}; the "|| true" and -} make this work with set -e. - system_binary=$(command -v "${cmd}") || true - if [ -z "${system_binary-}" ]; then - system_binary="" - printf "System %s not found.\n" "${cmd}" 1>&2 + _find_system_binary=$(command -v "${_find_system_cmd}") || true + if [ -z "${_find_system_binary-}" ]; then + _find_system_binary="" + printf "System %s not found.\n" "${_find_system_cmd}" 1>&2 # If the command exists, check it ensures the ${args}. - elif ${cmd_with_args} 2>&1 >/dev/null | \ + elif ${_find_system_cmd_with_args} 2>&1 >/dev/null | \ grep -qE "(invalid|illegal) option"; then - system_binary="" - printf "Cannot use system %s; does not" "${cmd}" 1>&2 + _find_system_binary="" + printf "Cannot use system %s; does not" \ + "${_find_system_cmd}" 1>&2 printf " support necessary arguments.\n" 1>&2 fi - echo "${system_binary}" + echo "${_find_system_binary}" } ## has_pid (cmd): # Look for ${cmd} in ps; return 0 if ${cmd} exists. has_pid() { - cmd=$1 - pid=$(ps -Aopid,args | grep -F "${cmd}" | grep -v "grep") || true - if [ -n "${pid}" ]; then + _has_pid_cmd=$1 + _has_pid_pid=$(ps -Aopid,args | grep -F "${_has_pid_cmd}" | \ + grep -v "grep") || true + if [ -n "${_has_pid_pid}" ]; then return 0 fi return 1 @@ -167,12 +169,12 @@ wait_while() { # file. If ${check_prev} is non-zero, check that the previous # ${c_exitfile} exists. setup_check() { - description=$1 - check_prev=${2:-1} + _setup_check_description=$1 + _setup_check_prev=${2:-1} # Should we check for the previous exitfile? if [ "${c_exitfile}" != "${NO_EXITFILE}" ] && \ - [ "${check_prev}" -gt 0 ] ; then + [ "${_setup_check_prev}" -gt 0 ] ; then # Check for the file. if [ ! -f "${c_exitfile}" ] ; then # We should have written the result of the @@ -188,7 +190,7 @@ setup_check() { c_exitfile="${s_basename}-${c_count_str}.exit" # Write the "description" file. - printf "%s\n" "${description}" > \ + printf "%s\n" "${_setup_check_description}" > \ "${s_basename}-${c_count_str}.desc" # Set up the valgrind command (or an empty string). @@ -203,12 +205,14 @@ setup_check() { # ${valgrind_exit_code}, return that. Otherwise, return 1 to indicate # failure. expected_exitcode() { - expected=$1 - exitcode=$2 + _expected_exitcode_expected=$1 + _expected_exitcode_exitcode=$2 - if [ "${exitcode}" -eq "${expected}" ]; then + if [ "${_expected_exitcode_exitcode}" -eq \ + "${_expected_exitcode_expected}" ]; then echo "0" - elif [ "${exitcode}" -eq "${valgrind_exit_code}" ]; then + elif [ "${_expected_exitcode_exitcode}" -eq \ + "${valgrind_exit_code}" ]; then echo "${valgrind_exit_code}" else echo "1" @@ -223,60 +227,62 @@ expected_exitcode() { # logfile. If the test failed and ${VERBOSE} is non-zero, print # the description to stderr. _check() { - log_basename=$1 - val_log_basename=$2 + _check_log_basename=$1 + _check_val_log_basename=$2 # Bail if there's no exitfiles. - exitfiles=$(ls "${log_basename}"-*.exit) || true - if [ -z "${exitfiles}" ]; then + _check_exitfiles=$(ls "${_check_log_basename}"-*.exit) || true + if [ -z "${_check_exitfiles}" ]; then echo "FAILED" 1>&2 s_retval=1 return fi # Count results - total_exitfiles=0 - skip_exitfiles=0 + _check_total=0 + _check_skip=0 # Check each exitfile. - for exitfile in $(echo "${exitfiles}" | sort); do - ret=$(cat "${exitfile}") - total_exitfiles=$(( total_exitfiles + 1 )) - if [ "${ret}" -lt 0 ]; then - skip_exitfiles=$(( skip_exitfiles + 1 )) + for _check_exitfile in $(echo "${_check_exitfiles}" | sort); do + _check_ret=$(cat "${_check_exitfile}") + _check_total=$(( _check_total + 1 )) + if [ "${_check_ret}" -lt 0 ]; then + _check_skip=$(( _check_skip + 1 )) fi # Check for test failure. - descfile=$(echo "${exitfile}" | sed 's/\.exit/\.desc/g') - if [ "${ret}" -gt 0 ]; then + _check_descfile=$(echo "${_check_exitfile}" \ + | sed 's/\.exit/\.desc/g') + if [ "${_check_ret}" -gt 0 ]; then echo "FAILED!" 1>&2 if [ "${VERBOSE}" -ne 0 ]; then printf "File %s contains exit code %s.\n" \ - "${exitfile}" "${ret}" 1>&2 + "${_check_exitfile}" "${_check_ret}" \ + 1>&2 printf "Test description: " 1>&2 - cat "${descfile}" 1>&2 + cat "${_check_descfile}" 1>&2 fi - s_retval=${ret} + s_retval=${_check_ret} return else # If there's no failure, delete the files. - rm "${exitfile}" - rm "${descfile}" + rm "${_check_exitfile}" + rm "${_check_descfile}" fi # Check valgrind logfile(s). - val_failed="$(valgrind_check "${exitfile}")" - if [ -n "${val_failed}" ]; then + _check_val_failed="$(valgrind_check "${_check_exitfile}")" + if [ -n "${_check_val_failed}" ]; then echo "FAILED!" 1>&2 s_retval="${valgrind_exit_code}" - cat "${val_failed}" 1>&2 + cat "${_check_val_failed}" 1>&2 return fi done # Notify about skip or success. - if [ "${skip_exitfiles}" -gt 0 ]; then - if [ "${skip_exitfiles}" -eq "${total_exitfiles}" ]; then + if [ "${_check_skip}" -gt 0 ]; then + if [ "${_check_skip}" -eq "${_check_total}" ]; then echo "SKIP!" 1>&2 else echo "PARTIAL SUCCESS / SKIP!" 1>&2 @@ -289,13 +295,13 @@ _check() { ## _scenario_runner (scenario_filename): # Run a test scenario from ${scenario_filename}. _scenario_runner() { - scenario_filename=$1 - basename=$(basename "${scenario_filename}" .sh) - printf " %s... " "${basename}" 1>&2 + _scenario_runner_filename=$1 + _scenario_runner_basename=$(basename "${_scenario_runner_filename}" .sh) + printf " %s... " "${_scenario_runner_basename}" 1>&2 # Initialize "scenario" and "check" variables. - s_basename=${out}/${basename} - s_val_basename=${out_valgrind}/${basename} + s_basename=${out}/${_scenario_runner_basename} + s_val_basename=${out_valgrind}/${_scenario_runner_basename} c_count_next=0 c_exitfile="${NO_EXITFILE}" c_valgrind_min=9 @@ -303,10 +309,10 @@ _scenario_runner() { # Load scenario_cmd() from the scenario file. unset scenario_cmd - . "${scenario_filename}" + . "${_scenario_runner_filename}" if ! command -v scenario_cmd 1>/dev/null ; then printf "ERROR: scenario_cmd() is not defined in\n" 1>&2 - printf " %s\n" "${scenario_filename}" 1>&2 + printf " %s\n" "${_scenario_runner_filename}" 1>&2 exit 1 fi @@ -326,9 +332,10 @@ _scenario_runner() { run_scenarios() { # Get the test number(s) to run. if [ "${N:-0}" -gt "0" ]; then - test_scenarios="$(printf "${scriptdir}/%02d-*.sh" "${N}")" + _run_scenarios_filenames="$(printf \ + "${scriptdir}/%02d-*.sh" "${N}")" else - test_scenarios="${scriptdir}/??-*.sh" + _run_scenarios_filenames="${scriptdir}/??-*.sh" fi # Clean up any previous directory, and create a new one. @@ -340,13 +347,13 @@ run_scenarios() { printf -- "Running tests\n" 1>&2 printf -- "-------------\n" 1>&2 - for scenario in ${test_scenarios}; do + for _run_scenarios_filename in ${_run_scenarios_filenames}; do # We can't call this function with $( ... ) because we # want to allow it to echo values to stdout. - _scenario_runner "${scenario}" - retval=$? - if [ "${retval}" -gt 0 ]; then - exit "${retval}" + _scenario_runner "${_run_scenarios_filename}" + _run_scenarios_retval=$? + if [ "${_run_scenarios_retval}" -gt 0 ]; then + exit "${_run_scenarios_retval}" fi done } diff --git a/tests/shared_valgrind_functions.sh b/tests/shared_valgrind_functions.sh index b30f5cd5..2cd971b2 100644 --- a/tests/shared_valgrind_functions.sh +++ b/tests/shared_valgrind_functions.sh @@ -43,10 +43,10 @@ _val_prepdir() { fi # Move the files away. - supp_tmp="$(mktemp /tmp/valgrind-suppressions.XXXXXX)" - fds_tmp="$(mktemp /tmp/valgrind-fds.XXXXXX)" - mv "${valgrind_suppressions}" "${supp_tmp}" - mv "${valgrind_fds_log}" "${fds_tmp}" + _val_prepdir_supp_tmp="$(mktemp /tmp/valgrind-suppressions.XXXXXX)" + _val_prepdir_fds_tmp="$(mktemp /tmp/valgrind-fds.XXXXXX)" + mv "${valgrind_suppressions}" "${_val_prepdir_supp_tmp}" + mv "${valgrind_fds_log}" "${_val_prepdir_fds_tmp}" fi # Always delete any previous valgrind directory. @@ -64,8 +64,8 @@ _val_prepdir() { # If we don't want to generate a new suppressions file, restore it. if [ "${USE_VALGRIND_NO_REGEN}" -gt 0 ]; then # Move the files back. - mv "${supp_tmp}" "${valgrind_suppressions}" - mv "${fds_tmp}" "${valgrind_fds_log}" + mv "${_val_prepdir_supp_tmp}" "${valgrind_suppressions}" + mv "${_val_prepdir_fds_tmp}" "${valgrind_fds_log}" fi # We don't want to back up this directory. @@ -88,14 +88,15 @@ _val_checkver() { fi # Check the version. - version=$(valgrind --version | cut -d "-" -f 2) - major=$(echo "${version}" | cut -d "." -f 1) - minor=$(echo "${version}" | cut -d "." -f 2) - if [ "${major}" -lt "3" ]; then + _val_checkver_version=$(valgrind --version | cut -d "-" -f 2) + _val_checkver_major=$(echo "${_val_checkver_version}" | cut -d "." -f 1) + _val_checkver_minor=$(echo "${_val_checkver_version}" | cut -d "." -f 2) + if [ "${_val_checkver_major}" -lt "3" ]; then printf "valgrind must be at least version 3.13\n" 1>&2 exit 1; fi - if [ "${major}" -eq "3" ] && [ "${minor}" -lt "13" ]; then + if [ "${_val_checkver_major}" -eq "3" ] && \ + [ "${_val_checkver_minor}" -lt "13" ]; then printf "valgrind must be at least version 3.13\n" 1>&2 exit 1; fi @@ -108,31 +109,32 @@ _val_seg() { _val_seg_filename=$1 # Find last relevant line. - lastline="$(grep -n "}" "${_val_seg_filename}" | cut -f1 -d:)" + _val_seg_lastline="$(grep -n "}" "${_val_seg_filename}" | cut -f1 -d:)" # Cut off anything below the 1st "fun:pl_" (inclusive). - funcline="$(grep -n "fun:pl_" "${_val_seg_filename}" | \ + _val_seg_funcline="$(grep -n "fun:pl_" "${_val_seg_filename}" | \ cut -f1 -d: | \ head -n1)" - if [ -n "${funcline}" ]; then - if [ "${lastline}" -gt "${funcline}" ]; then - lastline="${funcline}" + if [ -n "${_val_seg_funcline}" ]; then + if [ "${_val_seg_lastline}" -gt "${_val_seg_funcline}" ]; then + _val_seg_lastline="${_val_seg_funcline}" fi fi # Cut off anything below "fun:main" (including that line). (Due to # linking and/or optimizations, some memory leaks occur without # "fun:pl_" appearing in the valgrind suppression.) - funcline="$(grep -n "fun:main" "${_val_seg_filename}" | cut -f1 -d:)" - if [ -n "${funcline}" ]; then - if [ "${lastline}" -gt "${funcline}" ]; then - lastline="${funcline}" + _val_seg_funcline="$(grep -n "fun:main" "${_val_seg_filename}" | \ + cut -f1 -d:)" + if [ -n "${_val_seg_funcline}" ]; then + if [ "${_val_seg_lastline}" -gt "${_val_seg_funcline}" ]; then + _val_seg_lastline="${_val_seg_funcline}" fi fi # Only keep the beginning of each suppression. - lastline="$((lastline - 1))" - head -n "${lastline}" "${_val_seg_filename}" >> \ + _val_seg_lastline="$((_val_seg_lastline - 1))" + head -n "${_val_seg_lastline}" "${_val_seg_filename}" >> \ "${valgrind_suppressions}" printf "}\n" >> "${valgrind_suppressions}" } @@ -141,34 +143,35 @@ _val_seg() { # Generalize suppressions from a valgrind suppression file by omitting the # "fun:pl_*" and "fun:main" lines and anything below them. _val_generalize() { - filename=$1 + _val_generalize_filename=$1 # How many segments do we have? - num_segments="$(grep -c "^{" "${filename}")" + _val_generalize_num_segments="$(grep -c "^{" "${_val_generalize_filename}")" # Bail if there's nothing to do. - if [ "${num_segments}" -eq "0" ]; then + if [ "${_val_generalize_num_segments}" -eq "0" ]; then return fi # Sanity check. - if [ "${num_segments}" -gt 100 ]; then + if [ "${_val_generalize_num_segments}" -gt 100 ]; then printf "More than 100 valgrind suppressions?!\n" 1>&2 exit 1 fi # Split into segments. - csplit -f "${filename}" "${filename}" \ - "/{/" "{$((num_segments - 1))}" > /dev/null + csplit -f "${_val_generalize_filename}" "${_val_generalize_filename}" \ + "/{/" "{$((_val_generalize_num_segments - 1))}" > /dev/null # Skip "${filename}00" because that doesn't contain a suppression. - i=1 - while [ "${i}" -le "${num_segments}" ]; do + _val_generalize_i=1 + while [ "${_val_generalize_i}" -le "${_val_generalize_num_segments}" ]; do # Process segment - _val_seg "$(printf "%s%02i" "${filename}" "${i}")" + _val_seg "$(printf "%s%02i" \ + "${_val_generalize_filename}" "${_val_generalize_i}")" # Advance to the next suppression. - i=$((i + 1)) + _val_generalize_i=$((_val_generalize_i + 1)) done } @@ -178,7 +181,7 @@ _val_generalize() { # those leaks when testing other binaries. Record a log file which shows the # open file descriptors in ${valgrind_fds_log}. _val_ensure() { - potential_memleaks_binary=$1 + _val_ensure_potential_memleaks_binary=$1 # Quit if we're not using valgrind. if [ ! "${USE_VALGRIND}" -gt 0 ]; then @@ -191,19 +194,20 @@ _val_ensure() { fi printf "Generating valgrind suppressions... " 1>&2 - valgrind_suppressions_log="${out_valgrind}/suppressions.pre" + _val_ensure_log="${out_valgrind}/suppressions.pre" # Start off with an empty suppression file touch "${valgrind_suppressions}" # Get list of tests and the number of open descriptors at a normal exit - valgrind_suppressions_tests="${out_valgrind}/suppressions-names.txt" + _val_ensure_names="${out_valgrind}/suppressions-names.txt" valgrind --track-fds=yes --log-file="${valgrind_fds_log}" \ - "${potential_memleaks_binary}" > "${valgrind_suppressions_tests}" + "${_val_ensure_potential_memleaks_binary}" \ + > "${_val_ensure_names}" # Generate suppressions for each test - while read -r testname; do - this_valgrind_supp="${valgrind_suppressions_log}-${testname}" + while read -r _val_ensure_testname; do + _val_ensure_thisl="${_val_ensure_log}-${_val_ensure_testname}" # Run valgrind on the binary, sending it a "\n" so that # a test which uses STDIN will not wait for user input. @@ -212,21 +216,22 @@ _val_ensure() { --gen-suppressions=all \ --trace-children=yes \ --suppressions="${valgrind_suppressions}" \ - --log-file="${this_valgrind_supp}" \ - "${potential_memleaks_binary}" \ - "${testname}") \ + --log-file="${_val_ensure_thisl}" \ + "${_val_ensure_potential_memleaks_binary}" \ + "${_val_ensure_testname}") \ > /dev/null # Append name to suppressions file - printf "# %s\n" "${testname}" >> "${valgrind_suppressions}" + printf "# %s\n" "${_val_ensure_testname}" \ + >> "${valgrind_suppressions}" # Strip out useless parts from the log file, and allow the # suppressions to apply to other binaries. - _val_generalize "${this_valgrind_supp}" - done < "${valgrind_suppressions_tests}" + _val_generalize "${_val_ensure_thisl}" + done < "${_val_ensure_names}" # Clean up - rm -f "${valgrind_suppressions_log}" + rm -f "${_val_ensure_log}" printf "done.\n" 1>&2 } @@ -234,7 +239,7 @@ _val_ensure() { # Set up the valgrind command if ${USE_VALGRIND} is greater than or equal to # ${valgrind_min}. If ${str} is not blank, include it in the log filename. valgrind_setup() { - str=${1:-} + _valgrind_setup_str=${1:-} # Bail if we don't want to use valgrind for this check. if [ "${USE_VALGRIND}" -lt "${c_valgrind_min}" ]; then @@ -242,21 +247,21 @@ valgrind_setup() { fi # Set up the log filename. - if [ -n "${str}" ]; then - val_logfilename="${s_val_basename}-${c_count_str}-${str}-%p.log" + if [ -n "${_valgrind_setup_str}" ]; then + _valgrind_setup_logfilename="${s_val_basename}-${c_count_str}-${_valgrind_setup_str}-%p.log" else - val_logfilename="${s_val_basename}-${c_count_str}-%p.log" + _valgrind_setup_logfilename="${s_val_basename}-${c_count_str}-%p.log" fi # Set up valgrind command. - c_valgrind_cmd="valgrind \ - --log-file=${val_logfilename} \ + _valgrind_setup_cmd="valgrind \ + --log-file=${_valgrind_setup_logfilename} \ --track-fds=yes \ --trace-children=yes \ --leak-check=full --show-leak-kinds=all \ --errors-for-leak-kinds=all \ --suppressions=${valgrind_suppressions}" - echo "${c_valgrind_cmd}" + echo "${_valgrind_setup_cmd}" } ## valgrind_incomplete: @@ -275,22 +280,22 @@ valgrind_incomplete() { # Return the filename without ".log" of the valgrind logfile corresponding to # ${exitfile}. _val_getbase() { - exitfile=$1 - basename=$(basename "${exitfile}" ".exit") - echo "${out_valgrind}/${basename}" + _val_getbase_exitfile=$1 + _val_getbase_basename=$(basename "${_val_getbase_exitfile}" ".exit") + echo "${out_valgrind}/${_val_getbase_basename}" } ## _val_checkl(logfile) # Check for any (unsuppressed) memory leaks recorded in a valgrind logfile. # Echo the filename if there's a leak; otherwise, echo nothing. _val_checkl() { - logfile=$1 + _val_checkl_logfile=$1 # Bytes in use at exit. - in_use=$(grep "in use at exit:" "${logfile}" | awk '{print $6}') + _val_checkl_in_use=$(grep "in use at exit:" "${_val_checkl_logfile}" | awk '{print $6}') # Sanity check. - if [ "$(echo "${in_use}" | wc -w)" -ne "1" ]; then + if [ "$(echo "${_val_checkl_in_use}" | wc -w)" -ne "1" ]; then echo "Programmer error: invalid number valgrind outputs" 1>&2 exit 1 fi @@ -298,16 +303,16 @@ _val_checkl() { # Check for any leaks. Use string comparison, because valgrind formats # the number with commas, and sh can't convert strings like "1,000" # into an integer. - if [ "${in_use}" != "0" ] ; then + if [ "${_val_checkl_in_use}" != "0" ] ; then # Check if all of the leaked bytes are suppressed. The extra # whitespace in " suppressed" is necessary to distinguish # between two instances of "suppressed" in the log file. Use # string comparison due to the format of the number. - suppressed=$(grep " suppressed:" "${logfile}" | \ + _val_checkl_suppressed=$(grep " suppressed:" "${_val_checkl_logfile}" | \ awk '{print $3}') - if [ "${in_use}" != "${suppressed}" ]; then + if [ "${_val_checkl_in_use}" != "${_val_checkl_suppressed}" ]; then # There is an unsuppressed leak. - echo "${logfile}" + echo "${_val_checkl_logfile}" return fi fi @@ -319,22 +324,22 @@ _val_checkl() { # descriptors. The important thing is that the number of fds should # match the simple test case (executing potential_memleaks without # running any actual tests). - fds_in_use=$(grep "FILE DESCRIPTORS" "${logfile}" | awk '{print $4}') - valgrind_fds=$(grep "FILE DESCRIPTORS" "${valgrind_fds_log}" | \ + _val_checkl_fds_in_use=$(grep "FILE DESCRIPTORS" "${_val_checkl_logfile}" | awk '{print $4}') + _val_checkl_valgrind_fds=$(grep "FILE DESCRIPTORS" "${valgrind_fds_log}" | \ awk '{print $4}') - if [ "${fds_in_use}" != "${valgrind_fds}" ] ; then + if [ "${_val_checkl_fds_in_use}" != "${_val_checkl_valgrind_fds}" ] ; then # There is an unsuppressed leak. - echo "${logfile}" + echo "${_val_checkl_logfile}" return fi # Check the error summary. - num_errors=$(grep "ERROR SUMMARY: " "${logfile}" | awk '{print $4}') - if [ "${num_errors}" -gt 0 ]; then + _val_checkl_num_errors=$(grep "ERROR SUMMARY: " "${_val_checkl_logfile}" | awk '{print $4}') + if [ "${_val_checkl_num_errors}" -gt 0 ]; then # There was some other error(s) -- invalid read or write, # conditional jump based on uninitialized value(s), invalid # free, etc. - echo "${logfile}" + echo "${_val_checkl_logfile}" return fi } @@ -344,52 +349,52 @@ _val_checkl() { # test exitfile. Return the filename if there's a leak; otherwise return an # empty string. valgrind_check() { - exitfile="$1" - val_basename=$(_val_getbase "${exitfile}") + _valgrind_check_exitfile="$1" + _valgrind_check_basename=$(_val_getbase "$1") # Get list of files to check. (Yes, the star goes outside the quotes.) - logfiles=$(ls "${val_basename}"* 2>/dev/null) - num_logfiles=$(echo "${logfiles}" | wc -w) + _valgrind_check_logfiles=$(ls "${_valgrind_check_basename}"* 2>/dev/null) + _valgrind_check_num=$(echo "${_valgrind_check_logfiles}" | wc -w) # Bail if we don't have any valgrind logfiles to check. # Use numeric comparison, because wc leaves a tab in the output. - if [ "${num_logfiles}" -eq "0" ] ; then + if [ "${_valgrind_check_num}" -eq "0" ] ; then return fi # Check a single file. - if [ "${num_logfiles}" -eq "1" ]; then - _val_checkl "${logfiles}" + if [ "${_valgrind_check_num}" -eq "1" ]; then + _val_checkl "${_valgrind_check_logfiles}" return fi # If the valgrind logfiles contain "-valgrind-parent-", then we only # want to check the parent (the lowest pid). - for logfile in ${logfiles} ; do - if [ "${logfile#*-valgrind-parent-}" != "${logfile}" ]; then + for _valgrind_check_logfile in ${_valgrind_check_logfiles} ; do + if [ "${_valgrind_check_logfile#*-valgrind-parent-}" != "${_valgrind_check_logfile}" ]; then # Only check the parent - _val_checkl "${logfile}" + _val_checkl "${_valgrind_check_logfile}" return "$?" fi done # If there's two files, there's a fork() -- likely within # daemonize() -- so only pay attention to the child. - if [ "${num_logfiles}" -eq "2" ]; then + if [ "${_valgrind_check_num}" -eq "2" ]; then # Find both pids. - val_pids="" - for logfile in ${logfiles} ; do - val_pid=$(head -n 1 "${logfile}" | cut -d "=" -f 3) - val_pids="${val_pids} ${val_pid}" + _valgrind_check_val_pids="" + for _valgrind_check_logfile in ${_valgrind_check_logfiles} ; do + _valgrind_check_val_pid=$(head -n 1 "${_valgrind_check_logfile}" | cut -d "=" -f 3) + _valgrind_check_val_pids="${_valgrind_check_val_pids} ${_valgrind_check_val_pid}" done # Find the logfile which has a parent in the list of pids. - for logfile in ${logfiles} ; do - val_parent_pid=$(grep "Parent PID:" "${logfile}" | \ + for _valgrind_check_logfile in ${_valgrind_check_logfiles} ; do + _valgrind_check_val_parent_pid=$(grep "Parent PID:" "${_valgrind_check_logfile}" | \ awk '{ print $4 }') - if [ "${val_pids#*"${val_parent_pid}"}" != \ - "${val_pids}" ]; then - _val_checkl "${logfile}" + if [ "${_valgrind_check_val_pids#*"${_valgrind_check_val_parent_pid}"}" != \ + "${_valgrind_check_val_pids}" ]; then + _val_checkl "${_valgrind_check_logfile}" return "$?" fi done