summaryrefslogtreecommitdiff
path: root/dmake
diff options
context:
space:
mode:
authorKurt Zenker <kz@openoffice.org>2008-03-05 17:39:22 +0000
committerKurt Zenker <kz@openoffice.org>2008-03-05 17:39:22 +0000
commitf8b22fc6ec827b7644a870152a89804dee83e09f (patch)
tree3b62b00c57d459fbe631ea113217a388d6463ae5 /dmake
parent13b83ba8d55a311070b446d75aed99b52b682b73 (diff)
INTEGRATION: CWS dmake412_DEV300 (1.1.2); FILE ADDED
2008/02/05 22:02:17 vq 1.1.2.1: #i84800# Add testcase.
Diffstat (limited to 'dmake')
-rwxr-xr-xdmake/tests/targets-3064
1 files changed, 64 insertions, 0 deletions
diff --git a/dmake/tests/targets-30 b/dmake/tests/targets-30
new file mode 100755
index 000000000000..31e2e9712504
--- /dev/null
+++ b/dmake/tests/targets-30
@@ -0,0 +1,64 @@
+#!/bin/sh
+
+# 05.02.2008 Volker Quetschke
+# Check that OOODMAKEMODE=y does not normalize ./../foo.
+# (issue 84800)
+
+: ${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( $ -> \$ ).
+cat > $file1 <<EOT
+SHELL*:=/bin/sh
+SHELLFLAGS*:=-ce
+
+OOODMAKEMODE:=y
+
+# See if OOODMAKEMODE keeps ./../all
+./../all :
+ @echo X\$@Y
+
+EOT
+
+
+output1=`eval ${DMAKEPROG} -rf $file1 2>&1 `
+result1=$?
+if test $result1 -ne 0 -o "$output1" != "X./../allY"; then
+ echo "Test 1: Wrong result: $output1"
+ result1=1
+fi
+# Remember to quote variables in generated makefiles( $ -> \$ ).
+cat > $file1 <<EOT
+SHELL*:=/bin/sh
+SHELLFLAGS*:=-ce
+
+OOODMAKEMODE:=
+
+# See if OOODMAKEMODE= removes the leading .
+./../all :
+ @echo X\$@Y
+
+EOT
+
+
+output2=`eval ${DMAKEPROG} -rf $file1 2>&1 `
+result2=$?
+if test $result2 -ne 0 -o "$output2" != "X../allY"; then
+ echo "Test 2: Wrong result: $output2"
+ result2=1
+fi
+
+if test $result1 -eq 0 -a $result2 -eq 0 ; then
+ echo "Success - Cleaning up"
+ rm -rf $tmpfiles
+ exit 0
+else
+ echo "Failure!"
+ exit 1
+fi