Home | History | Annotate | Line # | Download | only in unit-tests
Makefile revision 1.92
      1  1.92  rillig # $NetBSD: Makefile,v 1.92 2020/08/15 01:49:07 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.92  rillig # Any test that is commented out must be ignored in
     37  1.92  rillig # src/tests/usr.bin/make/t_make.sh as well.
     38  1.92  rillig TESTS+=		# archive	# broken on FreeBSD, enabled in t_make.sh
     39  1.75  rillig TESTS+=		cmdline
     40  1.61  rillig TESTS+=		comment
     41  1.61  rillig TESTS+=		cond-late
     42  1.61  rillig TESTS+=		cond-short
     43  1.61  rillig TESTS+=		cond1
     44  1.61  rillig TESTS+=		cond2
     45  1.81  rillig TESTS+=		counter
     46  1.77  rillig TESTS+=		dir
     47  1.70  rillig TESTS+=		directives
     48  1.61  rillig TESTS+=		dollar
     49  1.61  rillig TESTS+=		doterror
     50  1.61  rillig TESTS+=		dotwait
     51  1.64  rillig TESTS+=		envfirst
     52  1.61  rillig TESTS+=		error
     53  1.63     sjg TESTS+=		# escape	# broken by reverting POSIX changes
     54  1.61  rillig TESTS+=		export
     55  1.61  rillig TESTS+=		export-all
     56  1.61  rillig TESTS+=		export-env
     57  1.89  rillig TESTS+=		export-variants
     58  1.61  rillig TESTS+=		forloop
     59  1.61  rillig TESTS+=		forsubst
     60  1.61  rillig TESTS+=		hash
     61  1.86  rillig TESTS+=		impsrc
     62  1.61  rillig TESTS+=		include-main
     63  1.83  rillig TESTS+=		lint
     64  1.90  rillig TESTS+=		make-exported
     65  1.61  rillig TESTS+=		misc
     66  1.61  rillig TESTS+=		moderrs
     67  1.61  rillig TESTS+=		modmatch
     68  1.61  rillig TESTS+=		modmisc
     69  1.61  rillig TESTS+=		modorder
     70  1.61  rillig TESTS+=		modts
     71  1.61  rillig TESTS+=		modword
     72  1.61  rillig TESTS+=		order
     73  1.88  rillig TESTS+=		phony-end
     74  1.61  rillig TESTS+=		posix
     75  1.63     sjg TESTS+=		# posix1	# broken by reverting POSIX changes
     76  1.61  rillig TESTS+=		qequals
     77  1.84  rillig TESTS+=		recursive
     78  1.88  rillig TESTS+=		# suffixes	# runs into an endless loop (try -dA)
     79  1.61  rillig TESTS+=		sunshcmd
     80  1.61  rillig TESTS+=		sysv
     81  1.61  rillig TESTS+=		ternary
     82  1.61  rillig TESTS+=		unexport
     83  1.61  rillig TESTS+=		unexport-env
     84  1.91  rillig TESTS+=		use-inference
     85  1.61  rillig TESTS+=		varcmd
     86  1.64  rillig TESTS+=		vardebug
     87  1.64  rillig TESTS+=		varfind
     88  1.61  rillig TESTS+=		varmisc
     89  1.61  rillig TESTS+=		varmod-edge
     90  1.66  rillig TESTS+=		varparse-dynamic
     91  1.61  rillig TESTS+=		varquote
     92  1.61  rillig TESTS+=		varshell
     93  1.61  rillig 
     94  1.64  rillig # Override environment variables for some of the tests.
     95  1.82  rillig ENV.counter=		-i
     96  1.64  rillig ENV.envfirst=		FROM_ENV=value-from-env
     97  1.69  rillig ENV.export=		-i PATH=${PATH:Q}
     98  1.89  rillig ENV.export-variants=	-i PATH=${PATH:Q}
     99  1.83  rillig ENV.lint=		-i
    100  1.90  rillig ENV.make-exported=	-i PATH=${PATH:Q}
    101  1.84  rillig ENV.recursive=		-i
    102  1.65  rillig ENV.varmisc=		FROM_ENV=env
    103  1.65  rillig ENV.varmisc+=		FROM_ENV_BEFORE=env
    104  1.65  rillig ENV.varmisc+=		FROM_ENV_AFTER=env
    105  1.64  rillig 
    106  1.64  rillig # Override make flags for some of the tests; default is -k.
    107  1.82  rillig FLAGS.counter=		-r -dv
    108  1.61  rillig FLAGS.doterror=		# none
    109  1.68  rillig FLAGS.envfirst=		-e
    110  1.71     sjg FLAGS.export=		-r
    111  1.83  rillig FLAGS.lint=		-dL -k
    112  1.61  rillig FLAGS.order=		-j1
    113  1.85     sjg FLAGS.recursive=	-dL -r
    114  1.64  rillig FLAGS.vardebug=		-k -dv FROM_CMDLINE=
    115  1.61  rillig 
    116  1.61  rillig # Some tests need extra post-processing.
    117  1.80  rillig SED_CMDS.moderrs+=	-e 's,\(Regex compilation error:\).*,\1 (details omitted),'
    118  1.80  rillig SED_CMDS.modmisc+=	-e 's,\(Regex compilation error:\).*,\1 (details omitted),'
    119  1.79  rillig SED_CMDS.varmod-edge+=	-e 's, line [0-9]*:, line omitted:,'
    120  1.61  rillig SED_CMDS.varshell+=	-e 's,^[a-z]*sh: ,,'
    121  1.61  rillig SED_CMDS.varshell+=	-e '/command/s,No such.*,not found,'
    122  1.61  rillig 
    123  1.64  rillig # Some tests need an additional round of postprocessing.
    124  1.81  rillig POSTPROC.counter=	${TOOL_SED} -n -e '/:RELEVANT = yes/,/:RELEVANT = no/p'
    125  1.64  rillig POSTPROC.vardebug=	${TOOL_SED} -n -e '/:RELEVANT = yes/,/:RELEVANT = no/p'
    126  1.64  rillig 
    127  1.89  rillig export-all.rawout: export.mk
    128  1.89  rillig unexport.rawout: export.mk
    129  1.89  rillig unexport-env.rawout: export.mk
    130  1.89  rillig 
    131  1.61  rillig # End of the configuration section.
    132  1.61  rillig 
    133   1.1     sjg .MAIN: all
    134   1.1     sjg 
    135  1.61  rillig UNIT_TESTS:=	${.PARSEDIR}
    136  1.44     apb .PATH: ${UNIT_TESTS}
    137   1.7     sjg 
    138  1.61  rillig OUTFILES=	${TESTS:=.out}
    139  1.42     apb 
    140  1.42     apb all: ${OUTFILES}
    141   1.9     sjg 
    142  1.61  rillig CLEANFILES+=		*.rawout *.out *.status *.tmp *.core *.tmp
    143  1.61  rillig CLEANFILES+=		obj*.[och] lib*.a	# posix1.mk
    144  1.61  rillig CLEANFILES+=		issue* .[ab]*		# suffixes.mk
    145  1.61  rillig CLEANRECURSIVE+=	dir dummy		# posix1.mk
    146  1.48     apb 
    147   1.1     sjg clean:
    148  1.48     apb 	rm -f ${CLEANFILES}
    149  1.48     apb .if !empty(CLEANRECURSIVE)
    150  1.48     apb 	rm -rf ${CLEANRECURSIVE}
    151  1.48     apb .endif
    152   1.1     sjg 
    153  1.61  rillig TEST_MAKE?=	${.MAKE}
    154  1.61  rillig TOOL_SED?=	sed
    155   1.1     sjg 
    156  1.28     sjg # ensure consistent results from sort(1)
    157  1.61  rillig LC_ALL=		C
    158  1.61  rillig LANG=		C
    159  1.29     sjg .export LANG LC_ALL
    160  1.28     sjg 
    161  1.42     apb # the tests are actually done with sub-makes.
    162  1.42     apb .SUFFIXES: .mk .rawout .out
    163  1.42     apb .mk.rawout:
    164  1.64  rillig 	@echo testing ${.IMPSRC}
    165  1.64  rillig 	@set -eu; \
    166  1.64  rillig 	cd ${.OBJDIR}; \
    167  1.73     sjg 	env ${ENV.${.TARGET:R}} ${TEST_MAKE} -C ${.CURDIR} \
    168  1.64  rillig 	  ${FLAGS.${.TARGET:R}:U-k} -f ${.IMPSRC} \
    169  1.64  rillig 	  > ${.TARGET}.tmp 2>&1 \
    170  1.64  rillig 	&& status=$$? || status=$$?; \
    171  1.64  rillig 	echo $$status > ${.TARGET:R}.status
    172  1.42     apb 	@mv ${.TARGET}.tmp ${.TARGET}
    173  1.42     apb 
    174  1.62  rillig # Post-process the test output so that the results can be compared.
    175  1.62  rillig #
    176  1.62  rillig # always pretend .MAKE was called 'make'
    177  1.61  rillig _SED_CMDS+=	-e 's,^${TEST_MAKE:T:S,.,\\.,g}[][0-9]*:,make:,'
    178  1.61  rillig _SED_CMDS+=	-e 's,${TEST_MAKE:S,.,\\.,g},make,'
    179  1.62  rillig # replace anything after 'stopped in' with unit-tests
    180  1.61  rillig _SED_CMDS+=	-e '/stopped/s, /.*, unit-tests,'
    181  1.62  rillig # strip ${.CURDIR}/ from the output
    182  1.61  rillig _SED_CMDS+=	-e 's,${.CURDIR:S,.,\\.,g}/,,g'
    183  1.61  rillig _SED_CMDS+=	-e 's,${UNIT_TESTS:S,.,\\.,g}/,,g'
    184  1.61  rillig 
    185  1.42     apb .rawout.out:
    186  1.42     apb 	@echo postprocess ${.TARGET}
    187  1.61  rillig 	@${TOOL_SED} ${_SED_CMDS} ${SED_CMDS.${.TARGET:R}} \
    188  1.64  rillig 	  < ${.IMPSRC} > ${.TARGET}.tmp1
    189  1.74     sjg 	@${POSTPROC.${.TARGET:R}:Ucat} < ${.TARGET}.tmp1 > ${.TARGET}.tmp2
    190  1.64  rillig 	@rm ${.TARGET}.tmp1
    191  1.64  rillig 	@echo "exit status `cat ${.TARGET:R}.status`" >> ${.TARGET}.tmp2
    192  1.64  rillig 	@mv ${.TARGET}.tmp2 ${.TARGET}
    193  1.42     apb 
    194  1.42     apb # Compare all output files
    195  1.42     apb test:	${OUTFILES} .PHONY
    196  1.42     apb 	@failed= ; \
    197  1.61  rillig 	for test in ${TESTS}; do \
    198  1.42     apb 	  diff -u ${UNIT_TESTS}/$${test}.exp $${test}.out \
    199  1.42     apb 	  || failed="$${failed}$${failed:+ }$${test}" ; \
    200  1.42     apb 	done ; \
    201  1.42     apb 	if [ -n "$${failed}" ]; then \
    202  1.42     apb 	  echo "Failed tests: $${failed}" ; false ; \
    203  1.42     apb 	else \
    204  1.42     apb 	  echo "All tests passed" ; \
    205  1.42     apb 	fi
    206   1.1     sjg 
    207   1.1     sjg accept:
    208  1.61  rillig 	@for test in ${TESTS}; do \
    209  1.42     apb 	  cmp -s ${UNIT_TESTS}/$${test}.exp $${test}.out \
    210  1.42     apb 	  || { echo "Replacing $${test}.exp" ; \
    211  1.42     apb 	       cp $${test}.out ${UNIT_TESTS}/$${test}.exp ; } \
    212  1.42     apb 	done
    213   1.1     sjg 
    214  1.78  rillig SYNC_MI_AWK= \
    215  1.78  rillig 	BEGIN {								\
    216  1.78  rillig 	  testsdir = "usr.bin/make/unit-tests";				\
    217  1.78  rillig 	  linestart = "./usr/tests/" testsdir;				\
    218  1.78  rillig 	  fmt = linestart "/%s\ttests-usr.bin-tests\tcompattestfile,atf\\n"; \
    219  1.78  rillig 	  cmd = "cd " testsdir " && ls *.exp *.mk | xargs printf '" fmt "'" \
    220  1.78  rillig 	}								\
    221  1.78  rillig 	function startswith(s, prefix) {				\
    222  1.78  rillig 	  return substr(s, 1, length(prefix)) == prefix;		\
    223  1.78  rillig 	}								\
    224  1.78  rillig 	startswith($$1, linestart) && $$1 ~ /\.(exp|mk)$$/ { next }	\
    225  1.78  rillig 	{ print $$0 }							\
    226  1.78  rillig 	$$1 == linestart "/Makefile" { system(cmd) }
    227  1.78  rillig 
    228  1.78  rillig sync-mi:
    229  1.78  rillig 	@set -eu;							\
    230  1.78  rillig 	cd "${MAKEFILE:tA:H}/../../..";					\
    231  1.78  rillig 	mi="distrib/sets/lists/tests/mi";				\
    232  1.78  rillig 	awk ${SYNC_MI_AWK:Q} < "$$mi" > "$$mi.$@";			\
    233  1.78  rillig 	mv -f "$$mi.$@" "$$mi";						\
    234  1.78  rillig 	cvs diff "$$mi" || true
    235  1.78  rillig 
    236  1.50     sjg .if exists(${TEST_MAKE})
    237  1.61  rillig ${TESTS:=.rawout}: ${TEST_MAKE}
    238  1.50     sjg .endif
    239  1.50     sjg 
    240  1.42     apb .-include <bsd.obj.mk>
    241