3 # Build and test Git in a 32-bit environment
6 # run-linux32-build.sh <host-user-id>
11 if test $# -ne 1 || test -z "$1"
13 echo >&2 "usage: run-linux32-build.sh <host-user-id>"
19 switch_cmd="linux32 --32bit i386"
26 # Update packages to the latest available versions
27 command $switch_cmd sh -c '
28 apt update >/dev/null &&
29 apt install -y build-essential libcurl4-openssl-dev libssl-dev \
30 libexpat-dev gettext python >/dev/null
33 # If this script runs inside a docker container, then all commands are
34 # usually executed as root. Consequently, the host user might not be
35 # able to access the test output files.
36 # If a non 0 host user id is given, then create a user "ci" with that
37 # user id to make everything accessible to the host user.
39 if test $HOST_UID -eq 0
41 # Just in case someone does want to run the test suite as root.
45 if test "$(id -u $CI_USER 2>/dev/null)" = $HOST_UID
47 echo "user '$CI_USER' already exists with the requested ID $HOST_UID"
49 useradd -u $HOST_UID $CI_USER
52 # Due to a bug the test suite was run as root in the past, so
53 # a prove state file created back then is only accessible by
54 # root. Now that bug is fixed, the test suite is run as a
55 # regular user, but the prove state file coming from Travis
56 # CI's cache might still be owned by root.
57 # Make sure that this user has rights to any cached files,
58 # including an existing prove state file.
59 test -n "$cache_dir" && chown -R $HOST_UID:$HOST_UID "$cache_dir"
63 command $switch_cmd su -m -l $CI_USER -c "
65 export DEVELOPER='$DEVELOPER'
66 export DEFAULT_TEST_TARGET='$DEFAULT_TEST_TARGET'
67 export GIT_PROVE_OPTS='$GIT_PROVE_OPTS'
68 export GIT_TEST_OPTS='$GIT_TEST_OPTS'
69 export GIT_TEST_CLONE_2GB='$GIT_TEST_CLONE_2GB'
70 export MAKEFLAGS='$MAKEFLAGS'
71 export cache_dir='$cache_dir'
73 test -n '$cache_dir' && ln -s '$cache_dir/.prove' t/.prove