Makefile revision 1.92 1 1.92 rillig # $NetBSD: Makefile,v 1.92 2020/08/15 01:49:07 rillig Exp $
2 1.1 sjg #
3 1.1 sjg # Unit tests for make(1)
4 1.60 rillig #
5 1.1 sjg # The main targets are:
6 1.1 sjg #
7 1.60 rillig # all:
8 1.60 rillig # run all the tests
9 1.60 rillig # test:
10 1.60 rillig # run 'all', and compare to expected results
11 1.60 rillig # accept:
12 1.60 rillig # move generated output to expected results
13 1.60 rillig #
14 1.61 rillig # Settable variables
15 1.61 rillig #
16 1.61 rillig # TEST_MAKE
17 1.61 rillig # The make program to be tested.
18 1.61 rillig #
19 1.60 rillig #
20 1.60 rillig # Adding a test case
21 1.60 rillig #
22 1.11 sjg # Each feature should get its own set of tests in its own suitably
23 1.42 apb # named makefile (*.mk), with its own set of expected results (*.exp),
24 1.61 rillig # and it should be added to the TESTS list.
25 1.60 rillig #
26 1.60 rillig # Any added files must also be added to src/distrib/sets/lists/tests/mi.
27 1.78 rillig # To do that, just run "make sync-mi" in this directory.
28 1.78 rillig #
29 1.78 rillig # A few *.mk files are helper files for other tests (such as include-sub.mk)
30 1.78 rillig # and are thus not added to TESTS. Such files must be ignored in
31 1.78 rillig # src/tests/usr.bin/make/t_make.sh.
32 1.60 rillig #
33 1.1 sjg
34 1.61 rillig # Each test is in a sub-makefile.
35 1.61 rillig # Keep the list sorted.
36 1.92 rillig # Any test that is commented out must be ignored in
37 1.92 rillig # src/tests/usr.bin/make/t_make.sh as well.
38 1.92 rillig TESTS+= # archive # broken on FreeBSD, enabled in t_make.sh
39 1.75 rillig TESTS+= cmdline
40 1.61 rillig TESTS+= comment
41 1.61 rillig TESTS+= cond-late
42 1.61 rillig TESTS+= cond-short
43 1.61 rillig TESTS+= cond1
44 1.61 rillig TESTS+= cond2
45 1.81 rillig TESTS+= counter
46 1.77 rillig TESTS+= dir
47 1.70 rillig TESTS+= directives
48 1.61 rillig TESTS+= dollar
49 1.61 rillig TESTS+= doterror
50 1.61 rillig TESTS+= dotwait
51 1.64 rillig TESTS+= envfirst
52 1.61 rillig TESTS+= error
53 1.63 sjg TESTS+= # escape # broken by reverting POSIX changes
54 1.61 rillig TESTS+= export
55 1.61 rillig TESTS+= export-all
56 1.61 rillig TESTS+= export-env
57 1.89 rillig TESTS+= export-variants
58 1.61 rillig TESTS+= forloop
59 1.61 rillig TESTS+= forsubst
60 1.61 rillig TESTS+= hash
61 1.86 rillig TESTS+= impsrc
62 1.61 rillig TESTS+= include-main
63 1.83 rillig TESTS+= lint
64 1.90 rillig TESTS+= make-exported
65 1.61 rillig TESTS+= misc
66 1.61 rillig TESTS+= moderrs
67 1.61 rillig TESTS+= modmatch
68 1.61 rillig TESTS+= modmisc
69 1.61 rillig TESTS+= modorder
70 1.61 rillig TESTS+= modts
71 1.61 rillig TESTS+= modword
72 1.61 rillig TESTS+= order
73 1.88 rillig TESTS+= phony-end
74 1.61 rillig TESTS+= posix
75 1.63 sjg TESTS+= # posix1 # broken by reverting POSIX changes
76 1.61 rillig TESTS+= qequals
77 1.84 rillig TESTS+= recursive
78 1.88 rillig TESTS+= # suffixes # runs into an endless loop (try -dA)
79 1.61 rillig TESTS+= sunshcmd
80 1.61 rillig TESTS+= sysv
81 1.61 rillig TESTS+= ternary
82 1.61 rillig TESTS+= unexport
83 1.61 rillig TESTS+= unexport-env
84 1.91 rillig TESTS+= use-inference
85 1.61 rillig TESTS+= varcmd
86 1.64 rillig TESTS+= vardebug
87 1.64 rillig TESTS+= varfind
88 1.61 rillig TESTS+= varmisc
89 1.61 rillig TESTS+= varmod-edge
90 1.66 rillig TESTS+= varparse-dynamic
91 1.61 rillig TESTS+= varquote
92 1.61 rillig TESTS+= varshell
93 1.61 rillig
94 1.64 rillig # Override environment variables for some of the tests.
95 1.82 rillig ENV.counter= -i
96 1.64 rillig ENV.envfirst= FROM_ENV=value-from-env
97 1.69 rillig ENV.export= -i PATH=${PATH:Q}
98 1.89 rillig ENV.export-variants= -i PATH=${PATH:Q}
99 1.83 rillig ENV.lint= -i
100 1.90 rillig ENV.make-exported= -i PATH=${PATH:Q}
101 1.84 rillig ENV.recursive= -i
102 1.65 rillig ENV.varmisc= FROM_ENV=env
103 1.65 rillig ENV.varmisc+= FROM_ENV_BEFORE=env
104 1.65 rillig ENV.varmisc+= FROM_ENV_AFTER=env
105 1.64 rillig
106 1.64 rillig # Override make flags for some of the tests; default is -k.
107 1.82 rillig FLAGS.counter= -r -dv
108 1.61 rillig FLAGS.doterror= # none
109 1.68 rillig FLAGS.envfirst= -e
110 1.71 sjg FLAGS.export= -r
111 1.83 rillig FLAGS.lint= -dL -k
112 1.61 rillig FLAGS.order= -j1
113 1.85 sjg FLAGS.recursive= -dL -r
114 1.64 rillig FLAGS.vardebug= -k -dv FROM_CMDLINE=
115 1.61 rillig
116 1.61 rillig # Some tests need extra post-processing.
117 1.80 rillig SED_CMDS.moderrs+= -e 's,\(Regex compilation error:\).*,\1 (details omitted),'
118 1.80 rillig SED_CMDS.modmisc+= -e 's,\(Regex compilation error:\).*,\1 (details omitted),'
119 1.79 rillig SED_CMDS.varmod-edge+= -e 's, line [0-9]*:, line omitted:,'
120 1.61 rillig SED_CMDS.varshell+= -e 's,^[a-z]*sh: ,,'
121 1.61 rillig SED_CMDS.varshell+= -e '/command/s,No such.*,not found,'
122 1.61 rillig
123 1.64 rillig # Some tests need an additional round of postprocessing.
124 1.81 rillig POSTPROC.counter= ${TOOL_SED} -n -e '/:RELEVANT = yes/,/:RELEVANT = no/p'
125 1.64 rillig POSTPROC.vardebug= ${TOOL_SED} -n -e '/:RELEVANT = yes/,/:RELEVANT = no/p'
126 1.64 rillig
127 1.89 rillig export-all.rawout: export.mk
128 1.89 rillig unexport.rawout: export.mk
129 1.89 rillig unexport-env.rawout: export.mk
130 1.89 rillig
131 1.61 rillig # End of the configuration section.
132 1.61 rillig
133 1.1 sjg .MAIN: all
134 1.1 sjg
135 1.61 rillig UNIT_TESTS:= ${.PARSEDIR}
136 1.44 apb .PATH: ${UNIT_TESTS}
137 1.7 sjg
138 1.61 rillig OUTFILES= ${TESTS:=.out}
139 1.42 apb
140 1.42 apb all: ${OUTFILES}
141 1.9 sjg
142 1.61 rillig CLEANFILES+= *.rawout *.out *.status *.tmp *.core *.tmp
143 1.61 rillig CLEANFILES+= obj*.[och] lib*.a # posix1.mk
144 1.61 rillig CLEANFILES+= issue* .[ab]* # suffixes.mk
145 1.61 rillig CLEANRECURSIVE+= dir dummy # posix1.mk
146 1.48 apb
147 1.1 sjg clean:
148 1.48 apb rm -f ${CLEANFILES}
149 1.48 apb .if !empty(CLEANRECURSIVE)
150 1.48 apb rm -rf ${CLEANRECURSIVE}
151 1.48 apb .endif
152 1.1 sjg
153 1.61 rillig TEST_MAKE?= ${.MAKE}
154 1.61 rillig TOOL_SED?= sed
155 1.1 sjg
156 1.28 sjg # ensure consistent results from sort(1)
157 1.61 rillig LC_ALL= C
158 1.61 rillig LANG= C
159 1.29 sjg .export LANG LC_ALL
160 1.28 sjg
161 1.42 apb # the tests are actually done with sub-makes.
162 1.42 apb .SUFFIXES: .mk .rawout .out
163 1.42 apb .mk.rawout:
164 1.64 rillig @echo testing ${.IMPSRC}
165 1.64 rillig @set -eu; \
166 1.64 rillig cd ${.OBJDIR}; \
167 1.73 sjg env ${ENV.${.TARGET:R}} ${TEST_MAKE} -C ${.CURDIR} \
168 1.64 rillig ${FLAGS.${.TARGET:R}:U-k} -f ${.IMPSRC} \
169 1.64 rillig > ${.TARGET}.tmp 2>&1 \
170 1.64 rillig && status=$$? || status=$$?; \
171 1.64 rillig echo $$status > ${.TARGET:R}.status
172 1.42 apb @mv ${.TARGET}.tmp ${.TARGET}
173 1.42 apb
174 1.62 rillig # Post-process the test output so that the results can be compared.
175 1.62 rillig #
176 1.62 rillig # always pretend .MAKE was called 'make'
177 1.61 rillig _SED_CMDS+= -e 's,^${TEST_MAKE:T:S,.,\\.,g}[][0-9]*:,make:,'
178 1.61 rillig _SED_CMDS+= -e 's,${TEST_MAKE:S,.,\\.,g},make,'
179 1.62 rillig # replace anything after 'stopped in' with unit-tests
180 1.61 rillig _SED_CMDS+= -e '/stopped/s, /.*, unit-tests,'
181 1.62 rillig # strip ${.CURDIR}/ from the output
182 1.61 rillig _SED_CMDS+= -e 's,${.CURDIR:S,.,\\.,g}/,,g'
183 1.61 rillig _SED_CMDS+= -e 's,${UNIT_TESTS:S,.,\\.,g}/,,g'
184 1.61 rillig
185 1.42 apb .rawout.out:
186 1.42 apb @echo postprocess ${.TARGET}
187 1.61 rillig @${TOOL_SED} ${_SED_CMDS} ${SED_CMDS.${.TARGET:R}} \
188 1.64 rillig < ${.IMPSRC} > ${.TARGET}.tmp1
189 1.74 sjg @${POSTPROC.${.TARGET:R}:Ucat} < ${.TARGET}.tmp1 > ${.TARGET}.tmp2
190 1.64 rillig @rm ${.TARGET}.tmp1
191 1.64 rillig @echo "exit status `cat ${.TARGET:R}.status`" >> ${.TARGET}.tmp2
192 1.64 rillig @mv ${.TARGET}.tmp2 ${.TARGET}
193 1.42 apb
194 1.42 apb # Compare all output files
195 1.42 apb test: ${OUTFILES} .PHONY
196 1.42 apb @failed= ; \
197 1.61 rillig for test in ${TESTS}; do \
198 1.42 apb diff -u ${UNIT_TESTS}/$${test}.exp $${test}.out \
199 1.42 apb || failed="$${failed}$${failed:+ }$${test}" ; \
200 1.42 apb done ; \
201 1.42 apb if [ -n "$${failed}" ]; then \
202 1.42 apb echo "Failed tests: $${failed}" ; false ; \
203 1.42 apb else \
204 1.42 apb echo "All tests passed" ; \
205 1.42 apb fi
206 1.1 sjg
207 1.1 sjg accept:
208 1.61 rillig @for test in ${TESTS}; do \
209 1.42 apb cmp -s ${UNIT_TESTS}/$${test}.exp $${test}.out \
210 1.42 apb || { echo "Replacing $${test}.exp" ; \
211 1.42 apb cp $${test}.out ${UNIT_TESTS}/$${test}.exp ; } \
212 1.42 apb done
213 1.1 sjg
214 1.78 rillig SYNC_MI_AWK= \
215 1.78 rillig BEGIN { \
216 1.78 rillig testsdir = "usr.bin/make/unit-tests"; \
217 1.78 rillig linestart = "./usr/tests/" testsdir; \
218 1.78 rillig fmt = linestart "/%s\ttests-usr.bin-tests\tcompattestfile,atf\\n"; \
219 1.78 rillig cmd = "cd " testsdir " && ls *.exp *.mk | xargs printf '" fmt "'" \
220 1.78 rillig } \
221 1.78 rillig function startswith(s, prefix) { \
222 1.78 rillig return substr(s, 1, length(prefix)) == prefix; \
223 1.78 rillig } \
224 1.78 rillig startswith($$1, linestart) && $$1 ~ /\.(exp|mk)$$/ { next } \
225 1.78 rillig { print $$0 } \
226 1.78 rillig $$1 == linestart "/Makefile" { system(cmd) }
227 1.78 rillig
228 1.78 rillig sync-mi:
229 1.78 rillig @set -eu; \
230 1.78 rillig cd "${MAKEFILE:tA:H}/../../.."; \
231 1.78 rillig mi="distrib/sets/lists/tests/mi"; \
232 1.78 rillig awk ${SYNC_MI_AWK:Q} < "$$mi" > "$$mi.$@"; \
233 1.78 rillig mv -f "$$mi.$@" "$$mi"; \
234 1.78 rillig cvs diff "$$mi" || true
235 1.78 rillig
236 1.50 sjg .if exists(${TEST_MAKE})
237 1.61 rillig ${TESTS:=.rawout}: ${TEST_MAKE}
238 1.50 sjg .endif
239 1.50 sjg
240 1.42 apb .-include <bsd.obj.mk>
241