Makefile revision 1.279 1 # $NetBSD: Makefile,v 1.279 2021/06/16 09:39:48 rillig Exp $
2 #
3 # Unit tests for make(1)
4 #
5 # The main targets are:
6 #
7 # all:
8 # run all the tests
9 # test:
10 # run 'all', and compare to expected results
11 # accept:
12 # move generated output to expected results
13 #
14 # Settable variables
15 #
16 # TEST_MAKE
17 # The make program to be tested.
18 #
19 #
20 # Adding a test case
21 #
22 # Each feature should get its own set of tests in its own suitably
23 # named makefile (*.mk), with its own set of expected results (*.exp),
24 # and it should be added to the TESTS list.
25 #
26 # Any added files must also be added to src/distrib/sets/lists/tests/mi.
27 # To do that, just run "make sync-mi" in this directory.
28 #
29 # A few *.mk files are helper files for other tests (such as include-sub.mk)
30 # and are thus not added to TESTS. Such files must be ignored in
31 # src/tests/usr.bin/make/t_make.sh.
32 #
33
34 .MAIN: all
35
36 # we use these below but we might be an older make
37 .MAKE.OS?= ${uname -s:L:sh}
38 .MAKE.UID?= ${id -u:L:sh}
39
40 # Each test is in a sub-makefile.
41 # Keep the list sorted.
42 # Any test that is commented out must be ignored in
43 # src/tests/usr.bin/make/t_make.sh as well.
44 TESTS+= archive
45 TESTS+= archive-suffix
46 TESTS+= cmd-errors
47 TESTS+= cmd-errors-jobs
48 TESTS+= cmd-errors-lint
49 TESTS+= cmd-interrupt
50 TESTS+= cmdline
51 TESTS+= cmdline-redirect-stdin
52 TESTS+= cmdline-undefined
53 TESTS+= comment
54 TESTS+= compat-error
55 TESTS+= cond-cmp-numeric
56 TESTS+= cond-cmp-numeric-eq
57 TESTS+= cond-cmp-numeric-ge
58 TESTS+= cond-cmp-numeric-gt
59 TESTS+= cond-cmp-numeric-le
60 TESTS+= cond-cmp-numeric-lt
61 TESTS+= cond-cmp-numeric-ne
62 TESTS+= cond-cmp-string
63 TESTS+= cond-cmp-unary
64 TESTS+= cond-eof
65 TESTS+= cond-func
66 TESTS+= cond-func-commands
67 TESTS+= cond-func-defined
68 TESTS+= cond-func-empty
69 TESTS+= cond-func-exists
70 TESTS+= cond-func-make
71 TESTS+= cond-func-make-main
72 TESTS+= cond-func-target
73 TESTS+= cond-late
74 TESTS+= cond-op
75 TESTS+= cond-op-and
76 TESTS+= cond-op-and-lint
77 TESTS+= cond-op-not
78 TESTS+= cond-op-or
79 TESTS+= cond-op-or-lint
80 TESTS+= cond-op-parentheses
81 TESTS+= cond-short
82 TESTS+= cond-token-number
83 TESTS+= cond-token-plain
84 TESTS+= cond-token-string
85 TESTS+= cond-token-var
86 TESTS+= cond-undef-lint
87 TESTS+= cond1
88 TESTS+= counter
89 TESTS+= counter-append
90 TESTS+= dep
91 TESTS+= dep-colon
92 TESTS+= dep-colon-bug-cross-file
93 TESTS+= dep-double-colon
94 TESTS+= dep-double-colon-indep
95 TESTS+= dep-exclam
96 TESTS+= dep-none
97 TESTS+= dep-percent
98 TESTS+= dep-var
99 TESTS+= dep-wildcards
100 TESTS+= depsrc
101 TESTS+= depsrc-end
102 TESTS+= depsrc-exec
103 TESTS+= depsrc-ignore
104 TESTS+= depsrc-made
105 TESTS+= depsrc-make
106 TESTS+= depsrc-meta
107 TESTS+= depsrc-nometa
108 TESTS+= depsrc-nometa_cmp
109 TESTS+= depsrc-nopath
110 TESTS+= depsrc-notmain
111 TESTS+= depsrc-optional
112 TESTS+= depsrc-phony
113 TESTS+= depsrc-precious
114 TESTS+= depsrc-recursive
115 TESTS+= depsrc-silent
116 TESTS+= depsrc-use
117 TESTS+= depsrc-usebefore
118 TESTS+= depsrc-usebefore-double-colon
119 TESTS+= depsrc-wait
120 TESTS+= deptgt
121 TESTS+= deptgt-begin
122 TESTS+= deptgt-begin-fail
123 TESTS+= deptgt-begin-fail-indirect
124 TESTS+= deptgt-default
125 TESTS+= deptgt-delete_on_error
126 TESTS+= deptgt-end
127 TESTS+= deptgt-end-fail
128 TESTS+= deptgt-end-fail-all
129 TESTS+= deptgt-end-fail-indirect
130 TESTS+= deptgt-end-jobs
131 TESTS+= deptgt-error
132 TESTS+= deptgt-ignore
133 TESTS+= deptgt-interrupt
134 TESTS+= deptgt-main
135 TESTS+= deptgt-makeflags
136 TESTS+= deptgt-no_parallel
137 TESTS+= deptgt-nopath
138 TESTS+= deptgt-notparallel
139 TESTS+= deptgt-objdir
140 TESTS+= deptgt-order
141 TESTS+= deptgt-path
142 TESTS+= deptgt-path-suffix
143 TESTS+= deptgt-phony
144 TESTS+= deptgt-precious
145 TESTS+= deptgt-shell
146 TESTS+= deptgt-silent
147 TESTS+= deptgt-stale
148 TESTS+= deptgt-suffixes
149 TESTS+= dir
150 TESTS+= dir-expand-path
151 TESTS+= directive
152 TESTS+= directive-dinclude
153 TESTS+= directive-elif
154 TESTS+= directive-elifdef
155 TESTS+= directive-elifmake
156 TESTS+= directive-elifndef
157 TESTS+= directive-elifnmake
158 TESTS+= directive-else
159 TESTS+= directive-endfor
160 TESTS+= directive-endif
161 TESTS+= directive-error
162 TESTS+= directive-export
163 TESTS+= directive-export-env
164 TESTS+= directive-export-impl
165 TESTS+= directive-export-gmake
166 TESTS+= directive-export-literal
167 TESTS+= directive-for
168 TESTS+= directive-for-errors
169 TESTS+= directive-for-escape
170 TESTS+= directive-for-generating-endif
171 TESTS+= directive-for-lines
172 TESTS+= directive-for-null
173 TESTS+= directive-hyphen-include
174 TESTS+= directive-if
175 TESTS+= directive-if-nested
176 TESTS+= directive-ifdef
177 TESTS+= directive-ifmake
178 TESTS+= directive-ifndef
179 TESTS+= directive-ifnmake
180 TESTS+= directive-include
181 TESTS+= directive-include-fatal
182 TESTS+= directive-info
183 TESTS+= directive-misspellings
184 TESTS+= directive-sinclude
185 TESTS+= directive-undef
186 TESTS+= directive-unexport
187 TESTS+= directive-unexport-env
188 TESTS+= directive-warning
189 TESTS+= dollar
190 TESTS+= doterror
191 TESTS+= dotwait
192 TESTS+= envfirst
193 TESTS+= error
194 TESTS+= # escape # broken by reverting POSIX changes
195 TESTS+= export
196 TESTS+= export-all
197 TESTS+= export-env
198 TESTS+= export-variants
199 TESTS+= forloop
200 TESTS+= forsubst
201 TESTS+= gnode-submake
202 TESTS+= hanoi-include
203 TESTS+= impsrc
204 TESTS+= include-main
205 TESTS+= job-flags
206 TESTS+= job-output-long-lines
207 TESTS+= job-output-null
208 TESTS+= jobs-empty-commands
209 TESTS+= jobs-empty-commands-error
210 TESTS+= jobs-error-indirect
211 TESTS+= jobs-error-nested
212 TESTS+= jobs-error-nested-make
213 TESTS+= lint
214 TESTS+= make-exported
215 TESTS+= meta-cmd-cmp
216 TESTS+= moderrs
217 TESTS+= modmatch
218 TESTS+= modmisc
219 TESTS+= modts
220 TESTS+= modword
221 .if ${.MAKE.UID} > 0
222 TESTS+= objdir-writable
223 .endif
224 TESTS+= opt
225 TESTS+= opt-backwards
226 TESTS+= opt-chdir
227 TESTS+= opt-debug
228 TESTS+= opt-debug-all
229 TESTS+= opt-debug-archive
230 TESTS+= opt-debug-curdir
231 TESTS+= opt-debug-cond
232 TESTS+= opt-debug-dir
233 TESTS+= opt-debug-errors
234 TESTS+= opt-debug-errors-jobs
235 TESTS+= opt-debug-file
236 TESTS+= opt-debug-for
237 TESTS+= opt-debug-graph1
238 TESTS+= opt-debug-graph2
239 TESTS+= opt-debug-graph3
240 TESTS+= opt-debug-hash
241 TESTS+= opt-debug-jobs
242 TESTS+= opt-debug-lint
243 TESTS+= opt-debug-loud
244 TESTS+= opt-debug-meta
245 TESTS+= opt-debug-making
246 TESTS+= opt-debug-no-rm
247 TESTS+= opt-debug-parse
248 TESTS+= opt-debug-suff
249 TESTS+= opt-debug-targets
250 TESTS+= opt-debug-varraw
251 TESTS+= opt-debug-var
252 TESTS+= opt-debug-x-trace
253 TESTS+= opt-define
254 TESTS+= opt-env
255 TESTS+= opt-file
256 TESTS+= opt-ignore
257 TESTS+= opt-include-dir
258 TESTS+= opt-jobs
259 TESTS+= opt-jobs-internal
260 TESTS+= opt-jobs-no-action
261 TESTS+= opt-keep-going
262 TESTS+= opt-keep-going-multiple
263 TESTS+= opt-m-include-dir
264 TESTS+= opt-no-action
265 TESTS+= opt-no-action-at-all
266 TESTS+= opt-no-action-runflags
267 TESTS+= opt-no-action-touch
268 TESTS+= opt-query
269 TESTS+= opt-raw
270 TESTS+= opt-silent
271 TESTS+= opt-touch
272 TESTS+= opt-touch-jobs
273 TESTS+= opt-tracefile
274 TESTS+= opt-var-expanded
275 TESTS+= opt-var-literal
276 TESTS+= opt-warnings-as-errors
277 TESTS+= opt-where-am-i
278 TESTS+= opt-x-reduce-exported
279 TESTS+= order
280 TESTS+= parse-var
281 TESTS+= phony-end
282 TESTS+= posix
283 TESTS+= # posix1 # broken by reverting POSIX changes
284 TESTS+= recursive
285 TESTS+= sh
286 TESTS+= sh-dots
287 TESTS+= sh-errctl
288 TESTS+= sh-flags
289 TESTS+= sh-jobs
290 TESTS+= sh-jobs-error
291 TESTS+= sh-leading-at
292 TESTS+= sh-leading-hyphen
293 TESTS+= sh-leading-plus
294 TESTS+= sh-meta-chars
295 TESTS+= sh-multi-line
296 TESTS+= sh-single-line
297 TESTS+= shell-csh
298 TESTS+= shell-custom
299 TESTS+= shell-ksh
300 TESTS+= shell-sh
301 TESTS+= suff-add-later
302 TESTS+= suff-clear-regular
303 TESTS+= suff-clear-single
304 TESTS+= suff-incomplete
305 TESTS+= suff-lookup
306 TESTS+= suff-main
307 TESTS+= suff-main-several
308 TESTS+= suff-phony
309 TESTS+= suff-rebuild
310 TESTS+= suff-self
311 TESTS+= suff-transform-debug
312 TESTS+= suff-transform-endless
313 TESTS+= suff-transform-expand
314 TESTS+= suff-transform-select
315 TESTS+= sunshcmd
316 TESTS+= ternary
317 TESTS+= unexport
318 TESTS+= unexport-env
319 TESTS+= use-inference
320 TESTS+= var-class
321 TESTS+= var-class-cmdline
322 TESTS+= var-class-env
323 TESTS+= var-class-global
324 TESTS+= var-class-local
325 TESTS+= var-class-local-legacy
326 TESTS+= var-eval-short
327 TESTS+= var-op
328 TESTS+= var-op-append
329 TESTS+= var-op-assign
330 TESTS+= var-op-default
331 TESTS+= var-op-expand
332 TESTS+= var-op-shell
333 TESTS+= var-op-sunsh
334 TESTS+= var-recursive
335 TESTS+= varcmd
336 TESTS+= vardebug
337 TESTS+= varfind
338 TESTS+= varmisc
339 TESTS+= varmod
340 TESTS+= varmod-assign
341 TESTS+= varmod-defined
342 TESTS+= varmod-edge
343 TESTS+= varmod-exclam-shell
344 TESTS+= varmod-extension
345 TESTS+= varmod-gmtime
346 TESTS+= varmod-hash
347 TESTS+= varmod-head
348 TESTS+= varmod-ifelse
349 TESTS+= varmod-indirect
350 TESTS+= varmod-l-name-to-value
351 TESTS+= varmod-localtime
352 TESTS+= varmod-loop
353 TESTS+= varmod-loop-varname
354 TESTS+= varmod-match
355 TESTS+= varmod-match-escape
356 TESTS+= varmod-no-match
357 TESTS+= varmod-order
358 TESTS+= varmod-order-reverse
359 TESTS+= varmod-order-shuffle
360 TESTS+= varmod-path
361 TESTS+= varmod-quote
362 TESTS+= varmod-quote-dollar
363 TESTS+= varmod-range
364 TESTS+= varmod-remember
365 TESTS+= varmod-root
366 TESTS+= varmod-select-words
367 TESTS+= varmod-shell
368 TESTS+= varmod-subst
369 TESTS+= varmod-subst-regex
370 TESTS+= varmod-sun-shell
371 TESTS+= varmod-sysv
372 TESTS+= varmod-tail
373 TESTS+= varmod-to-abs
374 TESTS+= varmod-to-lower
375 TESTS+= varmod-to-many-words
376 TESTS+= varmod-to-one-word
377 TESTS+= varmod-to-separator
378 TESTS+= varmod-to-upper
379 TESTS+= varmod-undefined
380 TESTS+= varmod-unique
381 TESTS+= varname
382 TESTS+= varname-dollar
383 TESTS+= varname-dot-alltargets
384 TESTS+= varname-dot-curdir
385 TESTS+= varname-dot-includes
386 TESTS+= varname-dot-includedfromdir
387 TESTS+= varname-dot-includedfromfile
388 TESTS+= varname-dot-libs
389 TESTS+= varname-dot-make-dependfile
390 TESTS+= varname-dot-make-expand_variables
391 TESTS+= varname-dot-make-exported
392 TESTS+= varname-dot-make-jobs
393 TESTS+= varname-dot-make-jobs-prefix
394 TESTS+= varname-dot-make-level
395 TESTS+= varname-dot-make-makefile_preference
396 TESTS+= varname-dot-make-makefiles
397 TESTS+= varname-dot-make-meta-bailiwick
398 TESTS+= varname-dot-make-meta-created
399 TESTS+= varname-dot-make-meta-files
400 TESTS+= varname-dot-make-meta-ignore_filter
401 TESTS+= varname-dot-make-meta-ignore_paths
402 TESTS+= varname-dot-make-meta-ignore_patterns
403 TESTS+= varname-dot-make-meta-prefix
404 TESTS+= varname-dot-make-mode
405 TESTS+= varname-dot-make-path_filemon
406 TESTS+= varname-dot-make-pid
407 TESTS+= varname-dot-make-ppid
408 TESTS+= varname-dot-make-save_dollars
409 TESTS+= varname-dot-makeflags
410 TESTS+= varname-dot-makeoverrides
411 TESTS+= varname-dot-newline
412 TESTS+= varname-dot-objdir
413 TESTS+= varname-dot-parsedir
414 TESTS+= varname-dot-parsefile
415 TESTS+= varname-dot-path
416 TESTS+= varname-dot-shell
417 TESTS+= varname-dot-targets
418 TESTS+= varname-empty
419 TESTS+= varname-make
420 TESTS+= varname-make_print_var_on_error
421 TESTS+= varname-make_print_var_on_error-jobs
422 TESTS+= varname-makefile
423 TESTS+= varname-makeflags
424 TESTS+= varname-pwd
425 TESTS+= varname-vpath
426 TESTS+= varparse-dynamic
427 TESTS+= varparse-errors
428 TESTS+= varparse-mod
429 TESTS+= varparse-undef-partial
430 TESTS+= varquote
431
432 # Ideas for more tests:
433 # char-0020-space.mk
434 # char-005C-backslash.mk
435 # escape-cond-str.mk
436 # escape-cond-func-arg.mk
437 # escape-cond-func-arg.mk
438 # escape-varmod.mk
439 # escape-varmod-define.mk
440 # escape-varmod-match.mk
441 # escape-varname.mk
442 # escape-varassign-varname.mk
443 # escape-varassign-varname-cmdline.mk
444 # escape-varassign-value.mk
445 # escape-varassign-value-cmdline.mk
446 # escape-dependency-source.mk
447 # escape-dependency-target.mk
448 # escape-for-varname.mk
449 # escape-for-item.mk
450 # posix-*.mk (see posix.mk and posix1.mk)
451
452 # Additional environment variables for some of the tests.
453 # The base environment is -i PATH="$PATH".
454 ENV.depsrc-optional+= TZ=UTC
455 ENV.envfirst= FROM_ENV=value-from-env
456 ENV.varmisc= FROM_ENV=env
457 ENV.varmisc+= FROM_ENV_BEFORE=env
458 ENV.varmisc+= FROM_ENV_AFTER=env
459 ENV.varmod-localtime+= TZ=Europe/Berlin
460 ENV.varname-vpath+= VPATH=varname-vpath.dir:varname-vpath.dir2
461
462 # Override make flags for some of the tests; default is -k.
463 # If possible, write ".MAKEFLAGS: -dv" in the test .mk file instead of
464 # settings FLAGS.test=-dv here, since that is closer to the test code.
465 FLAGS.cond-func-make= via-cmdline
466 FLAGS.directive-ifmake= first second
467 FLAGS.doterror= # none, especially not -k
468 FLAGS.jobs-error-indirect= # none, especially not -k
469 FLAGS.jobs-error-nested= # none, especially not -k
470 FLAGS.jobs-error-nested-make= # none, especially not -k
471 FLAGS.varname-empty= -dv '$${:U}=cmdline-u' '=cmdline-plain'
472
473 # Some tests need extra postprocessing.
474 SED_CMDS.dir= ${:D remove output from -DCLEANUP mode }
475 SED_CMDS.dir+= -e '/^OpenDirs_Done:/d'
476 SED_CMDS.dir+= -e '/^CachedDir /d'
477 SED_CMDS.export= -e '/^[^=_A-Za-z0-9]*=/d'
478 SED_CMDS.export-all= ${SED_CMDS.export}
479 SED_CMDS.export-env= ${SED_CMDS.export}
480 SED_CMDS.job-output-long-lines= \
481 ${:D Job separators on their own line are ok. } \
482 -e '/^--- job-[ab] ---$$/d' \
483 ${:D Plain output lines are ok as well. } \
484 ${:D They may come in multiples of 1024 or as 10000. } \
485 -e '/^aa*$$/d' \
486 -e '/^bb*$$/d' \
487 ${:D The following lines should rather not occur since the job } \
488 ${:D marker should always be at the beginning of the line. } \
489 -e '/^aa*--- job-b ---$$/d' \
490 -e '/^bb*--- job-a ---$$/d'
491 SED_CMDS.opt-chdir= -e 's,\(nonexistent\).[1-9][0-9]*,\1,'
492 SED_CMDS.opt-debug-graph1= ${STD_SED_CMDS.dg1}
493 SED_CMDS.opt-debug-graph2= ${STD_SED_CMDS.dg2}
494 SED_CMDS.opt-debug-graph3= ${STD_SED_CMDS.dg3}
495 SED_CMDS.opt-debug-jobs= -e 's,([0-9][0-9]*),(<pid>),'
496 SED_CMDS.opt-debug-jobs+= -e 's,pid [0-9][0-9]*,pid <pid>,'
497 SED_CMDS.opt-debug-jobs+= -e 's,Process [0-9][0-9]*,Process <pid>,'
498 SED_CMDS.opt-debug-jobs+= -e 's,JobFinish: [0-9][0-9]*,JobFinish: <pid>,'
499 SED_CMDS.opt-debug-jobs+= -e 's,Command: ${.SHELL:T},Command: <shell>,'
500 # The "-q" may be there or not, see jobs.c, variable shells.
501 SED_CMDS.opt-debug-jobs+= -e 's,^\(.Command: <shell>\) -q,\1,'
502 SED_CMDS.opt-debug-lint+= ${STD_SED_CMDS.regex}
503 SED_CMDS.opt-jobs-no-action= ${STD_SED_CMDS.hide-from-output}
504 SED_CMDS.opt-no-action-runflags= ${STD_SED_CMDS.hide-from-output}
505 # For Compat_RunCommand, useShell == false.
506 SED_CMDS.sh-dots= -e 's,^.*\.\.\.:.*,<not found: ...>,'
507 # For Compat_RunCommand, useShell == true.
508 SED_CMDS.sh-dots+= -e 's,^make: exec(\(.*\)) failed (.*)$$,<not found: \1>,'
509 SED_CMDS.sh-dots+= -e 's,^\(\*\*\* Error code \)[1-9][0-9]*,\1<nonzero>,'
510 SED_CMDS.sh-errctl= ${STD_SED_CMDS.dj}
511 SED_CMDS.sh-flags= ${STD_SED_CMDS.hide-from-output}
512 SED_CMDS.suff-main+= ${STD_SED_CMDS.dg1}
513 SED_CMDS.suff-main-several+= ${STD_SED_CMDS.dg1}
514 SED_CMDS.suff-transform-debug+= ${STD_SED_CMDS.dg1}
515 SED_CMDS.var-op-shell+= ${STD_SED_CMDS.shell}
516 SED_CMDS.var-op-shell+= -e '/command/s,No such.*,not found,'
517 SED_CMDS.vardebug+= -e 's,${.SHELL},</path/to/shell>,'
518 SED_CMDS.varmod-subst-regex+= ${STD_SED_CMDS.regex}
519 SED_CMDS.varname-dot-parsedir= -e '/in some cases/ s,^make: "[^"]*,make: "<normalized>,'
520 SED_CMDS.varname-dot-parsefile= -e '/in some cases/ s,^make: "[^"]*,make: "<normalized>,'
521 SED_CMDS.varname-dot-shell= -e 's, = /[^ ]*, = (details omitted),g'
522 SED_CMDS.varname-dot-shell+= -e 's,"/[^" ]*","(details omitted)",g'
523 SED_CMDS.varname-dot-shell+= -e 's,\[/[^] ]*\],[(details omitted)],g'
524 SED_CMDS.varname-empty= -e 's,${.CURDIR},<curdir>,g'
525 SED_CMDS.varname-empty+= -e '/\.PARSEDIR/d'
526 SED_CMDS.varname-empty+= -e '/\.SHELL/d'
527
528 # Some tests need an additional round of postprocessing.
529 POSTPROC.deptgt-suffixes= awk '/^\#\*\*\* Suffixes/,/^never-stop/'
530 POSTPROC.gnode-submake= awk '/Input graph/, /^$$/'
531
532 # Some tests reuse other tests, which makes them unnecessarily fragile.
533 export-all.rawout: export.mk
534 unexport.rawout: export.mk
535 unexport-env.rawout: export.mk
536
537 # End of the configuration section.
538
539 # Some standard sed commands, to be used in the SED_CMDS above.
540
541 # Omit details such as process IDs from the output of the -dg1 option.
542 STD_SED_CMDS.dg1= -e 's,${.CURDIR}$$,<curdir>,'
543 STD_SED_CMDS.dg1+= -e 's, ${DEFSYSPATH:U/usr/share/mk}$$, <defsyspath>,'
544 STD_SED_CMDS.dg1+= -e 's,^\(\.MAKE *=\) .*,\1 <details omitted>,'
545 STD_SED_CMDS.dg1+= -e 's,^\(\.MAKE\.[A-Z_]* *=\) .*,\1 <details omitted>,'
546 STD_SED_CMDS.dg1+= -e 's,^\(MACHINE[_ARCH]* *=\) .*,\1 <details omitted>,'
547 STD_SED_CMDS.dg1+= -e 's,^\(MAKE *=\) .*,\1 <details omitted>,'
548 STD_SED_CMDS.dg1+= -e 's,^\(\.SHELL *=\) .*,\1 <details omitted>,'
549
550 STD_SED_CMDS.dg2= ${STD_SED_CMDS.dg1}
551 STD_SED_CMDS.dg2+= -e 's,\(last modified\) ..:..:.. ... ..\, ....,\1 <timestamp>,'
552 STD_SED_CMDS.dg3= ${STD_SED_CMDS.dg2}
553
554 # Omit details such as process IDs from the output of the -dj option.
555 STD_SED_CMDS.dj= \
556 -e '/Process/d;/JobFinish:/d' \
557 -e 's,^\(Job_TokenWithdraw\)([0-9]*),\1(<pid>),' \
558 -e 's,^([0-9][0-9]*) \(withdrew token\),(<pid>) \1,' \
559 -e 's, \(pid\) [0-9][0-9]*, \1 <pid>,' \
560 -e 's,^\( Command:\) .*,\1 <shell>,'
561
562 # Reduce the noise for tests running with the -n option, since there is no
563 # other way to suppress the echoing of the commands.
564 STD_SED_CMDS.hide-from-output= \
565 -e '/^echo hide-from-output/d' \
566 -e 's,hide-from-output ,,' \
567 -e 's,hide-from-output,,'
568
569 # Normalize the output for error messages from the shell.
570 #
571 # $shell -c '...'
572 # NetBSD sh ...: not found
573 # NetBSD ksh ksh: ...: not found
574 # bash 5.0.18 bash: ...: command not found
575 # bash 5.1.0 bash: line 1: ...: command not found
576 # dash dash: 1: ...: not found
577 #
578 # $shell -c '< /nonexistent'
579 # NetBSD sh sh: cannot open /nonexistent: no such file
580 # NetBSD ksh ksh: cannot open /nonexistent: No such file or directory
581 # bash 5.0.18 bash: /nonexistent: No such file or directory
582 # bash 5.1.0 bash: line 1: /nonexistent: No such file or directory
583 # dash dash: 1: cannot open /nonexistent: No such file
584 #
585 # echo '< /nonexistent' | $shell
586 # NetBSD sh sh: cannot open /nonexistent: no such file
587 # NetBSD ksh ksh: <stdin>[1]: cannot open /nonexistent: No such file or directory
588 # bash 5.0.18 bash: line 1: /nonexistent: No such file or directory
589 # bash 5.1.0 bash: line 1: /nonexistent: No such file or directory
590 # dash dash: 1: cannot open /nonexistent: No such file
591 #
592 STD_SED_CMDS.shell+= -e 's,^${.SHELL:T}: line [0-9][0-9]*: ,,'
593 STD_SED_CMDS.shell+= -e 's,^${.SHELL:T}: [0-9][0-9]*: ,,'
594 STD_SED_CMDS.shell+= -e 's,^${.SHELL:T}: ,,'
595
596 # The actual error messages for a failed regcomp or regexec differ between the
597 # implementations.
598 STD_SED_CMDS.regex= \
599 -e 's,\(Regex compilation error:\).*,\1 (details omitted),'
600
601 # End of the configuration helpers section.
602
603 UNIT_TESTS:= ${.PARSEDIR}
604 .PATH: ${UNIT_TESTS}
605
606 .if ${USE_ABSOLUTE_TESTNAMES:Uno} == yes
607 OUTFILES= ${TESTS:@test@${.CURDIR:tA}/${test}.out@}
608 .else
609 OUTFILES= ${TESTS:=.out}
610 .endif
611
612 all: ${OUTFILES}
613
614 CLEANFILES= *.rawout *.out *.status *.tmp *.core *.tmp
615 CLEANFILES+= obj*.[och] lib*.a # posix1.mk
616 CLEANFILES+= issue* .[ab]* # suffixes.mk
617 CLEANDIRS= dir dummy # posix1.mk
618
619 clean:
620 rm -f ${CLEANFILES}
621 rm -rf ${CLEANDIRS}
622
623 TEST_MAKE?= ${.MAKE}
624 TOOL_SED?= sed
625
626 # ensure consistent results from sort(1)
627 LC_ALL= C
628 LANG= C
629 .export LANG LC_ALL
630
631
632 # for many tests we need a TMPDIR that will not collide
633 # with other users.
634 .if ${.OBJDIR} != ${.CURDIR}
635 # easy
636 TMPDIR:= ${.OBJDIR}/tmp
637 .elif defined(TMPDIR)
638 TMPDIR:= ${TMPDIR}/uid${.MAKE.UID}
639 .else
640 TMPDIR:= /tmp/uid${.MAKE.UID}
641 .endif
642 # make sure it exists
643 .if !exist(${TMPDIR})
644 x!= echo; mkdir -p ${TMPDIR}
645 .endif
646
647 MAKE_TEST_ENV?= MALLOC_OPTIONS="JA" # for jemalloc
648 MAKE_TEST_ENV+= TMPDIR=${TMPDIR}
649
650 .if ${.MAKE.OS} == "NetBSD"
651 LIMIT_RESOURCES?= ulimit -v 200000
652 .endif
653 LIMIT_RESOURCES?= :
654
655 # Each test is run in a sub-make, to keep the tests for interfering with
656 # each other, and because they use different environment variables and
657 # command line options.
658 .SUFFIXES: .mk .rawout .out
659 .mk.rawout:
660 @${_MKMSG_TEST:Uecho '# test '} ${.PREFIX}
661 @set -eu; \
662 ${LIMIT_RESOURCES}; \
663 cd ${.OBJDIR}; \
664 env -i PATH="$$PATH" ${MAKE_TEST_ENV} ${ENV.${.PREFIX:T}} \
665 ${TEST_MAKE} \
666 -r -C ${.CURDIR} -f ${.IMPSRC} \
667 ${FLAGS.${.PREFIX:T}:U-k} \
668 > ${.TARGET}.tmp 2>&1 \
669 && status=$$? || status=$$?; \
670 echo $$status > ${.TARGET:R}.status
671 @mv ${.TARGET}.tmp ${.TARGET}
672
673 # Postprocess the test output so that the results can be compared.
674 #
675 # always pretend .MAKE was called 'make'
676 _SED_CMDS+= -e 's,^${TEST_MAKE:T:S,.,\\.,g}[][0-9]*:,make:,'
677 _SED_CMDS+= -e 's,${TEST_MAKE:S,.,\\.,g},make,'
678 _SED_CMDS+= -e 's,${TEST_MAKE:T:S,.,\\.,g}[][0-9]* warning,make warning,'
679 _SED_CMDS+= -e 's,^usage: ${TEST_MAKE:T:S,.,\\.,g} ,usage: make ,'
680 # replace anything after 'stopped in' with unit-tests
681 _SED_CMDS+= -e '/stopped/s, /.*, unit-tests,'
682 _SED_CMDS+= -e 's,${TMPDIR},TMPDIR,g'
683 # strip ${.CURDIR}/ from the output
684 _SED_CMDS+= -e 's,${.CURDIR:S,.,\\.,g}/,,g'
685 _SED_CMDS+= -e 's,${UNIT_TESTS:S,.,\\.,g}/,,g'
686
687 .rawout.out:
688 @${TOOL_SED} ${_SED_CMDS} ${SED_CMDS.${.PREFIX:T}} \
689 < ${.IMPSRC} > ${.TARGET}.tmp1
690 @${POSTPROC.${.PREFIX:T}:Ucat} < ${.TARGET}.tmp1 > ${.TARGET}.tmp2
691 @rm ${.TARGET}.tmp1
692 @echo "exit status `cat ${.TARGET:R}.status`" >> ${.TARGET}.tmp2
693 @mv ${.TARGET}.tmp2 ${.TARGET}
694
695 # Compare all output files
696 test: ${OUTFILES} .PHONY
697 @failed= ; \
698 for test in ${TESTS}; do \
699 diff -u ${UNIT_TESTS}/$${test}.exp $${test}.out \
700 || failed="$${failed}$${failed:+ }$${test}" ; \
701 done ; \
702 if [ -n "$${failed}" ]; then \
703 echo "Failed tests: $${failed}" ; false ; \
704 else \
705 echo "All tests passed" ; \
706 fi
707
708 accept:
709 @for test in ${TESTS}; do \
710 cmp -s ${UNIT_TESTS}/$${test}.exp $${test}.out \
711 || { echo "Replacing $${test}.exp" ; \
712 cp $${test}.out ${UNIT_TESTS}/$${test}.exp ; } \
713 done
714
715 # Note: only works for adding tests.
716 # To remove a test, the $$mi file must be edited manually.
717 sync-mi:
718 @set -eu; \
719 cd "${MAKEFILE:tA:H}/../../.."; \
720 mi="distrib/sets/lists/tests/mi"; \
721 cvs update "$$mi"; \
722 testsdir="usr.bin/make/unit-tests"; \
723 fmt="./usr/tests/$$testsdir/%s\ttests-usr.bin-tests\tcompattestfile,atf\\n"; \
724 cat "$$mi" > "$$mi.tmp"; \
725 (cd "$$testsdir" && ls *.exp *.mk) | xargs printf "$$fmt" >> "$$mi.tmp"; \
726 distrib/sets/fmt-list "$$mi.tmp"; \
727 mv "$$mi.tmp" "$$mi"; \
728 cvs diff "$$mi" || true
729
730 .if exists(${TEST_MAKE})
731 ${TESTS:=.rawout}: ${TEST_MAKE}
732 # in meta mode, we *know* if a target script is impacted
733 # by a makefile change.
734 .if ${.MAKE.MODE:Unormal:Mmeta} == ""
735 ${TESTS:=.rawout}: ${.PARSEDIR}/Makefile
736 .endif
737 .endif
738
739 .-include <bsd.obj.mk>
740