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