github.com/Prakhar-Agarwal-byte/moby@v0.0.0-20231027092010-a14e3e8ab87e/hack/make/.integration-daemon-start (about) 1 #!/usr/bin/env bash 2 3 # see test-integration for example usage of this script 4 5 base="$ABS_DEST/.." 6 export PATH="$base/dynbinary-daemon:$base/binary-daemon:$PATH" 7 8 if [ -z "$TEST_CLIENT_BINARY" ]; then 9 export TEST_CLIENT_BINARY=docker 10 fi 11 if [ -n "$DOCKER_CLI_PATH" ]; then 12 # /usr/local/cli is a bind mount to the base dir of DOCKER_CLI_PATH (if used) 13 export TEST_CLIENT_BINARY=/usr/local/cli/$(basename "$DOCKER_CLI_PATH") 14 fi 15 16 echo "Using test binary $TEST_CLIENT_BINARY" 17 if ! command -v "$TEST_CLIENT_BINARY" &> /dev/null; then 18 echo >&2 'error: missing test client $TEST_CLIENT_BINARY' 19 false 20 fi 21 22 # This is a temporary hack for split-binary mode. It can be removed once 23 # https://github.com/Prakhar-Agarwal-byte/moby/pull/22134 is merged into docker master 24 if [ "$(go env GOOS)" = 'windows' ]; then 25 return 26 fi 27 28 if [ -z "$DOCKER_TEST_HOST" ]; then 29 if docker version &> /dev/null; then 30 echo >&2 'skipping daemon start, since daemon appears to be already started' 31 return 32 fi 33 fi 34 35 if ! command -v dockerd &> /dev/null; then 36 echo >&2 'error: binary-daemon or dynbinary-daemon must be run before .integration-daemon-start' 37 false 38 fi 39 40 # intentionally open a couple bogus file descriptors to help test that they get scrubbed in containers 41 exec 41>&1 42>&2 42 43 # Allow pushing manifest v2 schema 1 images, as they're used to push 44 # images to our test-registries for testing _pulling_ schema 2v1 images. 45 export DOCKER_ALLOW_SCHEMA1_PUSH_DONOTUSE=1 46 export DOCKER_GRAPHDRIVER=${DOCKER_GRAPHDRIVER:-vfs} 47 export DOCKER_USERLANDPROXY=${DOCKER_USERLANDPROXY:-true} 48 49 # example usage: DOCKER_STORAGE_OPTS="dm.basesize=20G,dm.loopdatasize=200G" 50 storage_params="" 51 if [ -n "$DOCKER_STORAGE_OPTS" ]; then 52 IFS=',' 53 for i in ${DOCKER_STORAGE_OPTS}; do 54 storage_params="--storage-opt $i $storage_params" 55 done 56 unset IFS 57 fi 58 59 # example usage: DOCKER_REMAP_ROOT=default 60 extra_params="" 61 if [ "$DOCKER_REMAP_ROOT" ]; then 62 extra_params="--userns-remap $DOCKER_REMAP_ROOT" 63 fi 64 65 # example usage: DOCKER_EXPERIMENTAL=1 66 if [ "$DOCKER_EXPERIMENTAL" ]; then 67 echo >&2 '# DOCKER_EXPERIMENTAL is set: starting daemon with experimental features enabled! ' 68 extra_params="$extra_params --experimental" 69 fi 70 71 dockerd="dockerd" 72 if [ -f "/sys/fs/cgroup/cgroup.controllers" ]; then 73 if [ -z "$TEST_IGNORE_CGROUP_CHECK" ] && [ -z "$TEST_SKIP_INTEGRATION_CLI" ]; then 74 echo >&2 '# cgroup v2 requires TEST_SKIP_INTEGRATION_CLI to be set' 75 exit 1 76 fi 77 fi 78 79 if [ -n "$DOCKER_ROOTLESS" ]; then 80 if [ -z "$TEST_SKIP_INTEGRATION_CLI" ]; then 81 echo >&2 '# DOCKER_ROOTLESS requires TEST_SKIP_INTEGRATION_CLI to be set' 82 exit 1 83 fi 84 user="unprivilegeduser" 85 uid=$(id -u $user) 86 # shellcheck disable=SC2174 87 mkdir -p -m 700 "/tmp/docker-${uid}" 88 chown "$user" "/tmp/docker-${uid}" 89 chmod -R o+w "$DEST" 90 dockerd="sudo -u $user -E -E XDG_RUNTIME_DIR=/tmp/docker-${uid} -E HOME=/home/${user} -E PATH=$PATH -- dockerd-rootless.sh" 91 fi 92 93 if [ -z "$DOCKER_TEST_HOST" ]; then 94 # Start apparmor if it is enabled 95 if [ -e "/sys/module/apparmor/parameters/enabled" ] && [ "$(cat /sys/module/apparmor/parameters/enabled)" == "Y" ]; then 96 # reset container variable so apparmor profile is applied to process 97 # see https://github.com/docker/libcontainer/blob/master/apparmor/apparmor.go#L16 98 export container="" 99 ( 100 [ -n "$TESTDEBUG" ] && set -x 101 /etc/init.d/apparmor start 102 ) 103 fi 104 105 if [ -n "${DOCKER_ROOTLESS}" ]; then 106 # "pwd" tricks to make sure $DEST is an absolute path, not a relative one 107 export DOCKER_HOST="unix://$(cd "$DEST" && pwd)/docker.sock" 108 else 109 # Put socket in /run because: 110 # 1. That's the normal place for such things 111 # 2. When running on Docker For Mac, if you need to run tests with the bundles dir mounted (e.g. to poke through test artifacts). 112 # the socket will not work because it will be over osxfs. 113 mkdir -p /run/docker 114 sock_dir=$(mktemp -d -p /run/docker) 115 chmod 0755 "$sock_dir" 116 export DOCKER_HOST="unix://${sock_dir}/docker.sock" 117 fi 118 ( 119 echo "Starting dockerd" 120 [ -n "$TESTDEBUG" ] && set -x 121 exec \ 122 ${dockerd} --debug \ 123 --host "$DOCKER_HOST" \ 124 --storage-driver "$DOCKER_GRAPHDRIVER" \ 125 --pidfile "$DEST/docker.pid" \ 126 --userland-proxy="$DOCKER_USERLANDPROXY" \ 127 ${storage_params} \ 128 ${extra_params} \ 129 &> "$DEST/docker.log" 130 ) & 131 else 132 export DOCKER_HOST="$DOCKER_TEST_HOST" 133 fi 134 135 # give it a little time to come up so it's "ready" 136 tries=60 137 echo "INFO: Waiting for daemon to start..." 138 while ! ${TEST_CLIENT_BINARY} version &> /dev/null; do 139 ((tries--)) 140 if [ $tries -le 0 ]; then 141 printf "\n" 142 if [ -z "$DOCKER_HOST" ]; then 143 echo >&2 "error: daemon failed to start" 144 echo >&2 " check $DEST/docker.log for details" 145 else 146 echo >&2 "error: daemon at $DOCKER_HOST fails to '$TEST_CLIENT_BINARY version':" 147 ${TEST_CLIENT_BINARY} version >&2 || true 148 # Additional Windows CI debugging as this is a common error as of 149 # January 2016 150 if [ "$(go env GOOS)" = 'windows' ]; then 151 echo >&2 "Container log below:" 152 echo >&2 "---" 153 # Important - use the docker on the CI host, not the one built locally 154 # which is currently in our path. 155 ! /c/bin/docker -H=$MAIN_DOCKER_HOST logs docker-$COMMITHASH 156 echo >&2 "---" 157 fi 158 fi 159 false 160 fi 161 printf "." 162 sleep 2 163 done 164 printf "\n" 165 166 if [ "$(docker version --format '{{ .Server.Os }}')" != 'windows' ]; then 167 bundle .build-empty-images 168 fi