summaryrefslogtreecommitdiff
path: root/dmake
diff options
context:
space:
mode:
authorIvo Hinkelmann <ihi@openoffice.org>2006-06-29 10:30:03 +0000
committerIvo Hinkelmann <ihi@openoffice.org>2006-06-29 10:30:03 +0000
commit745ed32b42e6587a45f03b36efc594a450573cb6 (patch)
tree842ebc9ab84f10ae4ba826adc2e465d3939cd2f7 /dmake
parentd9ba77e604149a2761a5aaa051fd90810d68f502 (diff)
INTEGRATION: CWS dmake45 (1.1.2); FILE ADDED
2006/06/22 20:45:44 vq 1.1.2.2: #i66650# Make dmake testsuite more portable. (Usable with Solaris.) Patch by hjs. 2006/06/04 00:34:07 vq 1.1.2.1: #i64869# Add testcases and regenerate autotools files.
Diffstat (limited to 'dmake')
-rw-r--r--dmake/tests/targets-178
-rw-r--r--dmake/tests/targets-270
2 files changed, 148 insertions, 0 deletions
diff --git a/dmake/tests/targets-1 b/dmake/tests/targets-1
new file mode 100644
index 000000000000..688c33cf024b
--- /dev/null
+++ b/dmake/tests/targets-1
@@ -0,0 +1,78 @@
+#!/bin/sh
+
+# 03.06.2006 Volker Quetschke
+# Percent target definitions were not handled properly before.
+# (issue 64869)
+
+: ${DMAKEPROG:=dmake}
+file1="mfile1.mk"
+file2="mfile2.mk"
+tmpfiles="$file1 $file2"
+
+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( $ -> \$ ).
+# Testcase 1 - This segfaulted before 4.5
+cat > $file1 <<EOT
+SHELL*:=/bin/sh
+SHELLFLAGS*:=-ce
+
+allnew : all
+
+%.x all : %.c
+ +true $@
+
+qqq.c :
+ +echo OK
+
+EOT
+
+# Testcase 2 - earlier than dmake 4.5 the second %-target was defined
+# without the prerequisites, i.e. qqq.c was not build
+cat > $file2 <<EOT
+SHELL*:=/bin/sh
+SHELLFLAGS*:=-ce
+
+allnew : qqq.y
+
+%.x %.y : %.c
+ +true "building %.y"
+
+qqq.c :
+ +echo building qqq.c
+
+EOT
+
+output1=`eval ${DMAKEPROG} -r -f $file1 2>&1 `
+result1=$?
+output2=`eval ${DMAKEPROG} -r -f $file2 2>&1 `
+result2=$?
+
+if echo $output1 | grep 'Error: -- A non-%' > /dev/null 2>&1 ; then
+ #echo "Test 1: Right result: $output1"
+ result1=0
+else
+ echo "Test 1: Wrong result: $output1"
+ echo
+ result1=1
+fi
+
+if echo $output2 | grep -v 'building qqq.c' > /dev/null 2>&1 ; then
+ echo "Test 2: Wrong result: $output2"
+ echo
+ result2=1
+fi
+
+if test $result1 -eq 0 -a $result2 -eq 0; then
+ echo "Success - Cleaning up"
+ rm -rf $tmpfiles
+exit
+ result=0
+else
+ echo "Failure!"
+ result=1
+fi
+exit $result
diff --git a/dmake/tests/targets-2 b/dmake/tests/targets-2
new file mode 100644
index 000000000000..fbc1b0e39c7c
--- /dev/null
+++ b/dmake/tests/targets-2
@@ -0,0 +1,70 @@
+#!/bin/sh
+
+# 03.06.2006 Volker Quetschke
+# Percent target definitions were not handled properly before.
+# (issue 64869) - Two more testcases
+
+: ${DMAKEPROG:=dmake}
+file1="mfile1.mk"
+file2="mfile2.mk"
+tmpfiles="$file1 $file2"
+
+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( $ -> \$ ).
+# Testcase 1 - %-target prerequisite - syntax error
+cat > $file1 <<EOT
+SHELL*:=/bin/sh
+SHELLFLAGS*:=-ce
+
+.PHONY all : %.c
+ +true all
+
+EOT
+
+# Testcase 2 - The recipe part is ignored - syntax error
+cat > $file2 <<EOT
+SHELL*:=/bin/sh
+SHELLFLAGS*:=-ce
+
+all :
+ +true all
+
+.PHONY : all ; +echo no recipe expected
+
+EOT
+
+output1=`eval ${DMAKEPROG} -r -f $file1 2>&1 `
+result1=$?
+output2=`eval ${DMAKEPROG} -r -f $file2 2>&1 `
+result2=$?
+
+if echo $output1 | grep 'Error: -- Syntax' > /dev/null 2>&1 ; then
+ result1=0
+else
+ echo "Test 1: Wrong result: $output1"
+ echo
+ result1=1
+fi
+
+if echo $output2 | grep 'Error: -- Unexpected recipe' > /dev/null 2>&1 ; then
+ result2=0
+else
+ echo "Test 2: Wrong result: $output2"
+ echo
+ result1=1
+fi
+
+if test $result1 -eq 0 -a $result2 -eq 0; then
+ echo "Success - Cleaning up"
+ rm -rf $tmpfiles
+exit
+ result=0
+else
+ echo "Failure!"
+ result=1
+fi
+exit $result