2010-10-10 10:12:46 +11:00
#!/usr/bin/env bash
2010-10-02 12:43:50 -07:00
export TMPDIR="$SELFTEST_TMPDIR"
SERVERNAME="$ENVNAME"
[ -z "$SERVERNAME" ] && SERVERNAME="base"
basedir=$TMPDIR
2010-10-02 14:23:43 -07:00
[ -r $basedir/$SERVERNAME.pid ] && {
2022-02-21 14:06:36 +01:00
for i in {2..100}; do
if [ ! -r "$basedir/${SERVERNAME}-$i.pid" ]; then
SERVERNAME="${SERVERNAME}-$i"
break
fi
done
2010-10-02 14:23:43 -07:00
}
2020-01-20 21:19:40 +01:00
rm -f $basedir/$SERVERNAME.{launch,log,parent.pid,pid,status}
2010-10-02 14:23:43 -07:00
2010-10-02 12:43:50 -07:00
# set most of the environment vars we have in the screen session too
_ENV=""
printenv |
2022-02-21 14:06:36 +01:00
egrep -v '^TERMCAP|^WINDOW|^SHELL|^STY|^SHLVL|^SAMBA_VALGRIND|\$' |
egrep '^[A-Z]' |
sed "s/\(^[^=]*=\)\(.*\)/export \1'\2'/g" >$basedir/$SERVERNAME.vars
2010-10-02 12:43:50 -07:00
2022-02-21 14:06:36 +01:00
cat <<EOF >$basedir/$SERVERNAME.launch
2010-11-02 00:55:25 +11:00
cd $PWD
2010-10-02 12:43:50 -07:00
echo \$\$ > $basedir/$SERVERNAME.pid
. $basedir/$SERVERNAME.vars
2010-10-02 14:23:43 -07:00
echo "\$(date) starting $SERVERNAME" >> $basedir/$SERVERNAME.log
2010-10-02 12:43:50 -07:00
$@
echo \$? > $basedir/$SERVERNAME.status
read parent < $basedir/$SERVERNAME.parent.pid
kill \$parent
EOF
pid=$$
2022-02-21 14:06:36 +01:00
cleanup()
{
trap "exit 1" SIGINT SIGTERM SIGPIPE
[ -r $basedir/$SERVERNAME.status ] && {
read status <$basedir/$SERVERNAME.status
echo "$(date) samba exited with status $status" >>$basedir/$SERVERNAME.log
exit $status
}
2020-01-20 21:22:39 +01:00
2022-02-21 14:06:36 +01:00
case $ENVNAME in
*.nmbd | *.smbd | *.winbindd | *.samba | *.samba_dcerpcd)
kill $(cat $basedir/../"${ENVNAME%\.*}"/pid/"${ENVNAME##*\.}".pid)
;;
esac
2020-01-20 21:22:39 +01:00
2022-02-21 14:06:36 +01:00
read pid <$basedir/$SERVERNAME.pid
echo "$(date) Killing samba pid $pid from $$" >>$basedir/$SERVERNAME.log
if [ "$pid" = "$$" ]; then
exit 1
fi
kill -9 $pid 2>&1
2010-10-02 12:43:50 -07:00
exit 1
}
2022-02-21 14:06:36 +01:00
echo $$ >$basedir/$SERVERNAME.parent.pid
2010-10-02 12:43:50 -07:00
trap cleanup SIGINT SIGTERM SIGPIPE
2014-06-05 15:07:07 +02:00
2013-12-12 11:38:22 +01:00
if [[ "$TMUX" ]]; then
2022-02-21 14:06:36 +01:00
TMUX_CMD=tmux
if [[ $TMUX = *tmate* ]]; then
TMUX_CMD=tmate
fi
2014-06-05 15:07:07 +02:00
2022-02-21 14:06:36 +01:00
$TMUX_CMD new-window -n test:$SERVERNAME "bash $basedir/$SERVERNAME.launch"
2017-06-15 17:36:58 +02:00
2022-02-21 14:06:36 +01:00
# tmux seems to lag a bit for new sessions. Don't create them too
# quickly one after another
sleep .1
2013-12-12 11:38:22 +01:00
else
2022-02-21 14:06:36 +01:00
screen -r -X screen -t test:$SERVERNAME bash $basedir/$SERVERNAME.launch
2013-12-12 11:38:22 +01:00
fi
2022-02-21 14:06:36 +01:00
echo "$(date) waiting in $$" >>$basedir/$SERVERNAME.log
2010-10-02 12:43:50 -07:00
read stdin_var
2022-02-21 14:06:36 +01:00
echo "$(date) EOF on stdin" >>$basedir/$SERVERNAME.log
2020-01-20 21:22:39 +01:00
case $ENVNAME in
2022-02-21 14:06:36 +01:00
*.nmbd | *.smbd | *.winbindd | *.samba | *.samba_dcerpcd)
2020-01-20 21:22:39 +01:00
kill $(cat $basedir/../"${ENVNAME%\.*}"/pid/"${ENVNAME##*\.}".pid)
;;
esac
2022-02-21 14:06:36 +01:00
read pid <$basedir/$SERVERNAME.pid
echo "$(date) killing $pid" >>$basedir/$SERVERNAME.log
kill $pid 2>/dev/null
echo "$(date) exiting" >>$basedir/$SERVERNAME.log
2010-10-02 12:43:50 -07:00
exit 0