.integration-daemon-start 5.3 KB

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