summaryrefslogtreecommitdiff
path: root/dmake/tests/misc-13
diff options
context:
space:
mode:
Diffstat (limited to 'dmake/tests/misc-13')
-rwxr-xr-xdmake/tests/misc-1351
1 files changed, 51 insertions, 0 deletions
diff --git a/dmake/tests/misc-13 b/dmake/tests/misc-13
new file mode 100755
index 000000000000..7493e744b6b6
--- /dev/null
+++ b/dmake/tests/misc-13
@@ -0,0 +1,51 @@
+#!/bin/sh
+
+# 29.09.2006 Volker Quetschke
+# Check if the directory cache can be made case insensitive
+# (issue 69814)
+
+: ${DMAKEPROG:=dmake}
+file1="mfile1.mk"
+file2="TeSt.target"
+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
+
+echo "Something" > $file2
+
+# Remember to quote variables in generated makefiles ( $ -> \$ ).
+# Also quote line continuations ( \<nl> -> \\<nl> ).
+cat > $file1 <<EOT
+SHELL*:=/bin/sh
+SHELLFLAGS*:=-ce
+
+.DIRCACHE=yes
+
+# Only test the directory cache for case insensitivity if the FS is also
+# case insensitive.
+.IF "\$(.DIRCACHERESPCASE)"!="y"
+test.target :
+ @echo "Building \$@"
+
+.ELSE
+TeSt.target :
+ @echo "Building \$@"
+
+.ENDIF
+
+EOT
+
+output=`eval ${DMAKEPROG} -vm -r -f $file1`
+result=$?
+
+if echo "$output" | grep -v ".target' is up to date" > /dev/null 2>&1 ; then
+ echo "Wrong result: ${output}"
+ result=1
+fi
+
+test $result -eq 0 && echo "Success - Cleaning up" && rm -f ${tmpfiles}
+test $result -ne 0 && echo "Failure!"
+exit $result