Implement TEST_SH for this test, add a test or two, and also some

commentary to explain some of the weirdness of shell quoting. (from kre@)
This commit is contained in:
christos 2016-03-12 14:58:03 +00:00
parent 9dbda5ea54
commit 796504694c
1 changed files with 65 additions and 22 deletions

View File

@ -1,4 +1,4 @@
# $NetBSD: t_varquote.sh,v 1.3 2016/02/19 13:48:28 christos Exp $ # $NetBSD: t_varquote.sh,v 1.4 2016/03/12 14:58:03 christos Exp $
# #
# Copyright (c) 2007 The NetBSD Foundation, Inc. # Copyright (c) 2007 The NetBSD Foundation, Inc.
# All rights reserved. # All rights reserved.
@ -24,6 +24,8 @@
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
# POSSIBILITY OF SUCH DAMAGE. # POSSIBILITY OF SUCH DAMAGE.
# #
# the implementation of "sh" to test
: ${TEST_SH:="/bin/sh"}
# Variable quoting test. # Variable quoting test.
@ -39,30 +41,70 @@ all_head() {
atf_set "descr" "Basic checks for variable quoting" atf_set "descr" "Basic checks for variable quoting"
} }
all_body() { all_body() {
foo='${a:-foo}'
check "$foo" '${a:-foo}'
foo="${a:-foo}" cat <<-'EOF' > script.sh
check "$foo" "foo" T=0
check() {
T=$((${T} + 1))
foo=${a:-"'{}'"} if [ "$1" != "$2" ]
check "$foo" "'{}'" then
printf '%s\n' "T${T}: expected [$2], found [$1]"
exit 1
fi
}
foo=${a:-${b:-"'{}'"}} #1
check "$foo" "'{}'" foo='${a:-foo}'
check "$foo" '${a:-foo}'
#2
foo="${a:-foo}"
check "$foo" "foo"
#3
foo=${a:-"'{}'"}
check "$foo" "'{}'"
#4
foo=${a:-${b:-"'{}'"}}
check "$foo" "'{}'"
#5
# ${ } The ' are inside ".." so are literal (not quotes).
foo="${a-'}'}"
check "$foo" "''}"
#6
# The rules for quoting in ${var-word} expressions are somewhat
# weird, in the following there is not one quoted string being
# assigned to foo (with internally quoted sub-strings), rather
# it is a mixed quoted/unquoted string, with parts that are
# quoted, separated by 2 unquoted sections...
# qqqqqqqqqq uuuuuuuuuu qq uuuu qqqq
foo="${a:-${b:-"${c:-${d:-"x}"}}y}"}}z}"
# " z*"
# ${a:- }
# ${b:- }
# " y*"
# ${c:- }
# ${d:- }
# "x*"
check "$foo" "x}y}z}"
#7
# And believe it or not, this is the one that gives
# most problems, with 3 different observed outputs...
# qqqqq qq q is one interpretation
# qqqqq QQQQ q is another (most common)
# (the third is syntax error...)
foo="${a:-"'{}'"}"
check "$foo" "'{}'"
foo="${a:-"'{}'"}" EOF
check "$foo" "'{}'"
foo="${a:-${b:-"${c:-${d:-"x}"}}y}"}}z}" OUT=$( ${TEST_SH} script.sh 2>&1 )
# " z*" if [ $? -ne 0 ]
# ${a:- } then
# ${b:- } atf_fail "${OUT}"
# " y*" elif [ -n "${OUT}" ]
# ${c:- } then
# ${d:- } atf_fail "script.sh unexpectedly said: ${OUT}"
# "x*" fi
check "$foo" "x}y}z}"
} }
atf_test_case nested_quotes_multiword atf_test_case nested_quotes_multiword
@ -72,7 +114,7 @@ nested_quotes_multiword_head() {
} }
nested_quotes_multiword_body() { nested_quotes_multiword_body() {
atf_check -s eq:0 -o match:"first-word second-word" -e empty \ atf_check -s eq:0 -o match:"first-word second-word" -e empty \
/bin/sh -c 'echo "${foo:="first-word"} second-word"' ${TEST_SH} -c 'echo "${foo:="first-word"} second-word"'
} }
atf_test_case default_assignment_with_arith atf_test_case default_assignment_with_arith
@ -81,7 +123,8 @@ default_assignment_with_arith_head() {
"string works (PR bin/50827)" "string works (PR bin/50827)"
} }
default_assignment_with_arith_body() { default_assignment_with_arith_body() {
atf_check -s eq:0 -o empty -e empty /bin/sh -c ': "${x=$((1))}"' atf_check -s eq:0 -o empty -e empty ${TEST_SH} -c ': "${x=$((1))}"'
atf_check -s eq:0 -o match:1 -e empty ${TEST_SH} -c 'echo "${x=$((1))}"'
} }