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