ca7e4f285c
We wish to fail if we have >0 zero errors, not >1 errors (i.e. exactly one error did not trigger a failure!) This change also brings consistency to the pass & failure paths by ensuring report_results exits in both cases, since report_results is supposed to be the last thing run in a test file. Change-Id: Id4721dffe13721e6c3cd71bca40c3395627e98bf
109 lines
2.8 KiB
Bash
109 lines
2.8 KiB
Bash
#!/usr/bin/env bash
|
|
|
|
# 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.
|
|
|
|
# we always start with no errors
|
|
ERROR=0
|
|
PASS=0
|
|
FAILED_FUNCS=""
|
|
|
|
# pass a test, printing out MSG
|
|
# usage: passed message
|
|
function passed {
|
|
local lineno
|
|
lineno=$(caller 0 | awk '{print $1}')
|
|
local function
|
|
function=$(caller 0 | awk '{print $2}')
|
|
local msg="$1"
|
|
if [ -z "$msg" ]; then
|
|
msg="OK"
|
|
fi
|
|
PASS=$((PASS+1))
|
|
echo "PASS: $function:L$lineno - $msg"
|
|
}
|
|
|
|
# fail a test, printing out MSG
|
|
# usage: failed message
|
|
function failed {
|
|
local lineno
|
|
lineno=$(caller 0 | awk '{print $1}')
|
|
local function
|
|
function=$(caller 0 | awk '{print $2}')
|
|
local msg="$1"
|
|
FAILED_FUNCS+="$function:L$lineno\n"
|
|
echo "ERROR: $function:L$lineno!"
|
|
echo " $msg"
|
|
ERROR=$((ERROR+1))
|
|
}
|
|
|
|
# assert string comparision of val1 equal val2, printing out msg
|
|
# usage: assert_equal val1 val2 msg
|
|
function assert_equal {
|
|
local lineno
|
|
lineno=`caller 0 | awk '{print $1}'`
|
|
local function
|
|
function=`caller 0 | awk '{print $2}'`
|
|
local msg=$3
|
|
|
|
if [ -z "$msg" ]; then
|
|
msg="OK"
|
|
fi
|
|
if [[ "$1" != "$2" ]]; then
|
|
FAILED_FUNCS+="$function:L$lineno\n"
|
|
echo "ERROR: $1 != $2 in $function:L$lineno!"
|
|
echo " $msg"
|
|
ERROR=$((ERROR+1))
|
|
else
|
|
PASS=$((PASS+1))
|
|
echo "PASS: $function:L$lineno - $msg"
|
|
fi
|
|
}
|
|
|
|
# assert variable is empty/blank, printing out msg
|
|
# usage: assert_empty VAR msg
|
|
function assert_empty {
|
|
local lineno
|
|
lineno=`caller 0 | awk '{print $1}'`
|
|
local function
|
|
function=`caller 0 | awk '{print $2}'`
|
|
local msg=$2
|
|
|
|
if [ -z "$msg" ]; then
|
|
msg="OK"
|
|
fi
|
|
if [[ ! -z ${!1} ]]; then
|
|
FAILED_FUNCS+="$function:L$lineno\n"
|
|
echo "ERROR: $1 not empty in $function:L$lineno!"
|
|
echo " $msg"
|
|
ERROR=$((ERROR+1))
|
|
else
|
|
PASS=$((PASS+1))
|
|
echo "PASS: $function:L$lineno - $msg"
|
|
fi
|
|
}
|
|
|
|
# Print a summary of passing and failing tests and exit
|
|
# (with an error if we have failed tests)
|
|
# usage: report_results
|
|
function report_results {
|
|
echo "$PASS Tests PASSED"
|
|
if [[ $ERROR -gt 0 ]]; then
|
|
echo
|
|
echo "The following $ERROR tests FAILED"
|
|
echo -e "$FAILED_FUNCS"
|
|
echo "---"
|
|
exit 1
|
|
fi
|
|
exit 0
|
|
}
|