Makefile revision 1.70
11.70Srillig# $NetBSD: Makefile,v 1.70 2020/07/27 20:46:17 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.61Srillig# Makefiles that are not added to TESTS must be ignored in 281.60Srillig# src/tests/usr.bin/make/t_make.sh (example: include-sub). 291.60Srillig# 301.1Ssjg 311.61Srillig# Each test is in a sub-makefile. 321.61Srillig# Keep the list sorted. 331.67SrilligTESTS+= archive 341.61SrilligTESTS+= comment 351.61SrilligTESTS+= cond-late 361.61SrilligTESTS+= cond-short 371.61SrilligTESTS+= cond1 381.61SrilligTESTS+= cond2 391.70SrilligTESTS+= directives 401.61SrilligTESTS+= dollar 411.61SrilligTESTS+= doterror 421.61SrilligTESTS+= dotwait 431.64SrilligTESTS+= envfirst 441.61SrilligTESTS+= error 451.63SsjgTESTS+= # escape # broken by reverting POSIX changes 461.61SrilligTESTS+= export 471.61SrilligTESTS+= export-all 481.61SrilligTESTS+= export-env 491.61SrilligTESTS+= forloop 501.61SrilligTESTS+= forsubst 511.61SrilligTESTS+= hash 521.63SsjgTESTS+= # impsrc # broken by reverting POSIX changes 531.61SrilligTESTS+= include-main 541.61SrilligTESTS+= misc 551.61SrilligTESTS+= moderrs 561.61SrilligTESTS+= modmatch 571.61SrilligTESTS+= modmisc 581.61SrilligTESTS+= modorder 591.61SrilligTESTS+= modts 601.61SrilligTESTS+= modword 611.61SrilligTESTS+= order 621.63SsjgTESTS+= # phony-end # broken by reverting POSIX changes 631.61SrilligTESTS+= posix 641.63SsjgTESTS+= # posix1 # broken by reverting POSIX changes 651.61SrilligTESTS+= qequals 661.63SsjgTESTS+= # suffixes # broken by reverting POSIX changes 671.61SrilligTESTS+= sunshcmd 681.61SrilligTESTS+= sysv 691.61SrilligTESTS+= ternary 701.61SrilligTESTS+= unexport 711.61SrilligTESTS+= unexport-env 721.61SrilligTESTS+= varcmd 731.64SrilligTESTS+= vardebug 741.64SrilligTESTS+= varfind 751.61SrilligTESTS+= varmisc 761.61SrilligTESTS+= varmod-edge 771.66SrilligTESTS+= varparse-dynamic 781.61SrilligTESTS+= varquote 791.61SrilligTESTS+= varshell 801.61Srillig 811.64Srillig# Override environment variables for some of the tests. 821.64SrilligENV.envfirst= FROM_ENV=value-from-env 831.69SrilligENV.export= -i PATH=${PATH:Q} 841.65SrilligENV.varmisc= FROM_ENV=env 851.65SrilligENV.varmisc+= FROM_ENV_BEFORE=env 861.65SrilligENV.varmisc+= FROM_ENV_AFTER=env 871.64Srillig 881.64Srillig# Override make flags for some of the tests; default is -k. 891.61SrilligFLAGS.doterror= # none 901.68SrilligFLAGS.envfirst= -e 911.61SrilligFLAGS.order= -j1 921.64SrilligFLAGS.vardebug= -k -dv FROM_CMDLINE= 931.61Srillig 941.61Srillig# Some tests need extra post-processing. 951.62SrilligSED_CMDS.modmisc+= -e 's,\(substitution error:\).*,\1 (details omitted),' 961.61SrilligSED_CMDS.varshell+= -e 's,^[a-z]*sh: ,,' 971.61SrilligSED_CMDS.varshell+= -e '/command/s,No such.*,not found,' 981.61Srillig 991.64Srillig# Some tests need an additional round of postprocessing. 1001.64SrilligPOSTPROC.vardebug= ${TOOL_SED} -n -e '/:RELEVANT = yes/,/:RELEVANT = no/p' 1011.64Srillig 1021.61Srillig# End of the configuration section. 1031.61Srillig 1041.1Ssjg.MAIN: all 1051.1Ssjg 1061.61SrilligUNIT_TESTS:= ${.PARSEDIR} 1071.44Sapb.PATH: ${UNIT_TESTS} 1081.7Ssjg 1091.61SrilligOUTFILES= ${TESTS:=.out} 1101.42Sapb 1111.42Sapball: ${OUTFILES} 1121.9Ssjg 1131.61SrilligCLEANFILES+= *.rawout *.out *.status *.tmp *.core *.tmp 1141.61SrilligCLEANFILES+= obj*.[och] lib*.a # posix1.mk 1151.61SrilligCLEANFILES+= issue* .[ab]* # suffixes.mk 1161.61SrilligCLEANRECURSIVE+= dir dummy # posix1.mk 1171.48Sapb 1181.1Ssjgclean: 1191.48Sapb rm -f ${CLEANFILES} 1201.48Sapb.if !empty(CLEANRECURSIVE) 1211.48Sapb rm -rf ${CLEANRECURSIVE} 1221.48Sapb.endif 1231.1Ssjg 1241.61SrilligTEST_MAKE?= ${.MAKE} 1251.61SrilligTOOL_SED?= sed 1261.1Ssjg 1271.28Ssjg# ensure consistent results from sort(1) 1281.61SrilligLC_ALL= C 1291.61SrilligLANG= C 1301.29Ssjg.export LANG LC_ALL 1311.28Ssjg 1321.42Sapb# the tests are actually done with sub-makes. 1331.42Sapb.SUFFIXES: .mk .rawout .out 1341.42Sapb.mk.rawout: 1351.64Srillig @echo testing ${.IMPSRC} 1361.64Srillig @set -eu; \ 1371.64Srillig cd ${.OBJDIR}; \ 1381.69Srillig env ${ENV.${.TARGET:R}} ${TEST_MAKE} \ 1391.64Srillig ${FLAGS.${.TARGET:R}:U-k} -f ${.IMPSRC} \ 1401.64Srillig > ${.TARGET}.tmp 2>&1 \ 1411.64Srillig && status=$$? || status=$$?; \ 1421.64Srillig echo $$status > ${.TARGET:R}.status 1431.42Sapb @mv ${.TARGET}.tmp ${.TARGET} 1441.42Sapb 1451.62Srillig# Post-process the test output so that the results can be compared. 1461.62Srillig# 1471.62Srillig# always pretend .MAKE was called 'make' 1481.61Srillig_SED_CMDS+= -e 's,^${TEST_MAKE:T:S,.,\\.,g}[][0-9]*:,make:,' 1491.61Srillig_SED_CMDS+= -e 's,${TEST_MAKE:S,.,\\.,g},make,' 1501.62Srillig# replace anything after 'stopped in' with unit-tests 1511.61Srillig_SED_CMDS+= -e '/stopped/s, /.*, unit-tests,' 1521.62Srillig# strip ${.CURDIR}/ from the output 1531.61Srillig_SED_CMDS+= -e 's,${.CURDIR:S,.,\\.,g}/,,g' 1541.61Srillig_SED_CMDS+= -e 's,${UNIT_TESTS:S,.,\\.,g}/,,g' 1551.61Srillig 1561.42Sapb.rawout.out: 1571.42Sapb @echo postprocess ${.TARGET} 1581.61Srillig @${TOOL_SED} ${_SED_CMDS} ${SED_CMDS.${.TARGET:R}} \ 1591.64Srillig < ${.IMPSRC} > ${.TARGET}.tmp1 1601.64Srillig @${POSTPROC.${.TARGET:R}:U${TOOL_SED}} < ${.TARGET}.tmp1 > ${.TARGET}.tmp2 1611.64Srillig @rm ${.TARGET}.tmp1 1621.64Srillig @echo "exit status `cat ${.TARGET:R}.status`" >> ${.TARGET}.tmp2 1631.64Srillig @mv ${.TARGET}.tmp2 ${.TARGET} 1641.42Sapb 1651.42Sapb# Compare all output files 1661.42Sapbtest: ${OUTFILES} .PHONY 1671.42Sapb @failed= ; \ 1681.61Srillig for test in ${TESTS}; do \ 1691.42Sapb diff -u ${UNIT_TESTS}/$${test}.exp $${test}.out \ 1701.42Sapb || failed="$${failed}$${failed:+ }$${test}" ; \ 1711.42Sapb done ; \ 1721.42Sapb if [ -n "$${failed}" ]; then \ 1731.42Sapb echo "Failed tests: $${failed}" ; false ; \ 1741.42Sapb else \ 1751.42Sapb echo "All tests passed" ; \ 1761.42Sapb fi 1771.1Ssjg 1781.1Ssjgaccept: 1791.61Srillig @for test in ${TESTS}; do \ 1801.42Sapb cmp -s ${UNIT_TESTS}/$${test}.exp $${test}.out \ 1811.42Sapb || { echo "Replacing $${test}.exp" ; \ 1821.42Sapb cp $${test}.out ${UNIT_TESTS}/$${test}.exp ; } \ 1831.42Sapb done 1841.1Ssjg 1851.50Ssjg.if exists(${TEST_MAKE}) 1861.61Srillig${TESTS:=.rawout}: ${TEST_MAKE} 1871.50Ssjg.endif 1881.50Ssjg 1891.42Sapb.-include <bsd.obj.mk> 190