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): update and add comments in ...
details: https://anonhg.NetBSD.org/src/rev/8dd7ec81c0d5
branches: trunk
changeset: 1016329:8dd7ec81c0d5
user: rillig <rillig%NetBSD.org@localhost>
date: Sun Nov 15 20:20:58 2020 +0000
description:
make(1): update and add comments in tests
As a result of the new comments, some line numbers have changed in the
output of the tests. No other changes.
diffstat:
usr.bin/make/unit-tests/Makefile | 22 +++++++++++++++-
usr.bin/make/unit-tests/dep-double-colon.mk | 7 +++-
usr.bin/make/unit-tests/dep-exclam.mk | 9 +++++-
usr.bin/make/unit-tests/depsrc-ignore.mk | 11 +++----
usr.bin/make/unit-tests/depsrc-make.mk | 4 ++-
usr.bin/make/unit-tests/depsrc-precious.mk | 12 +++++++-
usr.bin/make/unit-tests/depsrc-usebefore.mk | 6 +++-
usr.bin/make/unit-tests/depsrc.mk | 4 ++-
usr.bin/make/unit-tests/deptgt-error.mk | 5 ++-
usr.bin/make/unit-tests/deptgt-ignore.mk | 5 ++-
usr.bin/make/unit-tests/deptgt-interrupt.mk | 6 ++-
usr.bin/make/unit-tests/deptgt-main.mk | 6 ++-
usr.bin/make/unit-tests/deptgt-makeflags.mk | 5 ++-
usr.bin/make/unit-tests/directive-for.exp | 36 +++++++++++++-------------
usr.bin/make/unit-tests/directive-for.mk | 12 +++++++-
usr.bin/make/unit-tests/directive-if.exp | 24 ++++++++--------
usr.bin/make/unit-tests/directive-if.mk | 5 ++-
usr.bin/make/unit-tests/directive-ifmake.exp | 14 +++++-----
usr.bin/make/unit-tests/directive-ifmake.mk | 10 +++++-
usr.bin/make/unit-tests/directive-sinclude.mk | 6 +++-
usr.bin/make/unit-tests/moderrs.mk | 4 +-
usr.bin/make/unit-tests/modmisc.mk | 4 +-
usr.bin/make/unit-tests/modword.mk | 3 +-
usr.bin/make/unit-tests/sh-leading-at.mk | 7 ++++-
usr.bin/make/unit-tests/sh-leading-hyphen.mk | 7 ++++-
usr.bin/make/unit-tests/sh-meta-chars.mk | 8 ++++-
usr.bin/make/unit-tests/var-op-assign.exp | 4 +-
usr.bin/make/unit-tests/var-op-assign.mk | 19 +++++++++----
usr.bin/make/unit-tests/var-op-sunsh.mk | 4 ++-
usr.bin/make/unit-tests/varmod-shell.mk | 4 ++-
usr.bin/make/unit-tests/varmod-subst.mk | 19 +++++++++++++-
usr.bin/make/unit-tests/varmod-to-lower.mk | 4 ++-
usr.bin/make/unit-tests/varmod-to-separator.mk | 8 +++++-
usr.bin/make/unit-tests/varmod-undefined.mk | 3 +-
34 files changed, 216 insertions(+), 91 deletions(-)
diffs (truncated from 740 to 300 lines):
diff -r 2b5c1b793d89 -r 8dd7ec81c0d5 usr.bin/make/unit-tests/Makefile
--- a/usr.bin/make/unit-tests/Makefile Sun Nov 15 18:33:41 2020 +0000
+++ b/usr.bin/make/unit-tests/Makefile Sun Nov 15 20:20:58 2020 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: Makefile,v 1.200 2020/11/14 18:07:26 rillig Exp $
+# $NetBSD: Makefile,v 1.201 2020/11/15 20:20:58 rillig Exp $
#
# Unit tests for make(1)
#
@@ -381,6 +381,26 @@
TESTS+= varparse-undef-partial
TESTS+= varquote
+# Ideas for more tests:
+# char-0020-space.mk
+# char-005C-backslash.mk
+# escape-cond-str.mk
+# escape-cond-func-arg.mk
+# escape-cond-func-arg.mk
+# escape-varmod.mk
+# escape-varmod-define.mk
+# escape-varmod-match.mk
+# escape-varname.mk
+# escape-varassign-varname.mk
+# escape-varassign-varname-cmdline.mk
+# escape-varassign-value.mk
+# escape-varassign-value-cmdline.mk
+# escape-dependency-source.mk
+# escape-dependency-target.mk
+# escape-for-varname.mk
+# escape-for-item.mk
+# posix-*.mk (see posix.mk and posix1.mk)
+
.if ${.OBJDIR} != ${.CURDIR}
RO_OBJDIR:= ${.OBJDIR}/roobj
.else
diff -r 2b5c1b793d89 -r 8dd7ec81c0d5 usr.bin/make/unit-tests/dep-double-colon.mk
--- a/usr.bin/make/unit-tests/dep-double-colon.mk Sun Nov 15 18:33:41 2020 +0000
+++ b/usr.bin/make/unit-tests/dep-double-colon.mk Sun Nov 15 20:20:58 2020 +0000
@@ -1,6 +1,9 @@
-# $NetBSD: dep-double-colon.mk,v 1.4 2020/09/26 15:41:53 rillig Exp $
+# $NetBSD: dep-double-colon.mk,v 1.5 2020/11/15 20:20:58 rillig Exp $
#
-# Tests for the :: operator in dependency declarations.
+# Tests for the '::' operator in dependency declarations, which allows
+# several dependency groups for a single node, each having its own attributes
+# and dependencies. In the code, the additional dependency groups are called
+# cohorts.
all::
@echo 'command 1a'
diff -r 2b5c1b793d89 -r 8dd7ec81c0d5 usr.bin/make/unit-tests/dep-exclam.mk
--- a/usr.bin/make/unit-tests/dep-exclam.mk Sun Nov 15 18:33:41 2020 +0000
+++ b/usr.bin/make/unit-tests/dep-exclam.mk Sun Nov 15 20:20:58 2020 +0000
@@ -1,6 +1,11 @@
-# $NetBSD: dep-exclam.mk,v 1.2 2020/08/16 14:25:16 rillig Exp $
+# $NetBSD: dep-exclam.mk,v 1.3 2020/11/15 20:20:58 rillig Exp $
#
-# Tests for the ! operator in dependency declarations.
+# Tests for the ! operator in dependency declarations, which always re-creates
+# the target, whether or not it is out of date.
+#
+# TODO: Is this related to OP_PHONY?
+# TODO: Is this related to OP_EXEC?
+# TODO: Is this related to OP_MAKE?
# TODO: Implementation
diff -r 2b5c1b793d89 -r 8dd7ec81c0d5 usr.bin/make/unit-tests/depsrc-ignore.mk
--- a/usr.bin/make/unit-tests/depsrc-ignore.mk Sun Nov 15 18:33:41 2020 +0000
+++ b/usr.bin/make/unit-tests/depsrc-ignore.mk Sun Nov 15 20:20:58 2020 +0000
@@ -1,11 +1,10 @@
-# $NetBSD: depsrc-ignore.mk,v 1.4 2020/08/29 16:13:27 rillig Exp $
+# $NetBSD: depsrc-ignore.mk,v 1.5 2020/11/15 20:20:58 rillig Exp $
#
# Tests for the special source .IGNORE in dependency declarations,
# which ignores any command failures for that target.
#
-# Even though ignore-errors fails, the all target is still made.
-# Since the all target is not marked with .IGNORE, it stops at the
-# first failing command.
+# Even though 'ignore-errors' fails, 'all' is still made. Since 'all' is
+# not marked with .IGNORE, it stops at the first failing command.
#
# XXX: The ordering of the messages in the output is confusing.
# The "ignored" comes much too late to be related to the "false
@@ -24,8 +23,8 @@
# This is what actually happens, as of 2020-08-29. To verify it, set the
# following breakpoints in CompatRunCommand:
#
-# * the "!silent" line, to see all commands.
-# * the "fflush" line, to see stdout being flushed.
+# * the "!silent" line, to see all commands
+# * the "fflush" line, to see stdout being flushed
# * the "status = WEXITSTATUS" line
# * the "(continuing)" line
# * the "(ignored)" line
diff -r 2b5c1b793d89 -r 8dd7ec81c0d5 usr.bin/make/unit-tests/depsrc-make.mk
--- a/usr.bin/make/unit-tests/depsrc-make.mk Sun Nov 15 18:33:41 2020 +0000
+++ b/usr.bin/make/unit-tests/depsrc-make.mk Sun Nov 15 20:20:58 2020 +0000
@@ -1,9 +1,11 @@
-# $NetBSD: depsrc-make.mk,v 1.3 2020/09/05 15:57:12 rillig Exp $
+# $NetBSD: depsrc-make.mk,v 1.4 2020/11/15 20:20:58 rillig Exp $
#
# Tests for the special source .MAKE in dependency declarations, which
# executes the commands of the target even if the -n or -t command line
# options are given.
+# TODO: Add a test for the -t command line option.
+
.MAKEFLAGS: -n
all: this-is-made
diff -r 2b5c1b793d89 -r 8dd7ec81c0d5 usr.bin/make/unit-tests/depsrc-precious.mk
--- a/usr.bin/make/unit-tests/depsrc-precious.mk Sun Nov 15 18:33:41 2020 +0000
+++ b/usr.bin/make/unit-tests/depsrc-precious.mk Sun Nov 15 20:20:58 2020 +0000
@@ -1,6 +1,14 @@
-# $NetBSD: depsrc-precious.mk,v 1.2 2020/08/16 14:25:16 rillig Exp $
+# $NetBSD: depsrc-precious.mk,v 1.3 2020/11/15 20:20:58 rillig Exp $
#
-# Tests for the special source .PRECIOUS in dependency declarations.
+# Tests for the special source .PRECIOUS in dependency declarations, which
+# is only relevant if the commands for the target fail or are interrupted.
+# In such a case, the target file is usually removed, to avoid having
+# half-finished files with a timestamp suggesting the file were up-to-date.
+#
+# For targets marked with .PRECIOUS, the target file is not removed.
+# The author of the makefile is then responsible for avoiding the above
+# situation, in which the target would be wrongly considered up-to-date,
+# just because its timestamp says so.
# TODO: Implementation
diff -r 2b5c1b793d89 -r 8dd7ec81c0d5 usr.bin/make/unit-tests/depsrc-usebefore.mk
--- a/usr.bin/make/unit-tests/depsrc-usebefore.mk Sun Nov 15 18:33:41 2020 +0000
+++ b/usr.bin/make/unit-tests/depsrc-usebefore.mk Sun Nov 15 20:20:58 2020 +0000
@@ -1,7 +1,11 @@
-# $NetBSD: depsrc-usebefore.mk,v 1.5 2020/08/22 11:53:18 rillig Exp $
+# $NetBSD: depsrc-usebefore.mk,v 1.6 2020/11/15 20:20:58 rillig Exp $
#
# Tests for the special source .USEBEFORE in dependency declarations,
# which allows to prepend common commands to other targets.
+#
+# See also:
+# .USE
+# depsrc-use.mk
all: action directly
diff -r 2b5c1b793d89 -r 8dd7ec81c0d5 usr.bin/make/unit-tests/depsrc.mk
--- a/usr.bin/make/unit-tests/depsrc.mk Sun Nov 15 18:33:41 2020 +0000
+++ b/usr.bin/make/unit-tests/depsrc.mk Sun Nov 15 20:20:58 2020 +0000
@@ -1,9 +1,11 @@
-# $NetBSD: depsrc.mk,v 1.2 2020/08/16 14:25:16 rillig Exp $
+# $NetBSD: depsrc.mk,v 1.3 2020/11/15 20:20:58 rillig Exp $
#
# Tests for special sources (those starting with a dot, followed by
# uppercase letters) in dependency declarations, such as .PHONY.
# TODO: Implementation
+# TODO: Test 'target: ${:U.SILENT}'
+
all:
@:;
diff -r 2b5c1b793d89 -r 8dd7ec81c0d5 usr.bin/make/unit-tests/deptgt-error.mk
--- a/usr.bin/make/unit-tests/deptgt-error.mk Sun Nov 15 18:33:41 2020 +0000
+++ b/usr.bin/make/unit-tests/deptgt-error.mk Sun Nov 15 20:20:58 2020 +0000
@@ -1,6 +1,7 @@
-# $NetBSD: deptgt-error.mk,v 1.2 2020/08/16 14:25:16 rillig Exp $
+# $NetBSD: deptgt-error.mk,v 1.3 2020/11/15 20:20:58 rillig Exp $
#
-# Tests for the special target .ERROR in dependency declarations.
+# Tests for the special target .ERROR in dependency declarations, which
+# collects commands that are run when another target fails.
# TODO: Implementation
diff -r 2b5c1b793d89 -r 8dd7ec81c0d5 usr.bin/make/unit-tests/deptgt-ignore.mk
--- a/usr.bin/make/unit-tests/deptgt-ignore.mk Sun Nov 15 18:33:41 2020 +0000
+++ b/usr.bin/make/unit-tests/deptgt-ignore.mk Sun Nov 15 20:20:58 2020 +0000
@@ -1,6 +1,7 @@
-# $NetBSD: deptgt-ignore.mk,v 1.2 2020/08/16 14:25:16 rillig Exp $
+# $NetBSD: deptgt-ignore.mk,v 1.3 2020/11/15 20:20:58 rillig Exp $
#
-# Tests for the special target .IGNORE in dependency declarations.
+# Tests for the special target .IGNORE in dependency declarations, which
+# does not stop if a command from this target exits with a non-zero status.
# TODO: Implementation
diff -r 2b5c1b793d89 -r 8dd7ec81c0d5 usr.bin/make/unit-tests/deptgt-interrupt.mk
--- a/usr.bin/make/unit-tests/deptgt-interrupt.mk Sun Nov 15 18:33:41 2020 +0000
+++ b/usr.bin/make/unit-tests/deptgt-interrupt.mk Sun Nov 15 20:20:58 2020 +0000
@@ -1,6 +1,8 @@
-# $NetBSD: deptgt-interrupt.mk,v 1.2 2020/08/16 14:25:16 rillig Exp $
+# $NetBSD: deptgt-interrupt.mk,v 1.3 2020/11/15 20:20:58 rillig Exp $
#
-# Tests for the special target .INTERRUPT in dependency declarations.
+# Tests for the special target .INTERRUPT in dependency declarations, which
+# collects commands to be run when make is interrupted while building another
+# target.
# TODO: Implementation
diff -r 2b5c1b793d89 -r 8dd7ec81c0d5 usr.bin/make/unit-tests/deptgt-main.mk
--- a/usr.bin/make/unit-tests/deptgt-main.mk Sun Nov 15 18:33:41 2020 +0000
+++ b/usr.bin/make/unit-tests/deptgt-main.mk Sun Nov 15 20:20:58 2020 +0000
@@ -1,6 +1,8 @@
-# $NetBSD: deptgt-main.mk,v 1.2 2020/08/16 14:25:16 rillig Exp $
+# $NetBSD: deptgt-main.mk,v 1.3 2020/11/15 20:20:58 rillig Exp $
#
-# Tests for the special target .MAIN in dependency declarations.
+# Tests for the special target .MAIN in dependency declarations, which defines
+# the main target. This main target is built if no target has been specified
+# on the command line or via MAKEFLAGS.
# TODO: Implementation
diff -r 2b5c1b793d89 -r 8dd7ec81c0d5 usr.bin/make/unit-tests/deptgt-makeflags.mk
--- a/usr.bin/make/unit-tests/deptgt-makeflags.mk Sun Nov 15 18:33:41 2020 +0000
+++ b/usr.bin/make/unit-tests/deptgt-makeflags.mk Sun Nov 15 20:20:58 2020 +0000
@@ -1,7 +1,10 @@
-# $NetBSD: deptgt-makeflags.mk,v 1.5 2020/11/08 02:31:24 rillig Exp $
+# $NetBSD: deptgt-makeflags.mk,v 1.6 2020/11/15 20:20:58 rillig Exp $
#
# Tests for the special target .MAKEFLAGS in dependency declarations,
# which adds command line options later, at parse time.
+#
+# In these unit tests, it is often used to temporarily toggle the debug log
+# during parsing.
# The -D option sets a variable in the "Global" scope and thus can be
# undefined later.
diff -r 2b5c1b793d89 -r 8dd7ec81c0d5 usr.bin/make/unit-tests/directive-for.exp
--- a/usr.bin/make/unit-tests/directive-for.exp Sun Nov 15 18:33:41 2020 +0000
+++ b/usr.bin/make/unit-tests/directive-for.exp Sun Nov 15 20:20:58 2020 +0000
@@ -1,19 +1,19 @@
-make: "directive-for.mk" line 100: outer
-make: "directive-for.mk" line 125: a:\ a:\file.txt
-make: "directive-for.mk" line 125: d:\\
-make: "directive-for.mk" line 125: d:\\file.txt
-make: "directive-for.mk" line 132: ( ( (
-make: "directive-for.mk" line 132: [ [ [
-make: "directive-for.mk" line 132: { { {
-make: "directive-for.mk" line 132: ) ) )
-make: "directive-for.mk" line 132: ] ] ]
-make: "directive-for.mk" line 132: } } }
-make: "directive-for.mk" line 132: (()) (()) (())
-make: "directive-for.mk" line 132: [[]] [[]] [[]]
-make: "directive-for.mk" line 132: {{}} {{}} {{}}
-make: "directive-for.mk" line 132: )( )( )(
-make: "directive-for.mk" line 132: ][ ][ ][
-make: "directive-for.mk" line 132: }{ }{ }{
-make: "directive-for.mk" line 140: outer value value
-make: "directive-for.mk" line 140: outer "quoted" \"quoted\"
+make: "directive-for.mk" line 108: outer
+make: "directive-for.mk" line 133: a:\ a:\file.txt
+make: "directive-for.mk" line 133: d:\\
+make: "directive-for.mk" line 133: d:\\file.txt
+make: "directive-for.mk" line 140: ( ( (
+make: "directive-for.mk" line 140: [ [ [
+make: "directive-for.mk" line 140: { { {
+make: "directive-for.mk" line 140: ) ) )
+make: "directive-for.mk" line 140: ] ] ]
+make: "directive-for.mk" line 140: } } }
+make: "directive-for.mk" line 140: (()) (()) (())
+make: "directive-for.mk" line 140: [[]] [[]] [[]]
+make: "directive-for.mk" line 140: {{}} {{}} {{}}
+make: "directive-for.mk" line 140: )( )( )(
+make: "directive-for.mk" line 140: ][ ][ ][
+make: "directive-for.mk" line 140: }{ }{ }{
+make: "directive-for.mk" line 148: outer value value
+make: "directive-for.mk" line 148: outer "quoted" \"quoted\"
exit status 0
diff -r 2b5c1b793d89 -r 8dd7ec81c0d5 usr.bin/make/unit-tests/directive-for.mk
--- a/usr.bin/make/unit-tests/directive-for.mk Sun Nov 15 18:33:41 2020 +0000
+++ b/usr.bin/make/unit-tests/directive-for.mk Sun Nov 15 20:20:58 2020 +0000
@@ -1,6 +1,13 @@
-# $NetBSD: directive-for.mk,v 1.8 2020/10/25 15:49:03 rillig Exp $
+# $NetBSD: directive-for.mk,v 1.9 2020/11/15 20:20:58 rillig Exp $
#
# Tests for the .for directive.
+#
+# TODO: Describe naming conventions for the loop variables.
+# .for f in values
+# .for file in values
+# .for _FILE_ in values
+# .for .FILE. in values
+# .for _f_ in values
# Using the .for loop, lists of values can be produced.
# In simple cases, the :@var@${var}@ variable modifier can be used to
@@ -15,6 +22,7 @@
.endif
# The .for loop also works for multiple iteration variables.
+# This is something that the variable modifier :@ cannot do.
.for name value in VARNAME value NAME2 value2
${name}= ${value}
Home |
Main Index |
Thread Index |
Old Index