67 lines
1.4 KiB
Bash
Executable File
67 lines
1.4 KiB
Bash
Executable File
#!/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
|
|
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
|
|
"
|