1# $OpenBSD: Makefile,v 1.37 2025/01/23 15:23:28 bluhm Exp $ 2 3# The following ports must be installed for the regression tests: 4# p5-Socket6 Perl defines relating to AF_INET6 sockets 5# p5-IO-Socket-SSL perl interface to SSL sockets 6# p5-BSD-Resource BSD process resource limit and priority functions 7# 8# This package enables additional interoperability tests 9# rsyslog syslog daemon supporting databases, TCP, SSL, RELP 10# 11# Check wether all required perl packages are installed. If some 12# are missing print a warning and skip the tests, but do not fail. 13 14PERL_REQUIRE != perl -Mstrict -Mwarnings -e ' \ 15 eval { require Socket6 } or print $@; \ 16 eval { require IO::Socket::SSL } or print $@; \ 17 eval { require BSD::Resource } or print $@; \ 18' 19.if ! empty (PERL_REQUIRE) 20regress: 21 @echo "${PERL_REQUIRE}" 22 @echo 'run "pkg_add p5-Socket6 p5-IO-Socket-SSL p5-BSD-Resource"' 23 @echo SKIPPED 24.endif 25 26# Automatically generate regress targets from test cases in directory. 27 28PROGS = ttylog logflush 29PERLS = Client.pm Proc.pm RSyslogd.pm Server.pm \ 30 Syslogc.pm Syslogd.pm funcs.pl syslogd.pl 31ARGS != cd ${.CURDIR} && ls args-*.pl 32REGRESS_TARGETS = ${ARGS:S/^/run-/} 33.if ! exists(/usr/local/sbin/rsyslogd) 34REGRESS_SKIP_TARGETS = ${REGRESS_TARGETS:Mrun-args-rsyslog*} 35.endif 36LDFLAGS += -lutil 37CLEANFILES += *.log *.log.? *.conf ktrace.out stamp-* *.pid 38CLEANFILES += *.out *.sock *.ktrace *.fstat ttylog *.ph */*.ph 39CLEANFILES += *.pem *.req *.key *.crt *.srl empty toobig diskimage vnd 40 41run-args-rsyslog-client-tls.pl run-args-rsyslog-tls.pl: 42 # rsyslogd TLS client side is totally unreliable. Startup of 43 # GnuTLS may take a long time on slow machines. Disable test. 44 @echo DISABLED 45 46.MAIN: all 47 48REGRESS_SETUP_ONCE += setup 49setup: 50 [ -z "${SUDO}" ] || ${SUDO} true 51 ${SUDO} /etc/rc.d/syslogd stop 52 53REGRESS_CLEANUP += cleanup 54cleanup: 55 -${SUDO} /etc/rc.d/syslogd restart 56 57# Set variables so that make runs with and without obj directory. 58# Only do that if necessary to keep visible output short. 59 60.if ${.CURDIR} == ${.OBJDIR} 61PERLINC = -I. 62PERLPATH = 63.else 64PERLINC = -I${.CURDIR} -I${.OBJDIR} 65PERLPATH = ${.CURDIR}/ 66.endif 67 68# The arg tests take a perl hash with arguments controlling the 69# test parameters. Generally they consist of client, syslogd, server. 70 71.for a in ${ARGS} 72run-$a: $a 73 time SUDO=${SUDO} KTRACE=${KTRACE} SYSLOGD=${SYSLOGD} perl ${PERLINC} ${PERLPATH}syslogd.pl ${PERLPATH}$a 74.endfor 75 76# create certificates for TLS 77 78127.0.0.1.crt: 79 openssl req -batch -new -subj /L=OpenBSD/O=syslogd-regress/OU=syslogd/CN=127.0.0.1/ -nodes -newkey rsa -keyout 127.0.0.1.key -x509 -out $@ 80 ${SUDO} rm -f /etc/ssl/private/127.0.0.1:6514.key 81 ${SUDO} rm -f /etc/ssl/127.0.0.1:6514.crt 82 ${SUDO} rm -f /etc/ssl/private/127.0.0.1.key 83 ${SUDO} rm -f /etc/ssl/127.0.0.1.crt 84 ${SUDO} cp 127.0.0.1.key /etc/ssl/private/127.0.0.1.key 85 ${SUDO} cp 127.0.0.1.crt /etc/ssl/127.0.0.1.crt 86 ${SUDO} cp 127.0.0.1.key /etc/ssl/private/::1.key 87 ${SUDO} cp 127.0.0.1.crt /etc/ssl/::1.crt 88 ${SUDO} cp 127.0.0.1.key /etc/ssl/private/localhost.key 89 ${SUDO} cp 127.0.0.1.crt /etc/ssl/localhost.crt 90 91ca.crt fake-ca.crt: 92 openssl req -batch -new -subj /L=OpenBSD/O=syslogd-regress/OU=ca/CN=root/ -nodes -newkey rsa -keyout ${@:R}.key -x509 -out $@ 93 94client.req server.req: 95 openssl req -batch -new -subj /L=OpenBSD/O=syslogd-regress/OU=${@:R}/CN=localhost/ -nodes -newkey rsa -keyout ${@:R}.key -out $@ 96 97myhost-client.req: 98 openssl req -batch -new -subj /L=OpenBSD/O=syslogd-regress/OU=${@:R}/CN=myhost/ -nodes -newkey rsa -keyout ${@:R}.key -out $@ 99 100client.crt server.crt myhost-client.crt: ca.crt ${@:R}.req 101 openssl x509 -CAcreateserial -CAkey ca.key -CA ca.crt -req -in ${@:R}.req -out $@ 102 103empty: 104 true >$@ 105 106toobig: 107 dd if=/dev/zero of=$@ bs=1 count=1 seek=50M 108 109sys/syscall.ph: /usr/include/sys/syscall.h 110 cd /usr/include && h2ph -h -d ${.OBJDIR} ${@:R:S/$/.h/} 111 112# Create a full file system on vnd to trigger ENOSPC error. 113 114.PHONY: disk mount unconfig 115 116disk: unconfig 117 dd if=/dev/zero of=diskimage bs=512 count=4k 118 vnconfig diskimage >vnd 119 newfs -b 4096 -f 2048 -m 0 $$(<vnd)c 120 121mount: disk 122 mkdir -p /mnt/regress-syslogd 123 mount /dev/$$(<vnd)c /mnt/regress-syslogd 124 125unconfig: 126 -umount -f /dev/$$(<vnd)c 2>/dev/null || true 127 -rmdir /mnt/regress-syslogd 2>/dev/null || true 128 -vnconfig -u $$(<vnd) 2>/dev/null || true 129 130stamp-filesystem: 131 ${SUDO} ${.MAKE} -C ${.CURDIR} mount 132 ${SUDO} chmod 1777 /mnt/regress-syslogd 133 date >$@ 134 135REGRESS_CLEANUP += cleanup-filesystem 136cleanup-filesystem: 137 rm -f stamp-filesystem 138 -${SUDO} umount /mnt/regress-syslogd 139 -${SUDO} ${.MAKE} -C ${.CURDIR} unconfig 140 141${REGRESS_TARGETS:M*filesystem*}: stamp-filesystem 142${REGRESS_TARGETS:M*tls*}: client.crt server.crt 127.0.0.1.crt 143${REGRESS_TARGETS:M*multilisten*}: 127.0.0.1.crt 144${REGRESS_TARGETS:M*empty*}: empty 145${REGRESS_TARGETS:M*toobig*}: toobig 146${REGRESS_TARGETS:M*fake*}: fake-ca.crt 147${REGRESS_TARGETS:M*myhost*}: myhost-client.crt 148${REGRESS_TARGETS:M*sendsyslog*}: sys/syscall.ph 149${REGRESS_TARGETS}: ttylog logflush 150 151# make perl syntax check for all args files 152 153.PHONY: syntax libevent 154 155syntax: stamp-syntax 156 157stamp-syntax: ${PERLS} ${ARGS} 158.for p in ${PERLS} 159 @perl -c ${PERLINC} ${PERLPATH}$p 160.endfor 161.for a in ${ARGS} 162 @perl -c ${PERLPATH}$a 163.endfor 164 @date >$@ 165 166# run the tests with all variants of libevent backend 167libevent: 168 cd ${.CURDIR} && EVENT_NOKQUEUE=1 EVENT_NOPOLL=1 ${MAKE} regress 169 cd ${.CURDIR} && EVENT_NOKQUEUE=1 EVENT_NOSELECT=1 ${MAKE} regress 170 cd ${.CURDIR} && EVENT_NOPOLL=1 EVENT_NOSELECT=1 ${MAKE} regress 171 172.include <bsd.regress.mk> 173