INTEGRATION: CWS dmake49 (1.1.2); FILE ADDED

2007/06/22 20:47:10 vq 1.1.2.1: #i78061# Add testcase and documentation.
This commit is contained in:
Rüdiger Timm 2007-07-03 10:31:48 +00:00
parent b128608d01
commit 2d1cf982d8

68
dmake/tests/targets-19 Executable file
View file

@ -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