Makefile revision 1.29
1# $NetBSD: Makefile,v 1.29 2010/12/10 00:36:33 sjg Exp $ 2# 3# Unit tests for make(1) 4# The main targets are: 5# 6# all: run all the tests 7# test: run 'all', capture output and compare to expected results 8# accept: move generated output to expected results 9# 10# Adding a test case. 11# Each feature should get its own set of tests in its own suitably 12# named makefile which should be added to SUBFILES to hook it in. 13# 14 15.MAIN: all 16 17UNIT_TESTS:= ${.PARSEDIR} 18 19# Simple sub-makefiles - we run them as a black box 20# keep the list sorted. 21SUBFILES= \ 22 comment \ 23 cond1 \ 24 error \ 25 export \ 26 export-all \ 27 doterror \ 28 dotwait \ 29 forsubst \ 30 moderrs \ 31 modmatch \ 32 modmisc \ 33 modorder \ 34 modts \ 35 modword \ 36 posix \ 37 qequals \ 38 ternary \ 39 unexport \ 40 unexport-env \ 41 varcmd 42 43all: ${SUBFILES} 44 45flags.doterror= 46 47# the tests are actually done with sub-makes. 48.PHONY: ${SUBFILES} 49.PRECIOUS: ${SUBFILES} 50${SUBFILES}: 51 -@${.MAKE} ${flags.$@:U-k} -f ${UNIT_TESTS}/$@ 52 53clean: 54 rm -f *.out *.fail *.core 55 56.-include <bsd.obj.mk> 57 58TEST_MAKE?= ${.MAKE} 59TOOL_SED?= sed 60 61# ensure consistent results from sort(1) 62LC_ALL = C 63LANG= C 64.export LANG LC_ALL 65 66# The driver. 67# We always pretend .MAKE was called 'make' 68# and strip ${.CURDIR}/ from the output 69# and replace anything after 'stopped in' with unit-tests 70# so the results can be compared. 71test: 72 @echo "${TEST_MAKE} -f ${MAKEFILE} > ${.TARGET}.out 2>&1" 73 @cd ${.OBJDIR} && ${TEST_MAKE} -f ${MAKEFILE} 2>&1 | \ 74 ${TOOL_SED} -e 's,^${TEST_MAKE:T:C/\./\\\./g}:,make:,' \ 75 -e '/stopped/s, /.*, unit-tests,' \ 76 -e 's,${.CURDIR:C/\./\\\./g}/,,g' \ 77 -e 's,${UNIT_TESTS:C/\./\\\./g}/,,g' > ${.TARGET}.out || { \ 78 tail ${.TARGET}.out; mv ${.TARGET}.out ${.TARGET}.fail; exit 1; } 79 diff -u ${UNIT_TESTS}/${.TARGET}.exp ${.TARGET}.out 80 81accept: 82 mv test.out ${.CURDIR}/test.exp 83 84