|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
if test -z "$GIT_TEST_GIT_DAEMON"
|
|
|
|
then
|
|
|
|
skip_all="git-daemon testing disabled (define GIT_TEST_GIT_DAEMON to enable)"
|
|
|
|
test_done
|
|
|
|
fi
|
|
|
|
|
|
|
|
LIB_GIT_DAEMON_PORT=${LIB_GIT_DAEMON_PORT-'8121'}
|
|
|
|
|
|
|
|
GIT_DAEMON_PID=
|
|
|
|
GIT_DAEMON_DOCUMENT_ROOT_PATH="$PWD"/repo
|
|
|
|
GIT_DAEMON_URL=git://127.0.0.1:$LIB_GIT_DAEMON_PORT
|
|
|
|
|
|
|
|
start_git_daemon() {
|
|
|
|
if test -n "$GIT_DAEMON_PID"
|
|
|
|
then
|
|
|
|
error "start_git_daemon already called"
|
|
|
|
fi
|
|
|
|
|
|
|
|
mkdir -p "$GIT_DAEMON_DOCUMENT_ROOT_PATH"
|
|
|
|
|
|
|
|
trap 'code=$?; stop_git_daemon; (exit $code); die' EXIT
|
|
|
|
|
|
|
|
say >&3 "Starting git daemon ..."
|
|
|
|
mkfifo git_daemon_output
|
|
|
|
git daemon --listen=127.0.0.1 --port="$LIB_GIT_DAEMON_PORT" \
|
|
|
|
--reuseaddr --verbose \
|
|
|
|
--base-path="$GIT_DAEMON_DOCUMENT_ROOT_PATH" \
|
|
|
|
"$@" "$GIT_DAEMON_DOCUMENT_ROOT_PATH" \
|
|
|
|
>&3 2>git_daemon_output &
|
|
|
|
GIT_DAEMON_PID=$!
|
|
|
|
{
|
|
|
|
read line
|
|
|
|
echo >&4 "$line"
|
|
|
|
cat >&4 &
|
|
|
|
|
|
|
|
# Check expected output
|
|
|
|
if test x"$(expr "$line" : "\[[0-9]*\] \(.*\)")" != x"Ready to rumble"
|
|
|
|
then
|
|
|
|
kill "$GIT_DAEMON_PID"
|
|
|
|
wait "$GIT_DAEMON_PID"
|
|
|
|
trap 'die' EXIT
|
|
|
|
error "git daemon failed to start"
|
|
|
|
fi
|
|
|
|
} <git_daemon_output
|
|
|
|
}
|
|
|
|
|
|
|
|
stop_git_daemon() {
|
|
|
|
if test -z "$GIT_DAEMON_PID"
|
|
|
|
then
|
|
|
|
return
|
|
|
|
fi
|
|
|
|
|
|
|
|
trap 'die' EXIT
|
|
|
|
|
|
|
|
# kill git-daemon child of git
|
|
|
|
say >&3 "Stopping git daemon ..."
|
|
|
|
kill "$GIT_DAEMON_PID"
|
|
|
|
wait "$GIT_DAEMON_PID" >&3 2>&4
|
|
|
|
ret=$?
|
|
|
|
# expect exit with status 143 = 128+15 for signal TERM=15
|
|
|
|
if test $ret -ne 143
|
|
|
|
then
|
|
|
|
error "git daemon exited with status: $ret"
|
|
|
|
fi
|
|
|
|
GIT_DAEMON_PID=
|
|
|
|
rm -f git_daemon_output
|
|
|
|
}
|