Home | History | Annotate | Line # | Download | only in unit-tests
Makefile revision 1.75
      1  1.75  rillig # $NetBSD: Makefile,v 1.75 2020/07/28 22:44:44 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.61  rillig # Makefiles that are not added to TESTS must be ignored in
     28  1.60  rillig # src/tests/usr.bin/make/t_make.sh (example: include-sub).
     29  1.60  rillig #
     30   1.1     sjg 
     31  1.61  rillig # Each test is in a sub-makefile.
     32  1.61  rillig # Keep the list sorted.
     33  1.72  rillig TESTS+=		# archive	# broken on FreeBSD
     34  1.75  rillig TESTS+=		cmdline
     35  1.61  rillig TESTS+=		comment
     36  1.61  rillig TESTS+=		cond-late
     37  1.61  rillig TESTS+=		cond-short
     38  1.61  rillig TESTS+=		cond1
     39  1.61  rillig TESTS+=		cond2
     40  1.70  rillig TESTS+=		directives
     41  1.61  rillig TESTS+=		dollar
     42  1.61  rillig TESTS+=		doterror
     43  1.61  rillig TESTS+=		dotwait
     44  1.64  rillig TESTS+=		envfirst
     45  1.61  rillig TESTS+=		error
     46  1.63     sjg TESTS+=		# escape	# broken by reverting POSIX changes
     47  1.61  rillig TESTS+=		export
     48  1.61  rillig TESTS+=		export-all
     49  1.61  rillig TESTS+=		export-env
     50  1.61  rillig TESTS+=		forloop
     51  1.61  rillig TESTS+=		forsubst
     52  1.61  rillig TESTS+=		hash
     53  1.63     sjg TESTS+=		# impsrc	# broken by reverting POSIX changes
     54  1.61  rillig TESTS+=		include-main
     55  1.61  rillig TESTS+=		misc
     56  1.61  rillig TESTS+=		moderrs
     57  1.61  rillig TESTS+=		modmatch
     58  1.61  rillig TESTS+=		modmisc
     59  1.61  rillig TESTS+=		modorder
     60  1.61  rillig TESTS+=		modts
     61  1.61  rillig TESTS+=		modword
     62  1.61  rillig TESTS+=		order
     63  1.63     sjg TESTS+=		# phony-end	# broken by reverting POSIX changes
     64  1.61  rillig TESTS+=		posix
     65  1.63     sjg TESTS+=		# posix1	# broken by reverting POSIX changes
     66  1.61  rillig TESTS+=		qequals
     67  1.63     sjg TESTS+=		# suffixes	# broken by reverting POSIX changes
     68  1.61  rillig TESTS+=		sunshcmd
     69  1.61  rillig TESTS+=		sysv
     70  1.61  rillig TESTS+=		ternary
     71  1.61  rillig TESTS+=		unexport
     72  1.61  rillig TESTS+=		unexport-env
     73  1.61  rillig TESTS+=		varcmd
     74  1.64  rillig TESTS+=		vardebug
     75  1.64  rillig TESTS+=		varfind
     76  1.61  rillig TESTS+=		varmisc
     77  1.61  rillig TESTS+=		varmod-edge
     78  1.66  rillig TESTS+=		varparse-dynamic
     79  1.61  rillig TESTS+=		varquote
     80  1.61  rillig TESTS+=		varshell
     81  1.61  rillig 
     82  1.64  rillig # Override environment variables for some of the tests.
     83  1.64  rillig ENV.envfirst=		FROM_ENV=value-from-env
     84  1.69  rillig ENV.export=		-i PATH=${PATH:Q}
     85  1.65  rillig ENV.varmisc=		FROM_ENV=env
     86  1.65  rillig ENV.varmisc+=		FROM_ENV_BEFORE=env
     87  1.65  rillig ENV.varmisc+=		FROM_ENV_AFTER=env
     88  1.64  rillig 
     89  1.64  rillig # Override make flags for some of the tests; default is -k.
     90  1.61  rillig FLAGS.doterror=		# none
     91  1.68  rillig FLAGS.envfirst=		-e
     92  1.71     sjg FLAGS.export=		-r
     93  1.61  rillig FLAGS.order=		-j1
     94  1.64  rillig FLAGS.vardebug=		-k -dv FROM_CMDLINE=
     95  1.61  rillig 
     96  1.61  rillig # Some tests need extra post-processing.
     97  1.62  rillig SED_CMDS.modmisc+=	-e 's,\(substitution error:\).*,\1 (details omitted),'
     98  1.61  rillig SED_CMDS.varshell+=	-e 's,^[a-z]*sh: ,,'
     99  1.61  rillig SED_CMDS.varshell+=	-e '/command/s,No such.*,not found,'
    100  1.61  rillig 
    101  1.64  rillig # Some tests need an additional round of postprocessing.
    102  1.64  rillig POSTPROC.vardebug=	${TOOL_SED} -n -e '/:RELEVANT = yes/,/:RELEVANT = no/p'
    103  1.64  rillig 
    104  1.61  rillig # End of the configuration section.
    105  1.61  rillig 
    106   1.1     sjg .MAIN: all
    107   1.1     sjg 
    108  1.61  rillig UNIT_TESTS:=	${.PARSEDIR}
    109  1.44     apb .PATH: ${UNIT_TESTS}
    110   1.7     sjg 
    111  1.61  rillig OUTFILES=	${TESTS:=.out}
    112  1.42     apb 
    113  1.42     apb all: ${OUTFILES}
    114   1.9     sjg 
    115  1.61  rillig CLEANFILES+=		*.rawout *.out *.status *.tmp *.core *.tmp
    116  1.61  rillig CLEANFILES+=		obj*.[och] lib*.a	# posix1.mk
    117  1.61  rillig CLEANFILES+=		issue* .[ab]*		# suffixes.mk
    118  1.61  rillig CLEANRECURSIVE+=	dir dummy		# posix1.mk
    119  1.48     apb 
    120   1.1     sjg clean:
    121  1.48     apb 	rm -f ${CLEANFILES}
    122  1.48     apb .if !empty(CLEANRECURSIVE)
    123  1.48     apb 	rm -rf ${CLEANRECURSIVE}
    124  1.48     apb .endif
    125   1.1     sjg 
    126  1.61  rillig TEST_MAKE?=	${.MAKE}
    127  1.61  rillig TOOL_SED?=	sed
    128   1.1     sjg 
    129  1.28     sjg # ensure consistent results from sort(1)
    130  1.61  rillig LC_ALL=		C
    131  1.61  rillig LANG=		C
    132  1.29     sjg .export LANG LC_ALL
    133  1.28     sjg 
    134  1.42     apb # the tests are actually done with sub-makes.
    135  1.42     apb .SUFFIXES: .mk .rawout .out
    136  1.42     apb .mk.rawout:
    137  1.64  rillig 	@echo testing ${.IMPSRC}
    138  1.64  rillig 	@set -eu; \
    139  1.64  rillig 	cd ${.OBJDIR}; \
    140  1.73     sjg 	env ${ENV.${.TARGET:R}} ${TEST_MAKE} -C ${.CURDIR} \
    141  1.64  rillig 	  ${FLAGS.${.TARGET:R}:U-k} -f ${.IMPSRC} \
    142  1.64  rillig 	  > ${.TARGET}.tmp 2>&1 \
    143  1.64  rillig 	&& status=$$? || status=$$?; \
    144  1.64  rillig 	echo $$status > ${.TARGET:R}.status
    145  1.42     apb 	@mv ${.TARGET}.tmp ${.TARGET}
    146  1.42     apb 
    147  1.62  rillig # Post-process the test output so that the results can be compared.
    148  1.62  rillig #
    149  1.62  rillig # always pretend .MAKE was called 'make'
    150  1.61  rillig _SED_CMDS+=	-e 's,^${TEST_MAKE:T:S,.,\\.,g}[][0-9]*:,make:,'
    151  1.61  rillig _SED_CMDS+=	-e 's,${TEST_MAKE:S,.,\\.,g},make,'
    152  1.62  rillig # replace anything after 'stopped in' with unit-tests
    153  1.61  rillig _SED_CMDS+=	-e '/stopped/s, /.*, unit-tests,'
    154  1.62  rillig # strip ${.CURDIR}/ from the output
    155  1.61  rillig _SED_CMDS+=	-e 's,${.CURDIR:S,.,\\.,g}/,,g'
    156  1.61  rillig _SED_CMDS+=	-e 's,${UNIT_TESTS:S,.,\\.,g}/,,g'
    157  1.61  rillig 
    158  1.42     apb .rawout.out:
    159  1.42     apb 	@echo postprocess ${.TARGET}
    160  1.61  rillig 	@${TOOL_SED} ${_SED_CMDS} ${SED_CMDS.${.TARGET:R}} \
    161  1.64  rillig 	  < ${.IMPSRC} > ${.TARGET}.tmp1
    162  1.74     sjg 	@${POSTPROC.${.TARGET:R}:Ucat} < ${.TARGET}.tmp1 > ${.TARGET}.tmp2
    163  1.64  rillig 	@rm ${.TARGET}.tmp1
    164  1.64  rillig 	@echo "exit status `cat ${.TARGET:R}.status`" >> ${.TARGET}.tmp2
    165  1.64  rillig 	@mv ${.TARGET}.tmp2 ${.TARGET}
    166  1.42     apb 
    167  1.42     apb # Compare all output files
    168  1.42     apb test:	${OUTFILES} .PHONY
    169  1.42     apb 	@failed= ; \
    170  1.61  rillig 	for test in ${TESTS}; do \
    171  1.42     apb 	  diff -u ${UNIT_TESTS}/$${test}.exp $${test}.out \
    172  1.42     apb 	  || failed="$${failed}$${failed:+ }$${test}" ; \
    173  1.42     apb 	done ; \
    174  1.42     apb 	if [ -n "$${failed}" ]; then \
    175  1.42     apb 	  echo "Failed tests: $${failed}" ; false ; \
    176  1.42     apb 	else \
    177  1.42     apb 	  echo "All tests passed" ; \
    178  1.42     apb 	fi
    179   1.1     sjg 
    180   1.1     sjg accept:
    181  1.61  rillig 	@for test in ${TESTS}; do \
    182  1.42     apb 	  cmp -s ${UNIT_TESTS}/$${test}.exp $${test}.out \
    183  1.42     apb 	  || { echo "Replacing $${test}.exp" ; \
    184  1.42     apb 	       cp $${test}.out ${UNIT_TESTS}/$${test}.exp ; } \
    185  1.42     apb 	done
    186   1.1     sjg 
    187  1.50     sjg .if exists(${TEST_MAKE})
    188  1.61  rillig ${TESTS:=.rawout}: ${TEST_MAKE}
    189  1.50     sjg .endif
    190  1.50     sjg 
    191  1.42     apb .-include <bsd.obj.mk>
    192