diff options
Diffstat (limited to 'dmake/tests/targets-19')
-rwxr-xr-x | dmake/tests/targets-19 | 68 |
1 files changed, 68 insertions, 0 deletions
diff --git a/dmake/tests/targets-19 b/dmake/tests/targets-19 new file mode 100755 index 000000000000..3ca904f53e8d --- /dev/null +++ b/dmake/tests/targets-19 @@ -0,0 +1,68 @@ +#!/bin/sh + +# 22.06.2007 Volker Quetschke +# Check that multiple leading slashes are normalized. +# (issue 78061) + +: ${DMAKEPROG:=dmake} +file1="mfile1.mk" +tmpfiles="$file1" + +trap '{ echo "trapped signal - removing temporary files" ; rm -rf $tmpfiles ; }' 1 2 3 15 + +# Remove files from prior failed run +rm -rf $tmpfiles + +# Remember to quote variables in generated makefiles( $ -> \$ ). +# Test 1 - Test if excess leading slashes get removed +cat > $file1 <<EOT +SHELL*:=/bin/sh +SHELLFLAGS*:=-ce + +////all : + @echo X\$@Y + +EOT + +output1=`eval ${DMAKEPROG} -rf $file1 2>&1 ` +result1=$? +if test "$output1" != "X/allY"; then + echo "Subtest 1: Wrong result: $output1" + result1=1 +else + echo "Subtest 1: OK" +fi + + +# Test 2 - Test if excess leading slashes in DOS paths get removed +cat > $file1 <<EOT +SHELL*:=/bin/sh +SHELLFLAGS*:=-ce + +"c:////all" .WINPATH : + @echo X\$@Y + +EOT + +if test x`uname -o 2> /dev/null` = "xCygwin"; then + output2=`eval ${DMAKEPROG} -r -f $file1` + result2=$? + if test "$output2" != "Xc:/allY"; then + echo "Subtest 2: Wrong result: $output2" + result2=1 + else + echo "Subtest 2: OK" + fi +else + echo "Subtest 2 ignored for non cygwin environment" + result2=0 +fi + + +if test $result1 -eq 0 -a $result2 -eq 0; then + echo "Success - Cleaning up" && rm -f ${tmpfiles} + exit +else + echo "Failure!" + exit 1 +fi
\ No newline at end of file |