Home | History | Annotate | Line # | Download | only in unit-tests
Makefile revision 1.78
      1  1.78  rillig # $NetBSD: Makefile,v 1.78 2020/07/31 22:07:28 rillig Exp $
      2   1.1     sjg #
      3   1.1     sjg # Unit tests for make(1)
      4  1.60  rillig #
      5   1.1     sjg # The main targets are:
      6   1.1     sjg #
      7  1.60  rillig # all:
      8  1.60  rillig #	run all the tests
      9  1.60  rillig # test:
     10  1.60  rillig #	run 'all', and compare to expected results
     11  1.60  rillig # accept:
     12  1.60  rillig #	move generated output to expected results
     13  1.60  rillig #
     14  1.61  rillig # Settable variables
     15  1.61  rillig #
     16  1.61  rillig # TEST_MAKE
     17  1.61  rillig #	The make program to be tested.
     18  1.61  rillig #
     19  1.60  rillig #
     20  1.60  rillig # Adding a test case
     21  1.60  rillig #
     22  1.11     sjg # Each feature should get its own set of tests in its own suitably
     23  1.42     apb # named makefile (*.mk), with its own set of expected results (*.exp),
     24  1.61  rillig # and it should be added to the TESTS list.
     25  1.60  rillig #
     26  1.60  rillig # Any added files must also be added to src/distrib/sets/lists/tests/mi.
     27  1.78  rillig # To do that, just run "make sync-mi" in this directory.
     28  1.78  rillig #
     29  1.78  rillig # A few *.mk files are helper files for other tests (such as include-sub.mk)
     30  1.78  rillig # and are thus not added to TESTS.  Such files must be ignored in
     31  1.78  rillig # src/tests/usr.bin/make/t_make.sh.
     32  1.60  rillig #
     33   1.1     sjg 
     34  1.61  rillig # Each test is in a sub-makefile.
     35  1.61  rillig # Keep the list sorted.
     36  1.72  rillig TESTS+=		# archive	# broken on FreeBSD
     37  1.75  rillig TESTS+=		cmdline
     38  1.61  rillig TESTS+=		comment
     39  1.61  rillig TESTS+=		cond-late
     40  1.61  rillig TESTS+=		cond-short
     41  1.61  rillig TESTS+=		cond1
     42  1.61  rillig TESTS+=		cond2
     43  1.77  rillig TESTS+=		dir
     44  1.70  rillig TESTS+=		directives
     45  1.61  rillig TESTS+=		dollar
     46  1.61  rillig TESTS+=		doterror
     47  1.61  rillig TESTS+=		dotwait
     48  1.64  rillig TESTS+=		envfirst
     49  1.61  rillig TESTS+=		error
     50  1.63     sjg TESTS+=		# escape	# broken by reverting POSIX changes
     51  1.61  rillig TESTS+=		export
     52  1.61  rillig TESTS+=		export-all
     53  1.61  rillig TESTS+=		export-env
     54  1.61  rillig TESTS+=		forloop
     55  1.61  rillig TESTS+=		forsubst
     56  1.61  rillig TESTS+=		hash
     57  1.63     sjg TESTS+=		# impsrc	# broken by reverting POSIX changes
     58  1.61  rillig TESTS+=		include-main
     59  1.61  rillig TESTS+=		misc
     60  1.61  rillig TESTS+=		moderrs
     61  1.61  rillig TESTS+=		modmatch
     62  1.61  rillig TESTS+=		modmisc
     63  1.61  rillig TESTS+=		modorder
     64  1.61  rillig TESTS+=		modts
     65  1.61  rillig TESTS+=		modword
     66  1.61  rillig TESTS+=		order
     67  1.63     sjg TESTS+=		# phony-end	# broken by reverting POSIX changes
     68  1.61  rillig TESTS+=		posix
     69  1.63     sjg TESTS+=		# posix1	# broken by reverting POSIX changes
     70  1.61  rillig TESTS+=		qequals
     71  1.63     sjg TESTS+=		# suffixes	# broken by reverting POSIX changes
     72  1.61  rillig TESTS+=		sunshcmd
     73  1.61  rillig TESTS+=		sysv
     74  1.61  rillig TESTS+=		ternary
     75  1.61  rillig TESTS+=		unexport
     76  1.61  rillig TESTS+=		unexport-env
     77  1.61  rillig TESTS+=		varcmd
     78  1.64  rillig TESTS+=		vardebug
     79  1.64  rillig TESTS+=		varfind
     80  1.61  rillig TESTS+=		varmisc
     81  1.61  rillig TESTS+=		varmod-edge
     82  1.66  rillig TESTS+=		varparse-dynamic
     83  1.61  rillig TESTS+=		varquote
     84  1.61  rillig TESTS+=		varshell
     85  1.61  rillig 
     86  1.64  rillig # Override environment variables for some of the tests.
     87  1.64  rillig ENV.envfirst=		FROM_ENV=value-from-env
     88  1.69  rillig ENV.export=		-i PATH=${PATH:Q}
     89  1.65  rillig ENV.varmisc=		FROM_ENV=env
     90  1.65  rillig ENV.varmisc+=		FROM_ENV_BEFORE=env
     91  1.65  rillig ENV.varmisc+=		FROM_ENV_AFTER=env
     92  1.64  rillig 
     93  1.64  rillig # Override make flags for some of the tests; default is -k.
     94  1.61  rillig FLAGS.doterror=		# none
     95  1.68  rillig FLAGS.envfirst=		-e
     96  1.71     sjg FLAGS.export=		-r
     97  1.61  rillig FLAGS.order=		-j1
     98  1.64  rillig FLAGS.vardebug=		-k -dv FROM_CMDLINE=
     99  1.61  rillig 
    100  1.61  rillig # Some tests need extra post-processing.
    101  1.76  rillig SED_CMDS.moderrs+=	-e 's,\(substitution error:\).*,\1 (details omitted),'
    102  1.62  rillig SED_CMDS.modmisc+=	-e 's,\(substitution error:\).*,\1 (details omitted),'
    103  1.61  rillig SED_CMDS.varshell+=	-e 's,^[a-z]*sh: ,,'
    104  1.61  rillig SED_CMDS.varshell+=	-e '/command/s,No such.*,not found,'
    105  1.61  rillig 
    106  1.64  rillig # Some tests need an additional round of postprocessing.
    107  1.64  rillig POSTPROC.vardebug=	${TOOL_SED} -n -e '/:RELEVANT = yes/,/:RELEVANT = no/p'
    108  1.64  rillig 
    109  1.61  rillig # End of the configuration section.
    110  1.61  rillig 
    111   1.1     sjg .MAIN: all
    112   1.1     sjg 
    113  1.61  rillig UNIT_TESTS:=	${.PARSEDIR}
    114  1.44     apb .PATH: ${UNIT_TESTS}
    115   1.7     sjg 
    116  1.61  rillig OUTFILES=	${TESTS:=.out}
    117  1.42     apb 
    118  1.42     apb all: ${OUTFILES}
    119   1.9     sjg 
    120  1.61  rillig CLEANFILES+=		*.rawout *.out *.status *.tmp *.core *.tmp
    121  1.61  rillig CLEANFILES+=		obj*.[och] lib*.a	# posix1.mk
    122  1.61  rillig CLEANFILES+=		issue* .[ab]*		# suffixes.mk
    123  1.61  rillig CLEANRECURSIVE+=	dir dummy		# posix1.mk
    124  1.48     apb 
    125   1.1     sjg clean:
    126  1.48     apb 	rm -f ${CLEANFILES}
    127  1.48     apb .if !empty(CLEANRECURSIVE)
    128  1.48     apb 	rm -rf ${CLEANRECURSIVE}
    129  1.48     apb .endif
    130   1.1     sjg 
    131  1.61  rillig TEST_MAKE?=	${.MAKE}
    132  1.61  rillig TOOL_SED?=	sed
    133   1.1     sjg 
    134  1.28     sjg # ensure consistent results from sort(1)
    135  1.61  rillig LC_ALL=		C
    136  1.61  rillig LANG=		C
    137  1.29     sjg .export LANG LC_ALL
    138  1.28     sjg 
    139  1.42     apb # the tests are actually done with sub-makes.
    140  1.42     apb .SUFFIXES: .mk .rawout .out
    141  1.42     apb .mk.rawout:
    142  1.64  rillig 	@echo testing ${.IMPSRC}
    143  1.64  rillig 	@set -eu; \
    144  1.64  rillig 	cd ${.OBJDIR}; \
    145  1.73     sjg 	env ${ENV.${.TARGET:R}} ${TEST_MAKE} -C ${.CURDIR} \
    146  1.64  rillig 	  ${FLAGS.${.TARGET:R}:U-k} -f ${.IMPSRC} \
    147  1.64  rillig 	  > ${.TARGET}.tmp 2>&1 \
    148  1.64  rillig 	&& status=$$? || status=$$?; \
    149  1.64  rillig 	echo $$status > ${.TARGET:R}.status
    150  1.42     apb 	@mv ${.TARGET}.tmp ${.TARGET}
    151  1.42     apb 
    152  1.62  rillig # Post-process the test output so that the results can be compared.
    153  1.62  rillig #
    154  1.62  rillig # always pretend .MAKE was called 'make'
    155  1.61  rillig _SED_CMDS+=	-e 's,^${TEST_MAKE:T:S,.,\\.,g}[][0-9]*:,make:,'
    156  1.61  rillig _SED_CMDS+=	-e 's,${TEST_MAKE:S,.,\\.,g},make,'
    157  1.62  rillig # replace anything after 'stopped in' with unit-tests
    158  1.61  rillig _SED_CMDS+=	-e '/stopped/s, /.*, unit-tests,'
    159  1.62  rillig # strip ${.CURDIR}/ from the output
    160  1.61  rillig _SED_CMDS+=	-e 's,${.CURDIR:S,.,\\.,g}/,,g'
    161  1.61  rillig _SED_CMDS+=	-e 's,${UNIT_TESTS:S,.,\\.,g}/,,g'
    162  1.61  rillig 
    163  1.42     apb .rawout.out:
    164  1.42     apb 	@echo postprocess ${.TARGET}
    165  1.61  rillig 	@${TOOL_SED} ${_SED_CMDS} ${SED_CMDS.${.TARGET:R}} \
    166  1.64  rillig 	  < ${.IMPSRC} > ${.TARGET}.tmp1
    167  1.74     sjg 	@${POSTPROC.${.TARGET:R}:Ucat} < ${.TARGET}.tmp1 > ${.TARGET}.tmp2
    168  1.64  rillig 	@rm ${.TARGET}.tmp1
    169  1.64  rillig 	@echo "exit status `cat ${.TARGET:R}.status`" >> ${.TARGET}.tmp2
    170  1.64  rillig 	@mv ${.TARGET}.tmp2 ${.TARGET}
    171  1.42     apb 
    172  1.42     apb # Compare all output files
    173  1.42     apb test:	${OUTFILES} .PHONY
    174  1.42     apb 	@failed= ; \
    175  1.61  rillig 	for test in ${TESTS}; do \
    176  1.42     apb 	  diff -u ${UNIT_TESTS}/$${test}.exp $${test}.out \
    177  1.42     apb 	  || failed="$${failed}$${failed:+ }$${test}" ; \
    178  1.42     apb 	done ; \
    179  1.42     apb 	if [ -n "$${failed}" ]; then \
    180  1.42     apb 	  echo "Failed tests: $${failed}" ; false ; \
    181  1.42     apb 	else \
    182  1.42     apb 	  echo "All tests passed" ; \
    183  1.42     apb 	fi
    184   1.1     sjg 
    185   1.1     sjg accept:
    186  1.61  rillig 	@for test in ${TESTS}; do \
    187  1.42     apb 	  cmp -s ${UNIT_TESTS}/$${test}.exp $${test}.out \
    188  1.42     apb 	  || { echo "Replacing $${test}.exp" ; \
    189  1.42     apb 	       cp $${test}.out ${UNIT_TESTS}/$${test}.exp ; } \
    190  1.42     apb 	done
    191   1.1     sjg 
    192  1.78  rillig SYNC_MI_AWK= \
    193  1.78  rillig 	BEGIN {								\
    194  1.78  rillig 	  testsdir = "usr.bin/make/unit-tests";				\
    195  1.78  rillig 	  linestart = "./usr/tests/" testsdir;				\
    196  1.78  rillig 	  fmt = linestart "/%s\ttests-usr.bin-tests\tcompattestfile,atf\\n"; \
    197  1.78  rillig 	  cmd = "cd " testsdir " && ls *.exp *.mk | xargs printf '" fmt "'" \
    198  1.78  rillig 	}								\
    199  1.78  rillig 	function startswith(s, prefix) {				\
    200  1.78  rillig 	  return substr(s, 1, length(prefix)) == prefix;		\
    201  1.78  rillig 	}								\
    202  1.78  rillig 	startswith($$1, linestart) && $$1 ~ /\.(exp|mk)$$/ { next }	\
    203  1.78  rillig 	{ print $$0 }							\
    204  1.78  rillig 	$$1 == linestart "/Makefile" { system(cmd) }
    205  1.78  rillig 
    206  1.78  rillig sync-mi:
    207  1.78  rillig 	@set -eu;							\
    208  1.78  rillig 	cd "${MAKEFILE:tA:H}/../../..";					\
    209  1.78  rillig 	mi="distrib/sets/lists/tests/mi";				\
    210  1.78  rillig 	awk ${SYNC_MI_AWK:Q} < "$$mi" > "$$mi.$@";			\
    211  1.78  rillig 	mv -f "$$mi.$@" "$$mi";						\
    212  1.78  rillig 	cvs diff "$$mi" || true
    213  1.78  rillig 
    214  1.50     sjg .if exists(${TEST_MAKE})
    215  1.61  rillig ${TESTS:=.rawout}: ${TEST_MAKE}
    216  1.50     sjg .endif
    217  1.50     sjg 
    218  1.42     apb .-include <bsd.obj.mk>
    219