about summary refs log tree commit diff
path: root/third_party/git/t/lib-httpd.sh
diff options
context:
space:
mode:
authorVincent Ambo <mail@tazj.in>2021-09-21T10·03+0300
committerVincent Ambo <mail@tazj.in>2021-09-21T11·29+0300
commit43b1791ec601732ac31195df96781a848360a9ac (patch)
treedaae8d638343295d2f1f7da955e556ef4c958864 /third_party/git/t/lib-httpd.sh
parent2d8e7dc9d9c38127ec4ebd13aee8e8f586a43318 (diff)
chore(3p/git): Unvendor git and track patches instead r/2903
This was vendored a long time ago under the expectation that keeping
it in sync with cgit would be easier this way, but it has proven not
to be a big issue.

On the other hand, a vendored copy of git is an annoying maintenance
burden. It is much easier to rebase the single (dottime) patch that we
have.

This removes the vendored copy of git and instead passes the git
source code to cgit via `pkgs.srcOnly`, which includes the applied
patch so that cgit can continue rendering dottime.

Change-Id: If31f62dea7ce688fd1b9050204e9378019775f2b
Diffstat (limited to 'third_party/git/t/lib-httpd.sh')
-rw-r--r--third_party/git/t/lib-httpd.sh310
1 files changed, 0 insertions, 310 deletions
diff --git a/third_party/git/t/lib-httpd.sh b/third_party/git/t/lib-httpd.sh
deleted file mode 100644
index d2edfa4c503a..000000000000
--- a/third_party/git/t/lib-httpd.sh
+++ /dev/null
@@ -1,310 +0,0 @@
-# Shell library to run an HTTP server for use in tests.
-# Ends the test early if httpd tests should not be run,
-# for example because the user has not enabled them.
-#
-# Usage:
-#
-#	. ./test-lib.sh
-#	. "$TEST_DIRECTORY"/lib-httpd.sh
-#	start_httpd
-#
-#	test_expect_success '...' '
-#		...
-#	'
-#
-#	test_expect_success ...
-#
-#	test_done
-#
-# Can be configured using the following variables.
-#
-#    GIT_TEST_HTTPD              enable HTTPD tests
-#    LIB_HTTPD_PATH              web server path
-#    LIB_HTTPD_MODULE_PATH       web server modules path
-#    LIB_HTTPD_PORT              listening port
-#    LIB_HTTPD_DAV               enable DAV
-#    LIB_HTTPD_SVN               enable SVN at given location (e.g. "svn")
-#    LIB_HTTPD_SSL               enable SSL
-#
-# Copyright (c) 2008 Clemens Buchacher <drizzd@aon.at>
-#
-
-if test -n "$NO_CURL"
-then
-	skip_all='skipping test, git built without http support'
-	test_done
-fi
-
-if test -n "$NO_EXPAT" && test -n "$LIB_HTTPD_DAV"
-then
-	skip_all='skipping test, git built without expat support'
-	test_done
-fi
-
-if ! test_bool_env GIT_TEST_HTTPD true
-then
-	skip_all="Network testing disabled (unset GIT_TEST_HTTPD to enable)"
-	test_done
-fi
-
-if ! test_have_prereq NOT_ROOT; then
-	test_skip_or_die GIT_TEST_HTTPD \
-		"Cannot run httpd tests as root"
-fi
-
-HTTPD_PARA=""
-
-for DEFAULT_HTTPD_PATH in '/usr/sbin/httpd' '/usr/sbin/apache2'
-do
-	if test -x "$DEFAULT_HTTPD_PATH"
-	then
-		break
-	fi
-done
-
-for DEFAULT_HTTPD_MODULE_PATH in '/usr/libexec/apache2' \
-				 '/usr/lib/apache2/modules' \
-				 '/usr/lib64/httpd/modules' \
-				 '/usr/lib/httpd/modules'
-do
-	if test -d "$DEFAULT_HTTPD_MODULE_PATH"
-	then
-		break
-	fi
-done
-
-case $(uname) in
-	Darwin)
-		HTTPD_PARA="$HTTPD_PARA -DDarwin"
-	;;
-esac
-
-LIB_HTTPD_PATH=${LIB_HTTPD_PATH-"$DEFAULT_HTTPD_PATH"}
-test_set_port LIB_HTTPD_PORT
-
-TEST_PATH="$TEST_DIRECTORY"/lib-httpd
-HTTPD_ROOT_PATH="$PWD"/httpd
-HTTPD_DOCUMENT_ROOT_PATH=$HTTPD_ROOT_PATH/www
-
-# hack to suppress apache PassEnv warnings
-GIT_VALGRIND=$GIT_VALGRIND; export GIT_VALGRIND
-GIT_VALGRIND_OPTIONS=$GIT_VALGRIND_OPTIONS; export GIT_VALGRIND_OPTIONS
-GIT_TEST_SIDEBAND_ALL=$GIT_TEST_SIDEBAND_ALL; export GIT_TEST_SIDEBAND_ALL
-GIT_TRACE=$GIT_TRACE; export GIT_TRACE
-
-if ! test -x "$LIB_HTTPD_PATH"
-then
-	test_skip_or_die GIT_TEST_HTTPD "no web server found at '$LIB_HTTPD_PATH'"
-fi
-
-HTTPD_VERSION=$($LIB_HTTPD_PATH -v | \
-	sed -n 's/^Server version: Apache\/\([0-9]*\)\..*$/\1/p; q')
-
-if test -n "$HTTPD_VERSION"
-then
-	if test -z "$LIB_HTTPD_MODULE_PATH"
-	then
-		if ! test $HTTPD_VERSION -ge 2
-		then
-			test_skip_or_die GIT_TEST_HTTPD \
-				"at least Apache version 2 is required"
-		fi
-		if ! test -d "$DEFAULT_HTTPD_MODULE_PATH"
-		then
-			test_skip_or_die GIT_TEST_HTTPD \
-				"Apache module directory not found"
-		fi
-
-		LIB_HTTPD_MODULE_PATH="$DEFAULT_HTTPD_MODULE_PATH"
-	fi
-else
-	test_skip_or_die GIT_TEST_HTTPD \
-		"Could not identify web server at '$LIB_HTTPD_PATH'"
-fi
-
-install_script () {
-	write_script "$HTTPD_ROOT_PATH/$1" <"$TEST_PATH/$1"
-}
-
-prepare_httpd() {
-	mkdir -p "$HTTPD_DOCUMENT_ROOT_PATH"
-	cp "$TEST_PATH"/passwd "$HTTPD_ROOT_PATH"
-	install_script incomplete-length-upload-pack-v2-http.sh
-	install_script incomplete-body-upload-pack-v2-http.sh
-	install_script broken-smart-http.sh
-	install_script error-smart-http.sh
-	install_script error.sh
-	install_script apply-one-time-perl.sh
-
-	ln -s "$LIB_HTTPD_MODULE_PATH" "$HTTPD_ROOT_PATH/modules"
-
-	if test -n "$LIB_HTTPD_SSL"
-	then
-		HTTPD_PROTO=https
-
-		RANDFILE_PATH="$HTTPD_ROOT_PATH"/.rnd openssl req \
-			-config "$TEST_PATH/ssl.cnf" \
-			-new -x509 -nodes \
-			-out "$HTTPD_ROOT_PATH/httpd.pem" \
-			-keyout "$HTTPD_ROOT_PATH/httpd.pem"
-		GIT_SSL_NO_VERIFY=t
-		export GIT_SSL_NO_VERIFY
-		HTTPD_PARA="$HTTPD_PARA -DSSL"
-	else
-		HTTPD_PROTO=http
-	fi
-	HTTPD_DEST=127.0.0.1:$LIB_HTTPD_PORT
-	HTTPD_URL=$HTTPD_PROTO://$HTTPD_DEST
-	HTTPD_URL_USER=$HTTPD_PROTO://user%40host@$HTTPD_DEST
-	HTTPD_URL_USER_PASS=$HTTPD_PROTO://user%40host:pass%40host@$HTTPD_DEST
-
-	if test -n "$LIB_HTTPD_DAV" || test -n "$LIB_HTTPD_SVN"
-	then
-		HTTPD_PARA="$HTTPD_PARA -DDAV"
-
-		if test -n "$LIB_HTTPD_SVN"
-		then
-			HTTPD_PARA="$HTTPD_PARA -DSVN"
-			LIB_HTTPD_SVNPATH="$rawsvnrepo"
-			svnrepo="http://127.0.0.1:$LIB_HTTPD_PORT/"
-			svnrepo="$svnrepo$LIB_HTTPD_SVN"
-			export LIB_HTTPD_SVN LIB_HTTPD_SVNPATH
-		fi
-	fi
-}
-
-start_httpd() {
-	prepare_httpd >&3 2>&4
-
-	test_atexit stop_httpd
-
-	"$LIB_HTTPD_PATH" -d "$HTTPD_ROOT_PATH" \
-		-f "$TEST_PATH/apache.conf" $HTTPD_PARA \
-		-c "Listen 127.0.0.1:$LIB_HTTPD_PORT" -k start \
-		>&3 2>&4
-	if test $? -ne 0
-	then
-		cat "$HTTPD_ROOT_PATH"/error.log >&4 2>/dev/null
-		test_skip_or_die GIT_TEST_HTTPD "web server setup failed"
-	fi
-}
-
-stop_httpd() {
-	"$LIB_HTTPD_PATH" -d "$HTTPD_ROOT_PATH" \
-		-f "$TEST_PATH/apache.conf" $HTTPD_PARA -k stop
-}
-
-test_http_push_nonff () {
-	REMOTE_REPO=$1
-	LOCAL_REPO=$2
-	BRANCH=$3
-	EXPECT_CAS_RESULT=${4-failure}
-
-	test_expect_success 'non-fast-forward push fails' '
-		cd "$REMOTE_REPO" &&
-		HEAD=$(git rev-parse --verify HEAD) &&
-
-		cd "$LOCAL_REPO" &&
-		git checkout $BRANCH &&
-		echo "changed" > path2 &&
-		git commit -a -m path2 --amend &&
-
-		test_must_fail git push -v origin >output 2>&1 &&
-		(cd "$REMOTE_REPO" &&
-		 test $HEAD = $(git rev-parse --verify HEAD))
-	'
-
-	test_expect_success 'non-fast-forward push show ref status' '
-		grep "^ ! \[rejected\][ ]*$BRANCH -> $BRANCH (non-fast-forward)$" output
-	'
-
-	test_expect_success 'non-fast-forward push shows help message' '
-		test_i18ngrep "Updates were rejected because" output
-	'
-
-	test_expect_${EXPECT_CAS_RESULT} 'force with lease aka cas' '
-		HEAD=$(	cd "$REMOTE_REPO" && git rev-parse --verify HEAD ) &&
-		test_when_finished '\''
-			(cd "$REMOTE_REPO" && git update-ref HEAD "$HEAD")
-		'\'' &&
-		(
-			cd "$LOCAL_REPO" &&
-			git push -v --force-with-lease=$BRANCH:$HEAD origin
-		) &&
-		git rev-parse --verify "$BRANCH" >expect &&
-		(
-			cd "$REMOTE_REPO" && git rev-parse --verify HEAD
-		) >actual &&
-		test_cmp expect actual
-	'
-}
-
-setup_askpass_helper() {
-	test_expect_success 'setup askpass helper' '
-		write_script "$TRASH_DIRECTORY/askpass" <<-\EOF &&
-		echo >>"$TRASH_DIRECTORY/askpass-query" "askpass: $*" &&
-		case "$*" in
-		*Username*)
-			what=user
-			;;
-		*Password*)
-			what=pass
-			;;
-		esac &&
-		cat "$TRASH_DIRECTORY/askpass-$what"
-		EOF
-		GIT_ASKPASS="$TRASH_DIRECTORY/askpass" &&
-		export GIT_ASKPASS &&
-		export TRASH_DIRECTORY
-	'
-}
-
-set_askpass() {
-	>"$TRASH_DIRECTORY/askpass-query" &&
-	echo "$1" >"$TRASH_DIRECTORY/askpass-user" &&
-	echo "$2" >"$TRASH_DIRECTORY/askpass-pass"
-}
-
-expect_askpass() {
-	dest=$HTTPD_DEST${3+/$3}
-
-	{
-		case "$1" in
-		none)
-			;;
-		pass)
-			echo "askpass: Password for 'http://$2@$dest': "
-			;;
-		both)
-			echo "askpass: Username for 'http://$dest': "
-			echo "askpass: Password for 'http://$2@$dest': "
-			;;
-		*)
-			false
-			;;
-		esac
-	} >"$TRASH_DIRECTORY/askpass-expect" &&
-	test_cmp "$TRASH_DIRECTORY/askpass-expect" \
-		 "$TRASH_DIRECTORY/askpass-query"
-}
-
-strip_access_log() {
-	sed -e "
-		s/^.* \"//
-		s/\"//
-		s/ [1-9][0-9]*\$//
-		s/^GET /GET  /
-	" "$HTTPD_ROOT_PATH"/access.log
-}
-
-# Requires one argument: the name of a file containing the expected stripped
-# access log entries.
-check_access_log() {
-	sort "$1" >"$1".sorted &&
-	strip_access_log >access.log.stripped &&
-	sort access.log.stripped >access.log.sorted &&
-	if ! test_cmp "$1".sorted access.log.sorted
-	then
-		test_cmp "$1" access.log.stripped
-	fi
-}