2017-02-13 14:01:54 -05:00
|
|
|
#!/usr/bin/env bash
|
2014-12-19 02:20:59 -05:00
|
|
|
|
2017-06-16 20:18:44 -04:00
|
|
|
# see test-integration for example usage of this script
|
2014-12-19 02:20:59 -05:00
|
|
|
|
2016-02-19 17:42:51 -05:00
|
|
|
base="$ABS_DEST/.."
|
2019-02-18 23:02:50 -05:00
|
|
|
export PATH="$base/dynbinary-daemon:$base/binary-daemon:$PATH"
|
2014-12-19 02:20:59 -05:00
|
|
|
|
2017-04-17 19:18:46 -04:00
|
|
|
export TEST_CLIENT_BINARY=docker
|
2017-06-09 08:39:55 -04:00
|
|
|
|
2019-01-09 20:23:38 -05:00
|
|
|
if [ -n "$DOCKER_CLI_PATH" ]; then
|
2017-04-17 19:18:46 -04:00
|
|
|
export TEST_CLIENT_BINARY=/usr/local/cli/$(basename "$DOCKER_CLI_PATH")
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo "Using test binary $TEST_CLIENT_BINARY"
|
|
|
|
if ! command -v "$TEST_CLIENT_BINARY" &> /dev/null; then
|
|
|
|
echo >&2 'error: missing test client $TEST_CLIENT_BINARY'
|
2014-12-19 02:20:59 -05:00
|
|
|
false
|
|
|
|
fi
|
|
|
|
|
2016-02-19 17:42:51 -05:00
|
|
|
# This is a temporary hack for split-binary mode. It can be removed once
|
|
|
|
# https://github.com/docker/docker/pull/22134 is merged into docker master
|
2019-01-09 20:23:38 -05:00
|
|
|
if [ "$(go env GOOS)" = 'windows' ]; then
|
2019-08-02 09:58:33 -04:00
|
|
|
return
|
2016-02-19 17:42:51 -05:00
|
|
|
fi
|
|
|
|
|
2019-01-09 20:23:38 -05:00
|
|
|
if [ -z "$DOCKER_TEST_HOST" ]; then
|
2016-03-25 10:54:36 -04:00
|
|
|
if docker version &> /dev/null; then
|
|
|
|
echo >&2 'skipping daemon start, since daemon appears to be already started'
|
|
|
|
return
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2016-02-19 17:42:51 -05:00
|
|
|
if ! command -v dockerd &> /dev/null; then
|
|
|
|
echo >&2 'error: binary-daemon or dynbinary-daemon must be run before .integration-daemon-start'
|
|
|
|
false
|
|
|
|
fi
|
|
|
|
|
2014-12-19 02:20:59 -05:00
|
|
|
# intentionally open a couple bogus file descriptors to help test that they get scrubbed in containers
|
|
|
|
exec 41>&1 42>&2
|
|
|
|
|
2015-01-27 19:40:11 -05:00
|
|
|
export DOCKER_GRAPHDRIVER=${DOCKER_GRAPHDRIVER:-vfs}
|
2015-09-16 12:55:14 -04:00
|
|
|
export DOCKER_USERLANDPROXY=${DOCKER_USERLANDPROXY:-true}
|
2014-12-19 02:20:59 -05:00
|
|
|
|
2015-04-15 02:39:15 -04:00
|
|
|
# example usage: DOCKER_STORAGE_OPTS="dm.basesize=20G,dm.loopdatasize=200G"
|
|
|
|
storage_params=""
|
2019-01-09 20:23:38 -05:00
|
|
|
if [ -n "$DOCKER_STORAGE_OPTS" ]; then
|
2015-04-15 02:39:15 -04:00
|
|
|
IFS=','
|
|
|
|
for i in ${DOCKER_STORAGE_OPTS}; do
|
|
|
|
storage_params="--storage-opt $i $storage_params"
|
|
|
|
done
|
|
|
|
unset IFS
|
|
|
|
fi
|
|
|
|
|
2017-03-29 06:13:40 -04:00
|
|
|
# example usage: DOCKER_REMAP_ROOT=default
|
2015-09-18 13:41:12 -04:00
|
|
|
extra_params=""
|
2019-01-09 20:23:38 -05:00
|
|
|
if [ "$DOCKER_REMAP_ROOT" ]; then
|
2015-10-09 20:52:45 -04:00
|
|
|
extra_params="--userns-remap $DOCKER_REMAP_ROOT"
|
2015-09-18 13:41:12 -04:00
|
|
|
fi
|
|
|
|
|
2017-03-29 06:13:40 -04:00
|
|
|
# example usage: DOCKER_EXPERIMENTAL=1
|
2020-03-02 22:27:49 -05:00
|
|
|
if [ "$DOCKER_EXPERIMENTAL" ]; then
|
2016-10-06 10:09:54 -04:00
|
|
|
echo >&2 '# DOCKER_EXPERIMENTAL is set: starting daemon with experimental features enabled! '
|
|
|
|
extra_params="$extra_params --experimental"
|
|
|
|
fi
|
|
|
|
|
2020-02-18 04:43:56 -05:00
|
|
|
dockerd="dockerd"
|
|
|
|
if [ -n "$DOCKER_ROOTLESS" ]; then
|
|
|
|
if [ -z "$TEST_SKIP_INTEGRATION_CLI" ]; then
|
|
|
|
echo >&2 '# DOCKER_ROOTLESS requires TEST_SKIP_INTEGRATION_CLI to be set'
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
ln -sf "$(command -v vpnkit."$(uname -m)")" /usr/local/bin/vpnkit
|
|
|
|
user="unprivilegeduser"
|
|
|
|
uid=$(id -u $user)
|
|
|
|
# shellcheck disable=SC2174
|
|
|
|
mkdir -p -m 700 "/tmp/docker-${uid}"
|
|
|
|
chown "$user" "/tmp/docker-${uid}"
|
|
|
|
chmod -R o+w "$DEST"
|
|
|
|
dockerd="sudo -u $user -E -E XDG_RUNTIME_DIR=/tmp/docker-${uid} -E HOME=/home/${user} -E PATH=$PATH -- dockerd-rootless.sh"
|
|
|
|
fi
|
|
|
|
|
2019-01-09 20:23:38 -05:00
|
|
|
if [ -z "$DOCKER_TEST_HOST" ]; then
|
2015-05-04 16:20:01 -04:00
|
|
|
# Start apparmor if it is enabled
|
2019-01-09 20:23:38 -05:00
|
|
|
if [ -e "/sys/module/apparmor/parameters/enabled" ] && [ "$(cat /sys/module/apparmor/parameters/enabled)" == "Y" ]; then
|
2015-05-04 16:20:01 -04:00
|
|
|
# reset container variable so apparmor profile is applied to process
|
|
|
|
# see https://github.com/docker/libcontainer/blob/master/apparmor/apparmor.go#L16
|
|
|
|
export container=""
|
|
|
|
(
|
2019-01-09 20:23:38 -05:00
|
|
|
[ -n "$TESTDEBUG" ] && set -x
|
2015-05-04 16:20:01 -04:00
|
|
|
/etc/init.d/apparmor start
|
|
|
|
)
|
|
|
|
fi
|
|
|
|
|
2017-07-06 17:20:41 -04:00
|
|
|
# "pwd" tricks to make sure $DEST is an absolute path, not a relative one
|
|
|
|
export DOCKER_HOST="unix://$(cd "$DEST" && pwd)/docker.sock"
|
|
|
|
(
|
|
|
|
echo "Starting dockerd"
|
2019-01-09 20:23:38 -05:00
|
|
|
[ -n "$TESTDEBUG" ] && set -x
|
2017-07-06 17:20:41 -04:00
|
|
|
exec \
|
2020-02-18 04:43:56 -05:00
|
|
|
${dockerd} --debug \
|
2017-07-06 17:20:41 -04:00
|
|
|
--host "$DOCKER_HOST" \
|
|
|
|
--storage-driver "$DOCKER_GRAPHDRIVER" \
|
|
|
|
--pidfile "$DEST/docker.pid" \
|
|
|
|
--userland-proxy="$DOCKER_USERLANDPROXY" \
|
2019-01-09 20:50:47 -05:00
|
|
|
${storage_params} \
|
|
|
|
${extra_params} \
|
2020-03-02 22:27:49 -05:00
|
|
|
&> "$DEST/docker.log"
|
2014-12-24 00:57:14 -05:00
|
|
|
) &
|
2014-11-20 00:19:16 -05:00
|
|
|
else
|
2014-12-24 00:57:14 -05:00
|
|
|
export DOCKER_HOST="$DOCKER_TEST_HOST"
|
2014-11-20 00:19:16 -05:00
|
|
|
fi
|
2015-02-14 05:27:31 -05:00
|
|
|
|
2015-07-24 20:49:43 -04:00
|
|
|
# give it a little time to come up so it's "ready"
|
2015-12-03 14:09:14 -05:00
|
|
|
tries=60
|
|
|
|
echo "INFO: Waiting for daemon to start..."
|
2019-01-09 20:50:47 -05:00
|
|
|
while ! ${TEST_CLIENT_BINARY} version &> /dev/null; do
|
2020-03-02 22:27:49 -05:00
|
|
|
((tries--))
|
2019-01-09 20:23:38 -05:00
|
|
|
if [ $tries -le 0 ]; then
|
2015-12-03 14:09:14 -05:00
|
|
|
printf "\n"
|
2019-01-09 20:23:38 -05:00
|
|
|
if [ -z "$DOCKER_HOST" ]; then
|
2015-02-14 05:27:31 -05:00
|
|
|
echo >&2 "error: daemon failed to start"
|
|
|
|
echo >&2 " check $DEST/docker.log for details"
|
|
|
|
else
|
2017-04-17 19:18:46 -04:00
|
|
|
echo >&2 "error: daemon at $DOCKER_HOST fails to '$TEST_CLIENT_BINARY version':"
|
2019-01-09 20:50:47 -05:00
|
|
|
${TEST_CLIENT_BINARY} version >&2 || true
|
2016-01-06 14:09:47 -05:00
|
|
|
# Additional Windows CI debugging as this is a common error as of
|
|
|
|
# January 2016
|
2019-01-09 20:23:38 -05:00
|
|
|
if [ "$(go env GOOS)" = 'windows' ]; then
|
2016-01-06 14:09:47 -05:00
|
|
|
echo >&2 "Container log below:"
|
|
|
|
echo >&2 "---"
|
|
|
|
# Important - use the docker on the CI host, not the one built locally
|
|
|
|
# which is currently in our path.
|
|
|
|
! /c/bin/docker -H=$MAIN_DOCKER_HOST logs docker-$COMMITHASH
|
|
|
|
echo >&2 "---"
|
2016-04-25 11:18:34 -04:00
|
|
|
fi
|
2015-02-14 05:27:31 -05:00
|
|
|
fi
|
|
|
|
false
|
|
|
|
fi
|
2015-12-03 14:09:14 -05:00
|
|
|
printf "."
|
2015-02-14 05:27:31 -05:00
|
|
|
sleep 2
|
|
|
|
done
|
2015-12-03 14:09:14 -05:00
|
|
|
printf "\n"
|