blob: 09d397a8e3845ae71d780e1f19dad5974d22e529 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
|
# $OpenBSD: bsd.regress.mk,v 1.16 2018/10/05 11:15:29 bluhm Exp $
# Documented in bsd.regress.mk(5)
# No man pages for regression tests.
NOMAN=
# No installation.
install:
# If REGRESS_TARGETS is defined and PROG is not defined, set NOPROG
.if defined(REGRESS_TARGETS) && !defined(PROG)
NOPROG=
.endif
.include <bsd.prog.mk>
.MAIN: all
all: regress
# XXX - Need full path to REGRESS_LOG, otherwise there will be much pain.
REGRESS_LOG?=/dev/null
REGRESS_SKIP_TARGETS?=
REGRESS_SKIP_SLOW?=no
REGRESS_FAIL_EARLY?=no
_REGRESS_NAME=${.CURDIR:S/${BSDSRCDIR}\/regress\///}
_REGRESS_TMP?=/dev/null
_REGRESS_OUT= | tee -a ${REGRESS_LOG} ${_REGRESS_TMP} 2>&1 > /dev/null
.if defined(PROG) && !empty(PROG)
run-regress-${PROG}: ${PROG}
./${PROG}
.endif
.if defined(PROG) && !defined(REGRESS_TARGETS)
REGRESS_TARGETS=run-regress-${PROG}
. if defined(REGRESS_SKIP)
REGRESS_SKIP_TARGETS=run-regress-${PROG}
. endif
.endif
.if defined(REGRESS_SLOW_TARGETS) && ${REGRESS_SKIP_SLOW} != no
REGRESS_SKIP_TARGETS+=${REGRESS_SLOW_TARGETS}
.endif
.if ${REGRESS_FAIL_EARLY} != no
_SKIP_FAIL=
.else
_SKIP_FAIL=-
.endif
.if defined(REGRESS_ROOT_TARGETS)
_ROOTUSER!=id -g
SUDO?=
. if (${_ROOTUSER} != 0) && empty(SUDO)
REGRESS_SKIP_TARGETS+=${REGRESS_ROOT_TARGETS}
. endif
.endif
.if defined(ERRORS)
.BEGIN:
. for _m in ${ERRORS}
@echo 1>&2 ${_m}
. endfor
. if !empty(ERRORS:M"Fatal\:*") || !empty(ERRORS:M'Fatal\:*')
@exit 1
. endif
.endif
REGRESS_SETUP?=
REGRESS_SETUP_ONCE?=
REGRESS_CLEANUP?=
.if !empty(REGRESS_SETUP)
${REGRESS_TARGETS}: ${REGRESS_SETUP}
.endif
.if !empty(REGRESS_SETUP_ONCE)
CLEANFILES+=${REGRESS_SETUP_ONCE:S/^/stamp-/}
${REGRESS_TARGETS}: ${REGRESS_SETUP_ONCE:S/^/stamp-/}
${REGRESS_SETUP_ONCE:S/^/stamp-/}: .SILENT
${MAKE} -C ${.CURDIR} ${@:S/^stamp-//}
date >$@
REGRESS_CLEANUP+=${REGRESS_SETUP_ONCE:S/^/cleanup-stamp-/}
${REGRESS_SETUP_ONCE:S/^/cleanup-stamp-/}: .SILENT
rm -f ${@:S/^cleanup-//}
.endif
regress: .SILENT
.if ! ${REGRESS_LOG:M/*}
echo =========================================================
echo REGRESS_LOG must contain an absolute path to the log-file.
echo It currently points to: ${REGRESS_LOG}
echo =========================================================
exit 1
.endif
.if !empty(REGRESS_SETUP_ONCE)
rm -f ${REGRESS_SETUP_ONCE:S/^/stamp-/}
.endif
.for RT in ${REGRESS_TARGETS} ${REGRESS_CLEANUP}
. if ${REGRESS_SKIP_TARGETS:M${RT}}
@echo -n "SKIP " ${_REGRESS_OUT}
. else
# XXX - we need a better method to see if a test fails due to timeout or just
# normal failure.
. if !defined(REGRESS_MAXTIME)
${_SKIP_FAIL}if cd ${.CURDIR} && ${MAKE} ${RT}; then \
echo -n "SUCCESS " ${_REGRESS_OUT} ; \
else \
echo -n "FAIL " ${_REGRESS_OUT} ; \
echo FAILED ; \
false; \
fi
. else
${_SKIP_FAIL}if cd ${.CURDIR} && \
(ulimit -t ${REGRESS_MAXTIME} ; ${MAKE} ${RT}); then \
echo -n "SUCCESS " ${_REGRESS_OUT} ; \
else \
echo -n "FAIL (possible timeout) " ${_REGRESS_OUT} ; \
echo FAILED ; \
false; \
fi
. endif
. endif
@echo ${_REGRESS_NAME}/${RT:S/^run-regress-//} ${_REGRESS_OUT}
.endfor
.PHONY: regress
|