summaryrefslogtreecommitdiff
path: root/hack/make/test-docker-py
diff options
context:
space:
mode:
Diffstat (limited to 'hack/make/test-docker-py')
-rw-r--r--hack/make/test-docker-py60
1 files changed, 52 insertions, 8 deletions
diff --git a/hack/make/test-docker-py b/hack/make/test-docker-py
index b30879e3a0..9625f47e61 100644
--- a/hack/make/test-docker-py
+++ b/hack/make/test-docker-py
@@ -3,18 +3,62 @@ set -e
source hack/make/.integration-test-helpers
-# subshell so that we can export PATH without breaking other things
+# The commit or tag to use for testing
+# TODO docker 17.06 cli client used in CI fails to build using a sha;
+# unable to prepare context: unable to 'git clone' to temporary context directory: error fetching: error: no such remote ref ead0bb9e08c13dd3d1712759491eee06bf5a5602
+#: exit status 128
+: "${DOCKER_PY_COMMIT:=4.0.2}"
+
+# custom options to pass py.test
+# TODO remove these skip once we update to a docker-py version that has https://github.com/docker/docker-py/pull/2369, https://github.com/docker/docker-py/pull/2380, https://github.com/docker/docker-py/pull/2382
+: "${PY_TEST_OPTIONS:=\
+--deselect=tests/integration/api_swarm_test.py::SwarmTest::test_init_swarm_data_path_addr \
+--deselect=tests/integration/api_exec_test.py::ExecTest::test_detach_with_arg \
+--deselect=tests/integration/api_exec_test.py::ExecDemuxTest::test_exec_command_tty_stream_no_demux \
+--deselect=tests/integration/api_build_test.py::BuildTest::test_build_invalid_platform \
+--deselect=tests/integration/api_image_test.py::PullImageTest::test_pull_invalid_platform \
+--junitxml=${DEST}/junit-report.xml \
+}"
(
bundle .integration-daemon-start
- dockerPy='/docker-py'
- [ -d "$dockerPy" ] || {
- dockerPy="$DEST/docker-py"
- git clone https://github.com/docker/docker-py.git "$dockerPy"
- }
+ docker_host_scheme=$(echo "${DOCKER_HOST}" | cut -d: -f1 -)
+
+ case "${docker_host_scheme}" in
+ unix)
+ # trim the tcp:// scheme, and bind-mount the docker socket into the container
+ run_opts="--mount type=bind,src=${DOCKER_HOST#unix://},dst=/var/run/docker.sock"
+ ;;
+
+ tcp)
+ # run container in host-mode networking so that it can connect to the
+ # daemon from the current networking namespace (e.g., to connect to localhost)
+ run_opts="--network=host -e DOCKER_HOST=${DOCKER_HOST}"
+ ;;
+
+ *)
+ echo "WARN: Skipping test-docker-py: connecting to docker daemon using ${docker_host_scheme} (${DOCKER_HOST}) not supported"
+ bundle .integration-daemon-stop
+ return 0
+ esac
- # exporting PYTHONPATH to import "docker" from our local docker-py
- test_env PYTHONPATH="$dockerPy" py.test --junitxml="$DEST/results.xml" "$dockerPy/tests/integration"
+ docker_py_image="docker-sdk-python3:${DOCKER_PY_COMMIT}"
+ if ! docker image inspect "dockerPyImage" &> /dev/null; then
+ echo INFO: Building ${docker_py_image}...
+ (
+ [ -n "${TESTDEBUG}" ] && set -x
+ [ -z "${TESTDEBUG}" ] && build_opts="--quiet"
+ [ -f /.dockerenv ] || build_opts="${build_opts} --network=host"
+ # shellcheck disable=SC2086
+ exec docker build ${build_opts} -t "${docker_py_image}" -f tests/Dockerfile "https://github.com/docker/docker-py.git#${DOCKER_PY_COMMIT}"
+ )
+ fi
+ echo INFO: Starting docker-py tests...
+ (
+ [ -n "${TESTDEBUG}" ] && set -x
+ # shellcheck disable=SC2086,SC2140
+ exec docker run --rm ${run_opts} --mount type=bind,"src=${ABS_DEST}","dst=/src/${DEST}" "${docker_py_image}" pytest ${PY_TEST_OPTIONS} tests/integration
+ )
bundle .integration-daemon-stop
) 2>&1 | tee -a "$DEST/test.log"