diff options
author | Ivo Hinkelmann <ihi@openoffice.org> | 2006-06-29 10:30:03 +0000 |
---|---|---|
committer | Ivo Hinkelmann <ihi@openoffice.org> | 2006-06-29 10:30:03 +0000 |
commit | 745ed32b42e6587a45f03b36efc594a450573cb6 (patch) | |
tree | 842ebc9ab84f10ae4ba826adc2e465d3939cd2f7 /dmake | |
parent | d9ba77e604149a2761a5aaa051fd90810d68f502 (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-1 | 78 | ||||
-rw-r--r-- | dmake/tests/targets-2 | 70 |
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 |