Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/usr.bin/make/unit-tests make(1): add test for harmless bug i...



details:   https://anonhg.NetBSD.org/src/rev/0156b9654e2f
branches:  trunk
changeset: 944291:0156b9654e2f
user:      rillig <rillig%NetBSD.org@localhost>
date:      Fri Sep 25 23:24:49 2020 +0000

description:
make(1): add test for harmless bug in Parse_File

When there is a dependency group at the end of a top-level makefile,
this dependency group is not finished properly.  This allows to add
further commands to the targets of this dependency group, which was not
intended.

diffstat:

 distrib/sets/lists/tests/mi                          |   4 +-
 usr.bin/make/unit-tests/Makefile                     |   3 +-
 usr.bin/make/unit-tests/dep-colon-bug-cross-file.exp |   3 +
 usr.bin/make/unit-tests/dep-colon-bug-cross-file.mk  |  43 ++++++++++++++++++++
 usr.bin/make/unit-tests/dep-wildcards.exp            |   1 +
 5 files changed, 52 insertions(+), 2 deletions(-)

diffs (97 lines):

diff -r c0cce1e10997 -r 0156b9654e2f distrib/sets/lists/tests/mi
--- a/distrib/sets/lists/tests/mi       Fri Sep 25 23:18:59 2020 +0000
+++ b/distrib/sets/lists/tests/mi       Fri Sep 25 23:24:49 2020 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: mi,v 1.929 2020/09/25 18:18:25 rillig Exp $
+# $NetBSD: mi,v 1.930 2020/09/25 23:24:49 rillig Exp $
 #
 # Note: don't delete entries from here - mark them as "obsolete" instead.
 #
@@ -4614,6 +4614,8 @@
 ./usr/tests/usr.bin/make/unit-tests/counter-append.mk                          tests-usr.bin-tests     compattestfile,atf
 ./usr/tests/usr.bin/make/unit-tests/counter.exp                                        tests-usr.bin-tests     compattestfile,atf
 ./usr/tests/usr.bin/make/unit-tests/counter.mk                                 tests-usr.bin-tests     compattestfile,atf
+./usr/tests/usr.bin/make/unit-tests/dep-colon-bug-cross-file.exp               tests-usr.bin-tests     compattestfile,atf
+./usr/tests/usr.bin/make/unit-tests/dep-colon-bug-cross-file.mk                        tests-usr.bin-tests     compattestfile,atf
 ./usr/tests/usr.bin/make/unit-tests/dep-colon.exp                              tests-usr.bin-tests     compattestfile,atf
 ./usr/tests/usr.bin/make/unit-tests/dep-colon.mk                               tests-usr.bin-tests     compattestfile,atf
 ./usr/tests/usr.bin/make/unit-tests/dep-double-colon.exp                       tests-usr.bin-tests     compattestfile,atf
diff -r c0cce1e10997 -r 0156b9654e2f usr.bin/make/unit-tests/Makefile
--- a/usr.bin/make/unit-tests/Makefile  Fri Sep 25 23:18:59 2020 +0000
+++ b/usr.bin/make/unit-tests/Makefile  Fri Sep 25 23:24:49 2020 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: Makefile,v 1.151 2020/09/25 20:11:06 rillig Exp $
+# $NetBSD: Makefile,v 1.152 2020/09/25 23:24:49 rillig Exp $
 #
 # Unit tests for make(1)
 #
@@ -74,6 +74,7 @@
 TESTS+=                counter-append
 TESTS+=                dep
 TESTS+=                dep-colon
+TESTS+=                dep-colon-bug-cross-file
 TESTS+=                dep-double-colon
 TESTS+=                dep-exclam
 TESTS+=                dep-none
diff -r c0cce1e10997 -r 0156b9654e2f usr.bin/make/unit-tests/dep-colon-bug-cross-file.exp
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/usr.bin/make/unit-tests/dep-colon-bug-cross-file.exp      Fri Sep 25 23:24:49 2020 +0000
@@ -0,0 +1,3 @@
+: pass 1
+: pass 2
+exit status 0
diff -r c0cce1e10997 -r 0156b9654e2f usr.bin/make/unit-tests/dep-colon-bug-cross-file.mk
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/usr.bin/make/unit-tests/dep-colon-bug-cross-file.mk       Fri Sep 25 23:24:49 2020 +0000
@@ -0,0 +1,43 @@
+# $NetBSD: dep-colon-bug-cross-file.mk,v 1.1 2020/09/25 23:24:49 rillig Exp $
+#
+# Until 2020-09-25, the very last dependency group of a top-level makefile
+# was not finished properly.  This made it possible to add further commands
+# to that target.
+#
+# In pass 1, there is a dependency group at the bottom of the file.
+# This dependency group is not finished properly.  Finishing the dependency
+# group would add the OP_HAS_COMMANDS flag to the "all" target, thereby
+# preventing any commands from being added later.
+#
+# After the file has been parsed completely, it is parsed again in pass 2.
+# In this pass, another command is added to the "current dependency group",
+# which is still the one from pass 1, which means it is possible to even
+# cross file boundaries.
+#
+# TODO: Finish the file properly in Parse_File.
+#
+# Oops, even worse.  Running this test in a make from 2020-09-25 or earlier
+# on NetBSD 8.0 x86_64 with MALLOC_OPTIONS=JA produces this or a similar
+# output:
+#
+#      make: cannot open ZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZZ.
+#
+# The 'Z' means access to already freed memory; see jemalloc(3).  The cause
+# for this is that in MainParseArgs, the command line arguments were not
+# properly copied before storing them with global variables.
+
+PASS?= 1
+
+.if ${PASS} == 2
+all:
+       : pass 2
+.endif
+
+.if ${PASS} == 1
+
+PASS=  2
+.MAKEFLAGS: -f ${.PARSEDIR:q}/${.PARSEFILE:q}
+
+all:
+       : pass 1
+.endif
diff -r c0cce1e10997 -r 0156b9654e2f usr.bin/make/unit-tests/dep-wildcards.exp
--- a/usr.bin/make/unit-tests/dep-wildcards.exp Fri Sep 25 23:18:59 2020 +0000
+++ b/usr.bin/make/unit-tests/dep-wildcards.exp Fri Sep 25 23:24:49 2020 +0000
@@ -1,3 +1,4 @@
+dep-colon-bug-cross-file.mk
 dep-colon.mk
 dep-double-colon.mk
 dep-exclam.mk



Home | Main Index | Thread Index | Old Index