2021-11-22 15:16:05 +01:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
# Test name, used everywhere as /tmp/sysklogd/$NM/foo
|
|
|
|
NM=$(basename "$0" .sh)
|
|
|
|
DIR=/tmp/sysklogd/$NM
|
|
|
|
|
|
|
|
FN=syslog-test
|
|
|
|
FN2=syslog-test2
|
|
|
|
LOG=$DIR/${FN}.log
|
|
|
|
LOG2=$DIR/${FN2}.log
|
|
|
|
LOGV1=$DIR/${FN}-v1.log
|
|
|
|
LOGCONS=$DIR/${FN}-cons.log
|
|
|
|
PID=$DIR/${FN}.pid
|
|
|
|
PID2=$DIR/${FN2}.pid
|
|
|
|
CAP=$DIR/${FN}.pcapng
|
|
|
|
CACHE=$DIR/${FN}.cache
|
|
|
|
CACHE2=$DIR/${FN2}.cache
|
|
|
|
CONF=$DIR/${FN}.conf
|
|
|
|
CONF2=$DIR/${FN2}.conf
|
|
|
|
CONFD=$DIR/${FN}.d
|
|
|
|
CONFD2=$DIR/${FN2}.d
|
|
|
|
SOCK=$DIR/${FN}.sock
|
|
|
|
SOCK2=$DIR/${FN2}.sock
|
|
|
|
ALTSOCK=$DIR/${FN}-alt.sock
|
|
|
|
PORT=5514
|
|
|
|
PORT2=5555
|
|
|
|
|
|
|
|
export SYSLOG_UNIX_PATH=${SOCK}
|
|
|
|
|
|
|
|
# Print heading for test phases
|
|
|
|
print()
|
|
|
|
{
|
|
|
|
printf "\e[7m>> %-76s\e[0m\n" "$1"
|
|
|
|
}
|
|
|
|
|
|
|
|
dprint()
|
|
|
|
{
|
|
|
|
printf "\e[2m%-76s\e[0m\n" "$1"
|
|
|
|
}
|
|
|
|
|
|
|
|
SKIP()
|
|
|
|
{
|
|
|
|
print "TEST: SKIP"
|
|
|
|
[ $# -gt 0 ] && echo "$*"
|
|
|
|
exit 77
|
|
|
|
}
|
|
|
|
|
|
|
|
FAIL()
|
|
|
|
{
|
|
|
|
print "TEST: FAIL"
|
|
|
|
[ $# -gt 0 ] && echo "$*"
|
|
|
|
exit 99
|
|
|
|
}
|
|
|
|
|
|
|
|
OK()
|
|
|
|
{
|
|
|
|
print "TEST: OK"
|
|
|
|
[ $# -gt 0 ] && echo "$*"
|
|
|
|
exit 0
|
|
|
|
}
|
|
|
|
|
2022-03-06 01:06:38 +01:00
|
|
|
# shellcheck disable=SC2068,SC2086
|
2021-11-22 15:16:05 +01:00
|
|
|
tenacious()
|
|
|
|
{
|
|
|
|
timeout=$1
|
|
|
|
shift
|
|
|
|
|
|
|
|
while [ $timeout -gt 0 ]; do
|
|
|
|
$@ && return
|
|
|
|
timeout=$((timeout - 1))
|
|
|
|
done
|
|
|
|
|
|
|
|
FAIL "Timeed out $*"
|
|
|
|
}
|
|
|
|
|
2022-05-20 06:32:56 +02:00
|
|
|
cap_start()
|
|
|
|
{
|
|
|
|
tshark -Qni lo -w "${CAP}" port 514 2>/dev/null &
|
|
|
|
TPID="$!"
|
|
|
|
echo "$TPID" >> "$DIR/PIDs"
|
|
|
|
sleep 1
|
|
|
|
}
|
|
|
|
|
|
|
|
cap_stop()
|
|
|
|
{
|
|
|
|
sleep 1
|
|
|
|
kill -TERM ${TPID}
|
|
|
|
wait ${TPID}
|
|
|
|
}
|
|
|
|
|
|
|
|
cap_dump()
|
|
|
|
{
|
|
|
|
tshark -r "${CAP}" 2>/dev/null
|
|
|
|
}
|
|
|
|
|
|
|
|
cap_find()
|
|
|
|
{
|
|
|
|
cap_dump | grep "$@"
|
|
|
|
}
|
|
|
|
|
|
|
|
logger()
|
|
|
|
{
|
|
|
|
[ -x ../src/logger ] || SKIP 'logger missing'
|
|
|
|
|
|
|
|
sock="${SOCK}"
|
|
|
|
if [ $# -gt 1 ] && [ -f "$1" ]; then
|
|
|
|
sock="$1"
|
|
|
|
shift
|
|
|
|
fi
|
|
|
|
|
|
|
|
../src/logger -u "$sock" "$@"
|
|
|
|
}
|
|
|
|
|
2022-03-06 00:56:03 +01:00
|
|
|
# shellcheck disable=SC2046,SC2086
|
|
|
|
do_setup()
|
2021-11-22 15:16:05 +01:00
|
|
|
{
|
2022-03-06 00:56:03 +01:00
|
|
|
order=$1
|
|
|
|
pidfn=$2
|
|
|
|
shift 2
|
|
|
|
opts="$*"
|
|
|
|
|
2021-11-22 15:16:05 +01:00
|
|
|
ip link set lo up
|
|
|
|
|
2022-03-06 00:56:03 +01:00
|
|
|
print "Starting $order syslogd ..."
|
|
|
|
../src/syslogd -dKF ${opts} &
|
2021-11-22 15:16:05 +01:00
|
|
|
|
2022-03-06 00:56:03 +01:00
|
|
|
sleep 2
|
|
|
|
[ -f "${pidfn}" ] || FAIL "Failed starting $order syslogd"
|
|
|
|
cat "${pidfn}" >> "$DIR/PIDs"
|
2021-11-22 15:16:05 +01:00
|
|
|
|
2022-03-06 00:56:03 +01:00
|
|
|
# Enable debugging ...
|
|
|
|
kill -USR1 $(cat "${pidfn}")
|
|
|
|
|
|
|
|
sleep 1
|
|
|
|
}
|
|
|
|
|
|
|
|
# set up and start primary syslogd
|
|
|
|
setup()
|
|
|
|
{
|
|
|
|
if [ ! -f "${CONF}" ]; then
|
|
|
|
cat <<-EOF > "${CONF}"
|
|
|
|
include ${CONFD}/*.conf
|
|
|
|
EOF
|
|
|
|
|
|
|
|
cat <<-EOF > "${CONFD}/foo.conf"
|
|
|
|
# Local log file, avoid sync to disk
|
|
|
|
*.* -${LOG}
|
|
|
|
EOF
|
|
|
|
|
|
|
|
cat <<-EOF > "${CONFD}/bar.conf"
|
|
|
|
# For remote logging
|
|
|
|
*.* @127.0.0.2
|
|
|
|
*.* @127.0.0.2:${PORT2} ;RFC3164
|
|
|
|
EOF
|
|
|
|
fi
|
2021-11-22 15:16:05 +01:00
|
|
|
|
2022-03-06 00:56:03 +01:00
|
|
|
do_setup "primary" "${PID}" "$*" -b ":${PORT}" -f "${CONF}" -p "${SOCK}" \
|
|
|
|
-p "${ALTSOCK}" -C "${CACHE}" -P "${PID}"
|
|
|
|
}
|
|
|
|
|
|
|
|
# set up and start second syslogd, e.g., for remote.sh
|
|
|
|
setup2()
|
|
|
|
{
|
|
|
|
cat <<-EOF > "${CONF2}"
|
|
|
|
include ${CONFD2}/*.conf
|
2021-11-22 15:16:05 +01:00
|
|
|
EOF
|
|
|
|
|
2022-03-06 00:56:03 +01:00
|
|
|
do_setup "secondary" "${PID2}" "$*" -f "${CONF2}" -p "${SOCK2}" \
|
|
|
|
-C "${CACHE2}" -P "${PID2}"
|
|
|
|
}
|
2021-11-22 15:16:05 +01:00
|
|
|
|
2022-05-20 06:32:56 +02:00
|
|
|
is_running()
|
|
|
|
{
|
|
|
|
kill -0 $(cat "$PID")
|
|
|
|
}
|
|
|
|
|
2022-03-06 00:56:03 +01:00
|
|
|
do_reload()
|
|
|
|
{
|
|
|
|
# shellcheck disable=SC2046
|
|
|
|
kill -HUP $(cat "$1")
|
2021-11-22 15:16:05 +01:00
|
|
|
sleep 1
|
|
|
|
}
|
|
|
|
|
2022-03-06 00:56:03 +01:00
|
|
|
reload()
|
|
|
|
{
|
|
|
|
do_reload "${PID}"
|
|
|
|
}
|
|
|
|
|
|
|
|
reload2()
|
|
|
|
{
|
|
|
|
do_reload "${PID2}"
|
|
|
|
}
|
|
|
|
|
2021-11-22 15:16:05 +01:00
|
|
|
# Stop all lingering collectors and other tools
|
|
|
|
kill_pids()
|
|
|
|
{
|
|
|
|
# shellcheck disable=SC2162
|
|
|
|
if [ -f "$DIR/PIDs" ]; then
|
|
|
|
while read ln; do kill "$ln" 2>/dev/null; done < "$DIR/PIDs"
|
|
|
|
rm "$DIR/PIDs"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
teardown()
|
|
|
|
{
|
|
|
|
kill_pids
|
|
|
|
sleep 1
|
|
|
|
|
|
|
|
rm -f ${LOG}
|
|
|
|
rm -f ${LOGV1}
|
|
|
|
rm -f ${LOG2}
|
|
|
|
rm -f ${LOGCONS}
|
|
|
|
rm -f ${PID}
|
|
|
|
rm -f ${PID2}
|
|
|
|
rm -f ${CAP}
|
|
|
|
rm -f ${SOCK}
|
|
|
|
rm -f ${CACHE}
|
|
|
|
rm -f ${CACHE2}
|
|
|
|
rm -f ${CONF}
|
|
|
|
rm -f ${CONF2}
|
|
|
|
rm -rf ${CONFD}
|
|
|
|
rm -rf ${CONFD2}
|
|
|
|
}
|
|
|
|
|
|
|
|
signal()
|
|
|
|
{
|
|
|
|
echo
|
|
|
|
if [ "$1" != "EXIT" ]; then
|
|
|
|
print "Got signal, cleaning up"
|
|
|
|
fi
|
|
|
|
teardown
|
|
|
|
}
|
|
|
|
|
|
|
|
# props to https://stackoverflow.com/a/2183063/1708249
|
|
|
|
trapit()
|
|
|
|
{
|
|
|
|
func="$1" ; shift
|
|
|
|
for sig ; do
|
2022-03-06 01:06:38 +01:00
|
|
|
trap '$func $sig' "$sig"
|
2021-11-22 15:16:05 +01:00
|
|
|
done
|
|
|
|
}
|
|
|
|
|
|
|
|
# Runs once when including lib.sh
|
2022-03-06 00:56:03 +01:00
|
|
|
mkdir -p "${CONFD}"
|
|
|
|
mkdir -p "${CONFD2}"
|
2021-11-22 15:16:05 +01:00
|
|
|
touch "$DIR/PIDs"
|
|
|
|
trapit signal INT TERM QUIT EXIT
|