Home | History | Annotate | Line # | Download | only in unit-tests
Makefile revision 1.62
      1  1.62  rillig # $NetBSD: Makefile,v 1.62 2020/07/04 22:17:09 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.61  rillig TESTS+=		comment
     34  1.61  rillig TESTS+=		cond-late
     35  1.61  rillig TESTS+=		cond-short
     36  1.61  rillig TESTS+=		cond1
     37  1.61  rillig TESTS+=		cond2
     38  1.61  rillig TESTS+=		dollar
     39  1.61  rillig TESTS+=		doterror
     40  1.61  rillig TESTS+=		dotwait
     41  1.61  rillig TESTS+=		error
     42  1.61  rillig TESTS+=		# escape	# broken by referting POSIX changes
     43  1.61  rillig TESTS+=		export
     44  1.61  rillig TESTS+=		export-all
     45  1.61  rillig TESTS+=		export-env
     46  1.61  rillig TESTS+=		forloop
     47  1.61  rillig TESTS+=		forsubst
     48  1.61  rillig TESTS+=		hash
     49  1.61  rillig TESTS+=		# impsrc	# broken by referting POSIX changes
     50  1.61  rillig TESTS+=		include-main
     51  1.61  rillig TESTS+=		misc
     52  1.61  rillig TESTS+=		moderrs
     53  1.61  rillig TESTS+=		modmatch
     54  1.61  rillig TESTS+=		modmisc
     55  1.61  rillig TESTS+=		modorder
     56  1.61  rillig TESTS+=		modts
     57  1.61  rillig TESTS+=		modword
     58  1.61  rillig TESTS+=		order
     59  1.61  rillig TESTS+=		# phony-end	# broken by referting POSIX changes
     60  1.61  rillig TESTS+=		posix
     61  1.61  rillig TESTS+=		# posix1	# broken by referting POSIX changes
     62  1.61  rillig TESTS+=		qequals
     63  1.61  rillig TESTS+=		# suffixes	# broken by referting POSIX changes
     64  1.61  rillig TESTS+=		sunshcmd
     65  1.61  rillig TESTS+=		sysv
     66  1.61  rillig TESTS+=		ternary
     67  1.61  rillig TESTS+=		unexport
     68  1.61  rillig TESTS+=		unexport-env
     69  1.61  rillig TESTS+=		varcmd
     70  1.61  rillig TESTS+=		varmisc
     71  1.61  rillig TESTS+=		varmod-edge
     72  1.61  rillig TESTS+=		varquote
     73  1.61  rillig TESTS+=		varshell
     74  1.61  rillig 
     75  1.61  rillig # Override make flags for certain tests; default is -k.
     76  1.61  rillig FLAGS.doterror=		# none
     77  1.61  rillig FLAGS.order=		-j1
     78  1.61  rillig 
     79  1.61  rillig # Some tests need extra post-processing.
     80  1.62  rillig SED_CMDS.modmisc+=	-e 's,\(substitution error:\).*,\1 (details omitted),'
     81  1.61  rillig SED_CMDS.varshell+=	-e 's,^[a-z]*sh: ,,'
     82  1.61  rillig SED_CMDS.varshell+=	-e '/command/s,No such.*,not found,'
     83  1.61  rillig 
     84  1.61  rillig # End of the configuration section.
     85  1.61  rillig 
     86   1.1     sjg .MAIN: all
     87   1.1     sjg 
     88  1.61  rillig UNIT_TESTS:=	${.PARSEDIR}
     89  1.44     apb .PATH: ${UNIT_TESTS}
     90   1.7     sjg 
     91  1.61  rillig OUTFILES=	${TESTS:=.out}
     92  1.42     apb 
     93  1.42     apb all: ${OUTFILES}
     94   1.9     sjg 
     95  1.61  rillig CLEANFILES+=		*.rawout *.out *.status *.tmp *.core *.tmp
     96  1.61  rillig CLEANFILES+=		obj*.[och] lib*.a	# posix1.mk
     97  1.61  rillig CLEANFILES+=		issue* .[ab]*		# suffixes.mk
     98  1.61  rillig CLEANRECURSIVE+=	dir dummy		# posix1.mk
     99  1.48     apb 
    100   1.1     sjg clean:
    101  1.48     apb 	rm -f ${CLEANFILES}
    102  1.48     apb .if !empty(CLEANRECURSIVE)
    103  1.48     apb 	rm -rf ${CLEANRECURSIVE}
    104  1.48     apb .endif
    105   1.1     sjg 
    106  1.61  rillig TEST_MAKE?=	${.MAKE}
    107  1.61  rillig TOOL_SED?=	sed
    108   1.1     sjg 
    109  1.28     sjg # ensure consistent results from sort(1)
    110  1.61  rillig LC_ALL=		C
    111  1.61  rillig LANG=		C
    112  1.29     sjg .export LANG LC_ALL
    113  1.28     sjg 
    114  1.42     apb # the tests are actually done with sub-makes.
    115  1.42     apb .SUFFIXES: .mk .rawout .out
    116  1.42     apb .mk.rawout:
    117  1.61  rillig 	@echo ${TEST_MAKE} ${FLAGS.${.TARGET:R}:U-k} -f ${.IMPSRC}
    118  1.42     apb 	-@cd ${.OBJDIR} && \
    119  1.61  rillig 	{ ${TEST_MAKE} ${FLAGS.${.TARGET:R}:U-k} -f ${.IMPSRC} \
    120  1.42     apb 	  2>&1 ; echo $$? >${.TARGET:R}.status ; } > ${.TARGET}.tmp
    121  1.42     apb 	@mv ${.TARGET}.tmp ${.TARGET}
    122  1.42     apb 
    123  1.62  rillig # Post-process the test output so that the results can be compared.
    124  1.62  rillig #
    125  1.62  rillig # always pretend .MAKE was called 'make'
    126  1.61  rillig _SED_CMDS+=	-e 's,^${TEST_MAKE:T:S,.,\\.,g}[][0-9]*:,make:,'
    127  1.61  rillig _SED_CMDS+=	-e 's,${TEST_MAKE:S,.,\\.,g},make,'
    128  1.62  rillig # replace anything after 'stopped in' with unit-tests
    129  1.61  rillig _SED_CMDS+=	-e '/stopped/s, /.*, unit-tests,'
    130  1.62  rillig # strip ${.CURDIR}/ from the output
    131  1.61  rillig _SED_CMDS+=	-e 's,${.CURDIR:S,.,\\.,g}/,,g'
    132  1.61  rillig _SED_CMDS+=	-e 's,${UNIT_TESTS:S,.,\\.,g}/,,g'
    133  1.61  rillig 
    134  1.42     apb .rawout.out:
    135  1.42     apb 	@echo postprocess ${.TARGET}
    136  1.61  rillig 	@${TOOL_SED} ${_SED_CMDS} ${SED_CMDS.${.TARGET:R}} \
    137  1.42     apb 	  < ${.IMPSRC} > ${.TARGET}.tmp
    138  1.42     apb 	@echo "exit status `cat ${.TARGET:R}.status`" >> ${.TARGET}.tmp
    139  1.42     apb 	@mv ${.TARGET}.tmp ${.TARGET}
    140  1.42     apb 
    141  1.42     apb # Compare all output files
    142  1.42     apb test:	${OUTFILES} .PHONY
    143  1.42     apb 	@failed= ; \
    144  1.61  rillig 	for test in ${TESTS}; do \
    145  1.42     apb 	  diff -u ${UNIT_TESTS}/$${test}.exp $${test}.out \
    146  1.42     apb 	  || failed="$${failed}$${failed:+ }$${test}" ; \
    147  1.42     apb 	done ; \
    148  1.42     apb 	if [ -n "$${failed}" ]; then \
    149  1.42     apb 	  echo "Failed tests: $${failed}" ; false ; \
    150  1.42     apb 	else \
    151  1.42     apb 	  echo "All tests passed" ; \
    152  1.42     apb 	fi
    153   1.1     sjg 
    154   1.1     sjg accept:
    155  1.61  rillig 	@for test in ${TESTS}; do \
    156  1.42     apb 	  cmp -s ${UNIT_TESTS}/$${test}.exp $${test}.out \
    157  1.42     apb 	  || { echo "Replacing $${test}.exp" ; \
    158  1.42     apb 	       cp $${test}.out ${UNIT_TESTS}/$${test}.exp ; } \
    159  1.42     apb 	done
    160   1.1     sjg 
    161  1.50     sjg .if exists(${TEST_MAKE})
    162  1.61  rillig ${TESTS:=.rawout}: ${TEST_MAKE}
    163  1.50     sjg .endif
    164  1.50     sjg 
    165  1.42     apb .-include <bsd.obj.mk>
    166