mirror of
https://github.com/sstephenson/bats.git
synced 2024-11-17 11:42:33 +01:00
Prefer let x+=1
for incrementing counters
The `((x++))` syntax is shorthand for `let x++`. According to `help let`: If the last ARG evaluates to 0, let returns 1; 0 is returned otherwise. Thus the exit status of the expression `x=0; let x++` is 1, since the post-increment `++` operator evaluates to the value of the variable before incrementing. In Bash 4, this non-zero exit status properly triggers `set -e`'s error trap, but in Bash 3 it does not. That's why the tests were passing on OS X (Bash 3) but not Linux (Bash 4). We can work around the problem by choosing an incrementation expression that never evaluates to 0, such as `+=` or the pre-increment `++` operator. For consistency and clarity, I've changed to `x+=1` everywhere. Ref. #25, #27
This commit is contained in:
parent
417acfff66
commit
bfa4ebcd0f
|
@ -67,7 +67,7 @@ for arg in "$@"; do
|
||||||
while option="${arg:$index:1}"; do
|
while option="${arg:$index:1}"; do
|
||||||
[ -n "$option" ] || break
|
[ -n "$option" ] || break
|
||||||
options[${#options[*]}]="$option"
|
options[${#options[*]}]="$option"
|
||||||
index=$(($index+1))
|
let index+=1
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
|
|
|
@ -17,7 +17,7 @@ trap "kill 0; exit 1" int
|
||||||
|
|
||||||
count=0
|
count=0
|
||||||
for filename in "$@"; do
|
for filename in "$@"; do
|
||||||
count=$(($count + $(bats-exec-test -c "$filename")))
|
let count+="$(bats-exec-test -c "$filename")"
|
||||||
done
|
done
|
||||||
|
|
||||||
if [ -n "$count_only_flag" ]; then
|
if [ -n "$count_only_flag" ]; then
|
||||||
|
@ -35,11 +35,11 @@ for filename in "$@"; do
|
||||||
while IFS= read -r line; do
|
while IFS= read -r line; do
|
||||||
case "$line" in
|
case "$line" in
|
||||||
"begin "* )
|
"begin "* )
|
||||||
index=$(($index + 1))
|
let index+=1
|
||||||
echo "${line/ $index / $(($offset + $index)) }"
|
echo "${line/ $index / $(($offset + $index)) }"
|
||||||
;;
|
;;
|
||||||
"ok "* | "not ok "* )
|
"ok "* | "not ok "* )
|
||||||
[ -n "$extended_syntax_flag" ] || index=$(($index + 1))
|
[ -n "$extended_syntax_flag" ] || let index+=1
|
||||||
echo "${line/ $index / $(($offset + $index)) }"
|
echo "${line/ $index / $(($offset + $index)) }"
|
||||||
[ "${line:0:6}" != "not ok" ] || status=1
|
[ "${line:0:6}" != "not ok" ] || status=1
|
||||||
;;
|
;;
|
||||||
|
|
|
@ -97,7 +97,7 @@ bats_capture_stack_trace() {
|
||||||
if [[ "$frame" = *"$test_pattern" ]]; then
|
if [[ "$frame" = *"$test_pattern" ]]; then
|
||||||
break
|
break
|
||||||
else
|
else
|
||||||
((index++))
|
let index+=1
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
|
@ -125,7 +125,7 @@ bats_print_stack_trace() {
|
||||||
echo "from function \`$fn' in file $filename, line $line,"
|
echo "from function \`$fn' in file $filename, line $line,"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
((index++))
|
let index+=1
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -197,7 +197,7 @@ bats_perform_tests() {
|
||||||
status=0
|
status=0
|
||||||
for test_name in "$@"; do
|
for test_name in "$@"; do
|
||||||
"$0" $BATS_EXTENDED_SYNTAX "$BATS_TEST_FILENAME" "$test_name" "$test_number" || status=1
|
"$0" $BATS_EXTENDED_SYNTAX "$BATS_TEST_FILENAME" "$test_name" "$test_number" || status=1
|
||||||
test_number=$(($test_number + 1))
|
let test_number+=1
|
||||||
done
|
done
|
||||||
exit "$status"
|
exit "$status"
|
||||||
}
|
}
|
||||||
|
|
|
@ -131,7 +131,7 @@ trap finish EXIT
|
||||||
while IFS= read -r line; do
|
while IFS= read -r line; do
|
||||||
case "$line" in
|
case "$line" in
|
||||||
"begin "* )
|
"begin "* )
|
||||||
index=$(( $index + 1 ))
|
let index+=1
|
||||||
name="${line#* $index }"
|
name="${line#* $index }"
|
||||||
buffer begin
|
buffer begin
|
||||||
flush
|
flush
|
||||||
|
@ -145,11 +145,10 @@ while IFS= read -r line; do
|
||||||
fi
|
fi
|
||||||
;;
|
;;
|
||||||
"not ok "* )
|
"not ok "* )
|
||||||
failures=$(( $failures + 1 ))
|
let failures+=1
|
||||||
buffer fail
|
buffer fail
|
||||||
;;
|
;;
|
||||||
"# "* )
|
"# "* )
|
||||||
|
|
||||||
buffer log "${line:2}"
|
buffer log "${line:2}"
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
|
@ -33,7 +33,7 @@ tests=()
|
||||||
index=0
|
index=0
|
||||||
|
|
||||||
while IFS= read -r line; do
|
while IFS= read -r line; do
|
||||||
index=$(($index + 1))
|
let index+=1
|
||||||
quoted_name="$(expr "$line" : ' *@test *\([^ ].*\) *{ *$' || true)"
|
quoted_name="$(expr "$line" : ' *@test *\([^ ].*\) *{ *$' || true)"
|
||||||
|
|
||||||
if [ -n "$quoted_name" ]; then
|
if [ -n "$quoted_name" ]; then
|
||||||
|
|
Loading…
Reference in New Issue
Block a user