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