mirror of
https://github.com/servalproject/serval-dna.git
synced 2025-01-30 08:03:49 +00:00
Transcribe from ./testdna to new test framework
- testframework.sh is now a very full-featured, creates test.log - some tests fail, looks like bugs in dna
This commit is contained in:
parent
1e2779a6e3
commit
f5acb301d8
1
.gitignore
vendored
1
.gitignore
vendored
@ -16,3 +16,4 @@ nacl/naclinc.txt
|
|||||||
nacl/nacllib.txt
|
nacl/nacllib.txt
|
||||||
serval.c
|
serval.c
|
||||||
dna
|
dna
|
||||||
|
test.log
|
||||||
|
540
testframework.sh
540
testframework.sh
@ -1,6 +1,6 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
#
|
#
|
||||||
# Serval Project testing framework
|
# Serval Project testing framework for Bash shell
|
||||||
# Copyright 2012 Paul Gardner-Stephen
|
# Copyright 2012 Paul Gardner-Stephen
|
||||||
#
|
#
|
||||||
# This program is free software; you can redistribute it and/or
|
# This program is free software; you can redistribute it and/or
|
||||||
@ -20,109 +20,204 @@
|
|||||||
# This file is sourced by all testing scripts. A typical test script looks
|
# This file is sourced by all testing scripts. A typical test script looks
|
||||||
# like this:
|
# like this:
|
||||||
#
|
#
|
||||||
# #!/bin/sh
|
# #!/bin/bash
|
||||||
# . testframework.sh
|
# source testframework.sh
|
||||||
# doc_feature1='Feature one works correctly'
|
# setup() {
|
||||||
|
# export BLAH_CONFIG=$TFWTMP/blah.conf
|
||||||
|
# echo "username=$LOGNAME" >$BLAH_CONFIG
|
||||||
|
# }
|
||||||
|
# teardown() {
|
||||||
|
# # $TFWTMP is always removed after every test, so no need to
|
||||||
|
# # remove blah.conf ourselves.
|
||||||
|
# }
|
||||||
|
# doc_feature1='Feature one works'
|
||||||
# test_feature1() {
|
# test_feature1() {
|
||||||
# execute feature1 --options arg1 arg2
|
# execute programUnderTest --feature1 arg1 arg2
|
||||||
# assertExitStatus == 0
|
# assertExitStatus '==' 0
|
||||||
# assertUserTime <= 0
|
# assertRealTime --message='ran in under half a second' '<=' 0.5
|
||||||
# assertStdoutIs ""
|
# assertStdoutIs ""
|
||||||
# assertStderrIs ""
|
# assertStderrIs ""
|
||||||
# }
|
# }
|
||||||
# doc_feature2='Name of feature two'
|
# doc_feature2='Feature two fails with status 1'
|
||||||
|
# setup_feature2() {
|
||||||
|
# # Overrides setup(), so we have to call it ourselves explicitly
|
||||||
|
# # here if we still want it.
|
||||||
|
# setup
|
||||||
|
# echo "option=specialValue" >>$BLAH_CONFIG
|
||||||
|
# }
|
||||||
# test_feature2() {
|
# test_feature2() {
|
||||||
# execute feature2 --options arg1 arg2
|
# execute programUnderTest --feature2 arg1 arg2
|
||||||
# assertExitStatus == 1
|
# assertExitStatus '==' 1
|
||||||
# assertStdoutIs ""
|
# assertStdoutIs ""
|
||||||
# assertStderrGrep "^ERROR: missing arg3$"
|
# assertStderrGrep "^ERROR: missing arg3$"
|
||||||
# }
|
# }
|
||||||
# runTests
|
# runTests "$@"
|
||||||
|
|
||||||
|
usage() {
|
||||||
|
echo "Usage: ${0##*/} [-t|--trace] [-v|--verbose] [--filter=prefix] [--]"
|
||||||
|
}
|
||||||
|
|
||||||
runTests() {
|
runTests() {
|
||||||
_tfw_stdout=1
|
_tfw_stdout=1
|
||||||
_tfw_stderr=2
|
_tfw_stdout=1
|
||||||
_tfw_checkBashVersion
|
_tfw_checkBashVersion
|
||||||
_tfw_setup
|
_tfw_trace=false
|
||||||
for testName in `_tfw_findTests` ; do
|
_tfw_verbose=false
|
||||||
local docvar="doc_$testName"
|
_tfw_logfile=test.log
|
||||||
_tfw_echo "${!docvar:-$testName}"
|
local allargs="$*"
|
||||||
(
|
local filter=
|
||||||
set -e
|
while [ $# -ne 0 ]; do
|
||||||
setup
|
case "$1" in
|
||||||
trap 'stat=$?; teardown; exit $stat' 0
|
--help) usage; exit 0;;
|
||||||
test_$testName
|
-t|--trace) _tfw_trace=true;;
|
||||||
)
|
-v|--verbose) _tfw_verbose=true;;
|
||||||
stat=$?
|
--filter=*) filter="${1#*=}";;
|
||||||
[ $stat -eq 255 ] && exit 255 # Bail out if _tfw_fatal was called in a test
|
--) shift; break;;
|
||||||
if [ $stat -eq 0 ]; then
|
--*) _tfw_fatal "unsupported option: $1";;
|
||||||
_tfw_echo PASS
|
*) _tfw_fatal "spurious argument: $1";;
|
||||||
else
|
esac
|
||||||
_tfw_echo FAIL
|
shift
|
||||||
|
# Kick off the log file.
|
||||||
|
done
|
||||||
|
{
|
||||||
|
date
|
||||||
|
echo "$0 $allargs"
|
||||||
|
} >$_tfw_logfile
|
||||||
|
# Iterate through all test cases.
|
||||||
|
local testcount=0
|
||||||
|
local passcount=0
|
||||||
|
for testName in `_tfw_findTests`
|
||||||
|
do
|
||||||
|
_tfw_testname=$testName
|
||||||
|
if [ -z "$filter" -o "${testName#$filter}" != "$testName" ]; then
|
||||||
|
let testcount=testcount+1
|
||||||
|
(
|
||||||
|
local docvar="doc_$testName"
|
||||||
|
_tfw_echo -n "$testcount. ${!docvar:-$testName}..."
|
||||||
|
trap '_tfw_status=$?; _tfw_teardown; exit $_tfw_status' 0 1 2 15
|
||||||
|
_tfw_result=ERROR
|
||||||
|
_tfw_setup
|
||||||
|
_tfw_result=FAIL
|
||||||
|
_tfw_phase=testcase
|
||||||
|
echo "# call test_$testName()"
|
||||||
|
$_tfw_trace && set -x
|
||||||
|
test_$testName
|
||||||
|
_tfw_result=PASS
|
||||||
|
exit 0
|
||||||
|
)
|
||||||
|
local stat=$?
|
||||||
|
case $stat in
|
||||||
|
255) exit 255;; # _tfw_fatal was called
|
||||||
|
254) _tfw_echo " ERROR";; # _tfw_failexit was called in setup or teardown or _tfw_error was called anywhere
|
||||||
|
0) _tfw_echo " PASS"; let passcount=passcount+1;;
|
||||||
|
*) _tfw_echo " FAIL";;
|
||||||
|
esac
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
return 0
|
s=$([ $testcount -eq 1 ] || echo s)
|
||||||
|
_tfw_echo "$testcount test$s, $passcount passed"
|
||||||
|
[ $passcount -eq $testcount ]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# The following functions can be overridden by a test script to provide a
|
||||||
|
# default fixture for all test cases.
|
||||||
|
|
||||||
setup() {
|
setup() {
|
||||||
: # To be overridden by the test script
|
:
|
||||||
}
|
}
|
||||||
|
|
||||||
teardown() {
|
teardown() {
|
||||||
: # To be overridden by the test script
|
:
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# The following functions are provided to facilitate writing test cases and
|
||||||
|
# fixtures.
|
||||||
|
|
||||||
execute() {
|
execute() {
|
||||||
_tfw_last_argv0="$1"
|
_tfw_last_argv0="$1"
|
||||||
/usr/bin/time --portability --output=$_tfw_tmp/times "$@" >$_tfw_tmp/stdout 2>$_tfw_tmp/stderr
|
echo "# execute $*"
|
||||||
|
/usr/bin/time --format='realtime=%e;usertime=%U;systime=%S' --output=$_tfw_tmp/times "$@" >$_tfw_tmp/stdout 2>$_tfw_tmp/stderr
|
||||||
_tfw_exitStatus=$?
|
_tfw_exitStatus=$?
|
||||||
}
|
echo "# Exit status = $_tfw_exitStatus"
|
||||||
|
if grep --quiet --invert-match --regexp='^realtime=[0-9.]*;usertime=[0-9.]*;systime=[0-9.]*$' $_tfw_tmp/times; then
|
||||||
assert() {
|
echo "# Times file contains spurious data:"
|
||||||
local message="$1"
|
_tfw_cat $_tfw_tmp/times
|
||||||
shift
|
if [ $_tfw_exitStatus -eq 0 ]; then
|
||||||
[ -z "$message" ] && message="assertion $@"
|
_tfw_exitStatus=255
|
||||||
if ! "$@"; then
|
echo "# Deeming exit status of command to be $_tfw_exitStatus"
|
||||||
fail "assertion failed: $message"
|
fi
|
||||||
|
realtime=0
|
||||||
|
usertime=0
|
||||||
|
systime=0
|
||||||
|
realtime_ms=0
|
||||||
|
#usertime_ms=0
|
||||||
|
#systime_ms=0
|
||||||
|
else
|
||||||
|
source $_tfw_tmp/times
|
||||||
|
realtime_ms=$(/usr/bin/awk "BEGIN { print int($realtime * 1000) }")
|
||||||
|
#usertime_ms=$(/usr/bin/awk "BEGIN { print int($usertime * 1000) }")
|
||||||
|
#systime_ms=$(/usr/bin/awk "BEGIN { print int($systime * 1000) }")
|
||||||
fi
|
fi
|
||||||
}
|
|
||||||
|
|
||||||
_tfw_cmp() {
|
|
||||||
[ $# -ne 3 ] && _tfw_error 2 "incorrect arguments"
|
|
||||||
local arg1="$1"
|
|
||||||
local op="$2"
|
|
||||||
local arg2="$3"
|
|
||||||
case $op in
|
|
||||||
'=='|'!='|'<'|'<='|'>'|'>=') awkop="$op";;
|
|
||||||
'~'|'!~') awkop="$op";;
|
|
||||||
*) _tfw_error "invalid operator: $op";;
|
|
||||||
esac
|
|
||||||
/usr/bin/awk -v arg1="$arg1" -v arg2="$arg2" -- 'BEGIN { exit (arg1 '"$awkop"' arg2) ? 0 : 1 }' </dev/null
|
|
||||||
}
|
|
||||||
|
|
||||||
assertCmp() {
|
|
||||||
local message="$1 (${2:-''} $3 ${4:-''})"
|
|
||||||
shift
|
|
||||||
assert "$message" _tfw_cmp "$@"
|
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
|
|
||||||
log() {
|
assert() {
|
||||||
_tfw_echo "$@"
|
_tfw_getopts_assert assert "$@"
|
||||||
|
shift $_tfw_getopts_shift
|
||||||
|
_tfw_assert "$@" || _tfw_failexit
|
||||||
|
echo "# Assertion passed: $*"
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
assertExpr() {
|
||||||
|
_tfw_getopts_assert assertexpr "$@"
|
||||||
|
shift $_tfw_getopts_shift
|
||||||
|
local awkexpr=$(_tfw_expr_to_awkexpr "$@")
|
||||||
|
_tfw_message="${_tfw_message+$_tfw_message }($awkexpr)"
|
||||||
|
_tfw_assert _tfw_eval_awkexpr "$awkexpr" || _tfw_failexit
|
||||||
|
echo "# Assertion passed: $awkexpr"
|
||||||
|
return 0
|
||||||
}
|
}
|
||||||
|
|
||||||
fail() {
|
fail() {
|
||||||
_tfw_echo "$1"
|
_tfw_getopts_assert fail "$@"
|
||||||
exit 1
|
shift $_tfw_getopts_shift
|
||||||
|
[ $# -ne 0 ] && _tfw_failmsg "$1"
|
||||||
|
_tfw_backtrace >&2
|
||||||
|
_tfw_failexit
|
||||||
|
}
|
||||||
|
|
||||||
|
error() {
|
||||||
|
_tfw_getopts_assert error "$@"
|
||||||
|
shift $_tfw_getopts_shift
|
||||||
|
[ $# -ne 0 ] && _tfw_errormsg "$1"
|
||||||
|
_tfw_backtrace >&2
|
||||||
|
_tfw_errorexit
|
||||||
|
}
|
||||||
|
|
||||||
|
fatal() {
|
||||||
|
[ $# -eq 0 ] && set -- "no reason given"
|
||||||
|
_tfw_fatalmsg "$@"
|
||||||
|
_tfw_backtrace >&2
|
||||||
|
_tfw_fatalexit
|
||||||
}
|
}
|
||||||
|
|
||||||
assertExitStatus() {
|
assertExitStatus() {
|
||||||
assertCmp "exit status of ${_tfw_last_argv0##*/} $_tfw_exitStatus $*" "$_tfw_exitStatus" "$@"
|
_tfw_getopts_assert exitstatus "$@"
|
||||||
|
shift $_tfw_getopts_shift
|
||||||
|
[ -z "$_tfw_message" ] && _tfw_message="exit status of ${_tfw_last_argv0##*/} ($_tfw_exitStatus) $*"
|
||||||
|
_tfw_assertExpr "$_tfw_exitStatus" "$@" || _tfw_failexit
|
||||||
|
echo "# Assertion passed: $_tfw_message"
|
||||||
|
return 0
|
||||||
}
|
}
|
||||||
|
|
||||||
assertRealTime() {
|
assertRealTime() {
|
||||||
local realtime=$(awk '$1 == "real" { print $2 }' $_tfw_tmp/times)
|
_tfw_getopts_assert realtime "$@"
|
||||||
assertCmp "real execution time of ${_tfw_last_argv0##*/}" "$realtime" "$@"
|
shift $_tfw_getopts_shift
|
||||||
|
[ -z "$_tfw_message" ] && _tfw_message="real execution time of ${_tfw_last_argv0##*/} ($realtime) $*"
|
||||||
|
_tfw_assertExpr "$realtime" "$@" || _tfw_failexit
|
||||||
|
echo "# Assertion passed: $_tfw_message"
|
||||||
|
return 0
|
||||||
}
|
}
|
||||||
|
|
||||||
replayStdout() {
|
replayStdout() {
|
||||||
@ -134,48 +229,235 @@ replayStderr() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
assertStdoutIs() {
|
assertStdoutIs() {
|
||||||
_tfw_assert_stdxxx_is stdout "$@"
|
_tfw_assert_stdxxx_is stdout "$@" || _tfw_failexit
|
||||||
}
|
}
|
||||||
|
|
||||||
assertStderrIs() {
|
assertStderrIs() {
|
||||||
_tfw_assert_stdxxx_is stderr "$@"
|
_tfw_assert_stdxxx_is stderr "$@" || _tfw_failexit
|
||||||
}
|
}
|
||||||
|
|
||||||
assertStdoutGrep() {
|
assertStdoutGrep() {
|
||||||
_tfw_assert_stdxxx_grep stdout "$@"
|
_tfw_assert_stdxxx_grep stdout "$@" || _tfw_failexit
|
||||||
}
|
}
|
||||||
|
|
||||||
assertStderrGrep() {
|
assertStderrGrep() {
|
||||||
_tfw_assert_stdxxx_grep stderr "$@"
|
_tfw_assert_stdxxx_grep stderr "$@" || _tfw_failexit
|
||||||
|
}
|
||||||
|
|
||||||
|
# Internal (private) functions that are not to be invoked directly from test
|
||||||
|
# scripts.
|
||||||
|
|
||||||
|
_tfw_setup() {
|
||||||
|
_tfw_phase=setup
|
||||||
|
_tfw_tmp=/tmp/_tfw-$$
|
||||||
|
/bin/mkdir $_tfw_tmp
|
||||||
|
exec <&- 5>&1 5>&2 >$_tfw_tmp/log.stdout 2>$_tfw_tmp/log.stderr 6>$_tfw_tmp/log.xtrace
|
||||||
|
BASH_XTRACEFD=6
|
||||||
|
_tfw_stdout=5
|
||||||
|
_tfw_stderr=5
|
||||||
|
if $_tfw_verbose; then
|
||||||
|
# These tail processes will die when the test case's subshell exits.
|
||||||
|
tail --pid=$$ --follow $_tfw_tmp/log.stdout >&$_tfw_stdout 2>/dev/null &
|
||||||
|
tail --pid=$$ --follow $_tfw_tmp/log.stderr >&$_tfw_stderr 2>/dev/null &
|
||||||
|
fi
|
||||||
|
export TFWTMP=$_tfw_tmp/tmp
|
||||||
|
/bin/mkdir $TFWTMP
|
||||||
|
echo '# SETUP'
|
||||||
|
case `type -t setup_$testName` in
|
||||||
|
function)
|
||||||
|
echo "# call setup_$testName()"
|
||||||
|
$_tfw_trace && set -x
|
||||||
|
setup_$testName $testName
|
||||||
|
set +x
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "# call setup($testName)"
|
||||||
|
$_tfw_trace && set -x
|
||||||
|
setup $testName
|
||||||
|
set +x
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
echo '# END SETUP'
|
||||||
|
}
|
||||||
|
|
||||||
|
_tfw_teardown() {
|
||||||
|
_tfw_phase=teardown
|
||||||
|
echo '# TEARDOWN'
|
||||||
|
case `type -t teardown_$testName` in
|
||||||
|
function)
|
||||||
|
echo "# call teardown_$testName()"
|
||||||
|
$_tfw_trace && set -x
|
||||||
|
teardown_$testName
|
||||||
|
set +x
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "# call teardown($testName)"
|
||||||
|
$_tfw_trace && set -x
|
||||||
|
teardown $testName
|
||||||
|
set +x
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
echo '# END TEARDOWN'
|
||||||
|
{
|
||||||
|
local banner="==================== $_tfw_testname ===================="
|
||||||
|
echo "$banner"
|
||||||
|
echo "TEST RESULT: $_tfw_result"
|
||||||
|
echo '++++++++++ log.stdout ++++++++++'
|
||||||
|
cat $_tfw_tmp/log.stdout
|
||||||
|
echo '++++++++++'
|
||||||
|
echo '++++++++++ log.stderr ++++++++++'
|
||||||
|
cat $_tfw_tmp/log.stderr
|
||||||
|
echo '++++++++++'
|
||||||
|
if $_tfw_trace; then
|
||||||
|
echo '++++++++++ log.xtrace ++++++++++'
|
||||||
|
cat $_tfw_tmp/log.xtrace
|
||||||
|
echo '++++++++++'
|
||||||
|
fi
|
||||||
|
echo "${banner//[^=]/=}"
|
||||||
|
} >>$_tfw_logfile
|
||||||
|
/bin/rm -rf $_tfw_tmp
|
||||||
|
}
|
||||||
|
|
||||||
|
_tfw_assert() {
|
||||||
|
if ! "$@"; then
|
||||||
|
_tfw_failmsg "assertion failed: ${_tfw_message:-$*}"
|
||||||
|
_tfw_backtrace >&2
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
_tfw_getopts_assert() {
|
||||||
|
local context="$1"
|
||||||
|
shift
|
||||||
|
_tfw_message=
|
||||||
|
_tfw_dump_stdout_on_fail=false
|
||||||
|
_tfw_dump_stderr_on_fail=false
|
||||||
|
_tfw_opt_matches=
|
||||||
|
_tfw_getopts_shift=0
|
||||||
|
while [ $# -ne 0 ]; do
|
||||||
|
case "$context:$1" in
|
||||||
|
*:--message=*) _tfw_message="${1#*=}";;
|
||||||
|
*:--stdout) _tfw_dump_stdout_on_fail=true;;
|
||||||
|
*:--stderr) _tfw_dump_stderr_on_fail=true;;
|
||||||
|
filegrep:--matches=*) _tfw_opt_matches="${1#*=}";;
|
||||||
|
*:--) let _tfw_getopts_shift=_tfw_getopts_shift+1; shift; break;;
|
||||||
|
*:--*) _tfw_error "unsupported option: $1";;
|
||||||
|
*) break;;
|
||||||
|
esac
|
||||||
|
let _tfw_getopts_shift=_tfw_getopts_shift+1
|
||||||
|
shift
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
_tfw_expr_to_awkexpr() {
|
||||||
|
local awkexpr=
|
||||||
|
for arg; do
|
||||||
|
if [ -z "${arg//[0-9]}" ]; then
|
||||||
|
awkexpr="${awkexpr:+$awkexpr }$arg"
|
||||||
|
else
|
||||||
|
case $arg in
|
||||||
|
'==' | '!=' | '<' | '<=' | '>' | '>=' | \
|
||||||
|
'~' | '!~' | '&&' | '||' | '!' )
|
||||||
|
awkexpr="${awkexpr:+$awkexpr }$arg"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
arg=${arg//\\/\\\\} #} restore Vim syntax highlighting
|
||||||
|
arg=${arg//"/\\"}
|
||||||
|
awkexpr="${awkexpr:+$awkexpr }\"$arg\""
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
echo $awkexpr
|
||||||
|
}
|
||||||
|
|
||||||
|
_tfw_eval_awkexpr() {
|
||||||
|
local awkerrs # on separate line so we don't lose exit status
|
||||||
|
awkerrs=$(/usr/bin/awk "BEGIN { exit(($*) ? 0 : 1) }" </dev/null 2>&1)
|
||||||
|
local stat=$?
|
||||||
|
if [ -n "$awkerrs" ]; then
|
||||||
|
_tfw_error "invalid expression: $*"
|
||||||
|
stat=254
|
||||||
|
fi
|
||||||
|
return $stat
|
||||||
|
}
|
||||||
|
|
||||||
|
_tfw_assertExpr() {
|
||||||
|
local awkexpr=$(_tfw_expr_to_awkexpr "$@")
|
||||||
|
_tfw_assert _tfw_eval_awkexpr "$awkexpr" || _tfw_failexit
|
||||||
|
echo "# Assertion passed: $awkexpr"
|
||||||
}
|
}
|
||||||
|
|
||||||
_tfw_assert_stdxxx_is() {
|
_tfw_assert_stdxxx_is() {
|
||||||
[ $# -ne 2 ] && _tfw_error 2 "incorrect arguments"
|
local qual="$1"
|
||||||
if ! [ "$2" = $(/bin/cat $_tfw_tmp/$1) ]; then
|
shift
|
||||||
_tfw_echo "assertion failed: $1 of ${_tfw_last_argv0##*/} is \"$2\""
|
_tfw_getopts_assert filecontent --$qual "$@"
|
||||||
_tfw_cat --$1
|
shift $_tfw_getopts_shift
|
||||||
exit 1
|
if [ $# -ne 1 ]; then
|
||||||
|
_tfw_error "incorrect arguments"
|
||||||
|
return 254
|
||||||
fi
|
fi
|
||||||
|
local message="${_tfw_message:-$qual of ${_tfw_last_argv0##*/} is \"$1\"}"
|
||||||
|
if ! [ "$1" = $(/bin/cat $_tfw_tmp/$qual) ]; then
|
||||||
|
_tfw_failmsg "assertion failed: $message"
|
||||||
|
_tfw_backtrace >&2
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
echo "# Assertion passed: $message"
|
||||||
|
return 0
|
||||||
}
|
}
|
||||||
|
|
||||||
_tfw_assert_stdxxx_grep() {
|
_tfw_assert_stdxxx_grep() {
|
||||||
[ $# -ne 2 ] && _tfw_error 2 "incorrect arguments"
|
local qual="$1"
|
||||||
if ! /bin/grep --quiet --regexp="$2" $_tfw_tmp/$1; then
|
shift
|
||||||
_tfw_echo "assertion failed: $1 of ${_tfw_last_argv0##*/} matches \"$2\""
|
_tfw_getopts_assert filegrep --$qual "$@"
|
||||||
_tfw_cat --$1
|
shift $((_tfw_getopts_shift - 1))
|
||||||
exit 1
|
if [ $# -ne 1 ]; then
|
||||||
|
_tfw_error "incorrect arguments"
|
||||||
|
return 254
|
||||||
fi
|
fi
|
||||||
|
local message="${_tfw_message:-$qual of ${_tfw_last_argv0##*/} contains a line matching \"$1\"}"
|
||||||
|
local matches=$(/bin/grep --regexp="$1" $_tfw_tmp/$qual | /usr/bin/wc --lines)
|
||||||
|
if [ -z "$_tfw_opt_matches" ]; then
|
||||||
|
message="${_tfw_message:-$qual of ${_tfw_last_argv0##*/} contains a line matching \"$1\"}"
|
||||||
|
if [ $matches -eq 0 ]; then
|
||||||
|
_tfw_failmsg "assertion failed: $message"
|
||||||
|
_tfw_backtrace >&2
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
elif [ -z "${_tfw_opt_matches//[0-9]}" ]; then
|
||||||
|
message="${_tfw_message:-$qual of ${_tfw_last_argv0##*/} contains exactly $_tfw_opt_matches line$s matching \"$1\"}"
|
||||||
|
if [ $matches -ne $_tfw_opt_matches ]; then
|
||||||
|
local s=$([ $_tfw_opt_matches -ne 1 ] && echo s)
|
||||||
|
_tfw_failmsg "assertion failed: $message"
|
||||||
|
_tfw_backtrace >&2
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
_tfw_error "unsupported value for --matches=$_tfw_opt_matches"
|
||||||
|
return 254
|
||||||
|
fi
|
||||||
|
echo "# Assertion passed: $message"
|
||||||
|
return 0
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Write to the real stdout of the test script.
|
||||||
_tfw_echo() {
|
_tfw_echo() {
|
||||||
echo "$@" >&$_tfw_stdout
|
echo "$@" >&$_tfw_stdout
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Write a message to the real stderr of the test script, so the user sees it
|
||||||
|
# immediately. Also write the message to the stderr log, so it can be recovered
|
||||||
|
# later.
|
||||||
_tfw_echoerr() {
|
_tfw_echoerr() {
|
||||||
echo "$@" >&$_tfw_stderr
|
echo "$@" >&$_tfw_stderr
|
||||||
|
if [ $_tfw_stderr -ne 2 ]; then
|
||||||
|
echo "$@" >&2
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
_tfw_catguts() {
|
_tfw_cat() {
|
||||||
for file; do
|
for file; do
|
||||||
case $file in
|
case $file in
|
||||||
--stdout)
|
--stdout)
|
||||||
@ -197,29 +479,6 @@ _tfw_catguts() {
|
|||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
_tfw_cat() {
|
|
||||||
_tfw_catguts "$@" >&$_tfw_stdout
|
|
||||||
}
|
|
||||||
|
|
||||||
_tfw_caterr() {
|
|
||||||
_tfw_catguts "$@" >&$_tfw_stderr
|
|
||||||
}
|
|
||||||
|
|
||||||
_tfw_setup() {
|
|
||||||
_tfw_tmp=/tmp/_tfw-$$
|
|
||||||
/bin/mkdir $_tfw_tmp
|
|
||||||
trap 'stat=$?; _tfw_teardown; exit $stat' 0 1 2 15
|
|
||||||
exec <&- 5>&1 5>&2 >$_tfw_tmp/log.stdout 2>$_tfw_tmp/log.stderr
|
|
||||||
_tfw_stdout=5
|
|
||||||
_tfw_stderr=5
|
|
||||||
export TFWTMP=$_tfw_tmp/tmp
|
|
||||||
/bin/mkdir $TFWTMP
|
|
||||||
}
|
|
||||||
|
|
||||||
_tfw_teardown() {
|
|
||||||
/bin/rm -rf $_tfw_tmp
|
|
||||||
}
|
|
||||||
|
|
||||||
_tfw_checkBashVersion() {
|
_tfw_checkBashVersion() {
|
||||||
case $BASH_VERSION in
|
case $BASH_VERSION in
|
||||||
[56789].* | 4.[23456789].*) ;;
|
[56789].* | 4.[23456789].*) ;;
|
||||||
@ -229,20 +488,73 @@ _tfw_checkBashVersion() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
_tfw_findTests() {
|
_tfw_findTests() {
|
||||||
builtin declare -F | sed -n -e '/^declare -f test_..*/s/^declare -f test_//p'
|
builtin declare -F | sed -n -e '/^declare -f test_..*/s/^declare -f test_//p' | sort
|
||||||
}
|
}
|
||||||
|
|
||||||
_tfw_error() {
|
# A "fail" event occurs when any assertion fails, and indicates that the test
|
||||||
local up=1
|
# has not passed. Other tests may still proceed. A "fail" event during setup
|
||||||
if [ $# -gt 1 ]; then
|
# or teardown is treated as an error, not a failure.
|
||||||
case $1 in
|
|
||||||
[1-9]) up=$1; shift;;
|
_tfw_failmsg() {
|
||||||
esac
|
# A failure during setup or teardown is treated as an error.
|
||||||
fi
|
case $_tfw_phase in
|
||||||
echo "${BASH_SOURCE[$up]}: ERROR in ${FUNCNAME[$up]}: $*" >&$_tfw_stderr
|
testcase) echo "FAIL: $*";;
|
||||||
exit 1
|
*) echo "ERROR: $*" >&2;;
|
||||||
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_tfw_backtrace() {
|
||||||
|
local -i up=1
|
||||||
|
while [ "${BASH_SOURCE[$up]}" == "${BASH_SOURCE[0]}" ]; do
|
||||||
|
let up=up+1
|
||||||
|
done
|
||||||
|
local -i i=0
|
||||||
|
while [ $up -lt ${#FUNCNAME[*]} -a "${BASH_SOURCE[$up]}" != "${BASH_SOURCE[0]}" ]; do
|
||||||
|
echo "[$i] ${FUNCNAME[$(($up-1))]}() called from ${FUNCNAME[$up]}() at line ${BASH_LINENO[$(($up-1))]} of ${BASH_SOURCE[$up]}"
|
||||||
|
let up=up+1
|
||||||
|
let i=i+1
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
_tfw_failexit() {
|
||||||
|
# When exiting a test case due to a failure, log any diagnostic output that
|
||||||
|
# has been requested.
|
||||||
|
$_tfw_dump_stdout_on_fail && _tfw_cat --stdout
|
||||||
|
$_tfw_dump_stderr_on_fail && _tfw_cat --stderr
|
||||||
|
# A failure during setup or teardown is treated as an error.
|
||||||
|
case $_tfw_phase in
|
||||||
|
testcase) exit 1;;
|
||||||
|
*) _tfw_errorexit;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
# An "error" event prevents a test from running, so it neither passes nor fails.
|
||||||
|
# Other tests may still proceed.
|
||||||
|
|
||||||
|
_tfw_error() {
|
||||||
|
local -i up=1
|
||||||
|
while true; do
|
||||||
|
case ${FUNCNAME[$up]} in
|
||||||
|
_tfw_*) let up=up+1;;
|
||||||
|
*) break;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
echo "ERROR in ${FUNCNAME[$up]}: $*" >&2
|
||||||
|
_tfw_backtrace >&2
|
||||||
|
_tfw_errorexit
|
||||||
|
}
|
||||||
|
|
||||||
|
_tfw_errorexit() {
|
||||||
|
# Do not exit process during teardown
|
||||||
|
case $_tfw_phase in
|
||||||
|
teardown) _tfw_result=ERROR; [ $_tfw_status -lt 254 ] && _tfw_status=254;;
|
||||||
|
*) exit 254;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
# A "fatal" event stops the entire test run, and generally indicates an
|
||||||
|
# insurmountable problem in the test script or in the test framework itself.
|
||||||
|
|
||||||
_tfw_fatalmsg() {
|
_tfw_fatalmsg() {
|
||||||
_tfw_echoerr "${BASH_SOURCE[1]}: FATAL: $*"
|
_tfw_echoerr "${BASH_SOURCE[1]}: FATAL: $*"
|
||||||
}
|
}
|
||||||
|
@ -1,35 +1,320 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Test script for Serval DNA executable.
|
||||||
|
# Copyright 2012 Paul Gardner-Stephen
|
||||||
|
#
|
||||||
|
# This program is free software; you can redistribute it and/or
|
||||||
|
# modify it under the terms of the GNU General Public License
|
||||||
|
# as published by the Free Software Foundation; either version 2
|
||||||
|
# of the License, or (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program; if not, write to the Free Software
|
||||||
|
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
|
||||||
source "${0%/*}/../testframework.sh"
|
source "${0%/*}/../testframework.sh"
|
||||||
dna="${0%/*}/../dna"
|
dna="${0%/*}/../dna"
|
||||||
|
|
||||||
|
# Default setup function
|
||||||
setup() {
|
setup() {
|
||||||
export SERVALINSTANCE_PATH=$TFWTMP/dna
|
export SERVALINSTANCE_PATH=$TFWTMP/dna
|
||||||
hlr_dat=$SERVALINSTANCE_PATH/hlr.dat
|
|
||||||
mkdir $SERVALINSTANCE_PATH
|
mkdir $SERVALINSTANCE_PATH
|
||||||
|
hlr_dat=$SERVALINSTANCE_PATH/hlr.dat
|
||||||
|
}
|
||||||
|
|
||||||
|
# Default teardown function
|
||||||
|
teardown() {
|
||||||
|
stop_dna_server
|
||||||
|
}
|
||||||
|
|
||||||
|
# Utility function
|
||||||
|
start_dna_server() {
|
||||||
|
# Ensure there are no existing DNA servers
|
||||||
|
pids=$(ps -u$UID | awk '$4 == "dna" {print $1}')
|
||||||
|
if [ -n "$pids" ]; then
|
||||||
|
error "cannot run test: dna process already running with pid: $pids"
|
||||||
|
fi
|
||||||
# Start DNA server
|
# Start DNA server
|
||||||
"$dna" -n -vvv -S 1 -f $hlr_dat >$SERVALINSTANCE_PATH/dna.log 2>&1 &
|
$dna -v verbose -f $hlr_dat -S 1 -n "$@" >$TFWTMP/dna.log 2>&1 &
|
||||||
sleep 1
|
sleep 1
|
||||||
pids=$(ps -u$UID | awk '$4 == "dna" {print $1}')
|
pids=$(ps -u$UID | awk '$4 == "dna" {print $1}')
|
||||||
if [ -z "$pids" ]; then
|
if [ -z "$pids" ]; then
|
||||||
_tfw_fatalmsg "dna did not start"
|
echo "dna server did not start"
|
||||||
_tfw_caterr $SERVALINSTANCE_PATH/dna.log
|
echo "--- dna.log ---"
|
||||||
_tfw_fatalexit
|
cat $SERVALINSTANCE_PATH/dna.log
|
||||||
|
echo "---"
|
||||||
|
fail
|
||||||
|
fi
|
||||||
|
if ! [ -s $SERVALINSTANCE_PATH/serval.pid ] && kill -0 $(cat $SERVALINSTANCE_PATH/serval.pid); then
|
||||||
|
echo "serval.pid was not created"
|
||||||
|
echo "--- dna.log ---"
|
||||||
|
cat $SERVALINSTANCE_PATH/dna.log
|
||||||
|
echo "---"
|
||||||
|
fail
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
teardown() {
|
# Utility function
|
||||||
|
stop_dna_server() {
|
||||||
[ -s $SERVALINSTANCE_PATH/serval.pid ] && kill $(cat $SERVALINSTANCE_PATH/serval.pid)
|
[ -s $SERVALINSTANCE_PATH/serval.pid ] && kill $(cat $SERVALINSTANCE_PATH/serval.pid)
|
||||||
|
if [ -s $TFWTMP/dna.log ]; then
|
||||||
|
echo '--- dna.log ---'
|
||||||
|
cat $TFWTMP/dna.log
|
||||||
|
echo '---'
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
doc_CreateSID='Create a new SID in <<3 seconds'
|
# Utility function
|
||||||
|
create_sid() {
|
||||||
|
execute $dna "$@" -d 0427679796 -C
|
||||||
|
assertExitStatus '==' 0
|
||||||
|
assertStdoutGrep --matches=1 '^OK:'
|
||||||
|
sid=`replayStdout | grep '^OK:' | cut -f2 -d:`
|
||||||
|
}
|
||||||
|
|
||||||
|
# Utility function
|
||||||
|
set_short_var() {
|
||||||
|
execute $dna -s $sid -i 0 -W note="a short literal value"
|
||||||
|
assertExitStatus '==' 0
|
||||||
|
}
|
||||||
|
|
||||||
|
# Utility function
|
||||||
|
echo_long_message() {
|
||||||
|
local i=0
|
||||||
|
while [ $i -lt 100 ]; do
|
||||||
|
echo "${i}ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890-${i}"
|
||||||
|
let i=i+1
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
# Test case, transcribed from ../testdna
|
||||||
|
doc_CreateSID='Create new SID'
|
||||||
|
setup_CreateSID() {
|
||||||
|
setup
|
||||||
|
start_dna_server
|
||||||
|
}
|
||||||
test_CreateSID() {
|
test_CreateSID() {
|
||||||
execute "$dna" -d 0427679796 -C
|
create_sid
|
||||||
|
assertRealTime '<' 0.5
|
||||||
|
assertExpr --stdout --message='valid SID was returned' "$sid" '~' '[0-9A-F]+'
|
||||||
|
}
|
||||||
|
|
||||||
|
# Test case, transcribed from ../testdna
|
||||||
|
doc_GetShortVar='Get short variable'
|
||||||
|
setup_GetShortVar() {
|
||||||
|
setup
|
||||||
|
start_dna_server
|
||||||
|
create_sid
|
||||||
|
}
|
||||||
|
test_GetShortVar() {
|
||||||
|
execute $dna -d 0427679796 -R dids
|
||||||
|
assertExitStatus '==' 0
|
||||||
|
assertRealTime '>' 2.9 # Waited for all replies
|
||||||
|
assertStdoutGrep --message='received an existing DID' "^DIDS:${sid}:[0-9]\+:0:0427679796"
|
||||||
|
assertStdoutGrep --matches=1 --message='filtered out duplicate responses' "^DIDS:${sid}:[0-9]\+:0:0427679796"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Test case, transcribed from ../testdna
|
||||||
|
doc_SetShortVar='Set short variable'
|
||||||
|
setup_SetShortVar() {
|
||||||
|
setup
|
||||||
|
start_dna_server
|
||||||
|
create_sid
|
||||||
|
}
|
||||||
|
test_SetShortVar() {
|
||||||
|
set_short_var
|
||||||
|
assertRealTime '<' 0.5
|
||||||
|
assertStdoutGrep --matches=1 --message='variable write confirmed' "^WROTE:$sid$"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Test case, transcribed from ../testdna
|
||||||
|
doc_SetGetShortVar='Set then get short variable'
|
||||||
|
setup_SetGetShortVar() {
|
||||||
|
setup
|
||||||
|
start_dna_server
|
||||||
|
create_sid
|
||||||
|
set_short_var
|
||||||
|
}
|
||||||
|
test_SetGetShortVar() {
|
||||||
|
execute $dna -s $sid -i 0 -R note
|
||||||
assertExitStatus '==' 0
|
assertExitStatus '==' 0
|
||||||
assertRealTime '<' 0.5
|
assertRealTime '<' 0.5
|
||||||
assertStdoutGrep '^OK:'
|
assertStdoutGrep --matches=1 --message='read variable correctly' "^NOTE:$sid:[0-9]\+:0:a short literal value"
|
||||||
sid=`replayStdout | grep '^OK:' | cut -f2 -d:`
|
|
||||||
assertCmp 'valid SID was returned' "$sid" '~' '[0-9A-F]+'
|
|
||||||
}
|
}
|
||||||
|
|
||||||
runTests
|
# Test case, transcribed from ../testdna
|
||||||
|
doc_GetShortVarToFile='Get variable into a file'
|
||||||
|
setup_GetShortVarToFile() {
|
||||||
|
setup
|
||||||
|
start_dna_server
|
||||||
|
create_sid
|
||||||
|
set_short_var
|
||||||
|
}
|
||||||
|
test_GetShortVarToFile() {
|
||||||
|
echo "WARNING: Known issue: output to file does not work with DID lists"
|
||||||
|
dnatest_dat=$TFWTMP/dnatest.dat
|
||||||
|
execute $dna -s $sid -O $dnatest_dat -i 0 -R note
|
||||||
|
assertExitStatus '==' 0
|
||||||
|
assertRealTime '<' 0.5
|
||||||
|
assertStdoutGrep --matches=1 --message='read variable into file' "^NOTE:$sid:[0-9]\+:0"
|
||||||
|
assertFileContents $dnatest_dat 'a short literal value'
|
||||||
|
}
|
||||||
|
|
||||||
|
# Test case, transcribed from ../testdna
|
||||||
|
doc_SetMultiShortVar='Set multiple instances of a short variable'
|
||||||
|
setup_SetMultiShortVar() {
|
||||||
|
setup
|
||||||
|
start_dna_server
|
||||||
|
create_sid
|
||||||
|
set_short_var
|
||||||
|
}
|
||||||
|
test_SetMultiShortVar() {
|
||||||
|
execute $dna -s $sid -i 1 -W note='$414243'
|
||||||
|
assertExitStatus '==' 0
|
||||||
|
assertRealTime '<' 0.5
|
||||||
|
assertStdoutGrep --matches=1 --message='variable write confirmed' "^WROTE:$sid$"
|
||||||
|
execute $dna -s $sid -i 1 -R note
|
||||||
|
assertExitStatus '==' 0
|
||||||
|
assertRealTime '<' 0.5
|
||||||
|
assertStdoutGrep --matches=1 --message='new variable correctly set in hex' "^NOTE:$sid:[0-9]\+:1:ABC$"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Test case, transcribed from ../testdna
|
||||||
|
doc_GetMultiShortVar='Get multiple instances of a short variable'
|
||||||
|
setup_GetMultiShortVar() {
|
||||||
|
setup
|
||||||
|
start_dna_server
|
||||||
|
create_sid
|
||||||
|
set_short_var
|
||||||
|
execute $dna -s $sid -i 1 -W note='$414243'
|
||||||
|
assertExitStatus '==' 0
|
||||||
|
execute $dna -s $sid -i 2 -W note
|
||||||
|
assertExitStatus '==' 0
|
||||||
|
}
|
||||||
|
test_GetMultiShortVar() {
|
||||||
|
execute $dna -s $sid -m -R note
|
||||||
|
assertExitStatus '==' 0
|
||||||
|
assertRealTime '<' 0.5
|
||||||
|
assertStdoutGrep --matches=1 --message='first variable read correctly' "^NOTE:$sid:[0-9]\+:0:a short literal value$"
|
||||||
|
assertStdoutGrep --matches=1 --message='second variable read correctly' "^NOTE:$sid:[0-9]\+:1:ABC$"
|
||||||
|
assertStdoutGrep --matches=1 --message='third variable read correctly' "^NOTE:$sid:[0-9]\+:2$"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Test case, transcribed from ../testdna
|
||||||
|
doc_OverwriteVarNoUpdate='Set does not overwrite variable'
|
||||||
|
setup_OverwriteVarNoUpdate() {
|
||||||
|
setup
|
||||||
|
start_dna_server
|
||||||
|
create_sid
|
||||||
|
set_short_var
|
||||||
|
}
|
||||||
|
test_OverwriteVarNoUpdate() {
|
||||||
|
execute $dna -s $sid -i 0 -W note="replacement short literal value"
|
||||||
|
assertExitStatus '==' 0
|
||||||
|
assertRealTime '<' 0.5
|
||||||
|
assertStdoutGrep --matches=0 --message='variable write not confirmed' "^WROTE:$sid$"
|
||||||
|
execute $dna -s $sid -i 0 -R note
|
||||||
|
assertExitStatus '==' 0
|
||||||
|
assertRealTime '<' 0.5
|
||||||
|
assertStdoutGrep --matches=1 --message='variable retains original value' "^NOTE:$sid:[0-9]\+:0:a short literal value"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Test case, transcribed from ../testdna
|
||||||
|
doc_UpdateVar='Update overwrites variable'
|
||||||
|
setup_UpdateVar() {
|
||||||
|
setup
|
||||||
|
start_dna_server
|
||||||
|
create_sid
|
||||||
|
set_short_var
|
||||||
|
}
|
||||||
|
test_UpdateVar() {
|
||||||
|
execute $dna -s $sid -i 0 -U note="replacement short literal value"
|
||||||
|
assertExitStatus '==' 0
|
||||||
|
assertRealTime '<' 0.5
|
||||||
|
assertStdoutGrep --matches=1 --message='variable write confirmed' "^WROTE:$sid$"
|
||||||
|
execute $dna -s $sid -i 0 -R note
|
||||||
|
assertExitStatus '==' 0
|
||||||
|
assertRealTime '<' 0.5
|
||||||
|
assertStdoutGrep --matches=1 --message='variable has new value' "^NOTE:$sid:[0-9]\+:0:replacement short literal value"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Test case, transcribed from ../testdna
|
||||||
|
doc_UpdateVarBigValue='Can set variable with multi-packet value'
|
||||||
|
setup_UpdateVarBigValue() {
|
||||||
|
setup
|
||||||
|
start_dna_server
|
||||||
|
create_sid
|
||||||
|
set_short_var
|
||||||
|
echo_long_message >$TFWTMP/dnatest.in
|
||||||
|
}
|
||||||
|
test_UpdateVarBigValue() {
|
||||||
|
execute $dna -s $sid -i 0 -U note="@dnatest.in"
|
||||||
|
assertExitStatus '==' 0
|
||||||
|
assertRealTime '<' 0.5
|
||||||
|
assertStdoutGrep --matches=1 --message='variable write confirmed' "^WROTE:$sid$"
|
||||||
|
execute $dna -v verbose -s $sid -O $TFWTMP/dnatest.out -i 0 -R note
|
||||||
|
assertExitStatus '==' 0
|
||||||
|
assertRealTime '<' 0.5
|
||||||
|
assertStdoutGrep --matches=1 --message='variable new value returned' "^NOTE:$sid:[0-9]\+:0"
|
||||||
|
assert --message='long value read correctly' cmp --quiet $TFWTMP/dnatest.in $TFWTMP/dnatest.out
|
||||||
|
}
|
||||||
|
|
||||||
|
# Test case, transcribed from ../testdna
|
||||||
|
doc_BitErrorCreateSID='Create new SID despite bit errors'
|
||||||
|
setup_BitErrorCreateSID() {
|
||||||
|
ber=0.001
|
||||||
|
setup
|
||||||
|
start_dna_server -B $ber
|
||||||
|
}
|
||||||
|
test_BitErrorCreateSID() {
|
||||||
|
local iterations=10
|
||||||
|
local i=0
|
||||||
|
local fails=0
|
||||||
|
local totaltime_ms=0
|
||||||
|
local maxtime_ms=0
|
||||||
|
while [ $i -lt $iterations ]; do
|
||||||
|
execute $dna -B $ber -d 0427679796 -C
|
||||||
|
assertExitStatus '==' 0
|
||||||
|
sid=`replayStdout | grep '^OK:' | cut -f2 -d:`
|
||||||
|
let totaltime_ms=totaltime_ms+realtime_ms
|
||||||
|
[ $realtime_ms -gt $maxtime_ms ] && maxtime_ms=$realtime_ms
|
||||||
|
if [ -z "$sid" ]; then
|
||||||
|
let fails=fails+1
|
||||||
|
echo "# iteration $i: no sid after ${realtime_ms} ms"
|
||||||
|
else
|
||||||
|
echo "# iteration $i: sid=$sid after ${realtime_ms} ms"
|
||||||
|
fi
|
||||||
|
let i=i+1
|
||||||
|
done
|
||||||
|
let meantime_ms=totaltime_ms/iterations
|
||||||
|
echo "# average time = $meantime_ms ms"
|
||||||
|
echo "# maximum time = $maxtime_ms ms"
|
||||||
|
assertExpr --message='packet loss was properly injected' $meantime_ms '>' 25
|
||||||
|
assertExpr --message="reliable at BER=$ber packet loss" $fails '<=' 4
|
||||||
|
assertExpr --message="timeout works at BER=$ber packet loss" $totaltime_ms '<=' 3000 '&&' $maxtime_ms '<=' 330
|
||||||
|
}
|
||||||
|
|
||||||
|
# Test case, transcribed from ../testdna
|
||||||
|
doc_SetVarBigValueBitErrors='Can set variable with multi-packet value despite bit errors'
|
||||||
|
setup_SetVarBigValueBitErrors() {
|
||||||
|
ber=0.00001
|
||||||
|
setup
|
||||||
|
start_dna_server -B $ber
|
||||||
|
echo_long_message >$TFWTMP/dnatest.in
|
||||||
|
}
|
||||||
|
test_SetVarBigValueBitErrors() {
|
||||||
|
execute $dna -B $ber -s $sid -i 0 -W note="@dnatest.in"
|
||||||
|
assertExitStatus '==' 0
|
||||||
|
assertStdoutGrep --matches=1 --message='variable write confirmed' "^WROTE:$sid$"
|
||||||
|
execute $dna -v verbose -B $ber -s $sid -O $TFWTMP/dnatest.out -i 0 -R note
|
||||||
|
assertExitStatus '==' 0
|
||||||
|
assertStdoutGrep --matches=1 --message='variable new value returned' "^NOTE:$sid:[0-9]\+:0"
|
||||||
|
assert --message='long value read correctly' cmp --quiet $TFWTMP/dnatest.in $TFWTMP/dnatest.out
|
||||||
|
}
|
||||||
|
|
||||||
|
runTests "$@"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user