Makefile revision 1.245
11.245Srillig# $NetBSD: Makefile,v 1.245 2020/12/12 15:06:11 rillig Exp $ 21.1Ssjg# 31.1Ssjg# Unit tests for make(1) 41.60Srillig# 51.1Ssjg# The main targets are: 61.1Ssjg# 71.60Srillig# all: 81.60Srillig# run all the tests 91.60Srillig# test: 101.60Srillig# run 'all', and compare to expected results 111.60Srillig# accept: 121.60Srillig# move generated output to expected results 131.60Srillig# 141.61Srillig# Settable variables 151.61Srillig# 161.61Srillig# TEST_MAKE 171.61Srillig# The make program to be tested. 181.61Srillig# 191.60Srillig# 201.60Srillig# Adding a test case 211.60Srillig# 221.11Ssjg# Each feature should get its own set of tests in its own suitably 231.42Sapb# named makefile (*.mk), with its own set of expected results (*.exp), 241.61Srillig# and it should be added to the TESTS list. 251.60Srillig# 261.60Srillig# Any added files must also be added to src/distrib/sets/lists/tests/mi. 271.78Srillig# To do that, just run "make sync-mi" in this directory. 281.78Srillig# 291.78Srillig# A few *.mk files are helper files for other tests (such as include-sub.mk) 301.78Srillig# and are thus not added to TESTS. Such files must be ignored in 311.78Srillig# src/tests/usr.bin/make/t_make.sh. 321.60Srillig# 331.1Ssjg 341.61Srillig# Each test is in a sub-makefile. 351.61Srillig# Keep the list sorted. 361.92Srillig# Any test that is commented out must be ignored in 371.92Srillig# src/tests/usr.bin/make/t_make.sh as well. 381.133SrilligTESTS+= archive 391.126SrilligTESTS+= archive-suffix 401.183SrilligTESTS+= cmd-errors 411.185SrilligTESTS+= cmd-errors-lint 421.124SrilligTESTS+= cmd-interrupt 431.75SrilligTESTS+= cmdline 441.188SrilligTESTS+= cmdline-undefined 451.61SrilligTESTS+= comment 461.93SrilligTESTS+= cond-cmp-numeric 471.117SrilligTESTS+= cond-cmp-numeric-eq 481.117SrilligTESTS+= cond-cmp-numeric-ge 491.117SrilligTESTS+= cond-cmp-numeric-gt 501.117SrilligTESTS+= cond-cmp-numeric-le 511.117SrilligTESTS+= cond-cmp-numeric-lt 521.117SrilligTESTS+= cond-cmp-numeric-ne 531.93SrilligTESTS+= cond-cmp-string 541.141SrilligTESTS+= cond-cmp-unary 551.103SrilligTESTS+= cond-func 561.93SrilligTESTS+= cond-func-commands 571.93SrilligTESTS+= cond-func-defined 581.93SrilligTESTS+= cond-func-empty 591.93SrilligTESTS+= cond-func-exists 601.93SrilligTESTS+= cond-func-make 611.217SrilligTESTS+= cond-func-make-main 621.93SrilligTESTS+= cond-func-target 631.61SrilligTESTS+= cond-late 641.93SrilligTESTS+= cond-op 651.93SrilligTESTS+= cond-op-and 661.192SrilligTESTS+= cond-op-and-lint 671.93SrilligTESTS+= cond-op-not 681.93SrilligTESTS+= cond-op-or 691.192SrilligTESTS+= cond-op-or-lint 701.93SrilligTESTS+= cond-op-parentheses 711.61SrilligTESTS+= cond-short 721.93SrilligTESTS+= cond-token-number 731.93SrilligTESTS+= cond-token-plain 741.93SrilligTESTS+= cond-token-string 751.93SrilligTESTS+= cond-token-var 761.142SrilligTESTS+= cond-undef-lint 771.61SrilligTESTS+= cond1 781.81SrilligTESTS+= counter 791.147SrilligTESTS+= counter-append 801.93SrilligTESTS+= dep 811.93SrilligTESTS+= dep-colon 821.152SrilligTESTS+= dep-colon-bug-cross-file 831.93SrilligTESTS+= dep-double-colon 841.172SrilligTESTS+= dep-double-colon-indep 851.93SrilligTESTS+= dep-exclam 861.107SrilligTESTS+= dep-none 871.174SrilligTESTS+= dep-percent 881.109SrilligTESTS+= dep-var 891.93SrilligTESTS+= dep-wildcards 901.93SrilligTESTS+= depsrc 911.173SrilligTESTS+= depsrc-end 921.93SrilligTESTS+= depsrc-exec 931.93SrilligTESTS+= depsrc-ignore 941.93SrilligTESTS+= depsrc-made 951.93SrilligTESTS+= depsrc-make 961.93SrilligTESTS+= depsrc-meta 971.93SrilligTESTS+= depsrc-nometa 981.93SrilligTESTS+= depsrc-nometa_cmp 991.93SrilligTESTS+= depsrc-nopath 1001.93SrilligTESTS+= depsrc-notmain 1011.93SrilligTESTS+= depsrc-optional 1021.93SrilligTESTS+= depsrc-phony 1031.93SrilligTESTS+= depsrc-precious 1041.93SrilligTESTS+= depsrc-recursive 1051.93SrilligTESTS+= depsrc-silent 1061.93SrilligTESTS+= depsrc-use 1071.93SrilligTESTS+= depsrc-usebefore 1081.105SrilligTESTS+= depsrc-usebefore-double-colon 1091.93SrilligTESTS+= depsrc-wait 1101.93SrilligTESTS+= deptgt 1111.93SrilligTESTS+= deptgt-begin 1121.224SrilligTESTS+= deptgt-begin-fail 1131.224SrilligTESTS+= deptgt-begin-fail-indirect 1141.93SrilligTESTS+= deptgt-default 1151.93SrilligTESTS+= deptgt-delete_on_error 1161.93SrilligTESTS+= deptgt-end 1171.222SrilligTESTS+= deptgt-end-fail 1181.237SrilligTESTS+= deptgt-end-fail-all 1191.223SrilligTESTS+= deptgt-end-fail-indirect 1201.146SrilligTESTS+= deptgt-end-jobs 1211.93SrilligTESTS+= deptgt-error 1221.93SrilligTESTS+= deptgt-ignore 1231.93SrilligTESTS+= deptgt-interrupt 1241.93SrilligTESTS+= deptgt-main 1251.93SrilligTESTS+= deptgt-makeflags 1261.93SrilligTESTS+= deptgt-no_parallel 1271.93SrilligTESTS+= deptgt-nopath 1281.93SrilligTESTS+= deptgt-notparallel 1291.93SrilligTESTS+= deptgt-objdir 1301.93SrilligTESTS+= deptgt-order 1311.93SrilligTESTS+= deptgt-path 1321.93SrilligTESTS+= deptgt-path-suffix 1331.93SrilligTESTS+= deptgt-phony 1341.93SrilligTESTS+= deptgt-precious 1351.93SrilligTESTS+= deptgt-shell 1361.93SrilligTESTS+= deptgt-silent 1371.93SrilligTESTS+= deptgt-stale 1381.93SrilligTESTS+= deptgt-suffixes 1391.77SrilligTESTS+= dir 1401.114SrilligTESTS+= dir-expand-path 1411.93SrilligTESTS+= directive 1421.140SrilligTESTS+= directive-dinclude 1431.93SrilligTESTS+= directive-elif 1441.93SrilligTESTS+= directive-elifdef 1451.93SrilligTESTS+= directive-elifmake 1461.93SrilligTESTS+= directive-elifndef 1471.93SrilligTESTS+= directive-elifnmake 1481.93SrilligTESTS+= directive-else 1491.93SrilligTESTS+= directive-endif 1501.93SrilligTESTS+= directive-error 1511.93SrilligTESTS+= directive-export 1521.93SrilligTESTS+= directive-export-env 1531.156SrilligTESTS+= directive-export-gmake 1541.93SrilligTESTS+= directive-export-literal 1551.130SrilligTESTS+= directive-for 1561.127SrilligTESTS+= directive-for-generating-endif 1571.140SrilligTESTS+= directive-hyphen-include 1581.93SrilligTESTS+= directive-if 1591.197SrilligTESTS+= directive-if-nested 1601.93SrilligTESTS+= directive-ifdef 1611.93SrilligTESTS+= directive-ifmake 1621.93SrilligTESTS+= directive-ifndef 1631.93SrilligTESTS+= directive-ifnmake 1641.140SrilligTESTS+= directive-include 1651.140SrilligTESTS+= directive-include-fatal 1661.93SrilligTESTS+= directive-info 1671.140SrilligTESTS+= directive-sinclude 1681.93SrilligTESTS+= directive-undef 1691.93SrilligTESTS+= directive-unexport 1701.93SrilligTESTS+= directive-unexport-env 1711.93SrilligTESTS+= directive-warning 1721.61SrilligTESTS+= dollar 1731.61SrilligTESTS+= doterror 1741.61SrilligTESTS+= dotwait 1751.64SrilligTESTS+= envfirst 1761.61SrilligTESTS+= error 1771.63SsjgTESTS+= # escape # broken by reverting POSIX changes 1781.61SrilligTESTS+= export 1791.61SrilligTESTS+= export-all 1801.61SrilligTESTS+= export-env 1811.89SrilligTESTS+= export-variants 1821.61SrilligTESTS+= forloop 1831.61SrilligTESTS+= forsubst 1841.190SrilligTESTS+= gnode-submake 1851.162SrilligTESTS+= hanoi-include 1861.86SrilligTESTS+= impsrc 1871.61SrilligTESTS+= include-main 1881.189SrilligTESTS+= job-flags 1891.154SrilligTESTS+= job-output-long-lines 1901.232SrilligTESTS+= jobs-error-indirect 1911.232SrilligTESTS+= jobs-error-nested 1921.232SrilligTESTS+= jobs-error-nested-make 1931.83SrilligTESTS+= lint 1941.90SrilligTESTS+= make-exported 1951.230SsjgTESTS+= meta-cmd-cmp 1961.61SrilligTESTS+= moderrs 1971.61SrilligTESTS+= modmatch 1981.61SrilligTESTS+= modmisc 1991.61SrilligTESTS+= modts 2001.61SrilligTESTS+= modword 2011.226Ssjg.if ${.MAKE.UID:U0} > 0 2021.198SsjgTESTS+= objdir-writable 2031.225Ssjg.endif 2041.93SrilligTESTS+= opt 2051.93SrilligTESTS+= opt-backwards 2061.93SrilligTESTS+= opt-chdir 2071.93SrilligTESTS+= opt-debug 2081.134SrilligTESTS+= opt-debug-all 2091.134SrilligTESTS+= opt-debug-archive 2101.134SrilligTESTS+= opt-debug-curdir 2111.134SrilligTESTS+= opt-debug-cond 2121.134SrilligTESTS+= opt-debug-dir 2131.134SrilligTESTS+= opt-debug-errors 2141.134SrilligTESTS+= opt-debug-file 2151.134SrilligTESTS+= opt-debug-for 2161.134SrilligTESTS+= opt-debug-graph1 2171.134SrilligTESTS+= opt-debug-graph2 2181.134SrilligTESTS+= opt-debug-graph3 2191.134SrilligTESTS+= opt-debug-hash 2201.134SrilligTESTS+= opt-debug-jobs 2211.134SrilligTESTS+= opt-debug-lint 2221.134SrilligTESTS+= opt-debug-loud 2231.134SrilligTESTS+= opt-debug-meta 2241.134SrilligTESTS+= opt-debug-making 2251.134SrilligTESTS+= opt-debug-no-rm 2261.134SrilligTESTS+= opt-debug-parse 2271.134SrilligTESTS+= opt-debug-suff 2281.134SrilligTESTS+= opt-debug-targets 2291.134SrilligTESTS+= opt-debug-varraw 2301.134SrilligTESTS+= opt-debug-var 2311.134SrilligTESTS+= opt-debug-x-trace 2321.93SrilligTESTS+= opt-define 2331.93SrilligTESTS+= opt-env 2341.93SrilligTESTS+= opt-file 2351.93SrilligTESTS+= opt-ignore 2361.93SrilligTESTS+= opt-include-dir 2371.93SrilligTESTS+= opt-jobs 2381.93SrilligTESTS+= opt-jobs-internal 2391.241SrilligTESTS+= opt-jobs-no-action 2401.93SrilligTESTS+= opt-keep-going 2411.238SrilligTESTS+= opt-keep-going-multiple 2421.93SrilligTESTS+= opt-m-include-dir 2431.93SrilligTESTS+= opt-no-action 2441.93SrilligTESTS+= opt-no-action-at-all 2451.242SrilligTESTS+= opt-no-action-runflags 2461.93SrilligTESTS+= opt-query 2471.93SrilligTESTS+= opt-raw 2481.93SrilligTESTS+= opt-silent 2491.93SrilligTESTS+= opt-touch 2501.199SrilligTESTS+= opt-touch-jobs 2511.93SrilligTESTS+= opt-tracefile 2521.93SrilligTESTS+= opt-var-expanded 2531.93SrilligTESTS+= opt-var-literal 2541.93SrilligTESTS+= opt-warnings-as-errors 2551.93SrilligTESTS+= opt-where-am-i 2561.93SrilligTESTS+= opt-x-reduce-exported 2571.61SrilligTESTS+= order 2581.162SrilligTESTS+= parse-var 2591.88SrilligTESTS+= phony-end 2601.61SrilligTESTS+= posix 2611.63SsjgTESTS+= # posix1 # broken by reverting POSIX changes 2621.84SrilligTESTS+= recursive 2631.93SrilligTESTS+= sh 2641.106SrilligTESTS+= sh-dots 2651.245SrilligTESTS+= sh-errctl 2661.244SrilligTESTS+= sh-flags 2671.93SrilligTESTS+= sh-jobs 2681.93SrilligTESTS+= sh-jobs-error 2691.93SrilligTESTS+= sh-leading-at 2701.93SrilligTESTS+= sh-leading-hyphen 2711.93SrilligTESTS+= sh-leading-plus 2721.93SrilligTESTS+= sh-meta-chars 2731.93SrilligTESTS+= sh-multi-line 2741.93SrilligTESTS+= sh-single-line 2751.162SrilligTESTS+= shell-csh 2761.162SrilligTESTS+= shell-custom 2771.162SrilligTESTS+= shell-ksh 2781.162SrilligTESTS+= shell-sh 2791.169SrilligTESTS+= suff-add-later 2801.169SrilligTESTS+= suff-clear-regular 2811.169SrilligTESTS+= suff-clear-single 2821.212SrilligTESTS+= suff-incomplete 2831.175SrilligTESTS+= suff-lookup 2841.167SrilligTESTS+= suff-main 2851.218SrilligTESTS+= suff-main-several 2861.220SrilligTESTS+= suff-phony 2871.150SrilligTESTS+= suff-rebuild 2881.203SrilligTESTS+= suff-self 2891.219SrilligTESTS+= suff-transform-debug 2901.169SrilligTESTS+= suff-transform-endless 2911.169SrilligTESTS+= suff-transform-expand 2921.169SrilligTESTS+= suff-transform-select 2931.61SrilligTESTS+= sunshcmd 2941.61SrilligTESTS+= ternary 2951.61SrilligTESTS+= unexport 2961.61SrilligTESTS+= unexport-env 2971.91SrilligTESTS+= use-inference 2981.93SrilligTESTS+= var-class 2991.93SrilligTESTS+= var-class-cmdline 3001.93SrilligTESTS+= var-class-env 3011.93SrilligTESTS+= var-class-global 3021.93SrilligTESTS+= var-class-local 3031.93SrilligTESTS+= var-class-local-legacy 3041.93SrilligTESTS+= var-op 3051.93SrilligTESTS+= var-op-append 3061.93SrilligTESTS+= var-op-assign 3071.93SrilligTESTS+= var-op-default 3081.93SrilligTESTS+= var-op-expand 3091.93SrilligTESTS+= var-op-shell 3101.162SrilligTESTS+= var-op-sunsh 3111.179SrilligTESTS+= var-recursive 3121.61SrilligTESTS+= varcmd 3131.64SrilligTESTS+= vardebug 3141.64SrilligTESTS+= varfind 3151.61SrilligTESTS+= varmisc 3161.93SrilligTESTS+= varmod 3171.93SrilligTESTS+= varmod-assign 3181.93SrilligTESTS+= varmod-defined 3191.61SrilligTESTS+= varmod-edge 3201.93SrilligTESTS+= varmod-exclam-shell 3211.93SrilligTESTS+= varmod-extension 3221.93SrilligTESTS+= varmod-gmtime 3231.93SrilligTESTS+= varmod-hash 3241.93SrilligTESTS+= varmod-head 3251.93SrilligTESTS+= varmod-ifelse 3261.234SrilligTESTS+= varmod-indirect 3271.93SrilligTESTS+= varmod-l-name-to-value 3281.93SrilligTESTS+= varmod-localtime 3291.93SrilligTESTS+= varmod-loop 3301.93SrilligTESTS+= varmod-match 3311.99SrilligTESTS+= varmod-match-escape 3321.93SrilligTESTS+= varmod-no-match 3331.93SrilligTESTS+= varmod-order 3341.93SrilligTESTS+= varmod-order-reverse 3351.93SrilligTESTS+= varmod-order-shuffle 3361.93SrilligTESTS+= varmod-path 3371.93SrilligTESTS+= varmod-quote 3381.93SrilligTESTS+= varmod-quote-dollar 3391.93SrilligTESTS+= varmod-range 3401.93SrilligTESTS+= varmod-remember 3411.93SrilligTESTS+= varmod-root 3421.93SrilligTESTS+= varmod-select-words 3431.93SrilligTESTS+= varmod-shell 3441.93SrilligTESTS+= varmod-subst 3451.93SrilligTESTS+= varmod-subst-regex 3461.93SrilligTESTS+= varmod-sysv 3471.93SrilligTESTS+= varmod-tail 3481.93SrilligTESTS+= varmod-to-abs 3491.93SrilligTESTS+= varmod-to-lower 3501.93SrilligTESTS+= varmod-to-many-words 3511.93SrilligTESTS+= varmod-to-one-word 3521.93SrilligTESTS+= varmod-to-separator 3531.93SrilligTESTS+= varmod-to-upper 3541.93SrilligTESTS+= varmod-undefined 3551.93SrilligTESTS+= varmod-unique 3561.93SrilligTESTS+= varname 3571.93SrilligTESTS+= varname-dollar 3581.93SrilligTESTS+= varname-dot-alltargets 3591.93SrilligTESTS+= varname-dot-curdir 3601.122SrilligTESTS+= varname-dot-includes 3611.93SrilligTESTS+= varname-dot-includedfromdir 3621.93SrilligTESTS+= varname-dot-includedfromfile 3631.122SrilligTESTS+= varname-dot-libs 3641.93SrilligTESTS+= varname-dot-make-dependfile 3651.93SrilligTESTS+= varname-dot-make-expand_variables 3661.93SrilligTESTS+= varname-dot-make-exported 3671.93SrilligTESTS+= varname-dot-make-jobs 3681.93SrilligTESTS+= varname-dot-make-jobs-prefix 3691.93SrilligTESTS+= varname-dot-make-level 3701.93SrilligTESTS+= varname-dot-make-makefile_preference 3711.93SrilligTESTS+= varname-dot-make-makefiles 3721.93SrilligTESTS+= varname-dot-make-meta-bailiwick 3731.93SrilligTESTS+= varname-dot-make-meta-created 3741.93SrilligTESTS+= varname-dot-make-meta-files 3751.93SrilligTESTS+= varname-dot-make-meta-ignore_filter 3761.93SrilligTESTS+= varname-dot-make-meta-ignore_paths 3771.93SrilligTESTS+= varname-dot-make-meta-ignore_patterns 3781.93SrilligTESTS+= varname-dot-make-meta-prefix 3791.93SrilligTESTS+= varname-dot-make-mode 3801.93SrilligTESTS+= varname-dot-make-path_filemon 3811.93SrilligTESTS+= varname-dot-make-pid 3821.93SrilligTESTS+= varname-dot-make-ppid 3831.93SrilligTESTS+= varname-dot-make-save_dollars 3841.233SrilligTESTS+= varname-dot-makeflags 3851.93SrilligTESTS+= varname-dot-makeoverrides 3861.93SrilligTESTS+= varname-dot-newline 3871.93SrilligTESTS+= varname-dot-objdir 3881.93SrilligTESTS+= varname-dot-parsedir 3891.93SrilligTESTS+= varname-dot-parsefile 3901.93SrilligTESTS+= varname-dot-path 3911.115SrilligTESTS+= varname-dot-shell 3921.93SrilligTESTS+= varname-dot-targets 3931.110SrilligTESTS+= varname-empty 3941.93SrilligTESTS+= varname-make 3951.93SrilligTESTS+= varname-make_print_var_on_error 3961.170SrilligTESTS+= varname-make_print_var_on_error-jobs 3971.132SrilligTESTS+= varname-makefile 3981.93SrilligTESTS+= varname-makeflags 3991.93SrilligTESTS+= varname-pwd 4001.93SrilligTESTS+= varname-vpath 4011.66SrilligTESTS+= varparse-dynamic 4021.191SrilligTESTS+= varparse-errors 4031.156SrilligTESTS+= varparse-mod 4041.149SrilligTESTS+= varparse-undef-partial 4051.61SrilligTESTS+= varquote 4061.61Srillig 4071.201Srillig# Ideas for more tests: 4081.201Srillig# char-0020-space.mk 4091.201Srillig# char-005C-backslash.mk 4101.201Srillig# escape-cond-str.mk 4111.201Srillig# escape-cond-func-arg.mk 4121.201Srillig# escape-cond-func-arg.mk 4131.201Srillig# escape-varmod.mk 4141.201Srillig# escape-varmod-define.mk 4151.201Srillig# escape-varmod-match.mk 4161.201Srillig# escape-varname.mk 4171.201Srillig# escape-varassign-varname.mk 4181.201Srillig# escape-varassign-varname-cmdline.mk 4191.201Srillig# escape-varassign-value.mk 4201.201Srillig# escape-varassign-value-cmdline.mk 4211.201Srillig# escape-dependency-source.mk 4221.201Srillig# escape-dependency-target.mk 4231.201Srillig# escape-for-varname.mk 4241.201Srillig# escape-for-item.mk 4251.201Srillig# posix-*.mk (see posix.mk and posix1.mk) 4261.201Srillig 4271.198Ssjg.if ${.OBJDIR} != ${.CURDIR} 4281.198SsjgRO_OBJDIR:= ${.OBJDIR}/roobj 4291.198Ssjg.else 4301.198SsjgRO_OBJDIR:= ${TMPDIR:U/tmp}/roobj 4311.198Ssjg.endif 4321.98Srillig# Additional environment variables for some of the tests. 4331.98Srillig# The base environment is -i PATH="$PATH". 4341.194SrilligENV.depsrc-optional+= TZ=UTC 4351.64SrilligENV.envfirst= FROM_ENV=value-from-env 4361.198SsjgENV.objdir-writable+= RO_OBJDIR=${RO_OBJDIR} 4371.65SrilligENV.varmisc= FROM_ENV=env 4381.65SrilligENV.varmisc+= FROM_ENV_BEFORE=env 4391.65SrilligENV.varmisc+= FROM_ENV_AFTER=env 4401.180SrilligENV.varmod-localtime+= TZ=Europe/Berlin 4411.196SrilligENV.varname-vpath+= VPATH=varname-vpath.dir:varname-vpath.dir2 4421.64Srillig 4431.64Srillig# Override make flags for some of the tests; default is -k. 4441.123Srillig# If possible, write ".MAKEFLAGS: -dv" in the test .mk file instead of 4451.123Srillig# settings FLAGS.test=-dv here, since that is closer to the test code. 4461.232SrilligFLAGS.cond-func-make= via-cmdline 4471.232SrilligFLAGS.directive-ifmake= first second 4481.232SrilligFLAGS.doterror= # none, especially not -k 4491.232SrilligFLAGS.jobs-error-indirect= # none, especially not -k 4501.232SrilligFLAGS.jobs-error-nested= # none, especially not -k 4511.232SrilligFLAGS.jobs-error-nested-make= # none, especially not -k 4521.232SrilligFLAGS.varname-empty= -dv '$${:U}=cmdline-u' '=cmdline-plain' 4531.61Srillig 4541.137Srillig# Some tests need extra postprocessing. 4551.227SrilligSED_CMDS.dir= ${:D remove output from -DCLEANUP mode } 4561.228SrilligSED_CMDS.dir+= -e '/^OpenDirs_Done:/d' 4571.229SrilligSED_CMDS.dir+= -e '/^CachedDir /d' 4581.216SrilligSED_CMDS.export= -e '/^[^=_A-Za-z0-9]*=/d' 4591.216SrilligSED_CMDS.export-all= ${SED_CMDS.export} 4601.216SrilligSED_CMDS.export-env= ${SED_CMDS.export} 4611.155SrilligSED_CMDS.job-output-long-lines= \ 4621.155Srillig ${:D Job separators on their own line are ok. } \ 4631.155Srillig -e '/^--- job-[ab] ---$$/d' \ 4641.155Srillig ${:D Plain output lines are ok as well. } \ 4651.155Srillig ${:D They may come in multiples of 1024 or as 10000. } \ 4661.155Srillig -e '/^aa*$$/d' \ 4671.155Srillig -e '/^bb*$$/d' \ 4681.155Srillig ${:D The following lines should rather not occur since the job } \ 4691.155Srillig ${:D marker should always be at the beginning of the line. } \ 4701.155Srillig -e '/^aa*--- job-b ---$$/d' \ 4711.155Srillig -e '/^bb*--- job-a ---$$/d' 4721.215SrilligSED_CMDS.objdir-writable= -e 's,${RO_OBJDIR},OBJDIR/roobj,g' 4731.215SrilligSED_CMDS.opt-debug-graph1= ${STD_SED_CMDS.dg1} 4741.162SrilligSED_CMDS.opt-debug-jobs= -e 's,([0-9][0-9]*),(<pid>),' 4751.162SrilligSED_CMDS.opt-debug-jobs+= -e 's,pid [0-9][0-9]*,pid <pid>,' 4761.162SrilligSED_CMDS.opt-debug-jobs+= -e 's,Process [0-9][0-9]*,Process <pid>,' 4771.162SrilligSED_CMDS.opt-debug-jobs+= -e 's,JobFinish: [0-9][0-9]*,JobFinish: <pid>,' 4781.210SrilligSED_CMDS.opt-debug-jobs+= -e 's,Command: ${.SHELL:T},Command: <shell>,' 4791.163Srillig# The "-q" may be there or not, see jobs.c, variable shells. 4801.211SrilligSED_CMDS.opt-debug-jobs+= -e 's,^\(.Command: <shell>\) -q,\1,' 4811.243SrilligSED_CMDS.opt-jobs-no-action= ${STD_SED_CMDS.hide-from-output} 4821.243SrilligSED_CMDS.opt-no-action-runflags= ${STD_SED_CMDS.hide-from-output} 4831.240Srillig# For Compat_RunCommand, useShell == FALSE. 4841.240SrilligSED_CMDS.sh-dots= -e 's,^.*\.\.\.:.*,<not found: ...>,' 4851.240Srillig# For Compat_RunCommand, useShell == TRUE. 4861.240SrilligSED_CMDS.sh-dots+= -e 's,^make: exec(\(.*\)) failed (.*)$$,<not found: \1>,' 4871.240SrilligSED_CMDS.sh-dots+= -e 's,^\(\*\*\* Error code \)[1-9][0-9]*,\1<nonzero>,' 4881.245SrilligSED_CMDS.sh-errctl= ${STD_SED_CMDS.dj} 4891.244SrilligSED_CMDS.sh-flags= ${STD_SED_CMDS.hide-from-output} 4901.215SrilligSED_CMDS.suff-main+= ${STD_SED_CMDS.dg1} 4911.218SrilligSED_CMDS.suff-main-several+= ${STD_SED_CMDS.dg1} 4921.219SrilligSED_CMDS.suff-transform-debug+= ${STD_SED_CMDS.dg1} 4931.207SsjgSED_CMDS.var-op-shell+= \ 4941.207Ssjg -e 's,^${.SHELL:T}: [ 0-9:]*,,' \ 4951.207Ssjg -e '/command/s,No such.*,not found,' 4961.205SrilligSED_CMDS.vardebug+= -e 's,${.SHELL},</path/to/shell>,' 4971.231SrilligSED_CMDS.varmod-edge+= -e 's, line [0-9]*:, line omitted:,' 4981.231SrilligSED_CMDS.varmod-gmtime+= -e 's,Tue Jan 19 03:14:08 2038,<normalized>,' 4991.231SrilligSED_CMDS.varmod-gmtime+= ${:D FreeBSD i386 still has 32-bit time_t. } 5001.231SrilligSED_CMDS.varmod-gmtime+= -e 's,Fri Dec 13 20:45:52 1901,<normalized>,' 5011.231SrilligSED_CMDS.varmod-localtime+= -e 's,Tue Jan 19 04:14:08 2038,<normalized>,' 5021.231SrilligSED_CMDS.varmod-localtime+= ${:D FreeBSD i386 still has 32-bit time_t. } 5031.231SrilligSED_CMDS.varmod-localtime+= -e 's,Fri Dec 13 21:45:52 1901,<normalized>,' 5041.94SrilligSED_CMDS.varmod-subst-regex+= \ 5051.94Srillig -e 's,\(Regex compilation error:\).*,\1 (details omitted),' 5061.144SrilligSED_CMDS.varname-dot-parsedir= -e '/in some cases/ s,^make: "[^"]*,make: "<normalized>,' 5071.144SrilligSED_CMDS.varname-dot-parsefile= -e '/in some cases/ s,^make: "[^"]*,make: "<normalized>,' 5081.177SrilligSED_CMDS.varname-dot-shell= -e 's, = /[^ ]*, = (details omitted),g' 5091.177SrilligSED_CMDS.varname-dot-shell+= -e 's,"/[^" ]*","(details omitted)",g' 5101.177SrilligSED_CMDS.varname-dot-shell+= -e 's,\[/[^] ]*\],[(details omitted)],g' 5111.61Srillig 5121.64Srillig# Some tests need an additional round of postprocessing. 5131.235SrilligPOSTPROC.deptgt-suffixes= awk '/^\#\*\*\* Suffixes/,/^never-stop/' 5141.235SrilligPOSTPROC.gnode-submake= awk '/Input graph/, /^$$/' 5151.235SrilligPOSTPROC.varname-empty= ${TOOL_SED} -n -e '/^Var_Set/p' -e '/^out:/p' 5161.64Srillig 5171.99Srillig# Some tests reuse other tests, which makes them unnecessarily fragile. 5181.89Srilligexport-all.rawout: export.mk 5191.89Srilligunexport.rawout: export.mk 5201.89Srilligunexport-env.rawout: export.mk 5211.89Srillig 5221.61Srillig# End of the configuration section. 5231.61Srillig 5241.215Srillig# Some standard sed commands, to be used in the SED_CMDS above. 5251.215Srillig 5261.245Srillig# Omit details such as process IDs from the output of the -dg1 option. 5271.235SrilligSTD_SED_CMDS.dg1= -e 's,${.CURDIR}$$,<curdir>,' 5281.235SrilligSTD_SED_CMDS.dg1+= -e 's, ${DEFSYSPATH:U/usr/share/mk}$$, <defsyspath>,' 5291.215SrilligSTD_SED_CMDS.dg1+= -e 's,^\(\.MAKE *=\) .*,\1 <details omitted>,' 5301.215SrilligSTD_SED_CMDS.dg1+= -e 's,^\(\.MAKE\.[A-Z_]* *=\) .*,\1 <details omitted>,' 5311.215SrilligSTD_SED_CMDS.dg1+= -e 's,^\(MACHINE[_ARCH]* *=\) .*,\1 <details omitted>,' 5321.215SrilligSTD_SED_CMDS.dg1+= -e 's,^\(MAKE *=\) .*,\1 <details omitted>,' 5331.221Srillig 5341.245Srillig# Omit details such as process IDs from the output of the -dj option. 5351.245SrilligSTD_SED_CMDS.dj= \ 5361.245Srillig -e 's,^\(Job_TokenWithdraw\)([0-9]*),\1(<pid>),' \ 5371.245Srillig -e 's,^([0-9][0-9]*) \(withdrew token\),(<pid>) \1,' \ 5381.245Srillig -e 's, \(pid\) [0-9][0-9]*, \1 <pid>,' \ 5391.245Srillig -e 's,^\(Process\) [0-9][0-9]*,\1 <pid>,' \ 5401.245Srillig -e 's,^\(JobFinish:\) [0-9][0-9]*,\1 <pid>,' \ 5411.245Srillig -e 's,^\( Command:\) .*,\1 <shell>,' 5421.245Srillig 5431.243Srillig# Reduce the noise for tests running with the -n option, since there is no 5441.243Srillig# other way to suppress the echoing of the commands. 5451.243SrilligSTD_SED_CMDS.hide-from-output= \ 5461.243Srillig -e '/^echo hide-from-output/d' \ 5471.243Srillig -e 's,hide-from-output ,,' \ 5481.243Srillig -e 's,hide-from-output,,' 5491.243Srillig 5501.215Srillig# End of the configuration helpers section. 5511.215Srillig 5521.1Ssjg.MAIN: all 5531.1Ssjg 5541.61SrilligUNIT_TESTS:= ${.PARSEDIR} 5551.44Sapb.PATH: ${UNIT_TESTS} 5561.7Ssjg 5571.145Srillig.if ${USE_ABSOLUTE_TESTNAMES:Uno} == yes 5581.145SrilligOUTFILES= ${TESTS:@test@${.CURDIR:tA}/${test}.out@} 5591.145Srillig.else 5601.61SrilligOUTFILES= ${TESTS:=.out} 5611.145Srillig.endif 5621.42Sapb 5631.42Sapball: ${OUTFILES} 5641.9Ssjg 5651.95SrilligCLEANFILES= *.rawout *.out *.status *.tmp *.core *.tmp 5661.61SrilligCLEANFILES+= obj*.[och] lib*.a # posix1.mk 5671.61SrilligCLEANFILES+= issue* .[ab]* # suffixes.mk 5681.95SrilligCLEANDIRS= dir dummy # posix1.mk 5691.48Sapb 5701.1Ssjgclean: 5711.48Sapb rm -f ${CLEANFILES} 5721.95Srillig rm -rf ${CLEANDIRS} 5731.1Ssjg 5741.61SrilligTEST_MAKE?= ${.MAKE} 5751.61SrilligTOOL_SED?= sed 5761.1Ssjg 5771.28Ssjg# ensure consistent results from sort(1) 5781.61SrilligLC_ALL= C 5791.61SrilligLANG= C 5801.29Ssjg.export LANG LC_ALL 5811.28Ssjg 5821.153SrilligMAKE_TEST_ENV?= MALLOC_OPTIONS="JA" # for jemalloc 5831.153Srillig 5841.236Ssjg.if ${.MAKE.OS:U${uname -s:L:sh}} == "NetBSD" 5851.213SrilligLIMIT_RESOURCES?= ulimit -v 200000 5861.213Srillig.endif 5871.213SrilligLIMIT_RESOURCES?= : 5881.213Srillig 5891.138Srillig# Each test is run in a sub-make, to keep the tests for interfering with 5901.138Srillig# each other, and because they use different environment variables and 5911.138Srillig# command line options. 5921.42Sapb.SUFFIXES: .mk .rawout .out 5931.42Sapb.mk.rawout: 5941.96Srillig @${_MKMSG_TEST:Uecho '# test '} ${.PREFIX} 5951.64Srillig @set -eu; \ 5961.213Srillig ${LIMIT_RESOURCES}; \ 5971.64Srillig cd ${.OBJDIR}; \ 5981.153Srillig env -i PATH="$$PATH" ${MAKE_TEST_ENV} ${ENV.${.PREFIX:T}} \ 5991.98Srillig ${TEST_MAKE} \ 6001.98Srillig -r -C ${.CURDIR} -f ${.IMPSRC} \ 6011.145Srillig ${FLAGS.${.PREFIX:T}:U-k} \ 6021.98Srillig > ${.TARGET}.tmp 2>&1 \ 6031.64Srillig && status=$$? || status=$$?; \ 6041.64Srillig echo $$status > ${.TARGET:R}.status 6051.42Sapb @mv ${.TARGET}.tmp ${.TARGET} 6061.42Sapb 6071.137Srillig# Postprocess the test output so that the results can be compared. 6081.62Srillig# 6091.62Srillig# always pretend .MAKE was called 'make' 6101.61Srillig_SED_CMDS+= -e 's,^${TEST_MAKE:T:S,.,\\.,g}[][0-9]*:,make:,' 6111.61Srillig_SED_CMDS+= -e 's,${TEST_MAKE:S,.,\\.,g},make,' 6121.200Srillig_SED_CMDS+= -e 's,${TEST_MAKE:T:S,.,\\.,g}[][0-9]* warning,make warning,' 6131.200Srillig_SED_CMDS+= -e 's,^usage: ${TEST_MAKE:T:S,.,\\.,g} ,usage: make ,' 6141.62Srillig# replace anything after 'stopped in' with unit-tests 6151.61Srillig_SED_CMDS+= -e '/stopped/s, /.*, unit-tests,' 6161.62Srillig# strip ${.CURDIR}/ from the output 6171.61Srillig_SED_CMDS+= -e 's,${.CURDIR:S,.,\\.,g}/,,g' 6181.61Srillig_SED_CMDS+= -e 's,${UNIT_TESTS:S,.,\\.,g}/,,g' 6191.61Srillig 6201.42Sapb.rawout.out: 6211.145Srillig @${TOOL_SED} ${_SED_CMDS} ${SED_CMDS.${.PREFIX:T}} \ 6221.64Srillig < ${.IMPSRC} > ${.TARGET}.tmp1 6231.145Srillig @${POSTPROC.${.PREFIX:T}:Ucat} < ${.TARGET}.tmp1 > ${.TARGET}.tmp2 6241.64Srillig @rm ${.TARGET}.tmp1 6251.64Srillig @echo "exit status `cat ${.TARGET:R}.status`" >> ${.TARGET}.tmp2 6261.64Srillig @mv ${.TARGET}.tmp2 ${.TARGET} 6271.42Sapb 6281.42Sapb# Compare all output files 6291.42Sapbtest: ${OUTFILES} .PHONY 6301.42Sapb @failed= ; \ 6311.61Srillig for test in ${TESTS}; do \ 6321.42Sapb diff -u ${UNIT_TESTS}/$${test}.exp $${test}.out \ 6331.42Sapb || failed="$${failed}$${failed:+ }$${test}" ; \ 6341.42Sapb done ; \ 6351.42Sapb if [ -n "$${failed}" ]; then \ 6361.42Sapb echo "Failed tests: $${failed}" ; false ; \ 6371.42Sapb else \ 6381.42Sapb echo "All tests passed" ; \ 6391.42Sapb fi 6401.1Ssjg 6411.1Ssjgaccept: 6421.61Srillig @for test in ${TESTS}; do \ 6431.42Sapb cmp -s ${UNIT_TESTS}/$${test}.exp $${test}.out \ 6441.42Sapb || { echo "Replacing $${test}.exp" ; \ 6451.42Sapb cp $${test}.out ${UNIT_TESTS}/$${test}.exp ; } \ 6461.42Sapb done 6471.1Ssjg 6481.139Srillig# Note: only works for adding tests. 6491.139Srillig# To remove a test, the $$mi file must be edited manually. 6501.78Srilligsync-mi: 6511.78Srillig @set -eu; \ 6521.78Srillig cd "${MAKEFILE:tA:H}/../../.."; \ 6531.78Srillig mi="distrib/sets/lists/tests/mi"; \ 6541.105Srillig cvs update "$$mi"; \ 6551.139Srillig testsdir="usr.bin/make/unit-tests"; \ 6561.139Srillig fmt="./usr/tests/$$testsdir/%s\ttests-usr.bin-tests\tcompattestfile,atf\\n"; \ 6571.182Srillig cat "$$mi" > "$$mi.tmp"; \ 6581.182Srillig (cd "$$testsdir" && ls *.exp *.mk) | xargs printf "$$fmt" >> "$$mi.tmp"; \ 6591.182Srillig distrib/sets/fmt-list "$$mi.tmp"; \ 6601.182Srillig mv "$$mi.tmp" "$$mi"; \ 6611.78Srillig cvs diff "$$mi" || true 6621.78Srillig 6631.50Ssjg.if exists(${TEST_MAKE}) 6641.168Ssjg${TESTS:=.rawout}: ${TEST_MAKE} 6651.168Ssjg# in meta mode, we *know* if a target script is impacted 6661.168Ssjg# by a makefile change. 6671.168Ssjg.if ${.MAKE.MODE:Unormal:Mmeta} == "" 6681.168Ssjg${TESTS:=.rawout}: ${.PARSEDIR}/Makefile 6691.168Ssjg.endif 6701.50Ssjg.endif 6711.50Ssjg 6721.42Sapb.-include <bsd.obj.mk> 673