|  | # Shell library to run git-daemon in tests.  Ends the test early if | 
|  | # GIT_TEST_GIT_DAEMON is not set. | 
|  | # | 
|  | # Usage: | 
|  | # | 
|  | #	. ./test-lib.sh | 
|  | #	. "$TEST_DIRECTORY"/lib-git-daemon.sh | 
|  | #	start_git_daemon | 
|  | # | 
|  | #	test_expect_success '...' ' | 
|  | #		... | 
|  | #	' | 
|  | # | 
|  | #	test_expect_success ... | 
|  | # | 
|  | #	test_done | 
|  |  | 
|  | if ! git env--helper --type=bool --default=true --exit-code GIT_TEST_GIT_DAEMON | 
|  | then | 
|  | skip_all="git-daemon testing disabled (unset GIT_TEST_GIT_DAEMON to enable)" | 
|  | test_done | 
|  | fi | 
|  |  | 
|  | if test_have_prereq !PIPE | 
|  | then | 
|  | test_skip_or_die GIT_TEST_GIT_DAEMON "file system does not support FIFOs" | 
|  | fi | 
|  |  | 
|  | test_set_port LIB_GIT_DAEMON_PORT | 
|  |  | 
|  | GIT_DAEMON_PID= | 
|  | GIT_DAEMON_PIDFILE="$PWD"/daemon.pid | 
|  | GIT_DAEMON_DOCUMENT_ROOT_PATH="$PWD"/repo | 
|  | GIT_DAEMON_HOST_PORT=127.0.0.1:$LIB_GIT_DAEMON_PORT | 
|  | GIT_DAEMON_URL=git://$GIT_DAEMON_HOST_PORT | 
|  |  | 
|  | registered_stop_git_daemon_atexit_handler= | 
|  | start_git_daemon() { | 
|  | if test -n "$GIT_DAEMON_PID" | 
|  | then | 
|  | error "start_git_daemon already called" | 
|  | fi | 
|  |  | 
|  | mkdir -p "$GIT_DAEMON_DOCUMENT_ROOT_PATH" | 
|  |  | 
|  | # One of the test scripts stops and then re-starts 'git daemon'. | 
|  | # Don't register and then run the same atexit handlers several times. | 
|  | if test -z "$registered_stop_git_daemon_atexit_handler" | 
|  | then | 
|  | test_atexit 'stop_git_daemon' | 
|  | registered_stop_git_daemon_atexit_handler=AlreadyDone | 
|  | fi | 
|  |  | 
|  | say >&3 "Starting git daemon ..." | 
|  | mkfifo git_daemon_output | 
|  | ${LIB_GIT_DAEMON_COMMAND:-git daemon} \ | 
|  | --listen=127.0.0.1 --port="$LIB_GIT_DAEMON_PORT" \ | 
|  | --reuseaddr --verbose --pid-file="$GIT_DAEMON_PIDFILE" \ | 
|  | --base-path="$GIT_DAEMON_DOCUMENT_ROOT_PATH" \ | 
|  | "$@" "$GIT_DAEMON_DOCUMENT_ROOT_PATH" \ | 
|  | >&3 2>git_daemon_output & | 
|  | GIT_DAEMON_PID=$! | 
|  | { | 
|  | read -r line <&7 | 
|  | printf "%s\n" "$line" >&4 | 
|  | cat <&7 >&4 & | 
|  | } 7<git_daemon_output && | 
|  |  | 
|  | # Check expected output | 
|  | if test x"$(expr "$line" : "\[[0-9]*\] \(.*\)")" != x"Ready to rumble" | 
|  | then | 
|  | kill "$GIT_DAEMON_PID" | 
|  | wait "$GIT_DAEMON_PID" | 
|  | unset GIT_DAEMON_PID | 
|  | test_skip_or_die GIT_TEST_GIT_DAEMON \ | 
|  | "git daemon failed to start" | 
|  | fi | 
|  | } | 
|  |  | 
|  | stop_git_daemon() { | 
|  | if test -z "$GIT_DAEMON_PID" | 
|  | then | 
|  | return | 
|  | fi | 
|  |  | 
|  | # kill git-daemon child of git | 
|  | say >&3 "Stopping git daemon ..." | 
|  | kill "$GIT_DAEMON_PID" | 
|  | wait "$GIT_DAEMON_PID" >&3 2>&4 | 
|  | ret=$? | 
|  | if ! test_match_signal 15 $ret | 
|  | then | 
|  | error "git daemon exited with status: $ret" | 
|  | fi | 
|  | kill "$(cat "$GIT_DAEMON_PIDFILE")" 2>/dev/null | 
|  | GIT_DAEMON_PID= | 
|  | rm -f git_daemon_output "$GIT_DAEMON_PIDFILE" | 
|  | } | 
|  |  | 
|  | # A stripped-down version of a netcat client, that connects to a "host:port" | 
|  | # given in $1, sends its stdin followed by EOF, then dumps the response (until | 
|  | # EOF) to stdout. | 
|  | fake_nc() { | 
|  | if ! test_declared_prereq FAKENC | 
|  | then | 
|  | echo >&4 "fake_nc: need to declare FAKENC prerequisite" | 
|  | return 127 | 
|  | fi | 
|  | perl -Mstrict -MIO::Socket::INET -e ' | 
|  | my $s = IO::Socket::INET->new(shift) | 
|  | or die "unable to open socket: $!"; | 
|  | print $s <STDIN>; | 
|  | $s->shutdown(1); | 
|  | print <$s>; | 
|  | ' "$@" | 
|  | } | 
|  |  | 
|  | test_lazy_prereq FAKENC ' | 
|  | perl -MIO::Socket::INET -e "exit 0" | 
|  | ' |