#!/bin/sh
#
# Build and test Git inside container
#
# Usage:
#   run-docker-build.sh <host-user-id>
#

set -ex

if test $# -ne 1 || test -z "$1"
then
	echo >&2 "usage: run-docker-build.sh <host-user-id>"
	exit 1
fi

case "$jobname" in
Linux32)
	switch_cmd="linux32 --32bit i386"
	;;
linux-musl)
	switch_cmd=
	useradd () { adduser -D "$@"; }
	;;
*)
	exit 1
	;;
esac

"${0%/*}/install-docker-dependencies.sh"

# If this script runs inside a docker container, then all commands are
# usually executed as root. Consequently, the host user might not be
# able to access the test output files.
# If a non 0 host user id is given, then create a user "ci" with that
# user id to make everything accessible to the host user.
HOST_UID=$1
if test $HOST_UID -eq 0
then
	# Just in case someone does want to run the test suite as root.
	CI_USER=root
else
	CI_USER=ci
	if test "$(id -u $CI_USER 2>/dev/null)" = $HOST_UID
	then
		echo "user '$CI_USER' already exists with the requested ID $HOST_UID"
	else
		useradd -u $HOST_UID $CI_USER
	fi

	# Due to a bug the test suite was run as root in the past, so
	# a prove state file created back then is only accessible by
	# root.  Now that bug is fixed, the test suite is run as a
	# regular user, but the prove state file coming from Travis
	# CI's cache might still be owned by root.
	# Make sure that this user has rights to any cached files,
	# including an existing prove state file.
	test -n "$cache_dir" && chown -R $HOST_UID:$HOST_UID "$cache_dir"
fi

# Build and test
command $switch_cmd su -m -l $CI_USER -c "
	set -ex
	export DEVELOPER='$DEVELOPER'
	export DEFAULT_TEST_TARGET='$DEFAULT_TEST_TARGET'
	export GIT_PROVE_OPTS='$GIT_PROVE_OPTS'
	export GIT_TEST_OPTS='$GIT_TEST_OPTS'
	export GIT_TEST_CLONE_2GB='$GIT_TEST_CLONE_2GB'
	export MAKEFLAGS='$MAKEFLAGS'
	export cache_dir='$cache_dir'
	cd /usr/src/git
	test -n '$cache_dir' && ln -s '$cache_dir/.prove' t/.prove
	make
	make test
"