Makefile revision 1.301
11.301Ssjg# $NetBSD: Makefile,v 1.301 2022/01/27 02:24:46 sjg 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.269Ssjg.MAIN: all 351.269Ssjg 361.254Ssjg# we use these below but we might be an older make 371.254Ssjg.MAKE.OS?= ${uname -s:L:sh} 381.247Ssjg.MAKE.UID?= ${id -u:L:sh} 391.247Ssjg 401.61Srillig# Each test is in a sub-makefile. 411.61Srillig# Keep the list sorted. 421.92Srillig# Any test that is commented out must be ignored in 431.92Srillig# src/tests/usr.bin/make/t_make.sh as well. 441.133SrilligTESTS+= archive 451.126SrilligTESTS+= archive-suffix 461.183SrilligTESTS+= cmd-errors 471.257SrilligTESTS+= cmd-errors-jobs 481.185SrilligTESTS+= cmd-errors-lint 491.124SrilligTESTS+= cmd-interrupt 501.75SrilligTESTS+= cmdline 511.265SrilligTESTS+= cmdline-redirect-stdin 521.188SrilligTESTS+= cmdline-undefined 531.61SrilligTESTS+= comment 541.249SrilligTESTS+= compat-error 551.93SrilligTESTS+= cond-cmp-numeric 561.117SrilligTESTS+= cond-cmp-numeric-eq 571.117SrilligTESTS+= cond-cmp-numeric-ge 581.117SrilligTESTS+= cond-cmp-numeric-gt 591.117SrilligTESTS+= cond-cmp-numeric-le 601.117SrilligTESTS+= cond-cmp-numeric-lt 611.117SrilligTESTS+= cond-cmp-numeric-ne 621.93SrilligTESTS+= cond-cmp-string 631.141SrilligTESTS+= cond-cmp-unary 641.250SrilligTESTS+= cond-eof 651.103SrilligTESTS+= cond-func 661.93SrilligTESTS+= cond-func-commands 671.93SrilligTESTS+= cond-func-defined 681.93SrilligTESTS+= cond-func-empty 691.93SrilligTESTS+= cond-func-exists 701.93SrilligTESTS+= cond-func-make 711.217SrilligTESTS+= cond-func-make-main 721.93SrilligTESTS+= cond-func-target 731.61SrilligTESTS+= cond-late 741.93SrilligTESTS+= cond-op 751.93SrilligTESTS+= cond-op-and 761.192SrilligTESTS+= cond-op-and-lint 771.93SrilligTESTS+= cond-op-not 781.93SrilligTESTS+= cond-op-or 791.192SrilligTESTS+= cond-op-or-lint 801.93SrilligTESTS+= cond-op-parentheses 811.61SrilligTESTS+= cond-short 821.93SrilligTESTS+= cond-token-number 831.93SrilligTESTS+= cond-token-plain 841.93SrilligTESTS+= cond-token-string 851.93SrilligTESTS+= cond-token-var 861.142SrilligTESTS+= cond-undef-lint 871.61SrilligTESTS+= cond1 881.81SrilligTESTS+= counter 891.147SrilligTESTS+= counter-append 901.93SrilligTESTS+= dep 911.93SrilligTESTS+= dep-colon 921.152SrilligTESTS+= dep-colon-bug-cross-file 931.93SrilligTESTS+= dep-double-colon 941.172SrilligTESTS+= dep-double-colon-indep 951.296SrilligTESTS+= dep-duplicate 961.93SrilligTESTS+= dep-exclam 971.107SrilligTESTS+= dep-none 981.290SrilligTESTS+= dep-op-missing 991.174SrilligTESTS+= dep-percent 1001.109SrilligTESTS+= dep-var 1011.93SrilligTESTS+= dep-wildcards 1021.93SrilligTESTS+= depsrc 1031.173SrilligTESTS+= depsrc-end 1041.93SrilligTESTS+= depsrc-exec 1051.93SrilligTESTS+= depsrc-ignore 1061.93SrilligTESTS+= depsrc-made 1071.93SrilligTESTS+= depsrc-make 1081.93SrilligTESTS+= depsrc-meta 1091.93SrilligTESTS+= depsrc-nometa 1101.93SrilligTESTS+= depsrc-nometa_cmp 1111.93SrilligTESTS+= depsrc-nopath 1121.93SrilligTESTS+= depsrc-notmain 1131.93SrilligTESTS+= depsrc-optional 1141.93SrilligTESTS+= depsrc-phony 1151.93SrilligTESTS+= depsrc-precious 1161.93SrilligTESTS+= depsrc-recursive 1171.93SrilligTESTS+= depsrc-silent 1181.93SrilligTESTS+= depsrc-use 1191.93SrilligTESTS+= depsrc-usebefore 1201.105SrilligTESTS+= depsrc-usebefore-double-colon 1211.93SrilligTESTS+= depsrc-wait 1221.93SrilligTESTS+= deptgt 1231.93SrilligTESTS+= deptgt-begin 1241.224SrilligTESTS+= deptgt-begin-fail 1251.224SrilligTESTS+= deptgt-begin-fail-indirect 1261.93SrilligTESTS+= deptgt-default 1271.93SrilligTESTS+= deptgt-delete_on_error 1281.93SrilligTESTS+= deptgt-end 1291.222SrilligTESTS+= deptgt-end-fail 1301.237SrilligTESTS+= deptgt-end-fail-all 1311.223SrilligTESTS+= deptgt-end-fail-indirect 1321.146SrilligTESTS+= deptgt-end-jobs 1331.93SrilligTESTS+= deptgt-error 1341.93SrilligTESTS+= deptgt-ignore 1351.93SrilligTESTS+= deptgt-interrupt 1361.93SrilligTESTS+= deptgt-main 1371.93SrilligTESTS+= deptgt-makeflags 1381.93SrilligTESTS+= deptgt-no_parallel 1391.93SrilligTESTS+= deptgt-nopath 1401.93SrilligTESTS+= deptgt-notparallel 1411.93SrilligTESTS+= deptgt-objdir 1421.93SrilligTESTS+= deptgt-order 1431.93SrilligTESTS+= deptgt-path 1441.93SrilligTESTS+= deptgt-path-suffix 1451.93SrilligTESTS+= deptgt-phony 1461.93SrilligTESTS+= deptgt-precious 1471.93SrilligTESTS+= deptgt-shell 1481.93SrilligTESTS+= deptgt-silent 1491.93SrilligTESTS+= deptgt-stale 1501.93SrilligTESTS+= deptgt-suffixes 1511.77SrilligTESTS+= dir 1521.114SrilligTESTS+= dir-expand-path 1531.93SrilligTESTS+= directive 1541.140SrilligTESTS+= directive-dinclude 1551.93SrilligTESTS+= directive-elif 1561.93SrilligTESTS+= directive-elifdef 1571.93SrilligTESTS+= directive-elifmake 1581.93SrilligTESTS+= directive-elifndef 1591.93SrilligTESTS+= directive-elifnmake 1601.93SrilligTESTS+= directive-else 1611.259SrilligTESTS+= directive-endfor 1621.93SrilligTESTS+= directive-endif 1631.93SrilligTESTS+= directive-error 1641.93SrilligTESTS+= directive-export 1651.93SrilligTESTS+= directive-export-env 1661.258SrilligTESTS+= directive-export-impl 1671.156SrilligTESTS+= directive-export-gmake 1681.93SrilligTESTS+= directive-export-literal 1691.130SrilligTESTS+= directive-for 1701.260SrilligTESTS+= directive-for-errors 1711.260SrilligTESTS+= directive-for-escape 1721.127SrilligTESTS+= directive-for-generating-endif 1731.283SrilligTESTS+= directive-for-if 1741.251SrilligTESTS+= directive-for-lines 1751.252SrilligTESTS+= directive-for-null 1761.140SrilligTESTS+= directive-hyphen-include 1771.93SrilligTESTS+= directive-if 1781.197SrilligTESTS+= directive-if-nested 1791.93SrilligTESTS+= directive-ifdef 1801.93SrilligTESTS+= directive-ifmake 1811.93SrilligTESTS+= directive-ifndef 1821.93SrilligTESTS+= directive-ifnmake 1831.140SrilligTESTS+= directive-include 1841.140SrilligTESTS+= directive-include-fatal 1851.93SrilligTESTS+= directive-info 1861.246SrilligTESTS+= directive-misspellings 1871.140SrilligTESTS+= directive-sinclude 1881.93SrilligTESTS+= directive-undef 1891.93SrilligTESTS+= directive-unexport 1901.93SrilligTESTS+= directive-unexport-env 1911.93SrilligTESTS+= directive-warning 1921.61SrilligTESTS+= dollar 1931.61SrilligTESTS+= doterror 1941.61SrilligTESTS+= dotwait 1951.61SrilligTESTS+= error 1961.63SsjgTESTS+= # escape # broken by reverting POSIX changes 1971.61SrilligTESTS+= export 1981.61SrilligTESTS+= export-all 1991.61SrilligTESTS+= export-env 2001.89SrilligTESTS+= export-variants 2011.61SrilligTESTS+= forloop 2021.61SrilligTESTS+= forsubst 2031.190SrilligTESTS+= gnode-submake 2041.162SrilligTESTS+= hanoi-include 2051.86SrilligTESTS+= impsrc 2061.61SrilligTESTS+= include-main 2071.189SrilligTESTS+= job-flags 2081.154SrilligTESTS+= job-output-long-lines 2091.276SrilligTESTS+= job-output-null 2101.263SrilligTESTS+= jobs-empty-commands 2111.279SrilligTESTS+= jobs-empty-commands-error 2121.232SrilligTESTS+= jobs-error-indirect 2131.232SrilligTESTS+= jobs-error-nested 2141.232SrilligTESTS+= jobs-error-nested-make 2151.83SrilligTESTS+= lint 2161.90SrilligTESTS+= make-exported 2171.230SsjgTESTS+= meta-cmd-cmp 2181.61SrilligTESTS+= moderrs 2191.61SrilligTESTS+= modmatch 2201.61SrilligTESTS+= modmisc 2211.247Ssjg.if ${.MAKE.UID} > 0 2221.198SsjgTESTS+= objdir-writable 2231.225Ssjg.endif 2241.93SrilligTESTS+= opt 2251.93SrilligTESTS+= opt-backwards 2261.93SrilligTESTS+= opt-chdir 2271.93SrilligTESTS+= opt-debug 2281.134SrilligTESTS+= opt-debug-all 2291.134SrilligTESTS+= opt-debug-archive 2301.134SrilligTESTS+= opt-debug-curdir 2311.134SrilligTESTS+= opt-debug-cond 2321.134SrilligTESTS+= opt-debug-dir 2331.134SrilligTESTS+= opt-debug-errors 2341.277SrilligTESTS+= opt-debug-errors-jobs 2351.134SrilligTESTS+= opt-debug-file 2361.134SrilligTESTS+= opt-debug-for 2371.134SrilligTESTS+= opt-debug-graph1 2381.134SrilligTESTS+= opt-debug-graph2 2391.134SrilligTESTS+= opt-debug-graph3 2401.134SrilligTESTS+= opt-debug-hash 2411.134SrilligTESTS+= opt-debug-jobs 2421.134SrilligTESTS+= opt-debug-lint 2431.134SrilligTESTS+= opt-debug-loud 2441.134SrilligTESTS+= opt-debug-meta 2451.134SrilligTESTS+= opt-debug-making 2461.134SrilligTESTS+= opt-debug-no-rm 2471.134SrilligTESTS+= opt-debug-parse 2481.134SrilligTESTS+= opt-debug-suff 2491.134SrilligTESTS+= opt-debug-targets 2501.134SrilligTESTS+= opt-debug-varraw 2511.134SrilligTESTS+= opt-debug-var 2521.134SrilligTESTS+= opt-debug-x-trace 2531.93SrilligTESTS+= opt-define 2541.93SrilligTESTS+= opt-env 2551.93SrilligTESTS+= opt-file 2561.93SrilligTESTS+= opt-ignore 2571.93SrilligTESTS+= opt-include-dir 2581.93SrilligTESTS+= opt-jobs 2591.93SrilligTESTS+= opt-jobs-internal 2601.241SrilligTESTS+= opt-jobs-no-action 2611.93SrilligTESTS+= opt-keep-going 2621.238SrilligTESTS+= opt-keep-going-multiple 2631.93SrilligTESTS+= opt-m-include-dir 2641.93SrilligTESTS+= opt-no-action 2651.93SrilligTESTS+= opt-no-action-at-all 2661.242SrilligTESTS+= opt-no-action-runflags 2671.264SrilligTESTS+= opt-no-action-touch 2681.93SrilligTESTS+= opt-query 2691.93SrilligTESTS+= opt-raw 2701.93SrilligTESTS+= opt-silent 2711.93SrilligTESTS+= opt-touch 2721.199SrilligTESTS+= opt-touch-jobs 2731.93SrilligTESTS+= opt-tracefile 2741.93SrilligTESTS+= opt-var-expanded 2751.93SrilligTESTS+= opt-var-literal 2761.291SrilligTESTS+= opt-version 2771.93SrilligTESTS+= opt-warnings-as-errors 2781.93SrilligTESTS+= opt-where-am-i 2791.93SrilligTESTS+= opt-x-reduce-exported 2801.61SrilligTESTS+= order 2811.289SrilligTESTS+= parse 2821.162SrilligTESTS+= parse-var 2831.88SrilligTESTS+= phony-end 2841.61SrilligTESTS+= posix 2851.63SsjgTESTS+= # posix1 # broken by reverting POSIX changes 2861.84SrilligTESTS+= recursive 2871.93SrilligTESTS+= sh 2881.106SrilligTESTS+= sh-dots 2891.245SrilligTESTS+= sh-errctl 2901.244SrilligTESTS+= sh-flags 2911.93SrilligTESTS+= sh-jobs 2921.93SrilligTESTS+= sh-jobs-error 2931.93SrilligTESTS+= sh-leading-at 2941.93SrilligTESTS+= sh-leading-hyphen 2951.93SrilligTESTS+= sh-leading-plus 2961.93SrilligTESTS+= sh-meta-chars 2971.93SrilligTESTS+= sh-multi-line 2981.93SrilligTESTS+= sh-single-line 2991.162SrilligTESTS+= shell-csh 3001.162SrilligTESTS+= shell-custom 3011.162SrilligTESTS+= shell-ksh 3021.162SrilligTESTS+= shell-sh 3031.169SrilligTESTS+= suff-add-later 3041.169SrilligTESTS+= suff-clear-regular 3051.169SrilligTESTS+= suff-clear-single 3061.212SrilligTESTS+= suff-incomplete 3071.175SrilligTESTS+= suff-lookup 3081.167SrilligTESTS+= suff-main 3091.218SrilligTESTS+= suff-main-several 3101.220SrilligTESTS+= suff-phony 3111.150SrilligTESTS+= suff-rebuild 3121.203SrilligTESTS+= suff-self 3131.219SrilligTESTS+= suff-transform-debug 3141.169SrilligTESTS+= suff-transform-endless 3151.169SrilligTESTS+= suff-transform-expand 3161.169SrilligTESTS+= suff-transform-select 3171.61SrilligTESTS+= sunshcmd 3181.61SrilligTESTS+= ternary 3191.61SrilligTESTS+= unexport 3201.61SrilligTESTS+= unexport-env 3211.91SrilligTESTS+= use-inference 3221.299SrilligTESTS+= var-scope 3231.299SrilligTESTS+= var-scope-cmdline 3241.299SrilligTESTS+= var-scope-env 3251.299SrilligTESTS+= var-scope-global 3261.299SrilligTESTS+= var-scope-local 3271.299SrilligTESTS+= var-scope-local-legacy 3281.273SrilligTESTS+= var-eval-short 3291.93SrilligTESTS+= var-op 3301.93SrilligTESTS+= var-op-append 3311.93SrilligTESTS+= var-op-assign 3321.93SrilligTESTS+= var-op-default 3331.93SrilligTESTS+= var-op-expand 3341.93SrilligTESTS+= var-op-shell 3351.162SrilligTESTS+= var-op-sunsh 3361.179SrilligTESTS+= var-recursive 3371.61SrilligTESTS+= varcmd 3381.64SrilligTESTS+= vardebug 3391.64SrilligTESTS+= varfind 3401.61SrilligTESTS+= varmisc 3411.93SrilligTESTS+= varmod 3421.93SrilligTESTS+= varmod-assign 3431.292SrilligTESTS+= varmod-assign-shell 3441.93SrilligTESTS+= varmod-defined 3451.61SrilligTESTS+= varmod-edge 3461.93SrilligTESTS+= varmod-exclam-shell 3471.93SrilligTESTS+= varmod-extension 3481.93SrilligTESTS+= varmod-gmtime 3491.93SrilligTESTS+= varmod-hash 3501.93SrilligTESTS+= varmod-head 3511.93SrilligTESTS+= varmod-ifelse 3521.234SrilligTESTS+= varmod-indirect 3531.93SrilligTESTS+= varmod-l-name-to-value 3541.93SrilligTESTS+= varmod-localtime 3551.93SrilligTESTS+= varmod-loop 3561.286SrilligTESTS+= varmod-loop-delete 3571.275SrilligTESTS+= varmod-loop-varname 3581.93SrilligTESTS+= varmod-match 3591.99SrilligTESTS+= varmod-match-escape 3601.93SrilligTESTS+= varmod-no-match 3611.93SrilligTESTS+= varmod-order 3621.281SsjgTESTS+= varmod-order-numeric 3631.93SrilligTESTS+= varmod-order-reverse 3641.93SrilligTESTS+= varmod-order-shuffle 3651.282SrilligTESTS+= varmod-order-string 3661.93SrilligTESTS+= varmod-path 3671.93SrilligTESTS+= varmod-quote 3681.93SrilligTESTS+= varmod-quote-dollar 3691.93SrilligTESTS+= varmod-range 3701.93SrilligTESTS+= varmod-remember 3711.93SrilligTESTS+= varmod-root 3721.93SrilligTESTS+= varmod-select-words 3731.93SrilligTESTS+= varmod-shell 3741.93SrilligTESTS+= varmod-subst 3751.93SrilligTESTS+= varmod-subst-regex 3761.271SrilligTESTS+= varmod-sun-shell 3771.93SrilligTESTS+= varmod-sysv 3781.93SrilligTESTS+= varmod-tail 3791.93SrilligTESTS+= varmod-to-abs 3801.93SrilligTESTS+= varmod-to-lower 3811.93SrilligTESTS+= varmod-to-many-words 3821.93SrilligTESTS+= varmod-to-one-word 3831.93SrilligTESTS+= varmod-to-separator 3841.93SrilligTESTS+= varmod-to-upper 3851.93SrilligTESTS+= varmod-undefined 3861.93SrilligTESTS+= varmod-unique 3871.93SrilligTESTS+= varname 3881.93SrilligTESTS+= varname-dollar 3891.93SrilligTESTS+= varname-dot-alltargets 3901.93SrilligTESTS+= varname-dot-curdir 3911.122SrilligTESTS+= varname-dot-includes 3921.93SrilligTESTS+= varname-dot-includedfromdir 3931.93SrilligTESTS+= varname-dot-includedfromfile 3941.122SrilligTESTS+= varname-dot-libs 3951.93SrilligTESTS+= varname-dot-make-dependfile 3961.93SrilligTESTS+= varname-dot-make-expand_variables 3971.93SrilligTESTS+= varname-dot-make-exported 3981.93SrilligTESTS+= varname-dot-make-jobs 3991.93SrilligTESTS+= varname-dot-make-jobs-prefix 4001.93SrilligTESTS+= varname-dot-make-level 4011.93SrilligTESTS+= varname-dot-make-makefile_preference 4021.93SrilligTESTS+= varname-dot-make-makefiles 4031.93SrilligTESTS+= varname-dot-make-meta-bailiwick 4041.93SrilligTESTS+= varname-dot-make-meta-created 4051.93SrilligTESTS+= varname-dot-make-meta-files 4061.93SrilligTESTS+= varname-dot-make-meta-ignore_filter 4071.93SrilligTESTS+= varname-dot-make-meta-ignore_paths 4081.93SrilligTESTS+= varname-dot-make-meta-ignore_patterns 4091.93SrilligTESTS+= varname-dot-make-meta-prefix 4101.93SrilligTESTS+= varname-dot-make-mode 4111.93SrilligTESTS+= varname-dot-make-path_filemon 4121.93SrilligTESTS+= varname-dot-make-pid 4131.93SrilligTESTS+= varname-dot-make-ppid 4141.93SrilligTESTS+= varname-dot-make-save_dollars 4151.233SrilligTESTS+= varname-dot-makeflags 4161.93SrilligTESTS+= varname-dot-makeoverrides 4171.93SrilligTESTS+= varname-dot-newline 4181.93SrilligTESTS+= varname-dot-objdir 4191.93SrilligTESTS+= varname-dot-parsedir 4201.93SrilligTESTS+= varname-dot-parsefile 4211.93SrilligTESTS+= varname-dot-path 4221.115SrilligTESTS+= varname-dot-shell 4231.288SrilligTESTS+= varname-dot-suffixes 4241.93SrilligTESTS+= varname-dot-targets 4251.110SrilligTESTS+= varname-empty 4261.93SrilligTESTS+= varname-make 4271.93SrilligTESTS+= varname-make_print_var_on_error 4281.170SrilligTESTS+= varname-make_print_var_on_error-jobs 4291.132SrilligTESTS+= varname-makefile 4301.93SrilligTESTS+= varname-makeflags 4311.93SrilligTESTS+= varname-pwd 4321.93SrilligTESTS+= varname-vpath 4331.66SrilligTESTS+= varparse-dynamic 4341.191SrilligTESTS+= varparse-errors 4351.156SrilligTESTS+= varparse-mod 4361.149SrilligTESTS+= varparse-undef-partial 4371.61SrilligTESTS+= varquote 4381.61Srillig 4391.280Ssjg# Some tests just do not work on some platforms or environments 4401.280Ssjg# so allow for some filtering. 4411.280Ssjg.if !empty(BROKEN_TESTS) 4421.280SsjgTESTS:= ${TESTS:${BROKEN_TESTS:S,^,N,:ts:}} 4431.280Ssjg.endif 4441.280Ssjg 4451.201Srillig# Ideas for more tests: 4461.201Srillig# char-0020-space.mk 4471.201Srillig# char-005C-backslash.mk 4481.201Srillig# escape-cond-str.mk 4491.201Srillig# escape-cond-func-arg.mk 4501.201Srillig# escape-varmod.mk 4511.201Srillig# escape-varmod-define.mk 4521.201Srillig# escape-varmod-match.mk 4531.201Srillig# escape-varname.mk 4541.201Srillig# escape-varassign-varname.mk 4551.201Srillig# escape-varassign-varname-cmdline.mk 4561.201Srillig# escape-varassign-value.mk 4571.201Srillig# escape-varassign-value-cmdline.mk 4581.201Srillig# escape-dependency-source.mk 4591.201Srillig# escape-dependency-target.mk 4601.201Srillig# escape-for-varname.mk 4611.201Srillig# escape-for-item.mk 4621.201Srillig# posix-*.mk (see posix.mk and posix1.mk) 4631.201Srillig 4641.98Srillig# Additional environment variables for some of the tests. 4651.98Srillig# The base environment is -i PATH="$PATH". 4661.194SrilligENV.depsrc-optional+= TZ=UTC 4671.64SrilligENV.envfirst= FROM_ENV=value-from-env 4681.65SrilligENV.varmisc= FROM_ENV=env 4691.65SrilligENV.varmisc+= FROM_ENV_BEFORE=env 4701.65SrilligENV.varmisc+= FROM_ENV_AFTER=env 4711.180SrilligENV.varmod-localtime+= TZ=Europe/Berlin 4721.196SrilligENV.varname-vpath+= VPATH=varname-vpath.dir:varname-vpath.dir2 4731.64Srillig 4741.64Srillig# Override make flags for some of the tests; default is -k. 4751.123Srillig# If possible, write ".MAKEFLAGS: -dv" in the test .mk file instead of 4761.123Srillig# settings FLAGS.test=-dv here, since that is closer to the test code. 4771.232SrilligFLAGS.cond-func-make= via-cmdline 4781.232SrilligFLAGS.doterror= # none, especially not -k 4791.232SrilligFLAGS.jobs-error-indirect= # none, especially not -k 4801.232SrilligFLAGS.jobs-error-nested= # none, especially not -k 4811.232SrilligFLAGS.jobs-error-nested-make= # none, especially not -k 4821.232SrilligFLAGS.varname-empty= -dv '$${:U}=cmdline-u' '=cmdline-plain' 4831.61Srillig 4841.137Srillig# Some tests need extra postprocessing. 4851.227SrilligSED_CMDS.dir= ${:D remove output from -DCLEANUP mode } 4861.228SrilligSED_CMDS.dir+= -e '/^OpenDirs_Done:/d' 4871.229SrilligSED_CMDS.dir+= -e '/^CachedDir /d' 4881.216SrilligSED_CMDS.export= -e '/^[^=_A-Za-z0-9]*=/d' 4891.216SrilligSED_CMDS.export-all= ${SED_CMDS.export} 4901.216SrilligSED_CMDS.export-env= ${SED_CMDS.export} 4911.155SrilligSED_CMDS.job-output-long-lines= \ 4921.155Srillig ${:D Job separators on their own line are ok. } \ 4931.155Srillig -e '/^--- job-[ab] ---$$/d' \ 4941.155Srillig ${:D Plain output lines are ok as well. } \ 4951.155Srillig ${:D They may come in multiples of 1024 or as 10000. } \ 4961.155Srillig -e '/^aa*$$/d' \ 4971.155Srillig -e '/^bb*$$/d' \ 4981.155Srillig ${:D The following lines should rather not occur since the job } \ 4991.155Srillig ${:D marker should always be at the beginning of the line. } \ 5001.155Srillig -e '/^aa*--- job-b ---$$/d' \ 5011.155Srillig -e '/^bb*--- job-a ---$$/d' 5021.278SsjgSED_CMDS.opt-chdir= -e 's,\(nonexistent\).[1-9][0-9]*,\1,' 5031.215SrilligSED_CMDS.opt-debug-graph1= ${STD_SED_CMDS.dg1} 5041.266SrilligSED_CMDS.opt-debug-graph2= ${STD_SED_CMDS.dg2} 5051.266SrilligSED_CMDS.opt-debug-graph3= ${STD_SED_CMDS.dg3} 5061.162SrilligSED_CMDS.opt-debug-jobs= -e 's,([0-9][0-9]*),(<pid>),' 5071.162SrilligSED_CMDS.opt-debug-jobs+= -e 's,pid [0-9][0-9]*,pid <pid>,' 5081.162SrilligSED_CMDS.opt-debug-jobs+= -e 's,Process [0-9][0-9]*,Process <pid>,' 5091.162SrilligSED_CMDS.opt-debug-jobs+= -e 's,JobFinish: [0-9][0-9]*,JobFinish: <pid>,' 5101.210SrilligSED_CMDS.opt-debug-jobs+= -e 's,Command: ${.SHELL:T},Command: <shell>,' 5111.163Srillig# The "-q" may be there or not, see jobs.c, variable shells. 5121.211SrilligSED_CMDS.opt-debug-jobs+= -e 's,^\(.Command: <shell>\) -q,\1,' 5131.272SrilligSED_CMDS.opt-debug-lint+= ${STD_SED_CMDS.regex} 5141.243SrilligSED_CMDS.opt-jobs-no-action= ${STD_SED_CMDS.hide-from-output} 5151.243SrilligSED_CMDS.opt-no-action-runflags= ${STD_SED_CMDS.hide-from-output} 5161.301SsjgSED_CMDS.opt-where-am-i= -e '/usr.obj/d' 5171.274Srillig# For Compat_RunCommand, useShell == false. 5181.240SrilligSED_CMDS.sh-dots= -e 's,^.*\.\.\.:.*,<not found: ...>,' 5191.274Srillig# For Compat_RunCommand, useShell == true. 5201.240SrilligSED_CMDS.sh-dots+= -e 's,^make: exec(\(.*\)) failed (.*)$$,<not found: \1>,' 5211.240SrilligSED_CMDS.sh-dots+= -e 's,^\(\*\*\* Error code \)[1-9][0-9]*,\1<nonzero>,' 5221.245SrilligSED_CMDS.sh-errctl= ${STD_SED_CMDS.dj} 5231.244SrilligSED_CMDS.sh-flags= ${STD_SED_CMDS.hide-from-output} 5241.215SrilligSED_CMDS.suff-main+= ${STD_SED_CMDS.dg1} 5251.218SrilligSED_CMDS.suff-main-several+= ${STD_SED_CMDS.dg1} 5261.219SrilligSED_CMDS.suff-transform-debug+= ${STD_SED_CMDS.dg1} 5271.261SrilligSED_CMDS.var-op-shell+= ${STD_SED_CMDS.shell} 5281.261SrilligSED_CMDS.var-op-shell+= -e '/command/s,No such.*,not found,' 5291.261SrilligSED_CMDS.vardebug+= -e 's,${.SHELL},</path/to/shell>,' 5301.272SrilligSED_CMDS.varmod-subst-regex+= ${STD_SED_CMDS.regex} 5311.144SrilligSED_CMDS.varname-dot-parsedir= -e '/in some cases/ s,^make: "[^"]*,make: "<normalized>,' 5321.144SrilligSED_CMDS.varname-dot-parsefile= -e '/in some cases/ s,^make: "[^"]*,make: "<normalized>,' 5331.177SrilligSED_CMDS.varname-dot-shell= -e 's, = /[^ ]*, = (details omitted),g' 5341.177SrilligSED_CMDS.varname-dot-shell+= -e 's,"/[^" ]*","(details omitted)",g' 5351.177SrilligSED_CMDS.varname-dot-shell+= -e 's,\[/[^] ]*\],[(details omitted)],g' 5361.284SsjgSED_CMDS.varname-empty= ${.OBJDIR .PARSEDIR .PATH .SHELL:L:@v@-e '/\\$v/d'@} 5371.61Srillig 5381.64Srillig# Some tests need an additional round of postprocessing. 5391.235SrilligPOSTPROC.deptgt-suffixes= awk '/^\#\*\*\* Suffixes/,/^never-stop/' 5401.235SrilligPOSTPROC.gnode-submake= awk '/Input graph/, /^$$/' 5411.64Srillig 5421.99Srillig# Some tests reuse other tests, which makes them unnecessarily fragile. 5431.89Srilligexport-all.rawout: export.mk 5441.89Srilligunexport.rawout: export.mk 5451.89Srilligunexport-env.rawout: export.mk 5461.89Srillig 5471.61Srillig# End of the configuration section. 5481.61Srillig 5491.215Srillig# Some standard sed commands, to be used in the SED_CMDS above. 5501.215Srillig 5511.245Srillig# Omit details such as process IDs from the output of the -dg1 option. 5521.235SrilligSTD_SED_CMDS.dg1= -e 's,${.CURDIR}$$,<curdir>,' 5531.235SrilligSTD_SED_CMDS.dg1+= -e 's, ${DEFSYSPATH:U/usr/share/mk}$$, <defsyspath>,' 5541.215SrilligSTD_SED_CMDS.dg1+= -e 's,^\(\.MAKE *=\) .*,\1 <details omitted>,' 5551.215SrilligSTD_SED_CMDS.dg1+= -e 's,^\(\.MAKE\.[A-Z_]* *=\) .*,\1 <details omitted>,' 5561.215SrilligSTD_SED_CMDS.dg1+= -e 's,^\(MACHINE[_ARCH]* *=\) .*,\1 <details omitted>,' 5571.215SrilligSTD_SED_CMDS.dg1+= -e 's,^\(MAKE *=\) .*,\1 <details omitted>,' 5581.266SrilligSTD_SED_CMDS.dg1+= -e 's,^\(\.SHELL *=\) .*,\1 <details omitted>,' 5591.266Srillig 5601.266SrilligSTD_SED_CMDS.dg2= ${STD_SED_CMDS.dg1} 5611.266SrilligSTD_SED_CMDS.dg2+= -e 's,\(last modified\) ..:..:.. ... ..\, ....,\1 <timestamp>,' 5621.266SrilligSTD_SED_CMDS.dg3= ${STD_SED_CMDS.dg2} 5631.221Srillig 5641.245Srillig# Omit details such as process IDs from the output of the -dj option. 5651.245SrilligSTD_SED_CMDS.dj= \ 5661.248Ssjg -e '/Process/d;/JobFinish:/d' \ 5671.245Srillig -e 's,^\(Job_TokenWithdraw\)([0-9]*),\1(<pid>),' \ 5681.245Srillig -e 's,^([0-9][0-9]*) \(withdrew token\),(<pid>) \1,' \ 5691.245Srillig -e 's, \(pid\) [0-9][0-9]*, \1 <pid>,' \ 5701.245Srillig -e 's,^\( Command:\) .*,\1 <shell>,' 5711.245Srillig 5721.243Srillig# Reduce the noise for tests running with the -n option, since there is no 5731.243Srillig# other way to suppress the echoing of the commands. 5741.243SrilligSTD_SED_CMDS.hide-from-output= \ 5751.243Srillig -e '/^echo hide-from-output/d' \ 5761.243Srillig -e 's,hide-from-output ,,' \ 5771.243Srillig -e 's,hide-from-output,,' 5781.243Srillig 5791.261Srillig# Normalize the output for error messages from the shell. 5801.261Srillig# 5811.261Srillig# $shell -c '...' 5821.261Srillig# NetBSD sh ...: not found 5831.261Srillig# NetBSD ksh ksh: ...: not found 5841.262Srillig# bash 5.0.18 bash: ...: command not found 5851.262Srillig# bash 5.1.0 bash: line 1: ...: command not found 5861.261Srillig# dash dash: 1: ...: not found 5871.261Srillig# 5881.261Srillig# $shell -c '< /nonexistent' 5891.261Srillig# NetBSD sh sh: cannot open /nonexistent: no such file 5901.261Srillig# NetBSD ksh ksh: cannot open /nonexistent: No such file or directory 5911.262Srillig# bash 5.0.18 bash: /nonexistent: No such file or directory 5921.262Srillig# bash 5.1.0 bash: line 1: /nonexistent: No such file or directory 5931.261Srillig# dash dash: 1: cannot open /nonexistent: No such file 5941.261Srillig# 5951.262Srillig# echo '< /nonexistent' | $shell 5961.262Srillig# NetBSD sh sh: cannot open /nonexistent: no such file 5971.262Srillig# NetBSD ksh ksh: <stdin>[1]: cannot open /nonexistent: No such file or directory 5981.262Srillig# bash 5.0.18 bash: line 1: /nonexistent: No such file or directory 5991.262Srillig# bash 5.1.0 bash: line 1: /nonexistent: No such file or directory 6001.262Srillig# dash dash: 1: cannot open /nonexistent: No such file 6011.261Srillig# 6021.262SrilligSTD_SED_CMDS.shell+= -e 's,^${.SHELL:T}: line [0-9][0-9]*: ,,' 6031.262SrilligSTD_SED_CMDS.shell+= -e 's,^${.SHELL:T}: [0-9][0-9]*: ,,' 6041.261SrilligSTD_SED_CMDS.shell+= -e 's,^${.SHELL:T}: ,,' 6051.261Srillig 6061.272Srillig# The actual error messages for a failed regcomp or regexec differ between the 6071.272Srillig# implementations. 6081.272SrilligSTD_SED_CMDS.regex= \ 6091.272Srillig -e 's,\(Regex compilation error:\).*,\1 (details omitted),' 6101.272Srillig 6111.215Srillig# End of the configuration helpers section. 6121.215Srillig 6131.61SrilligUNIT_TESTS:= ${.PARSEDIR} 6141.44Sapb.PATH: ${UNIT_TESTS} 6151.7Ssjg 6161.145Srillig.if ${USE_ABSOLUTE_TESTNAMES:Uno} == yes 6171.145SrilligOUTFILES= ${TESTS:@test@${.CURDIR:tA}/${test}.out@} 6181.145Srillig.else 6191.61SrilligOUTFILES= ${TESTS:=.out} 6201.145Srillig.endif 6211.42Sapb 6221.42Sapball: ${OUTFILES} 6231.9Ssjg 6241.95SrilligCLEANFILES= *.rawout *.out *.status *.tmp *.core *.tmp 6251.61SrilligCLEANFILES+= obj*.[och] lib*.a # posix1.mk 6261.61SrilligCLEANFILES+= issue* .[ab]* # suffixes.mk 6271.95SrilligCLEANDIRS= dir dummy # posix1.mk 6281.48Sapb 6291.1Ssjgclean: 6301.48Sapb rm -f ${CLEANFILES} 6311.95Srillig rm -rf ${CLEANDIRS} 6321.1Ssjg 6331.61SrilligTEST_MAKE?= ${.MAKE} 6341.61SrilligTOOL_SED?= sed 6351.1Ssjg 6361.28Ssjg# ensure consistent results from sort(1) 6371.61SrilligLC_ALL= C 6381.61SrilligLANG= C 6391.29Ssjg.export LANG LC_ALL 6401.28Ssjg 6411.269Ssjg 6421.269Ssjg# for many tests we need a TMPDIR that will not collide 6431.269Ssjg# with other users. 6441.269Ssjg.if ${.OBJDIR} != ${.CURDIR} 6451.269Ssjg# easy 6461.269SsjgTMPDIR:= ${.OBJDIR}/tmp 6471.270Srillig.elif defined(TMPDIR) 6481.270SrilligTMPDIR:= ${TMPDIR}/uid${.MAKE.UID} 6491.269Ssjg.else 6501.270SrilligTMPDIR:= /tmp/uid${.MAKE.UID} 6511.269Ssjg.endif 6521.269Ssjg# make sure it exists 6531.269Ssjg.if !exist(${TMPDIR}) 6541.269Ssjgx!= echo; mkdir -p ${TMPDIR} 6551.269Ssjg.endif 6561.269Ssjg 6571.287SrilligMAKE_TEST_ENV= MALLOC_OPTIONS="JA" # for jemalloc 100 6581.287SrilligMAKE_TEST_ENV+= MALLOC_CONF="junk:true" # for jemalloc 510 6591.269SsjgMAKE_TEST_ENV+= TMPDIR=${TMPDIR} 6601.153Srillig 6611.254Ssjg.if ${.MAKE.OS} == "NetBSD" 6621.213SrilligLIMIT_RESOURCES?= ulimit -v 200000 6631.213Srillig.endif 6641.213SrilligLIMIT_RESOURCES?= : 6651.213Srillig 6661.138Srillig# Each test is run in a sub-make, to keep the tests for interfering with 6671.138Srillig# each other, and because they use different environment variables and 6681.138Srillig# command line options. 6691.42Sapb.SUFFIXES: .mk .rawout .out 6701.42Sapb.mk.rawout: 6711.96Srillig @${_MKMSG_TEST:Uecho '# test '} ${.PREFIX} 6721.64Srillig @set -eu; \ 6731.213Srillig ${LIMIT_RESOURCES}; \ 6741.64Srillig cd ${.OBJDIR}; \ 6751.153Srillig env -i PATH="$$PATH" ${MAKE_TEST_ENV} ${ENV.${.PREFIX:T}} \ 6761.98Srillig ${TEST_MAKE} \ 6771.98Srillig -r -C ${.CURDIR} -f ${.IMPSRC} \ 6781.145Srillig ${FLAGS.${.PREFIX:T}:U-k} \ 6791.98Srillig > ${.TARGET}.tmp 2>&1 \ 6801.64Srillig && status=$$? || status=$$?; \ 6811.64Srillig echo $$status > ${.TARGET:R}.status 6821.42Sapb @mv ${.TARGET}.tmp ${.TARGET} 6831.42Sapb 6841.137Srillig# Postprocess the test output so that the results can be compared. 6851.62Srillig# 6861.62Srillig# always pretend .MAKE was called 'make' 6871.61Srillig_SED_CMDS+= -e 's,^${TEST_MAKE:T:S,.,\\.,g}[][0-9]*:,make:,' 6881.61Srillig_SED_CMDS+= -e 's,${TEST_MAKE:S,.,\\.,g},make,' 6891.200Srillig_SED_CMDS+= -e 's,${TEST_MAKE:T:S,.,\\.,g}[][0-9]* warning,make warning,' 6901.200Srillig_SED_CMDS+= -e 's,^usage: ${TEST_MAKE:T:S,.,\\.,g} ,usage: make ,' 6911.62Srillig# replace anything after 'stopped in' with unit-tests 6921.61Srillig_SED_CMDS+= -e '/stopped/s, /.*, unit-tests,' 6931.294Srillig# Allow the test files to be placed anywhere. 6941.294Srillig_SED_CMDS+= -e 's,\(\.PARSEDIR}\) = `'"/[^']*'"',\1 = <some-dir>,' 6951.294Srillig_SED_CMDS+= -e 's,\(\.INCLUDEDFROMDIR}\) = `'"/[^']*'"',\1 = <some-dir>,' 6961.269Ssjg_SED_CMDS+= -e 's,${TMPDIR},TMPDIR,g' 6971.284Ssjg# canonicalize ${.OBJDIR} and ${.CURDIR} 6981.284Ssjg.if ${.OBJDIR} != ${.CURDIR} 6991.284Ssjg# yes this is inaccurate but none of the tests expect <objdir> anywhere 7001.284Ssjg# which we get depending on how MAKEOBJDIR is set. 7011.284Ssjg_SED_CMDS+= -e 's,${.OBJDIR},<curdir>,g' 7021.284Ssjg.endif 7031.284Ssjg_SED_CMDS+= -e 's,${.CURDIR},<curdir>,g' 7041.284Ssjg_SED_CMDS+= -e 's,<curdir>/,,g' 7051.61Srillig_SED_CMDS+= -e 's,${UNIT_TESTS:S,.,\\.,g}/,,g' 7061.61Srillig 7071.42Sapb.rawout.out: 7081.145Srillig @${TOOL_SED} ${_SED_CMDS} ${SED_CMDS.${.PREFIX:T}} \ 7091.64Srillig < ${.IMPSRC} > ${.TARGET}.tmp1 7101.145Srillig @${POSTPROC.${.PREFIX:T}:Ucat} < ${.TARGET}.tmp1 > ${.TARGET}.tmp2 7111.64Srillig @rm ${.TARGET}.tmp1 7121.64Srillig @echo "exit status `cat ${.TARGET:R}.status`" >> ${.TARGET}.tmp2 7131.64Srillig @mv ${.TARGET}.tmp2 ${.TARGET} 7141.42Sapb 7151.42Sapb# Compare all output files 7161.42Sapbtest: ${OUTFILES} .PHONY 7171.42Sapb @failed= ; \ 7181.61Srillig for test in ${TESTS}; do \ 7191.42Sapb diff -u ${UNIT_TESTS}/$${test}.exp $${test}.out \ 7201.42Sapb || failed="$${failed}$${failed:+ }$${test}" ; \ 7211.42Sapb done ; \ 7221.42Sapb if [ -n "$${failed}" ]; then \ 7231.42Sapb echo "Failed tests: $${failed}" ; false ; \ 7241.42Sapb else \ 7251.42Sapb echo "All tests passed" ; \ 7261.42Sapb fi 7271.1Ssjg 7281.1Ssjgaccept: 7291.61Srillig @for test in ${TESTS}; do \ 7301.42Sapb cmp -s ${UNIT_TESTS}/$${test}.exp $${test}.out \ 7311.42Sapb || { echo "Replacing $${test}.exp" ; \ 7321.42Sapb cp $${test}.out ${UNIT_TESTS}/$${test}.exp ; } \ 7331.42Sapb done 7341.1Ssjg 7351.139Srillig# Note: only works for adding tests. 7361.139Srillig# To remove a test, the $$mi file must be edited manually. 7371.78Srilligsync-mi: 7381.78Srillig @set -eu; \ 7391.78Srillig cd "${MAKEFILE:tA:H}/../../.."; \ 7401.78Srillig mi="distrib/sets/lists/tests/mi"; \ 7411.105Srillig cvs update "$$mi"; \ 7421.139Srillig testsdir="usr.bin/make/unit-tests"; \ 7431.139Srillig fmt="./usr/tests/$$testsdir/%s\ttests-usr.bin-tests\tcompattestfile,atf\\n"; \ 7441.182Srillig cat "$$mi" > "$$mi.tmp"; \ 7451.182Srillig (cd "$$testsdir" && ls *.exp *.mk) | xargs printf "$$fmt" >> "$$mi.tmp"; \ 7461.182Srillig distrib/sets/fmt-list "$$mi.tmp"; \ 7471.182Srillig mv "$$mi.tmp" "$$mi"; \ 7481.78Srillig cvs diff "$$mi" || true 7491.78Srillig 7501.50Ssjg.if exists(${TEST_MAKE}) 7511.168Ssjg${TESTS:=.rawout}: ${TEST_MAKE} 7521.168Ssjg# in meta mode, we *know* if a target script is impacted 7531.168Ssjg# by a makefile change. 7541.168Ssjg.if ${.MAKE.MODE:Unormal:Mmeta} == "" 7551.168Ssjg${TESTS:=.rawout}: ${.PARSEDIR}/Makefile 7561.168Ssjg.endif 7571.50Ssjg.endif 7581.50Ssjg 7591.42Sapb.-include <bsd.obj.mk> 760