Skip to content
Failed

Console Output

Pull request #2959 updated
09:08:51 Connecting to https://api.github.com using docker-jenkins/****** (docker-jenkins GitHub credentials)
Loading trusted files from base branch master at a48a5a9647761406d66e8271f19fab7fa0c5f582 rather than b6deb149ce8ba3fc6638315c15a4f71bc424434b
Obtained Jenkinsfile from a48a5a9647761406d66e8271f19fab7fa0c5f582
Running in Durability level: PERFORMANCE_OPTIMIZED
Loading library jps@master
Examining docker/jps
Attempting to resolve master as a branch
Resolved master as branch master at revision 5d8b74fd03a1c7cc00e1c1f32d100ed97a17f4f0
The recommended git tool is: NONE
using credential jps-reader
 > git rev-parse --resolve-git-dir /var/cloudbees-jenkins-distribution/workspace/docker-py_PR-2959@libs/jps/.git # timeout=10
Fetching changes from the remote Git repository
 > git config remote.origin.url https://github.com/docker/jps.git # timeout=10
Fetching without tags
Fetching upstream changes from https://github.com/docker/jps.git
 > git --version # timeout=10
 > git --version # 'git version 2.20.1'
using GIT_ASKPASS to set credentials GitHub credentials for docker/jps
 > git fetch --no-tags --force --progress -- https://github.com/docker/jps.git +refs/heads/master:refs/remotes/origin/master # timeout=10
Checking out Revision 5d8b74fd03a1c7cc00e1c1f32d100ed97a17f4f0 (master)
 > git config core.sparsecheckout # timeout=10
 > git checkout -f 5d8b74fd03a1c7cc00e1c1f32d100ed97a17f4f0 # timeout=10
Commit message: "Merge pull request #25 from ingshtrom/in-2733-load-from-file"
 > git rev-list --no-walk 5d8b74fd03a1c7cc00e1c1f32d100ed97a17f4f0 # timeout=10
Excluding src/test/ from checkout of git https://github.com/docker/jps.git so that shared library test code cannot be accessed by Pipelines.
To remove this log message, move the test code outside of src/. To restore the previous behavior that allowed access to files in src/test/, pass -Dorg.jenkinsci.plugins.workflow.libs.SCMSourceRetriever.INCLUDE_SRC_TEST_IN_LIBRARIES=true to the java command used to start Jenkins.
[Pipeline] Start of Pipeline
[Pipeline] node
Running on EC2 (managed-agents) - ubuntu-2004-cgroup1 (i-038677a38b0431f65) in /home/ubuntu/workspace/docker-py_PR-2959
[Pipeline] {
[Pipeline] withDockerRegistry
$ docker login -u dockerbuildbot -p ******** https://index.docker.io/v1/
WARNING! Using --password via the CLI is insecure. Use --password-stdin.
WARNING! Your password will be stored unencrypted in /home/ubuntu/workspace/docker-py_PR-2959@tmp/6b134ffb-98ae-44cb-846e-1b547814f627/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store

Login Succeeded
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] echo
09:08:54 cleanWorkspace: Ensuring workspace is owned by ubuntu
[Pipeline] echo
09:08:54 chowning workspace
[Pipeline] sh
09:08:54 + pwd
09:08:54 + id -u
09:08:54 + id -g
09:08:54 + docker run --rm -v /home/ubuntu/workspace/docker-py_PR-2959:/workspace busybox chown -R 1000:1000 /workspace
[Pipeline] echo
09:08:54 Removing all docker containers
[Pipeline] sh
09:08:55 + docker container ls -aq
[Pipeline] echo
09:08:55 Docker containers have been removed
[Pipeline] echo
09:08:55 cleanWorkspace: Removing existing workspace
[Pipeline] deleteDir
[Pipeline] echo
09:08:55 cleanWorkspace: Workspace is clean.
[Pipeline] stage
[Pipeline] { (build image)
[Pipeline] checkout
09:08:55 The recommended git tool is: git
09:08:55 using credential docker-jenkins-github-credentials
09:08:55 Cloning the remote Git repository
09:08:55 Cloning with configured refspecs honoured and without tags
09:08:56 Fetching without tags
09:08:56 Merging remotes/origin/master commit a48a5a9647761406d66e8271f19fab7fa0c5f582 into PR head commit b6deb149ce8ba3fc6638315c15a4f71bc424434b
Cloning repository https://github.com/docker/docker-py.git
 > git init /home/ubuntu/workspace/docker-py_PR-2959 # timeout=10
Fetching upstream changes from https://github.com/docker/docker-py.git
 > git --version # timeout=10
 > git --version # 'git version 2.25.1'
using GIT_ASKPASS to set credentials docker-jenkins GitHub credentials
 > git fetch --no-tags --force --progress -- https://github.com/docker/docker-py.git +refs/pull/2959/head:refs/remotes/origin/PR-2959 +refs/heads/master:refs/remotes/origin/master # timeout=10
 > git config remote.origin.url https://github.com/docker/docker-py.git # timeout=10
 > git config --add remote.origin.fetch +refs/pull/2959/head:refs/remotes/origin/PR-2959 # timeout=10
 > git config --add remote.origin.fetch +refs/heads/master:refs/remotes/origin/master # timeout=10
 > git config remote.origin.url https://github.com/docker/docker-py.git # timeout=10
Fetching upstream changes from https://github.com/docker/docker-py.git
using GIT_ASKPASS to set credentials docker-jenkins GitHub credentials
 > git fetch --no-tags --force --progress -- https://github.com/docker/docker-py.git +refs/pull/2959/head:refs/remotes/origin/PR-2959 +refs/heads/master:refs/remotes/origin/master # timeout=10
 > git config core.sparsecheckout # timeout=10
 > git checkout -f b6deb149ce8ba3fc6638315c15a4f71bc424434b # timeout=10
09:08:56 Merge succeeded, producing b6deb149ce8ba3fc6638315c15a4f71bc424434b
09:08:56 Checking out Revision b6deb149ce8ba3fc6638315c15a4f71bc424434b (PR-2959)
09:08:56 Commit message: "Added timeout to container.remove()"
09:08:56 First time build. Skipping changelog.
[Pipeline] sh
09:08:57 + git rev-parse HEAD
[Pipeline] withDockerRegistry
[Pipeline] {
 > git remote # timeout=10
 > git config --get remote.origin.url # timeout=10
using GIT_ASKPASS to set credentials docker-jenkins GitHub credentials
 > git merge a48a5a9647761406d66e8271f19fab7fa0c5f582 # timeout=10
 > git rev-parse HEAD^{commit} # timeout=10
 > git config core.sparsecheckout # timeout=10
 > git checkout -f b6deb149ce8ba3fc6638315c15a4f71bc424434b # timeout=10
 > git rev-list --no-walk 4da0542615d9ee1a0d6a4453f1367bceadb80862 # timeout=10
[Pipeline] isUnix
[Pipeline] sh
$ docker login -u dockerbuildbot -p ******** https://index.docker.io/v1/
WARNING! Using --password via the CLI is insecure. Use --password-stdin.
WARNING! Your password will be stored unencrypted in /home/ubuntu/workspace/docker-py_PR-2959@tmp/85625c0b-e382-4786-8f00-af3a35c0e45b/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store

Login Succeeded
09:08:57 + docker pull dockerpinata/docker-py:sshdind-b6deb149ce8ba3fc6638315c15a4f71bc424434b
09:08:57 Error response from daemon: manifest for dockerpinata/docker-py:sshdind-b6deb149ce8ba3fc6638315c15a4f71bc424434b not found: manifest unknown: manifest unknown
[Pipeline] isUnix
[Pipeline] sh
09:08:57 + docker build -t dockerpinata/docker-py:sshdind-b6deb149ce8ba3fc6638315c15a4f71bc424434b -f tests/Dockerfile-ssh-dind .
09:08:57 Sending build context to Docker daemon  1.375MB

09:08:57 Step 1/11 : ARG API_VERSION=1.39
09:08:57 Step 2/11 : ARG ENGINE_VERSION=19.03.12
09:08:57 Step 3/11 : FROM docker:${ENGINE_VERSION}-dind
09:08:57  ---> 66dc2d45749a
09:08:57 Step 4/11 : RUN apk add --no-cache 		openssh
09:08:57  ---> Using cache
09:08:57  ---> 12e585e7b058
09:08:57 Step 5/11 : RUN ssh-keygen -A
09:08:57  ---> Using cache
09:08:57  ---> 350563fadebd
09:08:57 Step 6/11 : RUN echo "IgnoreUserKnownHosts yes" > /etc/ssh/sshd_config &&   echo "PubkeyAuthentication yes" >> /etc/ssh/sshd_config &&   echo "PermitRootLogin yes" >> /etc/ssh/sshd_config
09:08:57  ---> Using cache
09:08:57  ---> 8af3891d0044
09:08:57 Step 7/11 : COPY tests/ssh-keys/authorized_keys /root/.ssh/authorized_keys
09:08:57  ---> Using cache
09:08:57  ---> 6ccc2b0e22c1
09:08:57 Step 8/11 : RUN chmod 600 /root/.ssh/authorized_keys
09:08:57  ---> Using cache
09:08:57  ---> 9ca81158932a
09:08:57 Step 9/11 : RUN echo "root:root" | chpasswd
09:08:57  ---> Using cache
09:08:57  ---> 655e263a43c3
09:08:57 Step 10/11 : RUN ln -s /usr/local/bin/docker /usr/bin/docker
09:08:57  ---> Using cache
09:08:57  ---> e25bf1ba92cd
09:08:57 Step 11/11 : EXPOSE 22
09:08:57  ---> Using cache
09:08:57  ---> 73f1eda909ee
09:08:57 Successfully built 73f1eda909ee
09:08:57 Successfully tagged dockerpinata/docker-py:sshdind-b6deb149ce8ba3fc6638315c15a4f71bc424434b
[Pipeline] isUnix
[Pipeline] sh
09:08:58 + docker tag dockerpinata/docker-py:sshdind-b6deb149ce8ba3fc6638315c15a4f71bc424434b dockerpinata/docker-py:sshdind-b6deb149ce8ba3fc6638315c15a4f71bc424434b
[Pipeline] isUnix
[Pipeline] sh
09:08:58 + docker push dockerpinata/docker-py:sshdind-b6deb149ce8ba3fc6638315c15a4f71bc424434b
09:08:58 The push refers to repository [docker.io/dockerpinata/docker-py]
09:08:58 86bb579f6752: Preparing
09:08:58 82ba5b31cfd4: Preparing
09:08:58 c4568674085a: Preparing
09:08:58 5544d117ad55: Preparing
09:08:58 bb1aaabdb023: Preparing
09:08:58 2851fd223900: Preparing
09:08:58 590de27e411e: Preparing
09:08:58 1149e736aa92: Preparing
09:08:58 39e79983ac8b: Preparing
09:08:58 da8c28465f82: Preparing
09:08:58 d1292e236c36: Preparing
09:08:58 8890c171a12b: Preparing
09:08:58 4ae5bd84d450: Preparing
09:08:58 723a561964c8: Preparing
09:08:58 78764725b56c: Preparing
09:08:58 51d6d3d09136: Preparing
09:08:58 1507bc794612: Preparing
09:08:58 50644c29ef5a: Preparing
09:08:58 2851fd223900: Waiting
09:08:58 590de27e411e: Waiting
09:08:58 1149e736aa92: Waiting
09:08:58 39e79983ac8b: Waiting
09:08:58 da8c28465f82: Waiting
09:08:58 d1292e236c36: Waiting
09:08:58 8890c171a12b: Waiting
09:08:58 4ae5bd84d450: Waiting
09:08:58 723a561964c8: Waiting
09:08:58 78764725b56c: Waiting
09:08:58 51d6d3d09136: Waiting
09:08:58 1507bc794612: Waiting
09:08:58 50644c29ef5a: Waiting
09:08:58 bb1aaabdb023: Layer already exists
09:08:58 c4568674085a: Layer already exists
09:08:58 5544d117ad55: Layer already exists
09:08:58 86bb579f6752: Layer already exists
09:08:58 82ba5b31cfd4: Layer already exists
09:08:58 2851fd223900: Layer already exists
09:08:58 39e79983ac8b: Layer already exists
09:08:58 590de27e411e: Layer already exists
09:08:58 da8c28465f82: Layer already exists
09:08:58 1149e736aa92: Layer already exists
09:08:58 d1292e236c36: Layer already exists
09:08:58 4ae5bd84d450: Layer already exists
09:08:58 723a561964c8: Layer already exists
09:08:58 8890c171a12b: Layer already exists
09:08:58 78764725b56c: Layer already exists
09:08:58 51d6d3d09136: Layer already exists
09:08:58 1507bc794612: Layer already exists
09:08:58 50644c29ef5a: Layer already exists
09:08:58 sshdind-b6deb149ce8ba3fc6638315c15a4f71bc424434b: digest: sha256:c0267dfcdda9054db51ad7a8b4ab64b2d79846e18bf61d63e261c164ffb59c7b size: 4067
[Pipeline] isUnix
[Pipeline] sh
09:08:58 + docker pull dockerpinata/docker-py:py3-b6deb149ce8ba3fc6638315c15a4f71bc424434b
09:08:58 Error response from daemon: manifest for dockerpinata/docker-py:py3-b6deb149ce8ba3fc6638315c15a4f71bc424434b not found: manifest unknown: manifest unknown
[Pipeline] isUnix
[Pipeline] sh
09:08:59 + docker build -t dockerpinata/docker-py:py3-b6deb149ce8ba3fc6638315c15a4f71bc424434b -f tests/Dockerfile --build-arg PYTHON_VERSION=3.7 .
09:08:59 Sending build context to Docker daemon  1.375MB

09:08:59 Step 1/21 : ARG PYTHON_VERSION=3.7
09:08:59 Step 2/21 : FROM python:${PYTHON_VERSION}
09:08:59  ---> 6bcd1cc24497
09:08:59 Step 3/21 : ARG APT_MIRROR
09:08:59  ---> Using cache
09:08:59  ---> 2de474830c97
09:08:59 Step 4/21 : RUN sed -ri "s/(httpredir|deb).debian.org/${APT_MIRROR:-deb.debian.org}/g" /etc/apt/sources.list     && sed -ri "s/(security).debian.org/${APT_MIRROR:-security.debian.org}/g" /etc/apt/sources.list
09:08:59  ---> Using cache
09:08:59  ---> ac4cdf29439a
09:08:59 Step 5/21 : RUN apt-get update && apt-get -y install --no-install-recommends     gnupg2     pass
09:08:59  ---> Using cache
09:08:59  ---> d8520bbf2e38
09:08:59 Step 6/21 : COPY tests/ssh-keys /root/.ssh
09:08:59  ---> Using cache
09:08:59  ---> a22df8619a8c
09:08:59 Step 7/21 : RUN chmod -R 600 /root/.ssh
09:08:59  ---> Using cache
09:08:59  ---> 66fb6c9c1812
09:08:59 Step 8/21 : COPY ./tests/gpg-keys /gpg-keys
09:08:59  ---> Using cache
09:08:59  ---> e43a5831c510
09:08:59 Step 9/21 : RUN gpg2 --import gpg-keys/secret
09:08:59  ---> Using cache
09:08:59  ---> 3a62ee7d63ed
09:08:59 Step 10/21 : RUN gpg2 --import-ownertrust gpg-keys/ownertrust
09:08:59  ---> Using cache
09:08:59  ---> 5d239e87aef4
09:08:59 Step 11/21 : RUN yes | pass init $(gpg2 --no-auto-check-trustdb --list-secret-key | awk '/^sec/{getline; $1=$1; print}')
09:08:59  ---> Using cache
09:08:59  ---> cde572e6819a
09:08:59 Step 12/21 : RUN gpg2 --check-trustdb
09:08:59  ---> Using cache
09:08:59  ---> 6dd225e1b15c
09:08:59 Step 13/21 : ARG CREDSTORE_VERSION=v0.6.3
09:08:59  ---> Using cache
09:08:59  ---> 93ba15db9ebd
09:08:59 Step 14/21 : RUN curl -sSL -o /opt/docker-credential-pass.tar.gz     https://github.com/docker/docker-credential-helpers/releases/download/$CREDSTORE_VERSION/docker-credential-pass-$CREDSTORE_VERSION-amd64.tar.gz &&     tar -xf /opt/docker-credential-pass.tar.gz -O > /usr/local/bin/docker-credential-pass &&     rm -rf /opt/docker-credential-pass.tar.gz &&     chmod +x /usr/local/bin/docker-credential-pass
09:08:59  ---> Using cache
09:08:59  ---> a384aee4cd80
09:08:59 Step 15/21 : WORKDIR /src
09:08:59  ---> Using cache
09:08:59  ---> 48b1610e24a3
09:08:59 Step 16/21 : COPY requirements.txt /src/requirements.txt
09:08:59  ---> Using cache
09:08:59  ---> 2763a91f67eb
09:08:59 Step 17/21 : RUN pip install -r requirements.txt
09:08:59  ---> Using cache
09:08:59  ---> b509f5cf18fc
09:08:59 Step 18/21 : COPY test-requirements.txt /src/test-requirements.txt
09:08:59  ---> Using cache
09:08:59  ---> f7e70a3b3b6e
09:08:59 Step 19/21 : RUN pip install -r test-requirements.txt
09:08:59  ---> Using cache
09:08:59  ---> f0cb3bdb9ee5
09:08:59 Step 20/21 : COPY . /src
09:08:59  ---> d88964906b45
09:08:59 Step 21/21 : RUN pip install .
09:08:59  ---> Running in ebe9083aa117
09:09:00 Processing /src
09:09:00   DEPRECATION: A future pip version will change local packages to be built in-place without first copying to a temporary directory. We recommend you use --use-feature=in-tree-build to test your packages with this new behavior before it becomes the default.
09:09:00    pip 21.3 will remove support for this functionality. You can find discussion regarding this at https://github.com/pypa/pip/issues/7555.
09:09:00 Requirement already satisfied: websocket-client>=0.32.0 in /usr/local/lib/python3.7/site-packages (from docker==5.1.0.dev0) (0.56.0)
09:09:00 Requirement already satisfied: requests!=2.18.0,>=2.14.2 in /usr/local/lib/python3.7/site-packages (from docker==5.1.0.dev0) (2.26.0)
09:09:00 Requirement already satisfied: idna<4,>=2.5 in /usr/local/lib/python3.7/site-packages (from requests!=2.18.0,>=2.14.2->docker==5.1.0.dev0) (2.5)
09:09:00 Requirement already satisfied: charset-normalizer~=2.0.0 in /usr/local/lib/python3.7/site-packages (from requests!=2.18.0,>=2.14.2->docker==5.1.0.dev0) (2.0.12)
09:09:00 Requirement already satisfied: urllib3<1.27,>=1.21.1 in /usr/local/lib/python3.7/site-packages (from requests!=2.18.0,>=2.14.2->docker==5.1.0.dev0) (1.26.5)
09:09:00 Requirement already satisfied: certifi>=2017.4.17 in /usr/local/lib/python3.7/site-packages (from requests!=2.18.0,>=2.14.2->docker==5.1.0.dev0) (2021.10.8)
09:09:00 Requirement already satisfied: six in /usr/local/lib/python3.7/site-packages (from websocket-client>=0.32.0->docker==5.1.0.dev0) (1.16.0)
09:09:00 Building wheels for collected packages: docker
09:09:00   Building wheel for docker (setup.py): started
09:09:00   Building wheel for docker (setup.py): finished with status 'done'
09:09:00   Created wheel for docker: filename=docker-5.1.0.dev0-py3-none-any.whl size=146357 sha256=01b4532f44268483be677153bb6822daa253f1e607f3e33713581d4dc7b056f1
09:09:00   Stored in directory: /tmp/pip-ephem-wheel-cache-aw8rlbs5/wheels/6f/63/19/359cf44f647b75d0ea75ecc03aa429fec4c372b453eb4b6525
09:09:00 Successfully built docker
09:09:00 Installing collected packages: docker
09:09:00 Successfully installed docker-5.1.0.dev0
09:09:00 WARNING: Running pip as the 'root' user can result in broken permissions and conflicting behaviour with the system package manager. It is recommended to use a virtual environment instead: https://pip.pypa.io/warnings/venv
09:09:00 WARNING: You are using pip version 21.2.4; however, version 22.0.3 is available.
09:09:00 You should consider upgrading via the '/usr/local/bin/python -m pip install --upgrade pip' command.
09:09:01 Removing intermediate container ebe9083aa117
09:09:01  ---> 7405e6d21ece
09:09:01 Successfully built 7405e6d21ece
09:09:01 Successfully tagged dockerpinata/docker-py:py3-b6deb149ce8ba3fc6638315c15a4f71bc424434b
[Pipeline] isUnix
[Pipeline] sh
09:09:01 + docker tag dockerpinata/docker-py:py3-b6deb149ce8ba3fc6638315c15a4f71bc424434b dockerpinata/docker-py:py3-b6deb149ce8ba3fc6638315c15a4f71bc424434b
[Pipeline] isUnix
[Pipeline] sh
09:09:02 + docker push dockerpinata/docker-py:py3-b6deb149ce8ba3fc6638315c15a4f71bc424434b
09:09:02 The push refers to repository [docker.io/dockerpinata/docker-py]
09:09:02 1e135a3c48c0: Preparing
09:09:02 5ce7d4700bb1: Preparing
09:09:02 524b138d080e: Preparing
09:09:02 b7a9492e68cb: Preparing
09:09:02 948a6544a554: Preparing
09:09:02 193ab1275ae4: Preparing
09:09:02 2fa212772c5d: Preparing
09:09:02 bf09c78f505c: Preparing
09:09:02 bce6b04d8bea: Preparing
09:09:02 44ee81a835ba: Preparing
09:09:02 07ca1f6b4018: Preparing
09:09:02 f58c39ffe925: Preparing
09:09:02 9d20ae4f45f4: Preparing
09:09:02 b6e388df8091: Preparing
09:09:02 1f29f3ac97d1: Preparing
09:09:02 f0c717faa2a8: Preparing
09:09:02 a98bf7e4c00c: Preparing
09:09:02 91861565d249: Preparing
09:09:02 13b05b508dcf: Preparing
09:09:02 1e3c20347499: Preparing
09:09:02 a3232401de62: Preparing
09:09:02 204e42b3d47b: Preparing
09:09:02 613ab28cf833: Preparing
09:09:02 bed676ceab7a: Preparing
09:09:02 6398d5cccd2c: Preparing
09:09:02 0b0f2f2f5279: Preparing
09:09:02 07ca1f6b4018: Waiting
09:09:02 f58c39ffe925: Waiting
09:09:02 9d20ae4f45f4: Waiting
09:09:02 b6e388df8091: Waiting
09:09:02 1f29f3ac97d1: Waiting
09:09:02 f0c717faa2a8: Waiting
09:09:02 a98bf7e4c00c: Waiting
09:09:02 91861565d249: Waiting
09:09:02 13b05b508dcf: Waiting
09:09:02 193ab1275ae4: Waiting
09:09:02 2fa212772c5d: Waiting
09:09:02 bf09c78f505c: Waiting
09:09:02 bce6b04d8bea: Waiting
09:09:02 44ee81a835ba: Waiting
09:09:02 1e3c20347499: Waiting
09:09:02 a3232401de62: Waiting
09:09:02 204e42b3d47b: Waiting
09:09:02 613ab28cf833: Waiting
09:09:02 bed676ceab7a: Waiting
09:09:02 6398d5cccd2c: Waiting
09:09:02 0b0f2f2f5279: Waiting
09:09:02 948a6544a554: Layer already exists
09:09:02 524b138d080e: Layer already exists
09:09:02 b7a9492e68cb: Layer already exists
09:09:02 2fa212772c5d: Layer already exists
09:09:02 bf09c78f505c: Layer already exists
09:09:02 bce6b04d8bea: Layer already exists
09:09:02 193ab1275ae4: Layer already exists
09:09:02 44ee81a835ba: Layer already exists
09:09:02 07ca1f6b4018: Layer already exists
09:09:02 f58c39ffe925: Layer already exists
09:09:02 9d20ae4f45f4: Layer already exists
09:09:02 b6e388df8091: Layer already exists
09:09:02 1f29f3ac97d1: Layer already exists
09:09:02 f0c717faa2a8: Layer already exists
09:09:02 a98bf7e4c00c: Layer already exists
09:09:02 91861565d249: Layer already exists
09:09:02 13b05b508dcf: Layer already exists
09:09:02 1e3c20347499: Layer already exists
09:09:02 a3232401de62: Layer already exists
09:09:02 204e42b3d47b: Layer already exists
09:09:02 bed676ceab7a: Layer already exists
09:09:02 6398d5cccd2c: Layer already exists
09:09:02 613ab28cf833: Layer already exists
09:09:02 0b0f2f2f5279: Layer already exists
09:09:03 1e135a3c48c0: Pushed
09:09:03 5ce7d4700bb1: Pushed
09:09:04 py3-b6deb149ce8ba3fc6638315c15a4f71bc424434b: digest: sha256:d15a9a0ef81a6314e15d310657ba593dd9e3da4e7e36d4721e461c49096ae0ac size: 5766
[Pipeline] }
[Pipeline] // withDockerRegistry
[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // withDockerRegistry
[Pipeline] }
[Pipeline] // node
[Pipeline] node
Running on EC2 (managed-agents) - ubuntu-2004-cgroup1 (i-038677a38b0431f65) in /home/ubuntu/workspace/docker-py_PR-2959
[Pipeline] {
[Pipeline] withDockerRegistry
$ docker login -u dockerbuildbot -p ******** https://index.docker.io/v1/
WARNING! Using --password via the CLI is insecure. Use --password-stdin.
WARNING! Your password will be stored unencrypted in /home/ubuntu/workspace/docker-py_PR-2959@tmp/9bb786ee-c77e-4a22-92b1-f2cc30d52a4a/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store

Login Succeeded
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] sh
09:09:11 + docker run --rm --entrypoint=python dockerpinata/docker-py:py3-b6deb149ce8ba3fc6638315c15a4f71bc424434b /src/scripts/versions.py
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // withDockerRegistry
[Pipeline] }
[Pipeline] // node
[Pipeline] parallel
[Pipeline] { (Branch: py3.7_19.03.12)
[Pipeline] { (Branch: py3.7_19.03.13)
[Pipeline] { (Branch: py3.7_20.10.12)
[Pipeline] node
[Pipeline] node
Running on EC2 (managed-agents) - ubuntu-2004-cgroup1 (i-038677a38b0431f65) in /home/ubuntu/workspace/docker-py_PR-2959
[Pipeline] node
[Pipeline] {
[Pipeline] withDockerRegistry
$ docker login -u dockerbuildbot -p ******** https://index.docker.io/v1/
WARNING! Using --password via the CLI is insecure. Use --password-stdin.
WARNING! Your password will be stored unencrypted in /home/ubuntu/workspace/docker-py_PR-2959@tmp/6123b866-cc11-48dc-9fc8-3431fcf84c8e/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store

Login Succeeded
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] echo
09:09:38 cleanWorkspace: Ensuring workspace is owned by ubuntu
[Pipeline] echo
09:09:38 chowning workspace
[Pipeline] sh
09:09:38 + pwd
09:09:38 + id -u
09:09:38 + id -g
09:09:38 + docker run --rm -v /home/ubuntu/workspace/docker-py_PR-2959:/workspace busybox chown -R 1000:1000 /workspace
[Pipeline] echo
09:09:39 Removing all docker containers
[Pipeline] sh
09:09:39 + docker container ls -aq
[Pipeline] echo
09:09:39 Docker containers have been removed
[Pipeline] echo
09:09:39 cleanWorkspace: Removing existing workspace
[Pipeline] deleteDir
[Pipeline] echo
09:09:39 cleanWorkspace: Workspace is clean.
[Pipeline] stage
[Pipeline] { (test python=py3.7 / docker=19.03.12)
[Pipeline] checkout
09:09:39 The recommended git tool is: git
09:09:39 using credential docker-jenkins-github-credentials
09:09:39 Cloning the remote Git repository
09:09:39 Cloning with configured refspecs honoured and without tags
09:09:40 Fetching without tags
09:09:40 Merging remotes/origin/master commit a48a5a9647761406d66e8271f19fab7fa0c5f582 into PR head commit b6deb149ce8ba3fc6638315c15a4f71bc424434b
09:09:40 Merge succeeded, producing b6deb149ce8ba3fc6638315c15a4f71bc424434b
09:09:40 Checking out Revision b6deb149ce8ba3fc6638315c15a4f71bc424434b (PR-2959)
Cloning repository https://github.com/docker/docker-py.git
 > git init /home/ubuntu/workspace/docker-py_PR-2959 # timeout=10
Fetching upstream changes from https://github.com/docker/docker-py.git
 > git --version # timeout=10
 > git --version # 'git version 2.25.1'
using GIT_ASKPASS to set credentials docker-jenkins GitHub credentials
 > git fetch --no-tags --force --progress -- https://github.com/docker/docker-py.git +refs/pull/2959/head:refs/remotes/origin/PR-2959 +refs/heads/master:refs/remotes/origin/master # timeout=10
 > git config remote.origin.url https://github.com/docker/docker-py.git # timeout=10
 > git config --add remote.origin.fetch +refs/pull/2959/head:refs/remotes/origin/PR-2959 # timeout=10
 > git config --add remote.origin.fetch +refs/heads/master:refs/remotes/origin/master # timeout=10
 > git config remote.origin.url https://github.com/docker/docker-py.git # timeout=10
Fetching upstream changes from https://github.com/docker/docker-py.git
using GIT_ASKPASS to set credentials docker-jenkins GitHub credentials
 > git fetch --no-tags --force --progress -- https://github.com/docker/docker-py.git +refs/pull/2959/head:refs/remotes/origin/PR-2959 +refs/heads/master:refs/remotes/origin/master # timeout=10
 > git config core.sparsecheckout # timeout=10
 > git checkout -f b6deb149ce8ba3fc6638315c15a4f71bc424434b # timeout=10
 > git remote # timeout=10
 > git config --get remote.origin.url # timeout=10
using GIT_ASKPASS to set credentials docker-jenkins GitHub credentials
 > git merge a48a5a9647761406d66e8271f19fab7fa0c5f582 # timeout=10
 > git rev-parse HEAD^{commit} # timeout=10
 > git config core.sparsecheckout # timeout=10
09:09:40 Commit message: "Added timeout to container.remove()"
[Pipeline] withDockerRegistry
[Pipeline] {
[Pipeline] sh
09:09:41 + docker run --rm -e DOCKER_TEST_API_VERSION=1.40 dockerpinata/docker-py:py3-b6deb149ce8ba3fc6638315c15a4f71bc424434b py.test -v -rxs --cov=docker tests/unit
 > git checkout -f b6deb149ce8ba3fc6638315c15a4f71bc424434b # timeout=10
09:09:42 ============================= test session starts ==============================
09:09:42 platform linux -- Python 3.7.12, pytest-6.2.5, py-1.11.0, pluggy-1.0.0 -- /usr/local/bin/python
09:09:42 cachedir: .pytest_cache
09:09:42 rootdir: /src, configfile: pytest.ini
09:09:42 plugins: timeout-2.0.1, cov-3.0.0
$ docker login -u dockerbuildbot -p ******** https://index.docker.io/v1/
WARNING! Using --password via the CLI is insecure. Use --password-stdin.
WARNING! Your password will be stored unencrypted in /home/ubuntu/workspace/docker-py_PR-2959@tmp/e71410fc-b22e-4503-8753-57d0a32d8db4/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store

Login Succeeded
09:09:43 collecting ... collected 571 items
09:09:43 
09:09:43 tests/unit/api_build_test.py::BuildTest::test_build_container PASSED     [  0%]
09:09:43 tests/unit/api_build_test.py::BuildTest::test_build_container_custom_context PASSED [  0%]
09:09:43 tests/unit/api_build_test.py::BuildTest::test_build_container_custom_context_gzip PASSED [  0%]
09:09:43 tests/unit/api_build_test.py::BuildTest::test_build_container_invalid_container_limits PASSED [  0%]
09:09:43 tests/unit/api_build_test.py::BuildTest::test_build_container_pull PASSED [  0%]
09:09:43 tests/unit/api_build_test.py::BuildTest::test_build_container_with_container_limits PASSED [  1%]
09:09:43 tests/unit/api_build_test.py::BuildTest::test_build_container_with_named_dockerfile PASSED [  1%]
09:09:43 tests/unit/api_build_test.py::BuildTest::test_build_remote_with_registry_auth PASSED [  1%]
09:09:43 tests/unit/api_build_test.py::BuildTest::test_process_dockerfile PASSED  [  1%]
09:09:43 tests/unit/api_build_test.py::BuildTest::test_process_dockerfile_win_longpath_prefix SKIPPED [  1%]
09:09:43 tests/unit/api_build_test.py::BuildTest::test_set_auth_headers_with_dict_and_auth_configs PASSED [  1%]
09:09:43 tests/unit/api_build_test.py::BuildTest::test_set_auth_headers_with_dict_and_no_auth_configs PASSED [  2%]
09:09:43 tests/unit/api_build_test.py::BuildTest::test_set_auth_headers_with_empty_dict_and_auth_configs PASSED [  2%]
09:09:43 tests/unit/api_container_test.py::StartContainerTest::test_start_container PASSED [  2%]
09:09:43 tests/unit/api_container_test.py::StartContainerTest::test_start_container_none PASSED [  2%]
09:09:43 tests/unit/api_container_test.py::StartContainerTest::test_start_container_privileged PASSED [  2%]
09:09:43 tests/unit/api_container_test.py::StartContainerTest::test_start_container_regression_573 PASSED [  2%]
09:09:43 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_binds_ro PASSED [  3%]
09:09:43 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_binds_rw PASSED [  3%]
09:09:43 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_dict_instead_of_id PASSED [  3%]
09:09:43 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_links PASSED [  3%]
09:09:43 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_links_as_list_of_tuples PASSED [  3%]
09:09:43 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_lxc_conf PASSED [  4%]
09:09:43 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_lxc_conf_compat PASSED [  4%]
09:09:43 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_multiple_links PASSED [  4%]
09:09:43 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_port_binds PASSED [  4%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container PASSED [  4%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_privileged PASSED [  4%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_added_capabilities PASSED [  5%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_aliases PASSED [  5%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds PASSED [  5%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_list PASSED [  5%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_mode PASSED [  5%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_mode_and_ro_error PASSED [  5%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_ro PASSED [  6%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_rw PASSED [  6%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_cgroup_parent PASSED [  6%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_device_requests PASSED [  6%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_devices PASSED [  6%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_dropped_capabilities PASSED [  7%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_entrypoint PASSED [  7%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_host_config_cpu_shares PASSED [  7%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_host_config_cpus PASSED [  7%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_host_config_cpuset PASSED [  7%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_host_config_cpuset_mems PASSED [  7%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_labels_dict PASSED [  8%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_labels_list PASSED [  8%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_links PASSED [  8%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_links_as_list_of_tuples PASSED [  8%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_lxc_conf PASSED [  8%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_lxc_conf_compat PASSED [  8%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mac_address PASSED [  9%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_int PASSED [  9%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string PASSED [  9%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string_with_g_unit PASSED [  9%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string_with_k_unit PASSED [  9%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string_with_m_unit PASSED [  9%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string_with_wrong_value PASSED [ 10%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_multiple_links PASSED [ 10%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_named_volume PASSED [ 10%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_port_binds PASSED [ 10%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_ports PASSED [ 10%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_restart_policy PASSED [ 11%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_stdin_open PASSED [ 11%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_stop_signal PASSED [ 11%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_sysctl PASSED [ 11%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_tmpfs_dict PASSED [ 11%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_tmpfs_list PASSED [ 11%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_unicode_envvars PASSED [ 12%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_volume_string PASSED [ 12%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_working_dir PASSED [ 12%]
09:09:43 tests/unit/api_container_test.py::CreateContainerTest::test_create_named_container PASSED [ 12%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_container_stats PASSED [ 12%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_container_top PASSED [ 12%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_container_top_with_psargs PASSED [ 13%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_container_update PASSED [ 13%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_diff PASSED        [ 13%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_diff_with_dict_instead_of_id PASSED [ 13%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_export PASSED      [ 13%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_export_with_dict_instead_of_id PASSED [ 14%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_inspect_container PASSED [ 14%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_inspect_container_undefined_id PASSED [ 14%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_kill_container PASSED [ 14%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_kill_container_with_dict_instead_of_id PASSED [ 14%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_kill_container_with_signal PASSED [ 14%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_list_containers PASSED [ 15%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_log_following PASSED [ 15%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_log_following_backwards PASSED [ 15%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_log_since PASSED   [ 15%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_log_since_with_datetime PASSED [ 15%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_log_since_with_invalid_value_raises_error PASSED [ 15%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_log_streaming PASSED [ 16%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_log_streaming_and_following PASSED [ 16%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_log_tail PASSED    [ 16%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_log_tty PASSED     [ 16%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_logs PASSED        [ 16%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_logs_with_dict_instead_of_id PASSED [ 16%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_pause_container PASSED [ 17%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_port PASSED        [ 17%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_remove_container FAILED [ 17%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_remove_container_with_dict_instead_of_id FAILED [ 17%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_rename_container PASSED [ 17%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_resize_container PASSED [ 18%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_restart_container PASSED [ 18%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_restart_container_with_dict_instead_of_id PASSED [ 18%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_stop_container PASSED [ 18%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_stop_container_with_dict_instead_of_id PASSED [ 18%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_unpause_container PASSED [ 18%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_wait PASSED        [ 19%]
09:09:43 tests/unit/api_container_test.py::ContainerTest::test_wait_with_dict_instead_of_id PASSED [ 19%]
09:09:43 tests/unit/api_exec_test.py::ExecTest::test_exec_create PASSED           [ 19%]
09:09:43 tests/unit/api_exec_test.py::ExecTest::test_exec_inspect PASSED          [ 19%]
09:09:43 tests/unit/api_exec_test.py::ExecTest::test_exec_resize PASSED           [ 19%]
09:09:43 tests/unit/api_exec_test.py::ExecTest::test_exec_start PASSED            [ 19%]
09:09:44 tests/unit/api_exec_test.py::ExecTest::test_exec_start_detached PASSED   [ 20%]
09:09:44 tests/unit/api_image_test.py::ImageTest::test_commit PASSED              [ 20%]
09:09:44 tests/unit/api_image_test.py::ImageTest::test_get_image PASSED           [ 20%]
09:09:44 tests/unit/api_image_test.py::ImageTest::test_image_history PASSED       [ 20%]
09:09:44 tests/unit/api_image_test.py::ImageTest::test_image_ids PASSED           [ 20%]
09:09:44 tests/unit/api_image_test.py::ImageTest::test_image_viz PASSED           [ 21%]
09:09:44 tests/unit/api_image_test.py::ImageTest::test_images PASSED              [ 21%]
09:09:44 tests/unit/api_image_test.py::ImageTest::test_images_filters PASSED      [ 21%]
09:09:44 tests/unit/api_image_test.py::ImageTest::test_images_name PASSED         [ 21%]
09:09:44 tests/unit/api_image_test.py::ImageTest::test_images_quiet PASSED        [ 21%]
09:09:44 tests/unit/api_image_test.py::ImageTest::test_import_image PASSED        [ 21%]
09:09:44 tests/unit/api_image_test.py::ImageTest::test_import_image_from_bytes PASSED [ 22%]
09:09:44 tests/unit/api_image_test.py::ImageTest::test_import_image_from_image PASSED [ 22%]
09:09:44 tests/unit/api_image_test.py::ImageTest::test_inspect_image PASSED       [ 22%]
09:09:44 tests/unit/api_image_test.py::ImageTest::test_inspect_image_undefined_id PASSED [ 22%]
09:09:44 tests/unit/api_image_test.py::ImageTest::test_load_image PASSED          [ 22%]
09:09:44 tests/unit/api_image_test.py::ImageTest::test_load_image_quiet PASSED    [ 22%]
09:09:44 tests/unit/api_image_test.py::ImageTest::test_pull PASSED                [ 23%]
09:09:44 tests/unit/api_image_test.py::ImageTest::test_pull_stream PASSED         [ 23%]
09:09:44 tests/unit/api_image_test.py::ImageTest::test_push_image PASSED          [ 23%]
09:09:44 tests/unit/api_image_test.py::ImageTest::test_push_image_stream PASSED   [ 23%]
09:09:44 tests/unit/api_image_test.py::ImageTest::test_push_image_with_auth PASSED [ 23%]
09:09:44 tests/unit/api_image_test.py::ImageTest::test_push_image_with_tag PASSED [ 23%]
09:09:44 tests/unit/api_image_test.py::ImageTest::test_remove_image PASSED        [ 24%]
09:09:44 tests/unit/api_image_test.py::ImageTest::test_tag_image PASSED           [ 24%]
09:09:44 tests/unit/api_image_test.py::ImageTest::test_tag_image_force PASSED     [ 24%]
09:09:44 tests/unit/api_image_test.py::ImageTest::test_tag_image_tag PASSED       [ 24%]
09:09:44 tests/unit/api_network_test.py::NetworkTest::test_connect_container_to_network PASSED [ 24%]
09:09:44 tests/unit/api_network_test.py::NetworkTest::test_create_network PASSED  [ 25%]
09:09:44 tests/unit/api_network_test.py::NetworkTest::test_disconnect_container_from_network PASSED [ 25%]
09:09:44 tests/unit/api_network_test.py::NetworkTest::test_inspect_network PASSED [ 25%]
09:09:44 tests/unit/api_network_test.py::NetworkTest::test_list_networks PASSED   [ 25%]
09:09:44 tests/unit/api_network_test.py::NetworkTest::test_remove_network PASSED  [ 25%]
09:09:44 tests/unit/api_test.py::DockerApiTest::test_auto_retrieve_server_version PASSED [ 25%]
09:09:44 tests/unit/api_test.py::DockerApiTest::test_create_host_config_secopt PASSED [ 26%]
09:09:44 tests/unit/api_test.py::DockerApiTest::test_ctor PASSED                  [ 26%]
09:09:44 tests/unit/api_test.py::DockerApiTest::test_events PASSED                [ 26%]
09:09:44 tests/unit/api_test.py::DockerApiTest::test_events_with_filters PASSED   [ 26%]
09:09:44 tests/unit/api_test.py::DockerApiTest::test_events_with_since_until PASSED [ 26%]
09:09:44 tests/unit/api_test.py::DockerApiTest::test_info PASSED                  [ 26%]
09:09:44 tests/unit/api_test.py::DockerApiTest::test_login PASSED                 [ 27%]
09:09:44 tests/unit/api_test.py::DockerApiTest::test_remove_link FAILED           [ 27%]
09:09:44 tests/unit/api_test.py::DockerApiTest::test_retrieve_server_version PASSED [ 27%]
09:09:44 tests/unit/api_test.py::DockerApiTest::test_search PASSED                [ 27%]
09:09:44 tests/unit/api_test.py::DockerApiTest::test_stream_helper_decoding PASSED [ 27%]
09:09:44 tests/unit/api_test.py::DockerApiTest::test_url_compatibility_http PASSED [ 28%]
09:09:44 tests/unit/api_test.py::DockerApiTest::test_url_compatibility_http_unix_triple_slash PASSED [ 28%]
09:09:44 tests/unit/api_test.py::DockerApiTest::test_url_compatibility_tcp PASSED [ 28%]
09:09:44 tests/unit/api_test.py::DockerApiTest::test_url_compatibility_unix PASSED [ 28%]
09:09:44 tests/unit/api_test.py::DockerApiTest::test_url_compatibility_unix_triple_slash PASSED [ 28%]
09:09:44 tests/unit/api_test.py::DockerApiTest::test_url_invalid_resource PASSED  [ 28%]
09:09:44 tests/unit/api_test.py::DockerApiTest::test_url_no_resource PASSED       [ 29%]
09:09:44 tests/unit/api_test.py::DockerApiTest::test_url_unversioned_api PASSED   [ 29%]
09:09:44 tests/unit/api_test.py::DockerApiTest::test_url_valid_resource PASSED    [ 29%]
09:09:44 tests/unit/api_test.py::DockerApiTest::test_version PASSED               [ 29%]
09:09:44 tests/unit/api_test.py::DockerApiTest::test_version_no_api_version PASSED [ 29%]
09:09:44 tests/unit/api_test.py::UnixSocketStreamTest::test_early_stream_response PASSED [ 29%]
09:09:44 tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_stream_no_tty PASSED [ 30%]
09:09:44 tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_stream_no_tty_demux PASSED [ 30%]
09:09:44 tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_stream_tty PASSED [ 30%]
09:09:45 tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_stream_tty_demux PASSED [ 30%]
09:09:45 tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_tty PASSED [ 30%]
09:09:45 tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_tty_demux PASSED [ 30%]
09:09:45 tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_tty PASSED [ 31%]
09:09:46 tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_tty_demux PASSED [ 31%]
09:09:46 tests/unit/api_test.py::UserAgentTest::test_custom_user_agent PASSED     [ 31%]
09:09:46 tests/unit/api_test.py::UserAgentTest::test_default_user_agent PASSED    [ 31%]
09:09:46 tests/unit/api_test.py::DisableSocketTest::test_disable_socket_timeout PASSED [ 31%]
09:09:46 tests/unit/api_test.py::DisableSocketTest::test_disable_socket_timeout2 PASSED [ 32%]
09:09:46 tests/unit/api_test.py::DisableSocketTest::test_disable_socket_timout_non_blocking PASSED [ 32%]
09:09:46 tests/unit/api_volume_test.py::VolumeTest::test_create_volume PASSED     [ 32%]
09:09:46 tests/unit/api_volume_test.py::VolumeTest::test_create_volume_invalid_opts_type PASSED [ 32%]
09:09:46 tests/unit/api_volume_test.py::VolumeTest::test_create_volume_with_driver PASSED [ 32%]
09:09:46 tests/unit/api_volume_test.py::VolumeTest::test_create_volume_with_invalid_labels PASSED [ 32%]
09:09:46 tests/unit/api_volume_test.py::VolumeTest::test_create_volume_with_labels PASSED [ 33%]
09:09:46 tests/unit/api_volume_test.py::VolumeTest::test_create_volume_with_no_specified_name PASSED [ 33%]
09:09:46 tests/unit/api_volume_test.py::VolumeTest::test_inspect_volume PASSED    [ 33%]
09:09:46 tests/unit/api_volume_test.py::VolumeTest::test_list_volumes PASSED      [ 33%]
09:09:46 tests/unit/api_volume_test.py::VolumeTest::test_list_volumes_and_filters PASSED [ 33%]
09:09:46 tests/unit/api_volume_test.py::VolumeTest::test_remove_volume PASSED     [ 33%]
09:09:46 tests/unit/auth_test.py::RegressionTest::test_803_urlsafe_encode PASSED  [ 34%]
09:09:46 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_explicit_hub_index_library_image PASSED [ 34%]
09:09:46 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_explicit_legacy_hub_index_library_image PASSED [ 34%]
09:09:46 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_invalid_index_name PASSED [ 34%]
09:09:46 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_dotted_hub_library_image PASSED [ 34%]
09:09:46 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_hub_image PASSED [ 35%]
09:09:46 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_hub_library_image PASSED [ 35%]
09:09:46 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_localhost PASSED [ 35%]
09:09:46 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_localhost_with_username PASSED [ 35%]
09:09:46 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_no_dots_but_port PASSED [ 35%]
09:09:46 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_no_dots_but_port_and_username PASSED [ 35%]
09:09:46 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_private_registry PASSED [ 36%]
09:09:46 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_private_registry_with_port PASSED [ 36%]
09:09:46 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_private_registry_with_username PASSED [ 36%]
09:09:46 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_auth_with_empty_credstore_and_auth_dict PASSED [ 36%]
09:09:46 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_default_explicit_none PASSED [ 36%]
09:09:46 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_default_registry PASSED [ 36%]
09:09:46 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_fully_explicit PASSED [ 37%]
09:09:46 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_hostname_only PASSED [ 37%]
09:09:46 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_legacy_config PASSED [ 37%]
09:09:46 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_match PASSED [ 37%]
09:09:46 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_path PASSED [ 37%]
09:09:46 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_path_trailing_slash PASSED [ 38%]
09:09:46 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_path_wrong_insecure_proto PASSED [ 38%]
09:09:46 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_path_wrong_secure_proto PASSED [ 38%]
09:09:46 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_protocol PASSED [ 38%]
09:09:46 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_path_wrong_proto PASSED [ 38%]
09:09:46 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_explicit_hub PASSED [ 38%]
09:09:46 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_explicit_legacy_hub PASSED [ 39%]
09:09:46 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_hub_image PASSED [ 39%]
09:09:46 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_library_image PASSED [ 39%]
09:09:46 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_private_registry PASSED [ 39%]
09:09:46 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_unauthenticated_registry PASSED [ 39%]
09:09:46 tests/unit/auth_test.py::LoadConfigTest::test_load_config_custom_config_env PASSED [ 39%]
09:09:46 tests/unit/auth_test.py::LoadConfigTest::test_load_config_custom_config_env_utf8 PASSED [ 40%]
09:09:46 tests/unit/auth_test.py::LoadConfigTest::test_load_config_custom_config_env_with_auths PASSED [ 40%]
09:09:46 tests/unit/auth_test.py::LoadConfigTest::test_load_config_identity_token PASSED [ 40%]
09:09:46 tests/unit/auth_test.py::LoadConfigTest::test_load_config_invalid_auth_dict PASSED [ 40%]
09:09:46 tests/unit/auth_test.py::LoadConfigTest::test_load_config_no_file PASSED [ 40%]
09:09:46 tests/unit/auth_test.py::LoadConfigTest::test_load_config_unknown_keys PASSED [ 40%]
09:09:46 tests/unit/auth_test.py::LoadConfigTest::test_load_config_with_random_name PASSED [ 41%]
09:09:46 tests/unit/auth_test.py::LoadConfigTest::test_load_json_config PASSED    [ 41%]
09:09:46 tests/unit/auth_test.py::LoadConfigTest::test_load_legacy_config PASSED  [ 41%]
09:09:46 tests/unit/auth_test.py::LoadConfigTest::test_load_modern_json_config PASSED [ 41%]
09:09:46 tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_3_sources PASSED [ 41%]
09:09:46 tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_credstore_only PASSED [ 42%]
09:09:46 tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_credstore_overrides_auth_entry PASSED [ 42%]
09:09:46 tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_helpers_override_default PASSED [ 42%]
09:09:46 tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_with_auths_entries PASSED [ 42%]
09:09:46 tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_with_credhelpers_only PASSED [ 42%]
09:09:46 tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_with_empty_auths_entry PASSED [ 42%]
09:09:46 tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_with_empty_credhelper PASSED [ 43%]
09:09:46 tests/unit/auth_test.py::CredstoreTest::test_get_credential_store PASSED [ 43%]
09:09:46 tests/unit/auth_test.py::CredstoreTest::test_get_credential_store_default_index PASSED [ 43%]
09:09:46 tests/unit/auth_test.py::CredstoreTest::test_get_credential_store_no_default PASSED [ 43%]
09:09:46 tests/unit/auth_test.py::CredstoreTest::test_get_credential_store_with_plain_dict PASSED [ 43%]
09:09:46 tests/unit/client_test.py::ClientTest::test_call_api_client_method PASSED [ 43%]
09:09:46 tests/unit/client_test.py::ClientTest::test_call_containers PASSED       [ 44%]
09:09:46 tests/unit/client_test.py::ClientTest::test_default_pool_size_unix PASSED [ 44%]
09:09:46 tests/unit/client_test.py::ClientTest::test_default_pool_size_win SKIPPED [ 44%]
09:09:46 tests/unit/client_test.py::ClientTest::test_events PASSED                [ 44%]
09:09:46 tests/unit/client_test.py::ClientTest::test_info PASSED                  [ 44%]
09:09:46 tests/unit/client_test.py::ClientTest::test_ping PASSED                  [ 45%]
09:09:46 tests/unit/client_test.py::ClientTest::test_pool_size_unix PASSED        [ 45%]
09:09:46 tests/unit/client_test.py::ClientTest::test_pool_size_win SKIPPED (N...) [ 45%]
09:09:46 tests/unit/client_test.py::ClientTest::test_version PASSED               [ 45%]
09:09:46 tests/unit/client_test.py::FromEnvTest::test_default_pool_size_from_env_unix PASSED [ 45%]
09:09:46 tests/unit/client_test.py::FromEnvTest::test_default_pool_size_from_env_win SKIPPED [ 45%]
09:09:46 tests/unit/client_test.py::FromEnvTest::test_from_env PASSED             [ 46%]
09:09:46 tests/unit/client_test.py::FromEnvTest::test_from_env_with_version PASSED [ 46%]
09:09:46 tests/unit/client_test.py::FromEnvTest::test_from_env_without_timeout_uses_default PASSED [ 46%]
09:09:46 tests/unit/client_test.py::FromEnvTest::test_from_env_without_version_uses_default PASSED [ 46%]
09:09:46 tests/unit/client_test.py::FromEnvTest::test_pool_size_from_env_unix PASSED [ 46%]
09:09:46 tests/unit/client_test.py::FromEnvTest::test_pool_size_from_env_win SKIPPED [ 46%]
09:09:46 tests/unit/context_test.py::BaseContextTest::test_context_inspect_without_params PASSED [ 47%]
09:09:46 tests/unit/context_test.py::BaseContextTest::test_default_in_context_list PASSED [ 47%]
09:09:46 tests/unit/context_test.py::BaseContextTest::test_fail_on_default_context_create PASSED [ 47%]
09:09:46 tests/unit/context_test.py::BaseContextTest::test_get_current_context PASSED [ 47%]
09:09:46 tests/unit/context_test.py::BaseContextTest::test_https_host PASSED      [ 47%]
09:09:46 tests/unit/context_test.py::BaseContextTest::test_url_compatibility_on_linux PASSED [ 47%]
09:09:46 tests/unit/context_test.py::BaseContextTest::test_url_compatibility_on_windows SKIPPED [ 48%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_cpu_cfs_types PASSED [ 48%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_cpu_count_types PASSED [ 48%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_cpu_percent_types PASSED [ 48%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_mem_swappiness PASSED [ 48%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_nano_cpus_types PASSED [ 49%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_no_options_newer_api_version PASSED [ 49%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_pid_mode PASSED [ 49%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_blkio_constraints PASSED [ 49%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_count PASSED [ 49%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_percent PASSED [ 49%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_period PASSED [ 50%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_quota PASSED [ 50%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_rt_period PASSED [ 50%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_rt_period_types PASSED [ 50%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_rt_runtime PASSED [ 50%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_dns_opt PASSED [ 50%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_isolation PASSED [ 51%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_kernel_memory PASSED [ 51%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_mem_reservation PASSED [ 51%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_nano_cpus PASSED [ 51%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_oom_kill_disable PASSED [ 51%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_oom_score_adj PASSED [ 52%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_pids_limit PASSED [ 52%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_shm_size PASSED [ 52%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_shm_size_in_mb PASSED [ 52%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_userns_mode PASSED [ 52%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_uts PASSED [ 52%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_volume_driver PASSED [ 53%]
09:09:46 tests/unit/dockertypes_test.py::HostConfigTest::test_ctrate_host_config_with_cpu_rt_runtime_types PASSED [ 53%]
09:09:46 tests/unit/dockertypes_test.py::ContainerSpecTest::test_parse_mounts PASSED [ 53%]
09:09:46 tests/unit/dockertypes_test.py::UlimitTest::test_create_host_config_dict_ulimit PASSED [ 53%]
09:09:46 tests/unit/dockertypes_test.py::UlimitTest::test_create_host_config_dict_ulimit_capitals PASSED [ 53%]
09:09:46 tests/unit/dockertypes_test.py::UlimitTest::test_create_host_config_obj_ulimit PASSED [ 53%]
09:09:46 tests/unit/dockertypes_test.py::UlimitTest::test_ulimit_invalid_type PASSED [ 54%]
09:09:46 tests/unit/dockertypes_test.py::LogConfigTest::test_create_host_config_dict_logconfig PASSED [ 54%]
09:09:46 tests/unit/dockertypes_test.py::LogConfigTest::test_create_host_config_obj_logconfig PASSED [ 54%]
09:09:46 tests/unit/dockertypes_test.py::LogConfigTest::test_logconfig_invalid_config_type PASSED [ 54%]
09:09:46 tests/unit/dockertypes_test.py::EndpointConfigTest::test_create_endpoint_config_with_aliases PASSED [ 54%]
09:09:46 tests/unit/dockertypes_test.py::IPAMConfigTest::test_create_ipam_config PASSED [ 54%]
09:09:46 tests/unit/dockertypes_test.py::ServiceModeTest::test_global_replicas_error PASSED [ 55%]
09:09:46 tests/unit/dockertypes_test.py::ServiceModeTest::test_global_simple PASSED [ 55%]
09:09:46 tests/unit/dockertypes_test.py::ServiceModeTest::test_invalid_mode PASSED [ 55%]
09:09:46 tests/unit/dockertypes_test.py::ServiceModeTest::test_replicated_replicas PASSED [ 55%]
09:09:46 tests/unit/dockertypes_test.py::ServiceModeTest::test_replicated_replicas_0 PASSED [ 55%]
09:09:46 tests/unit/dockertypes_test.py::ServiceModeTest::test_replicated_simple PASSED [ 56%]
09:09:46 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_bind PASSED  [ 56%]
09:09:46 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_bind_windows XFAIL [ 56%]
09:09:46 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_named_volume PASSED [ 56%]
09:09:46 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_invalid PASSED [ 56%]
09:09:46 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_no_source PASSED [ 56%]
09:09:46 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_ro PASSED [ 57%]
09:09:46 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_rw PASSED [ 57%]
09:09:46 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_short_form PASSED [ 57%]
09:09:46 tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_invalid PASSED [ 57%]
09:09:46 tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_multiple PASSED [ 57%]
09:09:46 tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_no_protocol_and_mode PASSED [ 57%]
09:09:46 tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_simple PASSED [ 58%]
09:09:46 tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_with_protocol PASSED [ 58%]
09:09:46 tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_with_protocol_and_mode PASSED [ 58%]
09:09:46 tests/unit/errors_test.py::APIErrorTest::test_api_error_is_caught_by_dockerexception PASSED [ 58%]
09:09:46 tests/unit/errors_test.py::APIErrorTest::test_create_error_from_exception PASSED [ 58%]
09:09:46 tests/unit/errors_test.py::APIErrorTest::test_is_client_error_400 PASSED [ 59%]
09:09:46 tests/unit/errors_test.py::APIErrorTest::test_is_client_error_500 PASSED [ 59%]
09:09:46 tests/unit/errors_test.py::APIErrorTest::test_is_error_300 PASSED        [ 59%]
09:09:46 tests/unit/errors_test.py::APIErrorTest::test_is_error_400 PASSED        [ 59%]
09:09:46 tests/unit/errors_test.py::APIErrorTest::test_is_error_500 PASSED        [ 59%]
09:09:46 tests/unit/errors_test.py::APIErrorTest::test_is_server_error_200 PASSED [ 59%]
09:09:46 tests/unit/errors_test.py::APIErrorTest::test_is_server_error_300 PASSED [ 60%]
09:09:46 tests/unit/errors_test.py::APIErrorTest::test_is_server_error_400 PASSED [ 60%]
09:09:46 tests/unit/errors_test.py::APIErrorTest::test_is_server_error_500 PASSED [ 60%]
09:09:46 tests/unit/errors_test.py::APIErrorTest::test_status_code_200 PASSED     [ 60%]
09:09:46 tests/unit/errors_test.py::APIErrorTest::test_status_code_400 PASSED     [ 60%]
09:09:46 tests/unit/errors_test.py::APIErrorTest::test_status_code_500 PASSED     [ 60%]
09:09:46 tests/unit/errors_test.py::ContainerErrorTest::test_container_with_stderr PASSED [ 61%]
09:09:46 tests/unit/errors_test.py::ContainerErrorTest::test_container_without_stderr PASSED [ 61%]
09:09:46 tests/unit/errors_test.py::CreateUnexpectedKwargsErrorTest::test_create_unexpected_kwargs_error_multiple PASSED [ 61%]
09:09:46 tests/unit/errors_test.py::CreateUnexpectedKwargsErrorTest::test_create_unexpected_kwargs_error_single PASSED [ 61%]
09:09:46 tests/unit/models_containers_test.py::ContainerCollectionTest::test_create PASSED [ 61%]
09:09:46 tests/unit/models_containers_test.py::ContainerCollectionTest::test_create_container_args PASSED [ 61%]
09:09:46 tests/unit/models_containers_test.py::ContainerCollectionTest::test_create_with_image_object PASSED [ 62%]
09:09:46 tests/unit/models_containers_test.py::ContainerCollectionTest::test_get PASSED [ 62%]
09:09:46 tests/unit/models_containers_test.py::ContainerCollectionTest::test_list PASSED [ 62%]
09:09:46 tests/unit/models_containers_test.py::ContainerCollectionTest::test_list_ignore_removed PASSED [ 62%]
09:09:46 tests/unit/models_containers_test.py::ContainerCollectionTest::test_run PASSED [ 62%]
09:09:46 tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_detach PASSED [ 63%]
09:09:46 tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_pull PASSED [ 63%]
09:09:46 tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_remove PASSED [ 63%]
09:09:46 tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_with_error PASSED [ 63%]
09:09:46 tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_with_image_object PASSED [ 63%]
09:09:46 tests/unit/models_containers_test.py::ContainerTest::test_attach PASSED  [ 63%]
09:09:46 tests/unit/models_containers_test.py::ContainerTest::test_commit PASSED  [ 64%]
09:09:46 tests/unit/models_containers_test.py::ContainerTest::test_diff PASSED    [ 64%]
09:09:46 tests/unit/models_containers_test.py::ContainerTest::test_exec_run PASSED [ 64%]
09:09:46 tests/unit/models_containers_test.py::ContainerTest::test_exec_run_failure PASSED [ 64%]
09:09:46 tests/unit/models_containers_test.py::ContainerTest::test_export PASSED  [ 64%]
09:09:46 tests/unit/models_containers_test.py::ContainerTest::test_get_archive PASSED [ 64%]
09:09:46 tests/unit/models_containers_test.py::ContainerTest::test_image PASSED   [ 65%]
09:09:46 tests/unit/models_containers_test.py::ContainerTest::test_kill PASSED    [ 65%]
09:09:46 tests/unit/models_containers_test.py::ContainerTest::test_labels PASSED  [ 65%]
09:09:46 tests/unit/models_containers_test.py::ContainerTest::test_logs PASSED    [ 65%]
09:09:46 tests/unit/models_containers_test.py::ContainerTest::test_name PASSED    [ 65%]
09:09:46 tests/unit/models_containers_test.py::ContainerTest::test_pause PASSED   [ 66%]
09:09:46 tests/unit/models_containers_test.py::ContainerTest::test_put_archive PASSED [ 66%]
09:09:46 tests/unit/models_containers_test.py::ContainerTest::test_remove PASSED  [ 66%]
09:09:46 tests/unit/models_containers_test.py::ContainerTest::test_rename PASSED  [ 66%]
09:09:46 tests/unit/models_containers_test.py::ContainerTest::test_resize PASSED  [ 66%]
09:09:46 tests/unit/models_containers_test.py::ContainerTest::test_restart PASSED [ 66%]
09:09:46 tests/unit/models_containers_test.py::ContainerTest::test_start PASSED   [ 67%]
09:09:46 tests/unit/models_containers_test.py::ContainerTest::test_stats PASSED   [ 67%]
09:09:46 tests/unit/models_containers_test.py::ContainerTest::test_status PASSED  [ 67%]
09:09:46 tests/unit/models_containers_test.py::ContainerTest::test_stop PASSED    [ 67%]
09:09:46 tests/unit/models_containers_test.py::ContainerTest::test_top PASSED     [ 67%]
09:09:47 tests/unit/models_containers_test.py::ContainerTest::test_unpause PASSED [ 67%]
09:09:47 tests/unit/models_containers_test.py::ContainerTest::test_update PASSED  [ 68%]
09:09:47 tests/unit/models_containers_test.py::ContainerTest::test_wait PASSED    [ 68%]
09:09:47 tests/unit/models_images_test.py::ImageCollectionTest::test_build PASSED [ 68%]
09:09:47 tests/unit/models_images_test.py::ImageCollectionTest::test_get PASSED   [ 68%]
09:09:47 tests/unit/models_images_test.py::ImageCollectionTest::test_labels PASSED [ 68%]
09:09:47 tests/unit/models_images_test.py::ImageCollectionTest::test_list PASSED  [ 69%]
09:09:47 tests/unit/models_images_test.py::ImageCollectionTest::test_load PASSED  [ 69%]
09:09:47 tests/unit/models_images_test.py::ImageCollectionTest::test_pull PASSED  [ 69%]
09:09:47 tests/unit/models_images_test.py::ImageCollectionTest::test_pull_multiple PASSED [ 69%]
09:09:47 tests/unit/models_images_test.py::ImageCollectionTest::test_pull_tag_precedence PASSED [ 69%]
09:09:47 tests/unit/models_images_test.py::ImageCollectionTest::test_pull_with_stream_param PASSED [ 69%]
09:09:47 tests/unit/models_images_test.py::ImageCollectionTest::test_push PASSED  [ 70%]
09:09:47 tests/unit/models_images_test.py::ImageCollectionTest::test_remove PASSED [ 70%]
09:09:47 tests/unit/models_images_test.py::ImageCollectionTest::test_search PASSED [ 70%]
09:09:47 tests/unit/models_images_test.py::ImageCollectionTest::test_search_limit PASSED [ 70%]
09:09:47 tests/unit/models_images_test.py::ImageTest::test_history PASSED         [ 70%]
09:09:47 tests/unit/models_images_test.py::ImageTest::test_save PASSED            [ 70%]
09:09:47 tests/unit/models_images_test.py::ImageTest::test_short_id PASSED        [ 71%]
09:09:47 tests/unit/models_images_test.py::ImageTest::test_tag PASSED             [ 71%]
09:09:47 tests/unit/models_images_test.py::ImageTest::test_tags PASSED            [ 71%]
09:09:47 tests/unit/models_networks_test.py::NetworkCollectionTest::test_create PASSED [ 71%]
09:09:47 tests/unit/models_networks_test.py::NetworkCollectionTest::test_get PASSED [ 71%]
09:09:47 tests/unit/models_networks_test.py::NetworkCollectionTest::test_list PASSED [ 71%]
09:09:47 tests/unit/models_networks_test.py::NetworkTest::test_connect PASSED     [ 72%]
09:09:47 tests/unit/models_networks_test.py::NetworkTest::test_disconnect PASSED  [ 72%]
09:09:47 tests/unit/models_networks_test.py::NetworkTest::test_remove PASSED      [ 72%]
09:09:47 tests/unit/models_resources_test.py::ModelTest::test_hash PASSED         [ 72%]
09:09:47 tests/unit/models_resources_test.py::ModelTest::test_reload PASSED       [ 72%]
09:09:47 tests/unit/models_secrets_test.py::CreateServiceTest::test_secrets_repr PASSED [ 73%]
09:09:47 tests/unit/models_services_test.py::CreateServiceKwargsTest::test_get_create_service_kwargs PASSED [ 73%]
09:09:47 tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_hostname_prefix_trim PASSED [ 73%]
09:09:47 tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_hostname_and_port PASSED [ 73%]
09:09:47 tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_hostname_only PASSED [ 73%]
09:09:47 tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_url PASSED [ 73%]
09:09:47 tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_user_and_hostname PASSED [ 74%]
09:09:47 tests/unit/ssladapter_test.py::SSLAdapterTest::test_only_uses_tls PASSED [ 74%]
09:09:47 tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_dns_failure PASSED [ 74%]
09:09:47 tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_dns_success PASSED [ 74%]
09:09:47 tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_ip_address_failure PASSED [ 74%]
09:09:47 tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_ip_address_success PASSED [ 74%]
09:09:47 tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_localhost_success PASSED [ 75%]
09:09:47 tests/unit/swarm_test.py::SwarmTest::test_join_swarm PASSED              [ 75%]
09:09:47 tests/unit/swarm_test.py::SwarmTest::test_join_swarm_no_listen_address_takes_default PASSED [ 75%]
09:09:47 tests/unit/swarm_test.py::SwarmTest::test_node_update PASSED             [ 75%]
09:09:47 tests/unit/types_containers_test.py::test_uid_0_is_not_elided PASSED     [ 75%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_directory PASSED  [ 76%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_single_exception PASSED [ 76%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_subdir_exception PASSED [ 76%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_subdir_exception_win32_pathsep SKIPPED [ 76%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_trailing_slash PASSED [ 76%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_wildcard_exception PASSED [ 76%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_double_wildcard PASSED [ 77%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_double_wildcard_with_exception PASSED [ 77%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_custom_dockerfile PASSED [ 77%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_dockerfile_child PASSED [ 77%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_dockerfile_dockerignore PASSED [ 77%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_include_absolute_path PASSED [ 77%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_include_wildcard PASSED [ 78%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_last_line_precedence PASSED [ 78%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_no_dupes PASSED   [ 78%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_no_excludes PASSED [ 78%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_parent_directory PASSED [ 78%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_question_mark PASSED [ 78%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_and_double_wildcard PASSED [ 79%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_filename PASSED [ 79%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_filename_leading_dot_slash PASSED [ 79%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_filename_trailing_slash PASSED [ 79%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_single_filename PASSED [ 79%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_single_filename_leading_slash PASSED [ 80%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_wildcard_filename PASSED [ 80%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_with_path_traversal PASSED [ 80%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_subdirectory PASSED [ 80%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_subdirectory_win32_pathsep SKIPPED [ 80%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_trailing_double_wildcard PASSED [ 80%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_exclude PASSED [ 81%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_filename_end PASSED [ 81%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_filename_start PASSED [ 81%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_subdir_single_filename PASSED [ 81%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_subdir_wildcard_filename PASSED [ 81%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_with_exception PASSED [ 81%]
09:09:47 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_with_wildcard_exception PASSED [ 82%]
09:09:47 tests/unit/utils_build_test.py::TarTest::test_tar_directory_link PASSED  [ 82%]
09:09:47 tests/unit/utils_build_test.py::TarTest::test_tar_socket_file PASSED     [ 82%]
09:09:47 tests/unit/utils_build_test.py::TarTest::test_tar_with_broken_symlinks PASSED [ 82%]
09:09:47 tests/unit/utils_build_test.py::TarTest::test_tar_with_directory_symlinks PASSED [ 82%]
09:09:47 tests/unit/utils_build_test.py::TarTest::test_tar_with_empty_directory PASSED [ 83%]
09:09:47 tests/unit/utils_build_test.py::TarTest::test_tar_with_excludes PASSED   [ 83%]
09:09:47 tests/unit/utils_build_test.py::TarTest::test_tar_with_file_symlinks PASSED [ 83%]
09:09:47 tests/unit/utils_build_test.py::TarTest::test_tar_with_inaccessible_file SKIPPED [ 83%]
09:09:47 tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_fallback PASSED [ 83%]
09:09:47 tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_environment PASSED [ 83%]
09:09:47 tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_explicit_path PASSED [ 84%]
09:09:47 tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_home_legacy_name PASSED [ 84%]
09:09:47 tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_home_posix PASSED [ 84%]
09:09:47 tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_home_windows SKIPPED [ 84%]
09:09:47 tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_custom_headers PASSED [ 84%]
09:09:47 tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_detach_keys PASSED [ 84%]
09:09:47 tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_from_env PASSED [ 85%]
09:09:47 tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_no_file PASSED [ 85%]
09:09:47 tests/unit/utils_json_stream_test.py::TestJsonSplitter::test_json_splitter_no_object PASSED [ 85%]
09:09:47 tests/unit/utils_json_stream_test.py::TestJsonSplitter::test_json_splitter_with_object PASSED [ 85%]
09:09:47 tests/unit/utils_json_stream_test.py::TestJsonSplitter::test_json_splitter_leading_whitespace PASSED [ 85%]
09:09:47 tests/unit/utils_json_stream_test.py::TestStreamAsText::test_stream_with_non_utf_unicode_character PASSED [ 85%]
09:09:47 tests/unit/utils_json_stream_test.py::TestStreamAsText::test_stream_with_utf_character PASSED [ 86%]
09:09:47 tests/unit/utils_json_stream_test.py::TestJsonStream::test_with_falsy_entries PASSED [ 86%]
09:09:47 tests/unit/utils_json_stream_test.py::TestJsonStream::test_with_leading_whitespace PASSED [ 86%]
09:09:47 tests/unit/utils_proxy_test.py::ProxyConfigTest::test_environment PASSED [ 86%]
09:09:47 tests/unit/utils_proxy_test.py::ProxyConfigTest::test_from_dict PASSED   [ 86%]
09:09:47 tests/unit/utils_proxy_test.py::ProxyConfigTest::test_inject_proxy_environment PASSED [ 87%]
09:09:47 tests/unit/utils_proxy_test.py::ProxyConfigTest::test_new PASSED         [ 87%]
09:09:47 tests/unit/utils_proxy_test.py::ProxyConfigTest::test_truthiness PASSED  [ 87%]
09:09:47 tests/unit/utils_test.py::DecoratorsTest::test_update_headers PASSED     [ 87%]
09:09:47 tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_alternate_env PASSED [ 87%]
09:09:47 tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_empty PASSED [ 87%]
09:09:47 tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_no_cert_path PASSED [ 88%]
09:09:47 tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_tls PASSED [ 88%]
09:09:47 tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_tls_verify_false PASSED [ 88%]
09:09:47 tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_tls_verify_false_no_cert PASSED [ 88%]
09:09:47 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_compact PASSED [ 88%]
09:09:47 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_complete PASSED [ 88%]
09:09:47 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_empty PASSED [ 89%]
09:09:47 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_list PASSED [ 89%]
09:09:47 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_no_mode PASSED [ 89%]
09:09:47 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_unicode_bytes_input PASSED [ 89%]
09:09:47 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_unicode_unicode_input PASSED [ 89%]
09:09:47 tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_commented_line PASSED [ 90%]
09:09:47 tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_invalid_line PASSED [ 90%]
09:09:47 tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_newline PASSED [ 90%]
09:09:47 tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_proper PASSED [ 90%]
09:09:47 tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_with_equals_character PASSED [ 90%]
09:09:47 tests/unit/utils_test.py::ParseHostTest::test_parse_host PASSED          [ 90%]
09:09:47 tests/unit/utils_test.py::ParseHostTest::test_parse_host_empty_value PASSED [ 91%]
09:09:47 tests/unit/utils_test.py::ParseHostTest::test_parse_host_tls PASSED      [ 91%]
09:09:47 tests/unit/utils_test.py::ParseHostTest::test_parse_host_tls_tcp_proto PASSED [ 91%]
09:09:47 tests/unit/utils_test.py::ParseHostTest::test_parse_host_trailing_slash PASSED [ 91%]
09:09:47 tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_image_no_tag PASSED [ 91%]
09:09:47 tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_image_sha PASSED [ 91%]
09:09:47 tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_image_tag PASSED [ 92%]
09:09:47 tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_user_image_no_tag PASSED [ 92%]
09:09:47 tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_user_image_tag PASSED [ 92%]
09:09:47 tests/unit/utils_test.py::ParseRepositoryTagTest::test_private_reg_image_no_tag PASSED [ 92%]
09:09:47 tests/unit/utils_test.py::ParseRepositoryTagTest::test_private_reg_image_sha PASSED [ 92%]
09:09:47 tests/unit/utils_test.py::ParseRepositoryTagTest::test_private_reg_image_tag PASSED [ 92%]
09:09:47 tests/unit/utils_test.py::ParseDeviceTest::test_dict PASSED              [ 93%]
09:09:47 tests/unit/utils_test.py::ParseDeviceTest::test_full_string_definition PASSED [ 93%]
09:09:47 tests/unit/utils_test.py::ParseDeviceTest::test_hybrid_list PASSED       [ 93%]
09:09:47 tests/unit/utils_test.py::ParseDeviceTest::test_partial_string_definition PASSED [ 93%]
09:09:47 tests/unit/utils_test.py::ParseDeviceTest::test_permissionless_string_definition PASSED [ 93%]
09:09:47 tests/unit/utils_test.py::ParseBytesTest::test_parse_bytes_float PASSED  [ 94%]
09:09:47 tests/unit/utils_test.py::ParseBytesTest::test_parse_bytes_invalid PASSED [ 94%]
09:09:47 tests/unit/utils_test.py::ParseBytesTest::test_parse_bytes_valid PASSED  [ 94%]
09:09:47 tests/unit/utils_test.py::UtilsTest::test_convert_filters PASSED         [ 94%]
09:09:47 tests/unit/utils_test.py::UtilsTest::test_decode_json_header PASSED      [ 94%]
09:09:47 tests/unit/utils_test.py::SplitCommandTest::test_split_command_with_unicode PASSED [ 94%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_matching_internal_port_ranges PASSED [ 95%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_matching_internal_ports PASSED [ 95%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_nonmatching_internal_port_ranges PASSED [ 95%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_nonmatching_internal_ports PASSED [ 95%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_one_port PASSED [ 95%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_port_range PASSED [ 95%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_host_only_with_colon PASSED    [ 96%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_non_matching_length_port_ranges PASSED [ 96%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_port_and_range_invalid PASSED  [ 96%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_port_only_with_colon PASSED    [ 96%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_split_port_empty_string PASSED [ 96%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_split_port_invalid PASSED      [ 97%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_split_port_invalid_protocol PASSED [ 97%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_split_port_no_host_port PASSED [ 97%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_split_port_non_string PASSED   [ 97%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_split_port_random_port_range_with_host_port PASSED [ 97%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_split_port_range_no_host_port PASSED [ 97%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_split_port_range_with_host_ip_no_port PASSED [ 98%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_split_port_range_with_host_port PASSED [ 98%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_split_port_range_with_protocol PASSED [ 98%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_split_port_with_host_ip PASSED [ 98%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_split_port_with_host_ip_no_port PASSED [ 98%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_split_port_with_host_port PASSED [ 98%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_split_port_with_ipv6_address PASSED [ 99%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_split_port_with_ipv6_square_brackets_address PASSED [ 99%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_split_port_with_protocol PASSED [ 99%]
09:09:47 tests/unit/utils_test.py::PortsTest::test_with_no_container_port PASSED  [ 99%]
09:09:47 tests/unit/utils_test.py::FormatEnvironmentTest::test_format_env_binary_unicode_value PASSED [ 99%]
09:09:48 tests/unit/utils_test.py::FormatEnvironmentTest::test_format_env_no_value PASSED [100%]
09:09:48 
09:09:48 =================================== FAILURES ===================================
09:09:48 _____________________ ContainerTest.test_remove_container ______________________
09:09:48 tests/unit/api_container_test.py:1413: in test_remove_container
09:09:48     timeout=DEFAULT_TIMEOUT_SECONDS
09:09:48 /usr/local/lib/python3.7/unittest/mock.py:878: in assert_called_with
09:09:48     raise AssertionError(_error_message()) from cause
09:09:48 E   AssertionError: Expected call: mock('DELETE', 'http+docker://localhost/v1.41/containers/3cc2351ab11b', params={'v': False, 'link': False, 'force': False}, timeout=60)
09:09:48 E   Actual call: mock('DELETE', 'http+docker://localhost/v1.41/containers/3cc2351ab11b', params={'v': False, 'link': False, 'force': False}, timeout=70)
09:09:48 _________ ContainerTest.test_remove_container_with_dict_instead_of_id __________
09:09:48 tests/unit/api_container_test.py:1423: in test_remove_container_with_dict_instead_of_id
09:09:48     timeout=DEFAULT_TIMEOUT_SECONDS
09:09:48 /usr/local/lib/python3.7/unittest/mock.py:878: in assert_called_with
09:09:48     raise AssertionError(_error_message()) from cause
09:09:48 E   AssertionError: Expected call: mock('DELETE', 'http+docker://localhost/v1.41/containers/3cc2351ab11b', params={'v': False, 'link': False, 'force': False}, timeout=60)
09:09:48 E   Actual call: mock('DELETE', 'http+docker://localhost/v1.41/containers/3cc2351ab11b', params={'v': False, 'link': False, 'force': False}, timeout=70)
09:09:48 ________________________ DockerApiTest.test_remove_link ________________________
09:09:48 tests/unit/api_test.py:323: in test_remove_link
09:09:48     timeout=DEFAULT_TIMEOUT_SECONDS
09:09:48 /usr/local/lib/python3.7/unittest/mock.py:878: in assert_called_with
09:09:48     raise AssertionError(_error_message()) from cause
09:09:48 E   AssertionError: Expected call: mock('DELETE', 'http+docker://localhost/v1.41/containers/3cc2351ab11b', params={'v': False, 'link': True, 'force': False}, timeout=60)
09:09:48 E   Actual call: mock('DELETE', 'http+docker://localhost/v1.41/containers/3cc2351ab11b', params={'v': False, 'link': True, 'force': False}, timeout=70)
09:09:48 
09:09:48 ---------- coverage: platform linux, python 3.7.12-final-0 -----------
09:09:48 Name                                  Stmts   Miss Branch BrPart  Cover
09:09:48 -----------------------------------------------------------------------
09:09:48 docker/__init__.py                        8      0      0      0   100%
09:09:48 docker/api/__init__.py                    1      0      0      0   100%
09:09:48 docker/api/build.py                     126     41     92     21    62%
09:09:48 docker/api/client.py                    261     65     92     11    75%
09:09:48 docker/api/config.py                     29     18      4      0    33%
09:09:48 docker/api/container.py                 272     73    108     27    65%
09:09:48 docker/api/daemon.py                     39      4     14      4    85%
09:09:48 docker/api/exec_api.py                   45     11     22      9    67%
09:09:48 docker/api/image.py                     159     43     60     14    70%
09:09:48 docker/api/network.py                    90     35     48     11    51%
09:09:48 docker/api/plugin.py                     89     68     14      0    20%
09:09:48 docker/api/secret.py                     34     22      8      0    29%
09:09:48 docker/api/service.py                   200    176    149      0     7%
09:09:48 docker/api/swarm.py                     106     67     38      1    28%
09:09:48 docker/api/volume.py                     38      9     14      2    71%
09:09:48 docker/auth.py                          197     16     74     16    88%
09:09:48 docker/client.py                         69      9      2      0    87%
09:09:48 docker/constants.py                      21      0      0      0   100%
09:09:48 docker/context/__init__.py                2      0      0      0   100%
09:09:48 docker/context/api.py                    78     41     38      8    39%
09:09:48 docker/context/config.py                 61     33     16      2    42%
09:09:48 docker/context/context.py               154     96     64      6    29%
09:09:48 docker/credentials/__init__.py            3      0      0      0   100%
09:09:48 docker/credentials/constants.py           4      0      0      0   100%
09:09:48 docker/credentials/errors.py             11      4      2      0    54%
09:09:48 docker/credentials/store.py              44     30     12      0    25%
09:09:48 docker/credentials/utils.py              23     18     12      0    14%
09:09:48 docker/errors.py                        110     26     20      4    71%
09:09:48 docker/models/__init__.py                 0      0      0      0   100%
09:09:48 docker/models/configs.py                 21      8      2      0    57%
09:09:48 docker/models/containers.py             183     11     70      9    91%
09:09:48 docker/models/images.py                 136     55     56      4    52%
09:09:48 docker/models/networks.py                37      7     12      3    71%
09:09:48 docker/models/nodes.py                   15      5      2      0    59%
09:09:48 docker/models/plugins.py                 48     29      8      0    34%
09:09:48 docker/models/resource.py                41     10      6      3    72%
09:09:48 docker/models/secrets.py                 22      4      2      0    75%
09:09:48 docker/models/services.py                87     35     36      4    59%
09:09:48 docker/models/swarm.py                   39     21      6      0    40%
09:09:48 docker/models/volumes.py                 23     10      4      0    48%
09:09:48 docker/tls.py                            37      6     14      6    76%
09:09:48 docker/transport/__init__.py             11      3      0      0    73%
09:09:48 docker/transport/basehttpadapter.py       6      0      2      1    88%
09:09:48 docker/transport/npipeconn.py            57     52      8      0     8%
09:09:48 docker/transport/npipesocket.py         134    130     20      0     3%
09:09:48 docker/transport/sshconn.py             162    105     54      3    30%
09:09:48 docker/transport/ssladapter.py           36     10     10      4    65%
09:09:48 docker/transport/unixconn.py             54      3      6      1    93%
09:09:48 docker/types/__init__.py                  6      0      0      0   100%
09:09:48 docker/types/base.py                      4      0      2      0   100%
09:09:48 docker/types/containers.py              419     79    326     43    81%
09:09:48 docker/types/daemon.py                   36     24     14      0    24%
09:09:48 docker/types/healthcheck.py              33     20      4      0    35%
09:09:48 docker/types/networks.py                 41     11     28      9    65%
09:09:48 docker/types/services.py                321    146    216     41    50%
09:09:48 docker/types/swarm.py                    51     45     40      0     7%
09:09:48 docker/utils/__init__.py                  3      0      0      0   100%
09:09:48 docker/utils/build.py                   150     24     72     10    83%
09:09:48 docker/utils/config.py                   36      1     10      1    96%
09:09:48 docker/utils/decorators.py               32      1     12      1    95%
09:09:48 docker/utils/fnmatch.py                  55     18     28      2    61%
09:09:48 docker/utils/json_stream.py              40      8     14      2    78%
09:09:48 docker/utils/ports.py                    50      3     32      2    91%
09:09:48 docker/utils/proxy.py                    32      1     12      0    98%
09:09:48 docker/utils/socket.py                   85     10     40      8    84%
09:09:48 docker/utils/utils.py                   278     18    171     13    92%
09:09:48 docker/version.py                         2      0      2      0   100%
09:09:48 -----------------------------------------------------------------------
09:09:48 TOTAL                                  5097   1818   2244    306    60%
09:09:48 
09:09:48 =========================== short test summary info ============================
09:09:48 XFAIL tests/unit/dockertypes_test.py::MountTest::test_parse_mount_bind_windows
09:09:48 SKIPPED [1] tests/unit/api_build_test.py:169: Windows-specific syntax
09:09:48 SKIPPED [1] tests/unit/client_test.py:99: Npipe Connection Pool only on Windows
09:09:48 SKIPPED [1] tests/unit/client_test.py:138: Npipe Connection Pool only on Windows
09:09:48 SKIPPED [1] tests/unit/client_test.py:212: Npipe Connection Pool only on Windows
09:09:48 SKIPPED [1] tests/unit/client_test.py:249: Npipe Connection Pool only on Windows
09:09:48 SKIPPED [1] tests/unit/context_test.py:18: Windows specific path check
09:09:48 SKIPPED [1] tests/unit/utils_build_test.py:230: Backslash patterns only on Windows
09:09:48 SKIPPED [1] tests/unit/utils_build_test.py:252: Backslash patterns only on Windows
09:09:48 SKIPPED [1] tests/unit/utils_build_test.py:400: root user always has access ; no chmod on Windows
09:09:48 SKIPPED [1] tests/unit/utils_config_test.py:54: condition: sys.platform != 'win32'
09:09:48 ============= 3 failed, 557 passed, 10 skipped, 1 xfailed in 6.24s =============
[Pipeline] sh
09:09:48 + docker stop dpy-dind-2-0-py3.7-19.03.12
09:09:48 Error response from daemon: No such container: dpy-dind-2-0-py3.7-19.03.12
[Pipeline] }
[Pipeline] // withDockerRegistry
[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // withDockerRegistry
[Pipeline] }
[Pipeline] // node
Running on EC2 (managed-agents) - ubuntu-2004-cgroup1 (i-038677a38b0431f65) in /home/ubuntu/workspace/docker-py_PR-2959
[Pipeline] }
Failed in branch py3.7_19.03.12
[Pipeline] {
[Pipeline] withDockerRegistry
$ docker login -u dockerbuildbot -p ******** https://index.docker.io/v1/
WARNING! Using --password via the CLI is insecure. Use --password-stdin.
WARNING! Your password will be stored unencrypted in /home/ubuntu/workspace/docker-py_PR-2959@tmp/ac6599bf-5752-4eed-a161-9f7d7e0229c0/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store

Login Succeeded
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] echo
09:09:49 cleanWorkspace: Ensuring workspace is owned by ubuntu
[Pipeline] echo
09:09:49 chowning workspace
[Pipeline] sh
09:09:49 + pwd
09:09:49 + id -u
09:09:49 + id -g
09:09:49 + docker run --rm -v /home/ubuntu/workspace/docker-py_PR-2959:/workspace busybox chown -R 1000:1000 /workspace
[Pipeline] echo
09:09:49 Removing all docker containers
[Pipeline] sh
09:09:50 + docker container ls -aq
[Pipeline] echo
09:09:50 Docker containers have been removed
[Pipeline] echo
09:09:50 cleanWorkspace: Removing existing workspace
[Pipeline] deleteDir
[Pipeline] echo
09:09:50 cleanWorkspace: Workspace is clean.
[Pipeline] stage
[Pipeline] { (test python=py3.7 / docker=19.03.13)
[Pipeline] checkout
09:09:50 The recommended git tool is: git
09:09:50 using credential docker-jenkins-github-credentials
09:09:50 Cloning the remote Git repository
09:09:50 Cloning with configured refspecs honoured and without tags
09:09:51 Fetching without tags
09:09:51 Merging remotes/origin/master commit a48a5a9647761406d66e8271f19fab7fa0c5f582 into PR head commit b6deb149ce8ba3fc6638315c15a4f71bc424434b
09:09:51 Merge succeeded, producing b6deb149ce8ba3fc6638315c15a4f71bc424434b
09:09:51 Checking out Revision b6deb149ce8ba3fc6638315c15a4f71bc424434b (PR-2959)
Cloning repository https://github.com/docker/docker-py.git
 > git init /home/ubuntu/workspace/docker-py_PR-2959 # timeout=10
Fetching upstream changes from https://github.com/docker/docker-py.git
 > git --version # timeout=10
 > git --version # 'git version 2.25.1'
using GIT_ASKPASS to set credentials docker-jenkins GitHub credentials
 > git fetch --no-tags --force --progress -- https://github.com/docker/docker-py.git +refs/pull/2959/head:refs/remotes/origin/PR-2959 +refs/heads/master:refs/remotes/origin/master # timeout=10
 > git config remote.origin.url https://github.com/docker/docker-py.git # timeout=10
 > git config --add remote.origin.fetch +refs/pull/2959/head:refs/remotes/origin/PR-2959 # timeout=10
 > git config --add remote.origin.fetch +refs/heads/master:refs/remotes/origin/master # timeout=10
 > git config remote.origin.url https://github.com/docker/docker-py.git # timeout=10
Fetching upstream changes from https://github.com/docker/docker-py.git
using GIT_ASKPASS to set credentials docker-jenkins GitHub credentials
 > git fetch --no-tags --force --progress -- https://github.com/docker/docker-py.git +refs/pull/2959/head:refs/remotes/origin/PR-2959 +refs/heads/master:refs/remotes/origin/master # timeout=10
 > git config core.sparsecheckout # timeout=10
 > git checkout -f b6deb149ce8ba3fc6638315c15a4f71bc424434b # timeout=10
 > git remote # timeout=10
 > git config --get remote.origin.url # timeout=10
using GIT_ASKPASS to set credentials docker-jenkins GitHub credentials
 > git merge a48a5a9647761406d66e8271f19fab7fa0c5f582 # timeout=10
 > git rev-parse HEAD^{commit} # timeout=10
09:09:51 Commit message: "Added timeout to container.remove()"
[Pipeline] withDockerRegistry
[Pipeline] {
[Pipeline] sh
09:09:52 + docker run --rm -e DOCKER_TEST_API_VERSION=1.40 dockerpinata/docker-py:py3-b6deb149ce8ba3fc6638315c15a4f71bc424434b py.test -v -rxs --cov=docker tests/unit
 > git config core.sparsecheckout # timeout=10
 > git checkout -f b6deb149ce8ba3fc6638315c15a4f71bc424434b # timeout=10
09:09:52 ============================= test session starts ==============================
09:09:52 platform linux -- Python 3.7.12, pytest-6.2.5, py-1.11.0, pluggy-1.0.0 -- /usr/local/bin/python
09:09:52 cachedir: .pytest_cache
09:09:52 rootdir: /src, configfile: pytest.ini
09:09:52 plugins: timeout-2.0.1, cov-3.0.0
$ docker login -u dockerbuildbot -p ******** https://index.docker.io/v1/
WARNING! Using --password via the CLI is insecure. Use --password-stdin.
WARNING! Your password will be stored unencrypted in /home/ubuntu/workspace/docker-py_PR-2959@tmp/7cf87af6-32fc-47ef-b148-b3feac4beda9/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store

Login Succeeded
Still waiting to schedule task
‘EC2 (managed-agents) - ubuntu-2004-cgroup1 (i-025857813df64a8aa)’ is offline
‘ppc64le-ubuntu-11’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘ppc64le-ubuntu-12’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘ppc64le-ubuntu-13’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘ppc64le-ubuntu-14’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘ppc64le-ubuntu-15’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘ppc64le-ubuntu-16’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘ppc64le-ubuntu-17’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘ppc64le-ubuntu-18’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘ppc64le-ubuntu-19’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘ppc64le-ubuntu-20’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘ppc64le-ubuntu-21’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘ppc64le-ubuntu-22’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘ppc64le-ubuntu-23’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘ppc64le-ubuntu-24’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘ppc64le-ubuntu-25’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘ppc64le-ubuntu-26’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘ppc64le-ubuntu-27’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘ppc64le-ubuntu-28’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘ppc64le-ubuntu-31’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘ppc64le-ubuntu-32’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘ppc64le-ubuntu-33’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘ppc64le-ubuntu-34’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘s390x-ubuntu-01’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘s390x-ubuntu-02’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘s390x-ubuntu-03’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘s390x-ubuntu-04’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘s390x-ubuntu-05’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘s390x-ubuntu-06’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘s390x-ubuntu-13’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘s390x-ubuntu-14’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘s390x-ubuntu-15’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘s390x-ubuntu-16’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘s390x-ubuntu-25’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘s390x-ubuntu-26’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘s390x-ubuntu-29’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
‘s390x-ubuntu-30’ doesn’t have label ‘amd64&&ubuntu-2004&&overlay2’
09:09:54 collecting ... collected 571 items
09:09:54 
09:09:54 tests/unit/api_build_test.py::BuildTest::test_build_container PASSED     [  0%]
09:09:54 tests/unit/api_build_test.py::BuildTest::test_build_container_custom_context PASSED [  0%]
09:09:54 tests/unit/api_build_test.py::BuildTest::test_build_container_custom_context_gzip PASSED [  0%]
09:09:54 tests/unit/api_build_test.py::BuildTest::test_build_container_invalid_container_limits PASSED [  0%]
09:09:54 tests/unit/api_build_test.py::BuildTest::test_build_container_pull PASSED [  0%]
09:09:54 tests/unit/api_build_test.py::BuildTest::test_build_container_with_container_limits PASSED [  1%]
09:09:54 tests/unit/api_build_test.py::BuildTest::test_build_container_with_named_dockerfile PASSED [  1%]
09:09:54 tests/unit/api_build_test.py::BuildTest::test_build_remote_with_registry_auth PASSED [  1%]
09:09:54 tests/unit/api_build_test.py::BuildTest::test_process_dockerfile PASSED  [  1%]
09:09:54 tests/unit/api_build_test.py::BuildTest::test_process_dockerfile_win_longpath_prefix SKIPPED [  1%]
09:09:54 tests/unit/api_build_test.py::BuildTest::test_set_auth_headers_with_dict_and_auth_configs PASSED [  1%]
09:09:54 tests/unit/api_build_test.py::BuildTest::test_set_auth_headers_with_dict_and_no_auth_configs PASSED [  2%]
09:09:54 tests/unit/api_build_test.py::BuildTest::test_set_auth_headers_with_empty_dict_and_auth_configs PASSED [  2%]
09:09:54 tests/unit/api_container_test.py::StartContainerTest::test_start_container PASSED [  2%]
09:09:54 tests/unit/api_container_test.py::StartContainerTest::test_start_container_none PASSED [  2%]
09:09:54 tests/unit/api_container_test.py::StartContainerTest::test_start_container_privileged PASSED [  2%]
09:09:54 tests/unit/api_container_test.py::StartContainerTest::test_start_container_regression_573 PASSED [  2%]
09:09:54 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_binds_ro PASSED [  3%]
09:09:54 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_binds_rw PASSED [  3%]
09:09:54 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_dict_instead_of_id PASSED [  3%]
09:09:54 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_links PASSED [  3%]
09:09:54 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_links_as_list_of_tuples PASSED [  3%]
09:09:54 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_lxc_conf PASSED [  4%]
09:09:54 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_lxc_conf_compat PASSED [  4%]
09:09:54 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_multiple_links PASSED [  4%]
09:09:54 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_port_binds PASSED [  4%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container PASSED [  4%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_privileged PASSED [  4%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_added_capabilities PASSED [  5%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_aliases PASSED [  5%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds PASSED [  5%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_list PASSED [  5%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_mode PASSED [  5%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_mode_and_ro_error PASSED [  5%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_ro PASSED [  6%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_rw PASSED [  6%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_cgroup_parent PASSED [  6%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_device_requests PASSED [  6%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_devices PASSED [  6%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_dropped_capabilities PASSED [  7%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_entrypoint PASSED [  7%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_host_config_cpu_shares PASSED [  7%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_host_config_cpus PASSED [  7%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_host_config_cpuset PASSED [  7%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_host_config_cpuset_mems PASSED [  7%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_labels_dict PASSED [  8%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_labels_list PASSED [  8%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_links PASSED [  8%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_links_as_list_of_tuples PASSED [  8%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_lxc_conf PASSED [  8%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_lxc_conf_compat PASSED [  8%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mac_address PASSED [  9%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_int PASSED [  9%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string PASSED [  9%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string_with_g_unit PASSED [  9%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string_with_k_unit PASSED [  9%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string_with_m_unit PASSED [  9%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string_with_wrong_value PASSED [ 10%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_multiple_links PASSED [ 10%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_named_volume PASSED [ 10%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_port_binds PASSED [ 10%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_ports PASSED [ 10%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_restart_policy PASSED [ 11%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_stdin_open PASSED [ 11%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_stop_signal PASSED [ 11%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_sysctl PASSED [ 11%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_tmpfs_dict PASSED [ 11%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_tmpfs_list PASSED [ 11%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_unicode_envvars PASSED [ 12%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_volume_string PASSED [ 12%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_working_dir PASSED [ 12%]
09:09:54 tests/unit/api_container_test.py::CreateContainerTest::test_create_named_container PASSED [ 12%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_container_stats PASSED [ 12%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_container_top PASSED [ 12%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_container_top_with_psargs PASSED [ 13%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_container_update PASSED [ 13%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_diff PASSED        [ 13%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_diff_with_dict_instead_of_id PASSED [ 13%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_export PASSED      [ 13%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_export_with_dict_instead_of_id PASSED [ 14%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_inspect_container PASSED [ 14%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_inspect_container_undefined_id PASSED [ 14%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_kill_container PASSED [ 14%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_kill_container_with_dict_instead_of_id PASSED [ 14%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_kill_container_with_signal PASSED [ 14%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_list_containers PASSED [ 15%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_log_following PASSED [ 15%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_log_following_backwards PASSED [ 15%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_log_since PASSED   [ 15%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_log_since_with_datetime PASSED [ 15%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_log_since_with_invalid_value_raises_error PASSED [ 15%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_log_streaming PASSED [ 16%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_log_streaming_and_following PASSED [ 16%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_log_tail PASSED    [ 16%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_log_tty PASSED     [ 16%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_logs PASSED        [ 16%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_logs_with_dict_instead_of_id PASSED [ 16%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_pause_container PASSED [ 17%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_port PASSED        [ 17%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_remove_container FAILED [ 17%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_remove_container_with_dict_instead_of_id FAILED [ 17%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_rename_container PASSED [ 17%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_resize_container PASSED [ 18%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_restart_container PASSED [ 18%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_restart_container_with_dict_instead_of_id PASSED [ 18%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_stop_container PASSED [ 18%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_stop_container_with_dict_instead_of_id PASSED [ 18%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_unpause_container PASSED [ 18%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_wait PASSED        [ 19%]
09:09:54 tests/unit/api_container_test.py::ContainerTest::test_wait_with_dict_instead_of_id PASSED [ 19%]
09:09:54 tests/unit/api_exec_test.py::ExecTest::test_exec_create PASSED           [ 19%]
09:09:54 tests/unit/api_exec_test.py::ExecTest::test_exec_inspect PASSED          [ 19%]
09:09:54 tests/unit/api_exec_test.py::ExecTest::test_exec_resize PASSED           [ 19%]
09:09:54 tests/unit/api_exec_test.py::ExecTest::test_exec_start PASSED            [ 19%]
09:09:54 tests/unit/api_exec_test.py::ExecTest::test_exec_start_detached PASSED   [ 20%]
09:09:54 tests/unit/api_image_test.py::ImageTest::test_commit PASSED              [ 20%]
09:09:54 tests/unit/api_image_test.py::ImageTest::test_get_image PASSED           [ 20%]
09:09:54 tests/unit/api_image_test.py::ImageTest::test_image_history PASSED       [ 20%]
09:09:54 tests/unit/api_image_test.py::ImageTest::test_image_ids PASSED           [ 20%]
09:09:54 tests/unit/api_image_test.py::ImageTest::test_image_viz PASSED           [ 21%]
09:09:54 tests/unit/api_image_test.py::ImageTest::test_images PASSED              [ 21%]
09:09:54 tests/unit/api_image_test.py::ImageTest::test_images_filters PASSED      [ 21%]
09:09:54 tests/unit/api_image_test.py::ImageTest::test_images_name PASSED         [ 21%]
09:09:54 tests/unit/api_image_test.py::ImageTest::test_images_quiet PASSED        [ 21%]
09:09:54 tests/unit/api_image_test.py::ImageTest::test_import_image PASSED        [ 21%]
09:09:54 tests/unit/api_image_test.py::ImageTest::test_import_image_from_bytes PASSED [ 22%]
09:09:54 tests/unit/api_image_test.py::ImageTest::test_import_image_from_image PASSED [ 22%]
09:09:54 tests/unit/api_image_test.py::ImageTest::test_inspect_image PASSED       [ 22%]
09:09:54 tests/unit/api_image_test.py::ImageTest::test_inspect_image_undefined_id PASSED [ 22%]
09:09:54 tests/unit/api_image_test.py::ImageTest::test_load_image PASSED          [ 22%]
09:09:54 tests/unit/api_image_test.py::ImageTest::test_load_image_quiet PASSED    [ 22%]
09:09:54 tests/unit/api_image_test.py::ImageTest::test_pull PASSED                [ 23%]
09:09:54 tests/unit/api_image_test.py::ImageTest::test_pull_stream PASSED         [ 23%]
09:09:54 tests/unit/api_image_test.py::ImageTest::test_push_image PASSED          [ 23%]
09:09:54 tests/unit/api_image_test.py::ImageTest::test_push_image_stream PASSED   [ 23%]
09:09:54 tests/unit/api_image_test.py::ImageTest::test_push_image_with_auth PASSED [ 23%]
09:09:54 tests/unit/api_image_test.py::ImageTest::test_push_image_with_tag PASSED [ 23%]
09:09:54 tests/unit/api_image_test.py::ImageTest::test_remove_image PASSED        [ 24%]
09:09:54 tests/unit/api_image_test.py::ImageTest::test_tag_image PASSED           [ 24%]
09:09:54 tests/unit/api_image_test.py::ImageTest::test_tag_image_force PASSED     [ 24%]
09:09:54 tests/unit/api_image_test.py::ImageTest::test_tag_image_tag PASSED       [ 24%]
09:09:54 tests/unit/api_network_test.py::NetworkTest::test_connect_container_to_network PASSED [ 24%]
09:09:54 tests/unit/api_network_test.py::NetworkTest::test_create_network PASSED  [ 25%]
09:09:54 tests/unit/api_network_test.py::NetworkTest::test_disconnect_container_from_network PASSED [ 25%]
09:09:54 tests/unit/api_network_test.py::NetworkTest::test_inspect_network PASSED [ 25%]
09:09:54 tests/unit/api_network_test.py::NetworkTest::test_list_networks PASSED   [ 25%]
09:09:54 tests/unit/api_network_test.py::NetworkTest::test_remove_network PASSED  [ 25%]
09:09:54 tests/unit/api_test.py::DockerApiTest::test_auto_retrieve_server_version PASSED [ 25%]
09:09:54 tests/unit/api_test.py::DockerApiTest::test_create_host_config_secopt PASSED [ 26%]
09:09:54 tests/unit/api_test.py::DockerApiTest::test_ctor PASSED                  [ 26%]
09:09:54 tests/unit/api_test.py::DockerApiTest::test_events PASSED                [ 26%]
09:09:54 tests/unit/api_test.py::DockerApiTest::test_events_with_filters PASSED   [ 26%]
09:09:54 tests/unit/api_test.py::DockerApiTest::test_events_with_since_until PASSED [ 26%]
09:09:54 tests/unit/api_test.py::DockerApiTest::test_info PASSED                  [ 26%]
09:09:54 tests/unit/api_test.py::DockerApiTest::test_login PASSED                 [ 27%]
09:09:54 tests/unit/api_test.py::DockerApiTest::test_remove_link FAILED           [ 27%]
09:09:54 tests/unit/api_test.py::DockerApiTest::test_retrieve_server_version PASSED [ 27%]
09:09:54 tests/unit/api_test.py::DockerApiTest::test_search PASSED                [ 27%]
09:09:54 tests/unit/api_test.py::DockerApiTest::test_stream_helper_decoding PASSED [ 27%]
09:09:54 tests/unit/api_test.py::DockerApiTest::test_url_compatibility_http PASSED [ 28%]
09:09:54 tests/unit/api_test.py::DockerApiTest::test_url_compatibility_http_unix_triple_slash PASSED [ 28%]
09:09:54 tests/unit/api_test.py::DockerApiTest::test_url_compatibility_tcp PASSED [ 28%]
09:09:55 tests/unit/api_test.py::DockerApiTest::test_url_compatibility_unix PASSED [ 28%]
09:09:55 tests/unit/api_test.py::DockerApiTest::test_url_compatibility_unix_triple_slash PASSED [ 28%]
09:09:55 tests/unit/api_test.py::DockerApiTest::test_url_invalid_resource PASSED  [ 28%]
09:09:55 tests/unit/api_test.py::DockerApiTest::test_url_no_resource PASSED       [ 29%]
09:09:55 tests/unit/api_test.py::DockerApiTest::test_url_unversioned_api PASSED   [ 29%]
09:09:55 tests/unit/api_test.py::DockerApiTest::test_url_valid_resource PASSED    [ 29%]
09:09:55 tests/unit/api_test.py::DockerApiTest::test_version PASSED               [ 29%]
09:09:55 tests/unit/api_test.py::DockerApiTest::test_version_no_api_version PASSED [ 29%]
09:09:55 tests/unit/api_test.py::UnixSocketStreamTest::test_early_stream_response PASSED [ 29%]
09:09:55 tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_stream_no_tty PASSED [ 30%]
09:09:55 tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_stream_no_tty_demux PASSED [ 30%]
09:09:55 tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_stream_tty PASSED [ 30%]
09:09:55 tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_stream_tty_demux PASSED [ 30%]
09:09:56 tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_tty PASSED [ 30%]
09:09:56 tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_tty_demux PASSED [ 30%]
09:09:56 tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_tty PASSED [ 31%]
09:09:56 tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_tty_demux PASSED [ 31%]
09:09:56 tests/unit/api_test.py::UserAgentTest::test_custom_user_agent PASSED     [ 31%]
09:09:56 tests/unit/api_test.py::UserAgentTest::test_default_user_agent PASSED    [ 31%]
09:09:56 tests/unit/api_test.py::DisableSocketTest::test_disable_socket_timeout PASSED [ 31%]
09:09:56 tests/unit/api_test.py::DisableSocketTest::test_disable_socket_timeout2 PASSED [ 32%]
09:09:56 tests/unit/api_test.py::DisableSocketTest::test_disable_socket_timout_non_blocking PASSED [ 32%]
09:09:56 tests/unit/api_volume_test.py::VolumeTest::test_create_volume PASSED     [ 32%]
09:09:56 tests/unit/api_volume_test.py::VolumeTest::test_create_volume_invalid_opts_type PASSED [ 32%]
09:09:56 tests/unit/api_volume_test.py::VolumeTest::test_create_volume_with_driver PASSED [ 32%]
09:09:56 tests/unit/api_volume_test.py::VolumeTest::test_create_volume_with_invalid_labels PASSED [ 32%]
09:09:56 tests/unit/api_volume_test.py::VolumeTest::test_create_volume_with_labels PASSED [ 33%]
09:09:56 tests/unit/api_volume_test.py::VolumeTest::test_create_volume_with_no_specified_name PASSED [ 33%]
09:09:56 tests/unit/api_volume_test.py::VolumeTest::test_inspect_volume PASSED    [ 33%]
09:09:56 tests/unit/api_volume_test.py::VolumeTest::test_list_volumes PASSED      [ 33%]
09:09:56 tests/unit/api_volume_test.py::VolumeTest::test_list_volumes_and_filters PASSED [ 33%]
09:09:56 tests/unit/api_volume_test.py::VolumeTest::test_remove_volume PASSED     [ 33%]
09:09:56 tests/unit/auth_test.py::RegressionTest::test_803_urlsafe_encode PASSED  [ 34%]
09:09:56 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_explicit_hub_index_library_image PASSED [ 34%]
09:09:56 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_explicit_legacy_hub_index_library_image PASSED [ 34%]
09:09:56 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_invalid_index_name PASSED [ 34%]
09:09:56 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_dotted_hub_library_image PASSED [ 34%]
09:09:56 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_hub_image PASSED [ 35%]
09:09:56 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_hub_library_image PASSED [ 35%]
09:09:56 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_localhost PASSED [ 35%]
09:09:56 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_localhost_with_username PASSED [ 35%]
09:09:56 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_no_dots_but_port PASSED [ 35%]
09:09:56 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_no_dots_but_port_and_username PASSED [ 35%]
09:09:56 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_private_registry PASSED [ 36%]
09:09:56 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_private_registry_with_port PASSED [ 36%]
09:09:57 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_private_registry_with_username PASSED [ 36%]
09:09:57 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_auth_with_empty_credstore_and_auth_dict PASSED [ 36%]
09:09:57 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_default_explicit_none PASSED [ 36%]
09:09:57 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_default_registry PASSED [ 36%]
09:09:57 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_fully_explicit PASSED [ 37%]
09:09:57 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_hostname_only PASSED [ 37%]
09:09:57 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_legacy_config PASSED [ 37%]
09:09:57 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_match PASSED [ 37%]
09:09:57 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_path PASSED [ 37%]
09:09:57 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_path_trailing_slash PASSED [ 38%]
09:09:57 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_path_wrong_insecure_proto PASSED [ 38%]
09:09:57 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_path_wrong_secure_proto PASSED [ 38%]
09:09:57 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_protocol PASSED [ 38%]
09:09:57 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_path_wrong_proto PASSED [ 38%]
09:09:57 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_explicit_hub PASSED [ 38%]
09:09:57 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_explicit_legacy_hub PASSED [ 39%]
09:09:57 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_hub_image PASSED [ 39%]
09:09:57 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_library_image PASSED [ 39%]
09:09:57 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_private_registry PASSED [ 39%]
09:09:57 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_unauthenticated_registry PASSED [ 39%]
09:09:57 tests/unit/auth_test.py::LoadConfigTest::test_load_config_custom_config_env PASSED [ 39%]
09:09:57 tests/unit/auth_test.py::LoadConfigTest::test_load_config_custom_config_env_utf8 PASSED [ 40%]
09:09:57 tests/unit/auth_test.py::LoadConfigTest::test_load_config_custom_config_env_with_auths PASSED [ 40%]
09:09:57 tests/unit/auth_test.py::LoadConfigTest::test_load_config_identity_token PASSED [ 40%]
09:09:57 tests/unit/auth_test.py::LoadConfigTest::test_load_config_invalid_auth_dict PASSED [ 40%]
09:09:57 tests/unit/auth_test.py::LoadConfigTest::test_load_config_no_file PASSED [ 40%]
09:09:57 tests/unit/auth_test.py::LoadConfigTest::test_load_config_unknown_keys PASSED [ 40%]
09:09:57 tests/unit/auth_test.py::LoadConfigTest::test_load_config_with_random_name PASSED [ 41%]
09:09:57 tests/unit/auth_test.py::LoadConfigTest::test_load_json_config PASSED    [ 41%]
09:09:57 tests/unit/auth_test.py::LoadConfigTest::test_load_legacy_config PASSED  [ 41%]
09:09:57 tests/unit/auth_test.py::LoadConfigTest::test_load_modern_json_config PASSED [ 41%]
09:09:57 tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_3_sources PASSED [ 41%]
09:09:57 tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_credstore_only PASSED [ 42%]
09:09:57 tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_credstore_overrides_auth_entry PASSED [ 42%]
09:09:57 tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_helpers_override_default PASSED [ 42%]
09:09:57 tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_with_auths_entries PASSED [ 42%]
09:09:57 tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_with_credhelpers_only PASSED [ 42%]
09:09:57 tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_with_empty_auths_entry PASSED [ 42%]
09:09:57 tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_with_empty_credhelper PASSED [ 43%]
09:09:57 tests/unit/auth_test.py::CredstoreTest::test_get_credential_store PASSED [ 43%]
09:09:57 tests/unit/auth_test.py::CredstoreTest::test_get_credential_store_default_index PASSED [ 43%]
09:09:57 tests/unit/auth_test.py::CredstoreTest::test_get_credential_store_no_default PASSED [ 43%]
09:09:57 tests/unit/auth_test.py::CredstoreTest::test_get_credential_store_with_plain_dict PASSED [ 43%]
09:09:57 tests/unit/client_test.py::ClientTest::test_call_api_client_method PASSED [ 43%]
09:09:57 tests/unit/client_test.py::ClientTest::test_call_containers PASSED       [ 44%]
09:09:57 tests/unit/client_test.py::ClientTest::test_default_pool_size_unix PASSED [ 44%]
09:09:57 tests/unit/client_test.py::ClientTest::test_default_pool_size_win SKIPPED [ 44%]
09:09:57 tests/unit/client_test.py::ClientTest::test_events PASSED                [ 44%]
09:09:57 tests/unit/client_test.py::ClientTest::test_info PASSED                  [ 44%]
09:09:57 tests/unit/client_test.py::ClientTest::test_ping PASSED                  [ 45%]
09:09:57 tests/unit/client_test.py::ClientTest::test_pool_size_unix PASSED        [ 45%]
09:09:57 tests/unit/client_test.py::ClientTest::test_pool_size_win SKIPPED (N...) [ 45%]
09:09:57 tests/unit/client_test.py::ClientTest::test_version PASSED               [ 45%]
09:09:57 tests/unit/client_test.py::FromEnvTest::test_default_pool_size_from_env_unix PASSED [ 45%]
09:09:57 tests/unit/client_test.py::FromEnvTest::test_default_pool_size_from_env_win SKIPPED [ 45%]
09:09:57 tests/unit/client_test.py::FromEnvTest::test_from_env PASSED             [ 46%]
09:09:57 tests/unit/client_test.py::FromEnvTest::test_from_env_with_version PASSED [ 46%]
09:09:57 tests/unit/client_test.py::FromEnvTest::test_from_env_without_timeout_uses_default PASSED [ 46%]
09:09:57 tests/unit/client_test.py::FromEnvTest::test_from_env_without_version_uses_default PASSED [ 46%]
09:09:57 tests/unit/client_test.py::FromEnvTest::test_pool_size_from_env_unix PASSED [ 46%]
09:09:57 tests/unit/client_test.py::FromEnvTest::test_pool_size_from_env_win SKIPPED [ 46%]
09:09:57 tests/unit/context_test.py::BaseContextTest::test_context_inspect_without_params PASSED [ 47%]
09:09:57 tests/unit/context_test.py::BaseContextTest::test_default_in_context_list PASSED [ 47%]
09:09:57 tests/unit/context_test.py::BaseContextTest::test_fail_on_default_context_create PASSED [ 47%]
09:09:57 tests/unit/context_test.py::BaseContextTest::test_get_current_context PASSED [ 47%]
09:09:57 tests/unit/context_test.py::BaseContextTest::test_https_host PASSED      [ 47%]
09:09:57 tests/unit/context_test.py::BaseContextTest::test_url_compatibility_on_linux PASSED [ 47%]
09:09:57 tests/unit/context_test.py::BaseContextTest::test_url_compatibility_on_windows SKIPPED [ 48%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_cpu_cfs_types PASSED [ 48%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_cpu_count_types PASSED [ 48%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_cpu_percent_types PASSED [ 48%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_mem_swappiness PASSED [ 48%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_nano_cpus_types PASSED [ 49%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_no_options_newer_api_version PASSED [ 49%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_pid_mode PASSED [ 49%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_blkio_constraints PASSED [ 49%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_count PASSED [ 49%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_percent PASSED [ 49%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_period PASSED [ 50%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_quota PASSED [ 50%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_rt_period PASSED [ 50%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_rt_period_types PASSED [ 50%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_rt_runtime PASSED [ 50%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_dns_opt PASSED [ 50%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_isolation PASSED [ 51%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_kernel_memory PASSED [ 51%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_mem_reservation PASSED [ 51%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_nano_cpus PASSED [ 51%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_oom_kill_disable PASSED [ 51%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_oom_score_adj PASSED [ 52%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_pids_limit PASSED [ 52%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_shm_size PASSED [ 52%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_shm_size_in_mb PASSED [ 52%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_userns_mode PASSED [ 52%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_uts PASSED [ 52%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_volume_driver PASSED [ 53%]
09:09:57 tests/unit/dockertypes_test.py::HostConfigTest::test_ctrate_host_config_with_cpu_rt_runtime_types PASSED [ 53%]
09:09:57 tests/unit/dockertypes_test.py::ContainerSpecTest::test_parse_mounts PASSED [ 53%]
09:09:57 tests/unit/dockertypes_test.py::UlimitTest::test_create_host_config_dict_ulimit PASSED [ 53%]
09:09:57 tests/unit/dockertypes_test.py::UlimitTest::test_create_host_config_dict_ulimit_capitals PASSED [ 53%]
09:09:57 tests/unit/dockertypes_test.py::UlimitTest::test_create_host_config_obj_ulimit PASSED [ 53%]
09:09:57 tests/unit/dockertypes_test.py::UlimitTest::test_ulimit_invalid_type PASSED [ 54%]
09:09:57 tests/unit/dockertypes_test.py::LogConfigTest::test_create_host_config_dict_logconfig PASSED [ 54%]
09:09:57 tests/unit/dockertypes_test.py::LogConfigTest::test_create_host_config_obj_logconfig PASSED [ 54%]
09:09:57 tests/unit/dockertypes_test.py::LogConfigTest::test_logconfig_invalid_config_type PASSED [ 54%]
09:09:57 tests/unit/dockertypes_test.py::EndpointConfigTest::test_create_endpoint_config_with_aliases PASSED [ 54%]
09:09:57 tests/unit/dockertypes_test.py::IPAMConfigTest::test_create_ipam_config PASSED [ 54%]
09:09:57 tests/unit/dockertypes_test.py::ServiceModeTest::test_global_replicas_error PASSED [ 55%]
09:09:57 tests/unit/dockertypes_test.py::ServiceModeTest::test_global_simple PASSED [ 55%]
09:09:57 tests/unit/dockertypes_test.py::ServiceModeTest::test_invalid_mode PASSED [ 55%]
09:09:57 tests/unit/dockertypes_test.py::ServiceModeTest::test_replicated_replicas PASSED [ 55%]
09:09:57 tests/unit/dockertypes_test.py::ServiceModeTest::test_replicated_replicas_0 PASSED [ 55%]
09:09:57 tests/unit/dockertypes_test.py::ServiceModeTest::test_replicated_simple PASSED [ 56%]
09:09:57 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_bind PASSED  [ 56%]
09:09:57 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_bind_windows XFAIL [ 56%]
09:09:57 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_named_volume PASSED [ 56%]
09:09:57 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_invalid PASSED [ 56%]
09:09:57 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_no_source PASSED [ 56%]
09:09:57 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_ro PASSED [ 57%]
09:09:57 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_rw PASSED [ 57%]
09:09:57 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_short_form PASSED [ 57%]
09:09:57 tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_invalid PASSED [ 57%]
09:09:57 tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_multiple PASSED [ 57%]
09:09:57 tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_no_protocol_and_mode PASSED [ 57%]
09:09:57 tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_simple PASSED [ 58%]
09:09:57 tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_with_protocol PASSED [ 58%]
09:09:57 tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_with_protocol_and_mode PASSED [ 58%]
09:09:57 tests/unit/errors_test.py::APIErrorTest::test_api_error_is_caught_by_dockerexception PASSED [ 58%]
09:09:57 tests/unit/errors_test.py::APIErrorTest::test_create_error_from_exception PASSED [ 58%]
09:09:57 tests/unit/errors_test.py::APIErrorTest::test_is_client_error_400 PASSED [ 59%]
09:09:57 tests/unit/errors_test.py::APIErrorTest::test_is_client_error_500 PASSED [ 59%]
09:09:57 tests/unit/errors_test.py::APIErrorTest::test_is_error_300 PASSED        [ 59%]
09:09:57 tests/unit/errors_test.py::APIErrorTest::test_is_error_400 PASSED        [ 59%]
09:09:57 tests/unit/errors_test.py::APIErrorTest::test_is_error_500 PASSED        [ 59%]
09:09:57 tests/unit/errors_test.py::APIErrorTest::test_is_server_error_200 PASSED [ 59%]
09:09:57 tests/unit/errors_test.py::APIErrorTest::test_is_server_error_300 PASSED [ 60%]
09:09:57 tests/unit/errors_test.py::APIErrorTest::test_is_server_error_400 PASSED [ 60%]
09:09:57 tests/unit/errors_test.py::APIErrorTest::test_is_server_error_500 PASSED [ 60%]
09:09:57 tests/unit/errors_test.py::APIErrorTest::test_status_code_200 PASSED     [ 60%]
09:09:57 tests/unit/errors_test.py::APIErrorTest::test_status_code_400 PASSED     [ 60%]
09:09:57 tests/unit/errors_test.py::APIErrorTest::test_status_code_500 PASSED     [ 60%]
09:09:57 tests/unit/errors_test.py::ContainerErrorTest::test_container_with_stderr PASSED [ 61%]
09:09:57 tests/unit/errors_test.py::ContainerErrorTest::test_container_without_stderr PASSED [ 61%]
09:09:57 tests/unit/errors_test.py::CreateUnexpectedKwargsErrorTest::test_create_unexpected_kwargs_error_multiple PASSED [ 61%]
09:09:57 tests/unit/errors_test.py::CreateUnexpectedKwargsErrorTest::test_create_unexpected_kwargs_error_single PASSED [ 61%]
09:09:57 tests/unit/models_containers_test.py::ContainerCollectionTest::test_create PASSED [ 61%]
09:09:57 tests/unit/models_containers_test.py::ContainerCollectionTest::test_create_container_args PASSED [ 61%]
09:09:57 tests/unit/models_containers_test.py::ContainerCollectionTest::test_create_with_image_object PASSED [ 62%]
09:09:57 tests/unit/models_containers_test.py::ContainerCollectionTest::test_get PASSED [ 62%]
09:09:57 tests/unit/models_containers_test.py::ContainerCollectionTest::test_list PASSED [ 62%]
09:09:57 tests/unit/models_containers_test.py::ContainerCollectionTest::test_list_ignore_removed PASSED [ 62%]
09:09:57 tests/unit/models_containers_test.py::ContainerCollectionTest::test_run PASSED [ 62%]
09:09:57 tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_detach PASSED [ 63%]
09:09:57 tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_pull PASSED [ 63%]
09:09:57 tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_remove PASSED [ 63%]
09:09:57 tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_with_error PASSED [ 63%]
09:09:57 tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_with_image_object PASSED [ 63%]
09:09:57 tests/unit/models_containers_test.py::ContainerTest::test_attach PASSED  [ 63%]
09:09:57 tests/unit/models_containers_test.py::ContainerTest::test_commit PASSED  [ 64%]
09:09:57 tests/unit/models_containers_test.py::ContainerTest::test_diff PASSED    [ 64%]
09:09:57 tests/unit/models_containers_test.py::ContainerTest::test_exec_run PASSED [ 64%]
09:09:57 tests/unit/models_containers_test.py::ContainerTest::test_exec_run_failure PASSED [ 64%]
09:09:57 tests/unit/models_containers_test.py::ContainerTest::test_export PASSED  [ 64%]
09:09:57 tests/unit/models_containers_test.py::ContainerTest::test_get_archive PASSED [ 64%]
09:09:57 tests/unit/models_containers_test.py::ContainerTest::test_image PASSED   [ 65%]
09:09:57 tests/unit/models_containers_test.py::ContainerTest::test_kill PASSED    [ 65%]
09:09:57 tests/unit/models_containers_test.py::ContainerTest::test_labels PASSED  [ 65%]
09:09:57 tests/unit/models_containers_test.py::ContainerTest::test_logs PASSED    [ 65%]
09:09:57 tests/unit/models_containers_test.py::ContainerTest::test_name PASSED    [ 65%]
09:09:57 tests/unit/models_containers_test.py::ContainerTest::test_pause PASSED   [ 66%]
09:09:57 tests/unit/models_containers_test.py::ContainerTest::test_put_archive PASSED [ 66%]
09:09:57 tests/unit/models_containers_test.py::ContainerTest::test_remove PASSED  [ 66%]
09:09:57 tests/unit/models_containers_test.py::ContainerTest::test_rename PASSED  [ 66%]
09:09:57 tests/unit/models_containers_test.py::ContainerTest::test_resize PASSED  [ 66%]
09:09:57 tests/unit/models_containers_test.py::ContainerTest::test_restart PASSED [ 66%]
09:09:57 tests/unit/models_containers_test.py::ContainerTest::test_start PASSED   [ 67%]
09:09:57 tests/unit/models_containers_test.py::ContainerTest::test_stats PASSED   [ 67%]
09:09:57 tests/unit/models_containers_test.py::ContainerTest::test_status PASSED  [ 67%]
09:09:57 tests/unit/models_containers_test.py::ContainerTest::test_stop PASSED    [ 67%]
09:09:57 tests/unit/models_containers_test.py::ContainerTest::test_top PASSED     [ 67%]
09:09:57 tests/unit/models_containers_test.py::ContainerTest::test_unpause PASSED [ 67%]
09:09:57 tests/unit/models_containers_test.py::ContainerTest::test_update PASSED  [ 68%]
09:09:57 tests/unit/models_containers_test.py::ContainerTest::test_wait PASSED    [ 68%]
09:09:57 tests/unit/models_images_test.py::ImageCollectionTest::test_build PASSED [ 68%]
09:09:57 tests/unit/models_images_test.py::ImageCollectionTest::test_get PASSED   [ 68%]
09:09:57 tests/unit/models_images_test.py::ImageCollectionTest::test_labels PASSED [ 68%]
09:09:57 tests/unit/models_images_test.py::ImageCollectionTest::test_list PASSED  [ 69%]
09:09:57 tests/unit/models_images_test.py::ImageCollectionTest::test_load PASSED  [ 69%]
09:09:57 tests/unit/models_images_test.py::ImageCollectionTest::test_pull PASSED  [ 69%]
09:09:57 tests/unit/models_images_test.py::ImageCollectionTest::test_pull_multiple PASSED [ 69%]
09:09:57 tests/unit/models_images_test.py::ImageCollectionTest::test_pull_tag_precedence PASSED [ 69%]
09:09:57 tests/unit/models_images_test.py::ImageCollectionTest::test_pull_with_stream_param PASSED [ 69%]
09:09:57 tests/unit/models_images_test.py::ImageCollectionTest::test_push PASSED  [ 70%]
09:09:57 tests/unit/models_images_test.py::ImageCollectionTest::test_remove PASSED [ 70%]
09:09:57 tests/unit/models_images_test.py::ImageCollectionTest::test_search PASSED [ 70%]
09:09:57 tests/unit/models_images_test.py::ImageCollectionTest::test_search_limit PASSED [ 70%]
09:09:57 tests/unit/models_images_test.py::ImageTest::test_history PASSED         [ 70%]
09:09:57 tests/unit/models_images_test.py::ImageTest::test_save PASSED            [ 70%]
09:09:57 tests/unit/models_images_test.py::ImageTest::test_short_id PASSED        [ 71%]
09:09:57 tests/unit/models_images_test.py::ImageTest::test_tag PASSED             [ 71%]
09:09:57 tests/unit/models_images_test.py::ImageTest::test_tags PASSED            [ 71%]
09:09:57 tests/unit/models_networks_test.py::NetworkCollectionTest::test_create PASSED [ 71%]
09:09:57 tests/unit/models_networks_test.py::NetworkCollectionTest::test_get PASSED [ 71%]
09:09:57 tests/unit/models_networks_test.py::NetworkCollectionTest::test_list PASSED [ 71%]
09:09:57 tests/unit/models_networks_test.py::NetworkTest::test_connect PASSED     [ 72%]
09:09:57 tests/unit/models_networks_test.py::NetworkTest::test_disconnect PASSED  [ 72%]
09:09:57 tests/unit/models_networks_test.py::NetworkTest::test_remove PASSED      [ 72%]
09:09:57 tests/unit/models_resources_test.py::ModelTest::test_hash PASSED         [ 72%]
09:09:57 tests/unit/models_resources_test.py::ModelTest::test_reload PASSED       [ 72%]
09:09:57 tests/unit/models_secrets_test.py::CreateServiceTest::test_secrets_repr PASSED [ 73%]
09:09:57 tests/unit/models_services_test.py::CreateServiceKwargsTest::test_get_create_service_kwargs PASSED [ 73%]
09:09:57 tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_hostname_prefix_trim PASSED [ 73%]
09:09:57 tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_hostname_and_port PASSED [ 73%]
09:09:57 tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_hostname_only PASSED [ 73%]
09:09:57 tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_url PASSED [ 73%]
09:09:57 tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_user_and_hostname PASSED [ 74%]
09:09:57 tests/unit/ssladapter_test.py::SSLAdapterTest::test_only_uses_tls PASSED [ 74%]
09:09:57 tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_dns_failure PASSED [ 74%]
09:09:57 tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_dns_success PASSED [ 74%]
09:09:57 tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_ip_address_failure PASSED [ 74%]
09:09:57 tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_ip_address_success PASSED [ 74%]
09:09:57 tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_localhost_success PASSED [ 75%]
09:09:57 tests/unit/swarm_test.py::SwarmTest::test_join_swarm PASSED              [ 75%]
09:09:57 tests/unit/swarm_test.py::SwarmTest::test_join_swarm_no_listen_address_takes_default PASSED [ 75%]
09:09:57 tests/unit/swarm_test.py::SwarmTest::test_node_update PASSED             [ 75%]
09:09:57 tests/unit/types_containers_test.py::test_uid_0_is_not_elided PASSED     [ 75%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_directory PASSED  [ 76%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_single_exception PASSED [ 76%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_subdir_exception PASSED [ 76%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_subdir_exception_win32_pathsep SKIPPED [ 76%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_trailing_slash PASSED [ 76%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_wildcard_exception PASSED [ 76%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_double_wildcard PASSED [ 77%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_double_wildcard_with_exception PASSED [ 77%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_custom_dockerfile PASSED [ 77%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_dockerfile_child PASSED [ 77%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_dockerfile_dockerignore PASSED [ 77%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_include_absolute_path PASSED [ 77%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_include_wildcard PASSED [ 78%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_last_line_precedence PASSED [ 78%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_no_dupes PASSED   [ 78%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_no_excludes PASSED [ 78%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_parent_directory PASSED [ 78%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_question_mark PASSED [ 78%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_and_double_wildcard PASSED [ 79%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_filename PASSED [ 79%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_filename_leading_dot_slash PASSED [ 79%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_filename_trailing_slash PASSED [ 79%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_single_filename PASSED [ 79%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_single_filename_leading_slash PASSED [ 80%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_wildcard_filename PASSED [ 80%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_with_path_traversal PASSED [ 80%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_subdirectory PASSED [ 80%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_subdirectory_win32_pathsep SKIPPED [ 80%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_trailing_double_wildcard PASSED [ 80%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_exclude PASSED [ 81%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_filename_end PASSED [ 81%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_filename_start PASSED [ 81%]
09:09:57 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_subdir_single_filename PASSED [ 81%]
09:09:58 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_subdir_wildcard_filename PASSED [ 81%]
09:09:58 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_with_exception PASSED [ 81%]
09:09:58 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_with_wildcard_exception PASSED [ 82%]
09:09:58 tests/unit/utils_build_test.py::TarTest::test_tar_directory_link PASSED  [ 82%]
09:09:58 tests/unit/utils_build_test.py::TarTest::test_tar_socket_file PASSED     [ 82%]
09:09:58 tests/unit/utils_build_test.py::TarTest::test_tar_with_broken_symlinks PASSED [ 82%]
09:09:58 tests/unit/utils_build_test.py::TarTest::test_tar_with_directory_symlinks PASSED [ 82%]
09:09:58 tests/unit/utils_build_test.py::TarTest::test_tar_with_empty_directory PASSED [ 83%]
09:09:58 tests/unit/utils_build_test.py::TarTest::test_tar_with_excludes PASSED   [ 83%]
09:09:58 tests/unit/utils_build_test.py::TarTest::test_tar_with_file_symlinks PASSED [ 83%]
09:09:58 tests/unit/utils_build_test.py::TarTest::test_tar_with_inaccessible_file SKIPPED [ 83%]
09:09:58 tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_fallback PASSED [ 83%]
09:09:58 tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_environment PASSED [ 83%]
09:09:58 tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_explicit_path PASSED [ 84%]
09:09:58 tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_home_legacy_name PASSED [ 84%]
09:09:58 tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_home_posix PASSED [ 84%]
09:09:58 tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_home_windows SKIPPED [ 84%]
09:09:58 tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_custom_headers PASSED [ 84%]
09:09:58 tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_detach_keys PASSED [ 84%]
09:09:58 tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_from_env PASSED [ 85%]
09:09:58 tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_no_file PASSED [ 85%]
09:09:58 tests/unit/utils_json_stream_test.py::TestJsonSplitter::test_json_splitter_no_object PASSED [ 85%]
09:09:58 tests/unit/utils_json_stream_test.py::TestJsonSplitter::test_json_splitter_with_object PASSED [ 85%]
09:09:58 tests/unit/utils_json_stream_test.py::TestJsonSplitter::test_json_splitter_leading_whitespace PASSED [ 85%]
09:09:58 tests/unit/utils_json_stream_test.py::TestStreamAsText::test_stream_with_non_utf_unicode_character PASSED [ 85%]
09:09:58 tests/unit/utils_json_stream_test.py::TestStreamAsText::test_stream_with_utf_character PASSED [ 86%]
09:09:58 tests/unit/utils_json_stream_test.py::TestJsonStream::test_with_falsy_entries PASSED [ 86%]
09:09:58 tests/unit/utils_json_stream_test.py::TestJsonStream::test_with_leading_whitespace PASSED [ 86%]
09:09:58 tests/unit/utils_proxy_test.py::ProxyConfigTest::test_environment PASSED [ 86%]
09:09:58 tests/unit/utils_proxy_test.py::ProxyConfigTest::test_from_dict PASSED   [ 86%]
09:09:58 tests/unit/utils_proxy_test.py::ProxyConfigTest::test_inject_proxy_environment PASSED [ 87%]
09:09:58 tests/unit/utils_proxy_test.py::ProxyConfigTest::test_new PASSED         [ 87%]
09:09:58 tests/unit/utils_proxy_test.py::ProxyConfigTest::test_truthiness PASSED  [ 87%]
09:09:58 tests/unit/utils_test.py::DecoratorsTest::test_update_headers PASSED     [ 87%]
09:09:58 tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_alternate_env PASSED [ 87%]
09:09:58 tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_empty PASSED [ 87%]
09:09:58 tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_no_cert_path PASSED [ 88%]
09:09:58 tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_tls PASSED [ 88%]
09:09:58 tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_tls_verify_false PASSED [ 88%]
09:09:58 tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_tls_verify_false_no_cert PASSED [ 88%]
09:09:58 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_compact PASSED [ 88%]
09:09:58 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_complete PASSED [ 88%]
09:09:58 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_empty PASSED [ 89%]
09:09:58 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_list PASSED [ 89%]
09:09:58 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_no_mode PASSED [ 89%]
09:09:58 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_unicode_bytes_input PASSED [ 89%]
09:09:58 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_unicode_unicode_input PASSED [ 89%]
09:09:58 tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_commented_line PASSED [ 90%]
09:09:58 tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_invalid_line PASSED [ 90%]
09:09:58 tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_newline PASSED [ 90%]
09:09:58 tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_proper PASSED [ 90%]
09:09:58 tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_with_equals_character PASSED [ 90%]
09:09:58 tests/unit/utils_test.py::ParseHostTest::test_parse_host PASSED          [ 90%]
09:09:58 tests/unit/utils_test.py::ParseHostTest::test_parse_host_empty_value PASSED [ 91%]
09:09:58 tests/unit/utils_test.py::ParseHostTest::test_parse_host_tls PASSED      [ 91%]
09:09:58 tests/unit/utils_test.py::ParseHostTest::test_parse_host_tls_tcp_proto PASSED [ 91%]
09:09:58 tests/unit/utils_test.py::ParseHostTest::test_parse_host_trailing_slash PASSED [ 91%]
09:09:58 tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_image_no_tag PASSED [ 91%]
09:09:58 tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_image_sha PASSED [ 91%]
09:09:58 tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_image_tag PASSED [ 92%]
09:09:58 tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_user_image_no_tag PASSED [ 92%]
09:09:58 tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_user_image_tag PASSED [ 92%]
09:09:58 tests/unit/utils_test.py::ParseRepositoryTagTest::test_private_reg_image_no_tag PASSED [ 92%]
09:09:58 tests/unit/utils_test.py::ParseRepositoryTagTest::test_private_reg_image_sha PASSED [ 92%]
09:09:58 tests/unit/utils_test.py::ParseRepositoryTagTest::test_private_reg_image_tag PASSED [ 92%]
09:09:58 tests/unit/utils_test.py::ParseDeviceTest::test_dict PASSED              [ 93%]
09:09:58 tests/unit/utils_test.py::ParseDeviceTest::test_full_string_definition PASSED [ 93%]
09:09:58 tests/unit/utils_test.py::ParseDeviceTest::test_hybrid_list PASSED       [ 93%]
09:09:58 tests/unit/utils_test.py::ParseDeviceTest::test_partial_string_definition PASSED [ 93%]
09:09:58 tests/unit/utils_test.py::ParseDeviceTest::test_permissionless_string_definition PASSED [ 93%]
09:09:58 tests/unit/utils_test.py::ParseBytesTest::test_parse_bytes_float PASSED  [ 94%]
09:09:58 tests/unit/utils_test.py::ParseBytesTest::test_parse_bytes_invalid PASSED [ 94%]
09:09:58 tests/unit/utils_test.py::ParseBytesTest::test_parse_bytes_valid PASSED  [ 94%]
09:09:58 tests/unit/utils_test.py::UtilsTest::test_convert_filters PASSED         [ 94%]
09:09:58 tests/unit/utils_test.py::UtilsTest::test_decode_json_header PASSED      [ 94%]
09:09:58 tests/unit/utils_test.py::SplitCommandTest::test_split_command_with_unicode PASSED [ 94%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_matching_internal_port_ranges PASSED [ 95%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_matching_internal_ports PASSED [ 95%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_nonmatching_internal_port_ranges PASSED [ 95%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_nonmatching_internal_ports PASSED [ 95%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_one_port PASSED [ 95%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_port_range PASSED [ 95%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_host_only_with_colon PASSED    [ 96%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_non_matching_length_port_ranges PASSED [ 96%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_port_and_range_invalid PASSED  [ 96%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_port_only_with_colon PASSED    [ 96%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_split_port_empty_string PASSED [ 96%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_split_port_invalid PASSED      [ 97%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_split_port_invalid_protocol PASSED [ 97%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_split_port_no_host_port PASSED [ 97%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_split_port_non_string PASSED   [ 97%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_split_port_random_port_range_with_host_port PASSED [ 97%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_split_port_range_no_host_port PASSED [ 97%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_split_port_range_with_host_ip_no_port PASSED [ 98%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_split_port_range_with_host_port PASSED [ 98%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_split_port_range_with_protocol PASSED [ 98%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_split_port_with_host_ip PASSED [ 98%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_split_port_with_host_ip_no_port PASSED [ 98%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_split_port_with_host_port PASSED [ 98%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_split_port_with_ipv6_address PASSED [ 99%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_split_port_with_ipv6_square_brackets_address PASSED [ 99%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_split_port_with_protocol PASSED [ 99%]
09:09:58 tests/unit/utils_test.py::PortsTest::test_with_no_container_port PASSED  [ 99%]
09:09:58 tests/unit/utils_test.py::FormatEnvironmentTest::test_format_env_binary_unicode_value PASSED [ 99%]
09:09:59 tests/unit/utils_test.py::FormatEnvironmentTest::test_format_env_no_value PASSED [100%]
09:09:59 
09:09:59 =================================== FAILURES ===================================
09:09:59 _____________________ ContainerTest.test_remove_container ______________________
09:09:59 tests/unit/api_container_test.py:1413: in test_remove_container
09:09:59     timeout=DEFAULT_TIMEOUT_SECONDS
09:09:59 /usr/local/lib/python3.7/unittest/mock.py:878: in assert_called_with
09:09:59     raise AssertionError(_error_message()) from cause
09:09:59 E   AssertionError: Expected call: mock('DELETE', 'http+docker://localhost/v1.41/containers/3cc2351ab11b', params={'v': False, 'link': False, 'force': False}, timeout=60)
09:09:59 E   Actual call: mock('DELETE', 'http+docker://localhost/v1.41/containers/3cc2351ab11b', params={'v': False, 'link': False, 'force': False}, timeout=70)
09:09:59 _________ ContainerTest.test_remove_container_with_dict_instead_of_id __________
09:09:59 tests/unit/api_container_test.py:1423: in test_remove_container_with_dict_instead_of_id
09:09:59     timeout=DEFAULT_TIMEOUT_SECONDS
09:09:59 /usr/local/lib/python3.7/unittest/mock.py:878: in assert_called_with
09:09:59     raise AssertionError(_error_message()) from cause
09:09:59 E   AssertionError: Expected call: mock('DELETE', 'http+docker://localhost/v1.41/containers/3cc2351ab11b', params={'v': False, 'link': False, 'force': False}, timeout=60)
09:09:59 E   Actual call: mock('DELETE', 'http+docker://localhost/v1.41/containers/3cc2351ab11b', params={'v': False, 'link': False, 'force': False}, timeout=70)
09:09:59 ________________________ DockerApiTest.test_remove_link ________________________
09:09:59 tests/unit/api_test.py:323: in test_remove_link
09:09:59     timeout=DEFAULT_TIMEOUT_SECONDS
09:09:59 /usr/local/lib/python3.7/unittest/mock.py:878: in assert_called_with
09:09:59     raise AssertionError(_error_message()) from cause
09:09:59 E   AssertionError: Expected call: mock('DELETE', 'http+docker://localhost/v1.41/containers/3cc2351ab11b', params={'v': False, 'link': True, 'force': False}, timeout=60)
09:09:59 E   Actual call: mock('DELETE', 'http+docker://localhost/v1.41/containers/3cc2351ab11b', params={'v': False, 'link': True, 'force': False}, timeout=70)
09:09:59 
09:09:59 ---------- coverage: platform linux, python 3.7.12-final-0 -----------
09:09:59 Name                                  Stmts   Miss Branch BrPart  Cover
09:09:59 -----------------------------------------------------------------------
09:09:59 docker/__init__.py                        8      0      0      0   100%
09:09:59 docker/api/__init__.py                    1      0      0      0   100%
09:09:59 docker/api/build.py                     126     41     92     21    62%
09:09:59 docker/api/client.py                    261     65     92     11    75%
09:09:59 docker/api/config.py                     29     18      4      0    33%
09:09:59 docker/api/container.py                 272     73    108     27    65%
09:09:59 docker/api/daemon.py                     39      4     14      4    85%
09:09:59 docker/api/exec_api.py                   45     11     22      9    67%
09:09:59 docker/api/image.py                     159     43     60     14    70%
09:09:59 docker/api/network.py                    90     35     48     11    51%
09:09:59 docker/api/plugin.py                     89     68     14      0    20%
09:09:59 docker/api/secret.py                     34     22      8      0    29%
09:09:59 docker/api/service.py                   200    176    149      0     7%
09:09:59 docker/api/swarm.py                     106     67     38      1    28%
09:09:59 docker/api/volume.py                     38      9     14      2    71%
09:09:59 docker/auth.py                          197     16     74     16    88%
09:09:59 docker/client.py                         69      9      2      0    87%
09:09:59 docker/constants.py                      21      0      0      0   100%
09:09:59 docker/context/__init__.py                2      0      0      0   100%
09:09:59 docker/context/api.py                    78     41     38      8    39%
09:09:59 docker/context/config.py                 61     33     16      2    42%
09:09:59 docker/context/context.py               154     96     64      6    29%
09:09:59 docker/credentials/__init__.py            3      0      0      0   100%
09:09:59 docker/credentials/constants.py           4      0      0      0   100%
09:09:59 docker/credentials/errors.py             11      4      2      0    54%
09:09:59 docker/credentials/store.py              44     30     12      0    25%
09:09:59 docker/credentials/utils.py              23     18     12      0    14%
09:09:59 docker/errors.py                        110     26     20      4    71%
09:09:59 docker/models/__init__.py                 0      0      0      0   100%
09:09:59 docker/models/configs.py                 21      8      2      0    57%
09:09:59 docker/models/containers.py             183     11     70      9    91%
09:09:59 docker/models/images.py                 136     55     56      4    52%
09:09:59 docker/models/networks.py                37      7     12      3    71%
09:09:59 docker/models/nodes.py                   15      5      2      0    59%
09:09:59 docker/models/plugins.py                 48     29      8      0    34%
09:09:59 docker/models/resource.py                41     10      6      3    72%
09:09:59 docker/models/secrets.py                 22      4      2      0    75%
09:09:59 docker/models/services.py                87     35     36      4    59%
09:09:59 docker/models/swarm.py                   39     21      6      0    40%
09:09:59 docker/models/volumes.py                 23     10      4      0    48%
09:09:59 docker/tls.py                            37      6     14      6    76%
09:09:59 docker/transport/__init__.py             11      3      0      0    73%
09:09:59 docker/transport/basehttpadapter.py       6      0      2      1    88%
09:09:59 docker/transport/npipeconn.py            57     52      8      0     8%
09:09:59 docker/transport/npipesocket.py         134    130     20      0     3%
09:09:59 docker/transport/sshconn.py             162    105     54      3    30%
09:09:59 docker/transport/ssladapter.py           36     10     10      4    65%
09:09:59 docker/transport/unixconn.py             54      3      6      1    93%
09:09:59 docker/types/__init__.py                  6      0      0      0   100%
09:09:59 docker/types/base.py                      4      0      2      0   100%
09:09:59 docker/types/containers.py              419     79    326     43    81%
09:09:59 docker/types/daemon.py                   36     24     14      0    24%
09:09:59 docker/types/healthcheck.py              33     20      4      0    35%
09:09:59 docker/types/networks.py                 41     11     28      9    65%
09:09:59 docker/types/services.py                321    146    216     41    50%
09:09:59 docker/types/swarm.py                    51     45     40      0     7%
09:09:59 docker/utils/__init__.py                  3      0      0      0   100%
09:09:59 docker/utils/build.py                   150     24     72     10    83%
09:09:59 docker/utils/config.py                   36      1     10      1    96%
09:09:59 docker/utils/decorators.py               32      1     12      1    95%
09:09:59 docker/utils/fnmatch.py                  55     18     28      2    61%
09:09:59 docker/utils/json_stream.py              40      8     14      2    78%
09:09:59 docker/utils/ports.py                    50      3     32      2    91%
09:09:59 docker/utils/proxy.py                    32      1     12      0    98%
09:09:59 docker/utils/socket.py                   85     10     40      8    84%
09:09:59 docker/utils/utils.py                   278     18    171     13    92%
09:09:59 docker/version.py                         2      0      2      0   100%
09:09:59 -----------------------------------------------------------------------
09:09:59 TOTAL                                  5097   1818   2244    306    60%
09:09:59 
09:09:59 =========================== short test summary info ============================
09:09:59 XFAIL tests/unit/dockertypes_test.py::MountTest::test_parse_mount_bind_windows
09:09:59 SKIPPED [1] tests/unit/api_build_test.py:169: Windows-specific syntax
09:09:59 SKIPPED [1] tests/unit/client_test.py:99: Npipe Connection Pool only on Windows
09:09:59 SKIPPED [1] tests/unit/client_test.py:138: Npipe Connection Pool only on Windows
09:09:59 SKIPPED [1] tests/unit/client_test.py:212: Npipe Connection Pool only on Windows
09:09:59 SKIPPED [1] tests/unit/client_test.py:249: Npipe Connection Pool only on Windows
09:09:59 SKIPPED [1] tests/unit/context_test.py:18: Windows specific path check
09:09:59 SKIPPED [1] tests/unit/utils_build_test.py:230: Backslash patterns only on Windows
09:09:59 SKIPPED [1] tests/unit/utils_build_test.py:252: Backslash patterns only on Windows
09:09:59 SKIPPED [1] tests/unit/utils_build_test.py:400: root user always has access ; no chmod on Windows
09:09:59 SKIPPED [1] tests/unit/utils_config_test.py:54: condition: sys.platform != 'win32'
09:09:59 ============= 3 failed, 557 passed, 10 skipped, 1 xfailed in 6.26s =============
[Pipeline] sh
09:09:59 + docker stop dpy-dind-2-0-py3.7-19.03.13
09:09:59 Error response from daemon: No such container: dpy-dind-2-0-py3.7-19.03.13
[Pipeline] }
[Pipeline] // withDockerRegistry
[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // withDockerRegistry
[Pipeline] }
[Pipeline] // node
Running on EC2 (managed-agents) - ubuntu-2004-cgroup1 (i-038677a38b0431f65) in /home/ubuntu/workspace/docker-py_PR-2959
[Pipeline] }
Failed in branch py3.7_19.03.13
[Pipeline] {
[Pipeline] withDockerRegistry
$ docker login -u dockerbuildbot -p ******** https://index.docker.io/v1/
WARNING! Using --password via the CLI is insecure. Use --password-stdin.
WARNING! Your password will be stored unencrypted in /home/ubuntu/workspace/docker-py_PR-2959@tmp/45498919-bf16-4df3-833f-1494f5e61537/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store

Login Succeeded
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] echo
09:09:59 cleanWorkspace: Ensuring workspace is owned by ubuntu
[Pipeline] echo
09:09:59 chowning workspace
[Pipeline] sh
09:10:00 + pwd
09:10:00 + id -u
09:10:00 + id -g
09:10:00 + docker run --rm -v /home/ubuntu/workspace/docker-py_PR-2959:/workspace busybox chown -R 1000:1000 /workspace
[Pipeline] echo
09:10:00 Removing all docker containers
[Pipeline] sh
09:10:01 + docker container ls -aq
[Pipeline] echo
09:10:01 Docker containers have been removed
[Pipeline] echo
09:10:01 cleanWorkspace: Removing existing workspace
[Pipeline] deleteDir
[Pipeline] echo
09:10:01 cleanWorkspace: Workspace is clean.
[Pipeline] stage
[Pipeline] { (test python=py3.7 / docker=20.10.12)
[Pipeline] checkout
09:10:01 The recommended git tool is: git
09:10:01 using credential docker-jenkins-github-credentials
09:10:01 Cloning the remote Git repository
09:10:01 Cloning with configured refspecs honoured and without tags
09:10:01 Fetching without tags
Cloning repository https://github.com/docker/docker-py.git
 > git init /home/ubuntu/workspace/docker-py_PR-2959 # timeout=10
Fetching upstream changes from https://github.com/docker/docker-py.git
 > git --version # timeout=10
 > git --version # 'git version 2.25.1'
using GIT_ASKPASS to set credentials docker-jenkins GitHub credentials
 > git fetch --no-tags --force --progress -- https://github.com/docker/docker-py.git +refs/pull/2959/head:refs/remotes/origin/PR-2959 +refs/heads/master:refs/remotes/origin/master # timeout=10
 > git config remote.origin.url https://github.com/docker/docker-py.git # timeout=10
 > git config --add remote.origin.fetch +refs/pull/2959/head:refs/remotes/origin/PR-2959 # timeout=10
 > git config --add remote.origin.fetch +refs/heads/master:refs/remotes/origin/master # timeout=10
 > git config remote.origin.url https://github.com/docker/docker-py.git # timeout=10
Fetching upstream changes from https://github.com/docker/docker-py.git
using GIT_ASKPASS to set credentials docker-jenkins GitHub credentials
 > git fetch --no-tags --force --progress -- https://github.com/docker/docker-py.git +refs/pull/2959/head:refs/remotes/origin/PR-2959 +refs/heads/master:refs/remotes/origin/master # timeout=10
09:10:02 Merging remotes/origin/master commit a48a5a9647761406d66e8271f19fab7fa0c5f582 into PR head commit b6deb149ce8ba3fc6638315c15a4f71bc424434b
09:10:02 Merge succeeded, producing b6deb149ce8ba3fc6638315c15a4f71bc424434b
09:10:02 Checking out Revision b6deb149ce8ba3fc6638315c15a4f71bc424434b (PR-2959)
09:10:02 Commit message: "Added timeout to container.remove()"
[Pipeline] withDockerRegistry
[Pipeline] {
[Pipeline] sh
09:10:03 + docker run --rm -e DOCKER_TEST_API_VERSION=1.40 dockerpinata/docker-py:py3-b6deb149ce8ba3fc6638315c15a4f71bc424434b py.test -v -rxs --cov=docker tests/unit
 > git config core.sparsecheckout # timeout=10
 > git checkout -f b6deb149ce8ba3fc6638315c15a4f71bc424434b # timeout=10
 > git remote # timeout=10
 > git config --get remote.origin.url # timeout=10
using GIT_ASKPASS to set credentials docker-jenkins GitHub credentials
 > git merge a48a5a9647761406d66e8271f19fab7fa0c5f582 # timeout=10
 > git rev-parse HEAD^{commit} # timeout=10
 > git config core.sparsecheckout # timeout=10
 > git checkout -f b6deb149ce8ba3fc6638315c15a4f71bc424434b # timeout=10
09:10:03 ============================= test session starts ==============================
09:10:03 platform linux -- Python 3.7.12, pytest-6.2.5, py-1.11.0, pluggy-1.0.0 -- /usr/local/bin/python
09:10:03 cachedir: .pytest_cache
09:10:03 rootdir: /src, configfile: pytest.ini
09:10:03 plugins: timeout-2.0.1, cov-3.0.0
$ docker login -u dockerbuildbot -p ******** https://index.docker.io/v1/
WARNING! Using --password via the CLI is insecure. Use --password-stdin.
WARNING! Your password will be stored unencrypted in /home/ubuntu/workspace/docker-py_PR-2959@tmp/03a2fac0-4546-4ff9-8014-66d86689656c/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store

Login Succeeded
09:10:04 collecting ... collected 571 items
09:10:04 
09:10:04 tests/unit/api_build_test.py::BuildTest::test_build_container PASSED     [  0%]
09:10:04 tests/unit/api_build_test.py::BuildTest::test_build_container_custom_context PASSED [  0%]
09:10:04 tests/unit/api_build_test.py::BuildTest::test_build_container_custom_context_gzip PASSED [  0%]
09:10:04 tests/unit/api_build_test.py::BuildTest::test_build_container_invalid_container_limits PASSED [  0%]
09:10:04 tests/unit/api_build_test.py::BuildTest::test_build_container_pull PASSED [  0%]
09:10:04 tests/unit/api_build_test.py::BuildTest::test_build_container_with_container_limits PASSED [  1%]
09:10:05 tests/unit/api_build_test.py::BuildTest::test_build_container_with_named_dockerfile PASSED [  1%]
09:10:05 tests/unit/api_build_test.py::BuildTest::test_build_remote_with_registry_auth PASSED [  1%]
09:10:05 tests/unit/api_build_test.py::BuildTest::test_process_dockerfile PASSED  [  1%]
09:10:05 tests/unit/api_build_test.py::BuildTest::test_process_dockerfile_win_longpath_prefix SKIPPED [  1%]
09:10:05 tests/unit/api_build_test.py::BuildTest::test_set_auth_headers_with_dict_and_auth_configs PASSED [  1%]
09:10:05 tests/unit/api_build_test.py::BuildTest::test_set_auth_headers_with_dict_and_no_auth_configs PASSED [  2%]
09:10:05 tests/unit/api_build_test.py::BuildTest::test_set_auth_headers_with_empty_dict_and_auth_configs PASSED [  2%]
09:10:05 tests/unit/api_container_test.py::StartContainerTest::test_start_container PASSED [  2%]
09:10:05 tests/unit/api_container_test.py::StartContainerTest::test_start_container_none PASSED [  2%]
09:10:05 tests/unit/api_container_test.py::StartContainerTest::test_start_container_privileged PASSED [  2%]
09:10:05 tests/unit/api_container_test.py::StartContainerTest::test_start_container_regression_573 PASSED [  2%]
09:10:05 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_binds_ro PASSED [  3%]
09:10:05 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_binds_rw PASSED [  3%]
09:10:05 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_dict_instead_of_id PASSED [  3%]
09:10:05 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_links PASSED [  3%]
09:10:05 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_links_as_list_of_tuples PASSED [  3%]
09:10:05 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_lxc_conf PASSED [  4%]
09:10:05 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_lxc_conf_compat PASSED [  4%]
09:10:05 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_multiple_links PASSED [  4%]
09:10:05 tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_port_binds PASSED [  4%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container PASSED [  4%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_privileged PASSED [  4%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_added_capabilities PASSED [  5%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_aliases PASSED [  5%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds PASSED [  5%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_list PASSED [  5%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_mode PASSED [  5%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_mode_and_ro_error PASSED [  5%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_ro PASSED [  6%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_rw PASSED [  6%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_cgroup_parent PASSED [  6%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_device_requests PASSED [  6%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_devices PASSED [  6%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_dropped_capabilities PASSED [  7%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_entrypoint PASSED [  7%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_host_config_cpu_shares PASSED [  7%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_host_config_cpus PASSED [  7%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_host_config_cpuset PASSED [  7%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_host_config_cpuset_mems PASSED [  7%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_labels_dict PASSED [  8%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_labels_list PASSED [  8%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_links PASSED [  8%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_links_as_list_of_tuples PASSED [  8%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_lxc_conf PASSED [  8%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_lxc_conf_compat PASSED [  8%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mac_address PASSED [  9%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_int PASSED [  9%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string PASSED [  9%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string_with_g_unit PASSED [  9%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string_with_k_unit PASSED [  9%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string_with_m_unit PASSED [  9%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string_with_wrong_value PASSED [ 10%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_multiple_links PASSED [ 10%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_named_volume PASSED [ 10%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_port_binds PASSED [ 10%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_ports PASSED [ 10%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_restart_policy PASSED [ 11%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_stdin_open PASSED [ 11%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_stop_signal PASSED [ 11%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_sysctl PASSED [ 11%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_tmpfs_dict PASSED [ 11%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_tmpfs_list PASSED [ 11%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_unicode_envvars PASSED [ 12%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_volume_string PASSED [ 12%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_working_dir PASSED [ 12%]
09:10:05 tests/unit/api_container_test.py::CreateContainerTest::test_create_named_container PASSED [ 12%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_container_stats PASSED [ 12%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_container_top PASSED [ 12%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_container_top_with_psargs PASSED [ 13%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_container_update PASSED [ 13%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_diff PASSED        [ 13%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_diff_with_dict_instead_of_id PASSED [ 13%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_export PASSED      [ 13%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_export_with_dict_instead_of_id PASSED [ 14%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_inspect_container PASSED [ 14%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_inspect_container_undefined_id PASSED [ 14%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_kill_container PASSED [ 14%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_kill_container_with_dict_instead_of_id PASSED [ 14%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_kill_container_with_signal PASSED [ 14%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_list_containers PASSED [ 15%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_log_following PASSED [ 15%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_log_following_backwards PASSED [ 15%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_log_since PASSED   [ 15%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_log_since_with_datetime PASSED [ 15%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_log_since_with_invalid_value_raises_error PASSED [ 15%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_log_streaming PASSED [ 16%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_log_streaming_and_following PASSED [ 16%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_log_tail PASSED    [ 16%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_log_tty PASSED     [ 16%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_logs PASSED        [ 16%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_logs_with_dict_instead_of_id PASSED [ 16%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_pause_container PASSED [ 17%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_port PASSED        [ 17%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_remove_container FAILED [ 17%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_remove_container_with_dict_instead_of_id FAILED [ 17%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_rename_container PASSED [ 17%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_resize_container PASSED [ 18%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_restart_container PASSED [ 18%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_restart_container_with_dict_instead_of_id PASSED [ 18%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_stop_container PASSED [ 18%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_stop_container_with_dict_instead_of_id PASSED [ 18%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_unpause_container PASSED [ 18%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_wait PASSED        [ 19%]
09:10:05 tests/unit/api_container_test.py::ContainerTest::test_wait_with_dict_instead_of_id PASSED [ 19%]
09:10:05 tests/unit/api_exec_test.py::ExecTest::test_exec_create PASSED           [ 19%]
09:10:05 tests/unit/api_exec_test.py::ExecTest::test_exec_inspect PASSED          [ 19%]
09:10:05 tests/unit/api_exec_test.py::ExecTest::test_exec_resize PASSED           [ 19%]
09:10:05 tests/unit/api_exec_test.py::ExecTest::test_exec_start PASSED            [ 19%]
09:10:05 tests/unit/api_exec_test.py::ExecTest::test_exec_start_detached PASSED   [ 20%]
09:10:05 tests/unit/api_image_test.py::ImageTest::test_commit PASSED              [ 20%]
09:10:05 tests/unit/api_image_test.py::ImageTest::test_get_image PASSED           [ 20%]
09:10:05 tests/unit/api_image_test.py::ImageTest::test_image_history PASSED       [ 20%]
09:10:05 tests/unit/api_image_test.py::ImageTest::test_image_ids PASSED           [ 20%]
09:10:05 tests/unit/api_image_test.py::ImageTest::test_image_viz PASSED           [ 21%]
09:10:05 tests/unit/api_image_test.py::ImageTest::test_images PASSED              [ 21%]
09:10:05 tests/unit/api_image_test.py::ImageTest::test_images_filters PASSED      [ 21%]
09:10:05 tests/unit/api_image_test.py::ImageTest::test_images_name PASSED         [ 21%]
09:10:05 tests/unit/api_image_test.py::ImageTest::test_images_quiet PASSED        [ 21%]
09:10:05 tests/unit/api_image_test.py::ImageTest::test_import_image PASSED        [ 21%]
09:10:05 tests/unit/api_image_test.py::ImageTest::test_import_image_from_bytes PASSED [ 22%]
09:10:05 tests/unit/api_image_test.py::ImageTest::test_import_image_from_image PASSED [ 22%]
09:10:05 tests/unit/api_image_test.py::ImageTest::test_inspect_image PASSED       [ 22%]
09:10:05 tests/unit/api_image_test.py::ImageTest::test_inspect_image_undefined_id PASSED [ 22%]
09:10:05 tests/unit/api_image_test.py::ImageTest::test_load_image PASSED          [ 22%]
09:10:05 tests/unit/api_image_test.py::ImageTest::test_load_image_quiet PASSED    [ 22%]
09:10:05 tests/unit/api_image_test.py::ImageTest::test_pull PASSED                [ 23%]
09:10:05 tests/unit/api_image_test.py::ImageTest::test_pull_stream PASSED         [ 23%]
09:10:05 tests/unit/api_image_test.py::ImageTest::test_push_image PASSED          [ 23%]
09:10:05 tests/unit/api_image_test.py::ImageTest::test_push_image_stream PASSED   [ 23%]
09:10:05 tests/unit/api_image_test.py::ImageTest::test_push_image_with_auth PASSED [ 23%]
09:10:05 tests/unit/api_image_test.py::ImageTest::test_push_image_with_tag PASSED [ 23%]
09:10:05 tests/unit/api_image_test.py::ImageTest::test_remove_image PASSED        [ 24%]
09:10:05 tests/unit/api_image_test.py::ImageTest::test_tag_image PASSED           [ 24%]
09:10:05 tests/unit/api_image_test.py::ImageTest::test_tag_image_force PASSED     [ 24%]
09:10:05 tests/unit/api_image_test.py::ImageTest::test_tag_image_tag PASSED       [ 24%]
09:10:05 tests/unit/api_network_test.py::NetworkTest::test_connect_container_to_network PASSED [ 24%]
09:10:05 tests/unit/api_network_test.py::NetworkTest::test_create_network PASSED  [ 25%]
09:10:05 tests/unit/api_network_test.py::NetworkTest::test_disconnect_container_from_network PASSED [ 25%]
09:10:05 tests/unit/api_network_test.py::NetworkTest::test_inspect_network PASSED [ 25%]
09:10:05 tests/unit/api_network_test.py::NetworkTest::test_list_networks PASSED   [ 25%]
09:10:05 tests/unit/api_network_test.py::NetworkTest::test_remove_network PASSED  [ 25%]
09:10:05 tests/unit/api_test.py::DockerApiTest::test_auto_retrieve_server_version PASSED [ 25%]
09:10:05 tests/unit/api_test.py::DockerApiTest::test_create_host_config_secopt PASSED [ 26%]
09:10:05 tests/unit/api_test.py::DockerApiTest::test_ctor PASSED                  [ 26%]
09:10:05 tests/unit/api_test.py::DockerApiTest::test_events PASSED                [ 26%]
09:10:05 tests/unit/api_test.py::DockerApiTest::test_events_with_filters PASSED   [ 26%]
09:10:05 tests/unit/api_test.py::DockerApiTest::test_events_with_since_until PASSED [ 26%]
09:10:05 tests/unit/api_test.py::DockerApiTest::test_info PASSED                  [ 26%]
09:10:05 tests/unit/api_test.py::DockerApiTest::test_login PASSED                 [ 27%]
09:10:06 tests/unit/api_test.py::DockerApiTest::test_remove_link FAILED           [ 27%]
09:10:06 tests/unit/api_test.py::DockerApiTest::test_retrieve_server_version PASSED [ 27%]
09:10:06 tests/unit/api_test.py::DockerApiTest::test_search PASSED                [ 27%]
09:10:06 tests/unit/api_test.py::DockerApiTest::test_stream_helper_decoding PASSED [ 27%]
09:10:06 tests/unit/api_test.py::DockerApiTest::test_url_compatibility_http PASSED [ 28%]
09:10:06 tests/unit/api_test.py::DockerApiTest::test_url_compatibility_http_unix_triple_slash PASSED [ 28%]
09:10:06 tests/unit/api_test.py::DockerApiTest::test_url_compatibility_tcp PASSED [ 28%]
09:10:06 tests/unit/api_test.py::DockerApiTest::test_url_compatibility_unix PASSED [ 28%]
09:10:06 tests/unit/api_test.py::DockerApiTest::test_url_compatibility_unix_triple_slash PASSED [ 28%]
09:10:06 tests/unit/api_test.py::DockerApiTest::test_url_invalid_resource PASSED  [ 28%]
09:10:06 tests/unit/api_test.py::DockerApiTest::test_url_no_resource PASSED       [ 29%]
09:10:06 tests/unit/api_test.py::DockerApiTest::test_url_unversioned_api PASSED   [ 29%]
09:10:06 tests/unit/api_test.py::DockerApiTest::test_url_valid_resource PASSED    [ 29%]
09:10:06 tests/unit/api_test.py::DockerApiTest::test_version PASSED               [ 29%]
09:10:06 tests/unit/api_test.py::DockerApiTest::test_version_no_api_version PASSED [ 29%]
09:10:06 tests/unit/api_test.py::UnixSocketStreamTest::test_early_stream_response PASSED [ 29%]
09:10:06 tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_stream_no_tty PASSED [ 30%]
09:10:06 tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_stream_no_tty_demux PASSED [ 30%]
09:10:06 tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_stream_tty PASSED [ 30%]
09:10:06 tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_stream_tty_demux PASSED [ 30%]
09:10:07 tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_tty PASSED [ 30%]
09:10:07 tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_tty_demux PASSED [ 30%]
09:10:07 tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_tty PASSED [ 31%]
09:10:07 tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_tty_demux PASSED [ 31%]
09:10:07 tests/unit/api_test.py::UserAgentTest::test_custom_user_agent PASSED     [ 31%]
09:10:07 tests/unit/api_test.py::UserAgentTest::test_default_user_agent PASSED    [ 31%]
09:10:07 tests/unit/api_test.py::DisableSocketTest::test_disable_socket_timeout PASSED [ 31%]
09:10:07 tests/unit/api_test.py::DisableSocketTest::test_disable_socket_timeout2 PASSED [ 32%]
09:10:07 tests/unit/api_test.py::DisableSocketTest::test_disable_socket_timout_non_blocking PASSED [ 32%]
09:10:07 tests/unit/api_volume_test.py::VolumeTest::test_create_volume PASSED     [ 32%]
09:10:07 tests/unit/api_volume_test.py::VolumeTest::test_create_volume_invalid_opts_type PASSED [ 32%]
09:10:07 tests/unit/api_volume_test.py::VolumeTest::test_create_volume_with_driver PASSED [ 32%]
09:10:07 tests/unit/api_volume_test.py::VolumeTest::test_create_volume_with_invalid_labels PASSED [ 32%]
09:10:07 tests/unit/api_volume_test.py::VolumeTest::test_create_volume_with_labels PASSED [ 33%]
09:10:07 tests/unit/api_volume_test.py::VolumeTest::test_create_volume_with_no_specified_name PASSED [ 33%]
09:10:07 tests/unit/api_volume_test.py::VolumeTest::test_inspect_volume PASSED    [ 33%]
09:10:07 tests/unit/api_volume_test.py::VolumeTest::test_list_volumes PASSED      [ 33%]
09:10:08 tests/unit/api_volume_test.py::VolumeTest::test_list_volumes_and_filters PASSED [ 33%]
09:10:08 tests/unit/api_volume_test.py::VolumeTest::test_remove_volume PASSED     [ 33%]
09:10:08 tests/unit/auth_test.py::RegressionTest::test_803_urlsafe_encode PASSED  [ 34%]
09:10:08 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_explicit_hub_index_library_image PASSED [ 34%]
09:10:08 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_explicit_legacy_hub_index_library_image PASSED [ 34%]
09:10:08 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_invalid_index_name PASSED [ 34%]
09:10:08 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_dotted_hub_library_image PASSED [ 34%]
09:10:08 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_hub_image PASSED [ 35%]
09:10:08 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_hub_library_image PASSED [ 35%]
09:10:08 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_localhost PASSED [ 35%]
09:10:08 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_localhost_with_username PASSED [ 35%]
09:10:08 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_no_dots_but_port PASSED [ 35%]
09:10:08 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_no_dots_but_port_and_username PASSED [ 35%]
09:10:08 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_private_registry PASSED [ 36%]
09:10:08 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_private_registry_with_port PASSED [ 36%]
09:10:08 tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_private_registry_with_username PASSED [ 36%]
09:10:08 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_auth_with_empty_credstore_and_auth_dict PASSED [ 36%]
09:10:08 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_default_explicit_none PASSED [ 36%]
09:10:08 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_default_registry PASSED [ 36%]
09:10:08 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_fully_explicit PASSED [ 37%]
09:10:08 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_hostname_only PASSED [ 37%]
09:10:08 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_legacy_config PASSED [ 37%]
09:10:08 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_match PASSED [ 37%]
09:10:08 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_path PASSED [ 37%]
09:10:08 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_path_trailing_slash PASSED [ 38%]
09:10:08 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_path_wrong_insecure_proto PASSED [ 38%]
09:10:08 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_path_wrong_secure_proto PASSED [ 38%]
09:10:08 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_protocol PASSED [ 38%]
09:10:08 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_path_wrong_proto PASSED [ 38%]
09:10:08 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_explicit_hub PASSED [ 38%]
09:10:08 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_explicit_legacy_hub PASSED [ 39%]
09:10:08 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_hub_image PASSED [ 39%]
09:10:08 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_library_image PASSED [ 39%]
09:10:08 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_private_registry PASSED [ 39%]
09:10:08 tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_unauthenticated_registry PASSED [ 39%]
09:10:08 tests/unit/auth_test.py::LoadConfigTest::test_load_config_custom_config_env PASSED [ 39%]
09:10:08 tests/unit/auth_test.py::LoadConfigTest::test_load_config_custom_config_env_utf8 PASSED [ 40%]
09:10:08 tests/unit/auth_test.py::LoadConfigTest::test_load_config_custom_config_env_with_auths PASSED [ 40%]
09:10:08 tests/unit/auth_test.py::LoadConfigTest::test_load_config_identity_token PASSED [ 40%]
09:10:08 tests/unit/auth_test.py::LoadConfigTest::test_load_config_invalid_auth_dict PASSED [ 40%]
09:10:08 tests/unit/auth_test.py::LoadConfigTest::test_load_config_no_file PASSED [ 40%]
09:10:08 tests/unit/auth_test.py::LoadConfigTest::test_load_config_unknown_keys PASSED [ 40%]
09:10:08 tests/unit/auth_test.py::LoadConfigTest::test_load_config_with_random_name PASSED [ 41%]
09:10:08 tests/unit/auth_test.py::LoadConfigTest::test_load_json_config PASSED    [ 41%]
09:10:08 tests/unit/auth_test.py::LoadConfigTest::test_load_legacy_config PASSED  [ 41%]
09:10:08 tests/unit/auth_test.py::LoadConfigTest::test_load_modern_json_config PASSED [ 41%]
09:10:08 tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_3_sources PASSED [ 41%]
09:10:08 tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_credstore_only PASSED [ 42%]
09:10:08 tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_credstore_overrides_auth_entry PASSED [ 42%]
09:10:08 tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_helpers_override_default PASSED [ 42%]
09:10:08 tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_with_auths_entries PASSED [ 42%]
09:10:08 tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_with_credhelpers_only PASSED [ 42%]
09:10:08 tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_with_empty_auths_entry PASSED [ 42%]
09:10:08 tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_with_empty_credhelper PASSED [ 43%]
09:10:08 tests/unit/auth_test.py::CredstoreTest::test_get_credential_store PASSED [ 43%]
09:10:08 tests/unit/auth_test.py::CredstoreTest::test_get_credential_store_default_index PASSED [ 43%]
09:10:08 tests/unit/auth_test.py::CredstoreTest::test_get_credential_store_no_default PASSED [ 43%]
09:10:08 tests/unit/auth_test.py::CredstoreTest::test_get_credential_store_with_plain_dict PASSED [ 43%]
09:10:08 tests/unit/client_test.py::ClientTest::test_call_api_client_method PASSED [ 43%]
09:10:08 tests/unit/client_test.py::ClientTest::test_call_containers PASSED       [ 44%]
09:10:08 tests/unit/client_test.py::ClientTest::test_default_pool_size_unix PASSED [ 44%]
09:10:08 tests/unit/client_test.py::ClientTest::test_default_pool_size_win SKIPPED [ 44%]
09:10:08 tests/unit/client_test.py::ClientTest::test_events PASSED                [ 44%]
09:10:08 tests/unit/client_test.py::ClientTest::test_info PASSED                  [ 44%]
09:10:08 tests/unit/client_test.py::ClientTest::test_ping PASSED                  [ 45%]
09:10:08 tests/unit/client_test.py::ClientTest::test_pool_size_unix PASSED        [ 45%]
09:10:08 tests/unit/client_test.py::ClientTest::test_pool_size_win SKIPPED (N...) [ 45%]
09:10:08 tests/unit/client_test.py::ClientTest::test_version PASSED               [ 45%]
09:10:08 tests/unit/client_test.py::FromEnvTest::test_default_pool_size_from_env_unix PASSED [ 45%]
09:10:08 tests/unit/client_test.py::FromEnvTest::test_default_pool_size_from_env_win SKIPPED [ 45%]
09:10:08 tests/unit/client_test.py::FromEnvTest::test_from_env PASSED             [ 46%]
09:10:08 tests/unit/client_test.py::FromEnvTest::test_from_env_with_version PASSED [ 46%]
09:10:08 tests/unit/client_test.py::FromEnvTest::test_from_env_without_timeout_uses_default PASSED [ 46%]
09:10:08 tests/unit/client_test.py::FromEnvTest::test_from_env_without_version_uses_default PASSED [ 46%]
09:10:08 tests/unit/client_test.py::FromEnvTest::test_pool_size_from_env_unix PASSED [ 46%]
09:10:08 tests/unit/client_test.py::FromEnvTest::test_pool_size_from_env_win SKIPPED [ 46%]
09:10:08 tests/unit/context_test.py::BaseContextTest::test_context_inspect_without_params PASSED [ 47%]
09:10:08 tests/unit/context_test.py::BaseContextTest::test_default_in_context_list PASSED [ 47%]
09:10:08 tests/unit/context_test.py::BaseContextTest::test_fail_on_default_context_create PASSED [ 47%]
09:10:08 tests/unit/context_test.py::BaseContextTest::test_get_current_context PASSED [ 47%]
09:10:08 tests/unit/context_test.py::BaseContextTest::test_https_host PASSED      [ 47%]
09:10:08 tests/unit/context_test.py::BaseContextTest::test_url_compatibility_on_linux PASSED [ 47%]
09:10:08 tests/unit/context_test.py::BaseContextTest::test_url_compatibility_on_windows SKIPPED [ 48%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_cpu_cfs_types PASSED [ 48%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_cpu_count_types PASSED [ 48%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_cpu_percent_types PASSED [ 48%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_mem_swappiness PASSED [ 48%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_nano_cpus_types PASSED [ 49%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_no_options_newer_api_version PASSED [ 49%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_pid_mode PASSED [ 49%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_blkio_constraints PASSED [ 49%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_count PASSED [ 49%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_percent PASSED [ 49%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_period PASSED [ 50%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_quota PASSED [ 50%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_rt_period PASSED [ 50%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_rt_period_types PASSED [ 50%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_rt_runtime PASSED [ 50%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_dns_opt PASSED [ 50%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_isolation PASSED [ 51%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_kernel_memory PASSED [ 51%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_mem_reservation PASSED [ 51%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_nano_cpus PASSED [ 51%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_oom_kill_disable PASSED [ 51%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_oom_score_adj PASSED [ 52%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_pids_limit PASSED [ 52%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_shm_size PASSED [ 52%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_shm_size_in_mb PASSED [ 52%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_userns_mode PASSED [ 52%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_uts PASSED [ 52%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_volume_driver PASSED [ 53%]
09:10:08 tests/unit/dockertypes_test.py::HostConfigTest::test_ctrate_host_config_with_cpu_rt_runtime_types PASSED [ 53%]
09:10:08 tests/unit/dockertypes_test.py::ContainerSpecTest::test_parse_mounts PASSED [ 53%]
09:10:08 tests/unit/dockertypes_test.py::UlimitTest::test_create_host_config_dict_ulimit PASSED [ 53%]
09:10:08 tests/unit/dockertypes_test.py::UlimitTest::test_create_host_config_dict_ulimit_capitals PASSED [ 53%]
09:10:08 tests/unit/dockertypes_test.py::UlimitTest::test_create_host_config_obj_ulimit PASSED [ 53%]
09:10:08 tests/unit/dockertypes_test.py::UlimitTest::test_ulimit_invalid_type PASSED [ 54%]
09:10:08 tests/unit/dockertypes_test.py::LogConfigTest::test_create_host_config_dict_logconfig PASSED [ 54%]
09:10:08 tests/unit/dockertypes_test.py::LogConfigTest::test_create_host_config_obj_logconfig PASSED [ 54%]
09:10:08 tests/unit/dockertypes_test.py::LogConfigTest::test_logconfig_invalid_config_type PASSED [ 54%]
09:10:08 tests/unit/dockertypes_test.py::EndpointConfigTest::test_create_endpoint_config_with_aliases PASSED [ 54%]
09:10:08 tests/unit/dockertypes_test.py::IPAMConfigTest::test_create_ipam_config PASSED [ 54%]
09:10:08 tests/unit/dockertypes_test.py::ServiceModeTest::test_global_replicas_error PASSED [ 55%]
09:10:08 tests/unit/dockertypes_test.py::ServiceModeTest::test_global_simple PASSED [ 55%]
09:10:08 tests/unit/dockertypes_test.py::ServiceModeTest::test_invalid_mode PASSED [ 55%]
09:10:08 tests/unit/dockertypes_test.py::ServiceModeTest::test_replicated_replicas PASSED [ 55%]
09:10:08 tests/unit/dockertypes_test.py::ServiceModeTest::test_replicated_replicas_0 PASSED [ 55%]
09:10:08 tests/unit/dockertypes_test.py::ServiceModeTest::test_replicated_simple PASSED [ 56%]
09:10:08 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_bind PASSED  [ 56%]
09:10:08 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_bind_windows XFAIL [ 56%]
09:10:08 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_named_volume PASSED [ 56%]
09:10:08 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_invalid PASSED [ 56%]
09:10:08 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_no_source PASSED [ 56%]
09:10:08 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_ro PASSED [ 57%]
09:10:08 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_rw PASSED [ 57%]
09:10:08 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_short_form PASSED [ 57%]
09:10:08 tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_invalid PASSED [ 57%]
09:10:08 tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_multiple PASSED [ 57%]
09:10:08 tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_no_protocol_and_mode PASSED [ 57%]
09:10:08 tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_simple PASSED [ 58%]
09:10:08 tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_with_protocol PASSED [ 58%]
09:10:08 tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_with_protocol_and_mode PASSED [ 58%]
09:10:08 tests/unit/errors_test.py::APIErrorTest::test_api_error_is_caught_by_dockerexception PASSED [ 58%]
09:10:08 tests/unit/errors_test.py::APIErrorTest::test_create_error_from_exception PASSED [ 58%]
09:10:08 tests/unit/errors_test.py::APIErrorTest::test_is_client_error_400 PASSED [ 59%]
09:10:08 tests/unit/errors_test.py::APIErrorTest::test_is_client_error_500 PASSED [ 59%]
09:10:08 tests/unit/errors_test.py::APIErrorTest::test_is_error_300 PASSED        [ 59%]
09:10:08 tests/unit/errors_test.py::APIErrorTest::test_is_error_400 PASSED        [ 59%]
09:10:08 tests/unit/errors_test.py::APIErrorTest::test_is_error_500 PASSED        [ 59%]
09:10:08 tests/unit/errors_test.py::APIErrorTest::test_is_server_error_200 PASSED [ 59%]
09:10:08 tests/unit/errors_test.py::APIErrorTest::test_is_server_error_300 PASSED [ 60%]
09:10:08 tests/unit/errors_test.py::APIErrorTest::test_is_server_error_400 PASSED [ 60%]
09:10:08 tests/unit/errors_test.py::APIErrorTest::test_is_server_error_500 PASSED [ 60%]
09:10:08 tests/unit/errors_test.py::APIErrorTest::test_status_code_200 PASSED     [ 60%]
09:10:08 tests/unit/errors_test.py::APIErrorTest::test_status_code_400 PASSED     [ 60%]
09:10:08 tests/unit/errors_test.py::APIErrorTest::test_status_code_500 PASSED     [ 60%]
09:10:08 tests/unit/errors_test.py::ContainerErrorTest::test_container_with_stderr PASSED [ 61%]
09:10:08 tests/unit/errors_test.py::ContainerErrorTest::test_container_without_stderr PASSED [ 61%]
09:10:08 tests/unit/errors_test.py::CreateUnexpectedKwargsErrorTest::test_create_unexpected_kwargs_error_multiple PASSED [ 61%]
09:10:08 tests/unit/errors_test.py::CreateUnexpectedKwargsErrorTest::test_create_unexpected_kwargs_error_single PASSED [ 61%]
09:10:08 tests/unit/models_containers_test.py::ContainerCollectionTest::test_create PASSED [ 61%]
09:10:08 tests/unit/models_containers_test.py::ContainerCollectionTest::test_create_container_args PASSED [ 61%]
09:10:08 tests/unit/models_containers_test.py::ContainerCollectionTest::test_create_with_image_object PASSED [ 62%]
09:10:08 tests/unit/models_containers_test.py::ContainerCollectionTest::test_get PASSED [ 62%]
09:10:08 tests/unit/models_containers_test.py::ContainerCollectionTest::test_list PASSED [ 62%]
09:10:08 tests/unit/models_containers_test.py::ContainerCollectionTest::test_list_ignore_removed PASSED [ 62%]
09:10:08 tests/unit/models_containers_test.py::ContainerCollectionTest::test_run PASSED [ 62%]
09:10:08 tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_detach PASSED [ 63%]
09:10:08 tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_pull PASSED [ 63%]
09:10:08 tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_remove PASSED [ 63%]
09:10:08 tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_with_error PASSED [ 63%]
09:10:08 tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_with_image_object PASSED [ 63%]
09:10:08 tests/unit/models_containers_test.py::ContainerTest::test_attach PASSED  [ 63%]
09:10:08 tests/unit/models_containers_test.py::ContainerTest::test_commit PASSED  [ 64%]
09:10:08 tests/unit/models_containers_test.py::ContainerTest::test_diff PASSED    [ 64%]
09:10:08 tests/unit/models_containers_test.py::ContainerTest::test_exec_run PASSED [ 64%]
09:10:08 tests/unit/models_containers_test.py::ContainerTest::test_exec_run_failure PASSED [ 64%]
09:10:08 tests/unit/models_containers_test.py::ContainerTest::test_export PASSED  [ 64%]
09:10:08 tests/unit/models_containers_test.py::ContainerTest::test_get_archive PASSED [ 64%]
09:10:08 tests/unit/models_containers_test.py::ContainerTest::test_image PASSED   [ 65%]
09:10:08 tests/unit/models_containers_test.py::ContainerTest::test_kill PASSED    [ 65%]
09:10:08 tests/unit/models_containers_test.py::ContainerTest::test_labels PASSED  [ 65%]
09:10:08 tests/unit/models_containers_test.py::ContainerTest::test_logs PASSED    [ 65%]
09:10:08 tests/unit/models_containers_test.py::ContainerTest::test_name PASSED    [ 65%]
09:10:08 tests/unit/models_containers_test.py::ContainerTest::test_pause PASSED   [ 66%]
09:10:08 tests/unit/models_containers_test.py::ContainerTest::test_put_archive PASSED [ 66%]
09:10:08 tests/unit/models_containers_test.py::ContainerTest::test_remove PASSED  [ 66%]
09:10:08 tests/unit/models_containers_test.py::ContainerTest::test_rename PASSED  [ 66%]
09:10:08 tests/unit/models_containers_test.py::ContainerTest::test_resize PASSED  [ 66%]
09:10:08 tests/unit/models_containers_test.py::ContainerTest::test_restart PASSED [ 66%]
09:10:08 tests/unit/models_containers_test.py::ContainerTest::test_start PASSED   [ 67%]
09:10:08 tests/unit/models_containers_test.py::ContainerTest::test_stats PASSED   [ 67%]
09:10:08 tests/unit/models_containers_test.py::ContainerTest::test_status PASSED  [ 67%]
09:10:08 tests/unit/models_containers_test.py::ContainerTest::test_stop PASSED    [ 67%]
09:10:08 tests/unit/models_containers_test.py::ContainerTest::test_top PASSED     [ 67%]
09:10:08 tests/unit/models_containers_test.py::ContainerTest::test_unpause PASSED [ 67%]
09:10:08 tests/unit/models_containers_test.py::ContainerTest::test_update PASSED  [ 68%]
09:10:08 tests/unit/models_containers_test.py::ContainerTest::test_wait PASSED    [ 68%]
09:10:08 tests/unit/models_images_test.py::ImageCollectionTest::test_build PASSED [ 68%]
09:10:08 tests/unit/models_images_test.py::ImageCollectionTest::test_get PASSED   [ 68%]
09:10:08 tests/unit/models_images_test.py::ImageCollectionTest::test_labels PASSED [ 68%]
09:10:08 tests/unit/models_images_test.py::ImageCollectionTest::test_list PASSED  [ 69%]
09:10:08 tests/unit/models_images_test.py::ImageCollectionTest::test_load PASSED  [ 69%]
09:10:08 tests/unit/models_images_test.py::ImageCollectionTest::test_pull PASSED  [ 69%]
09:10:08 tests/unit/models_images_test.py::ImageCollectionTest::test_pull_multiple PASSED [ 69%]
09:10:08 tests/unit/models_images_test.py::ImageCollectionTest::test_pull_tag_precedence PASSED [ 69%]
09:10:08 tests/unit/models_images_test.py::ImageCollectionTest::test_pull_with_stream_param PASSED [ 69%]
09:10:08 tests/unit/models_images_test.py::ImageCollectionTest::test_push PASSED  [ 70%]
09:10:08 tests/unit/models_images_test.py::ImageCollectionTest::test_remove PASSED [ 70%]
09:10:08 tests/unit/models_images_test.py::ImageCollectionTest::test_search PASSED [ 70%]
09:10:08 tests/unit/models_images_test.py::ImageCollectionTest::test_search_limit PASSED [ 70%]
09:10:08 tests/unit/models_images_test.py::ImageTest::test_history PASSED         [ 70%]
09:10:08 tests/unit/models_images_test.py::ImageTest::test_save PASSED            [ 70%]
09:10:08 tests/unit/models_images_test.py::ImageTest::test_short_id PASSED        [ 71%]
09:10:08 tests/unit/models_images_test.py::ImageTest::test_tag PASSED             [ 71%]
09:10:08 tests/unit/models_images_test.py::ImageTest::test_tags PASSED            [ 71%]
09:10:08 tests/unit/models_networks_test.py::NetworkCollectionTest::test_create PASSED [ 71%]
09:10:08 tests/unit/models_networks_test.py::NetworkCollectionTest::test_get PASSED [ 71%]
09:10:08 tests/unit/models_networks_test.py::NetworkCollectionTest::test_list PASSED [ 71%]
09:10:08 tests/unit/models_networks_test.py::NetworkTest::test_connect PASSED     [ 72%]
09:10:08 tests/unit/models_networks_test.py::NetworkTest::test_disconnect PASSED  [ 72%]
09:10:08 tests/unit/models_networks_test.py::NetworkTest::test_remove PASSED      [ 72%]
09:10:08 tests/unit/models_resources_test.py::ModelTest::test_hash PASSED         [ 72%]
09:10:08 tests/unit/models_resources_test.py::ModelTest::test_reload PASSED       [ 72%]
09:10:08 tests/unit/models_secrets_test.py::CreateServiceTest::test_secrets_repr PASSED [ 73%]
09:10:08 tests/unit/models_services_test.py::CreateServiceKwargsTest::test_get_create_service_kwargs PASSED [ 73%]
09:10:08 tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_hostname_prefix_trim PASSED [ 73%]
09:10:08 tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_hostname_and_port PASSED [ 73%]
09:10:08 tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_hostname_only PASSED [ 73%]
09:10:08 tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_url PASSED [ 73%]
09:10:08 tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_user_and_hostname PASSED [ 74%]
09:10:08 tests/unit/ssladapter_test.py::SSLAdapterTest::test_only_uses_tls PASSED [ 74%]
09:10:08 tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_dns_failure PASSED [ 74%]
09:10:08 tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_dns_success PASSED [ 74%]
09:10:08 tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_ip_address_failure PASSED [ 74%]
09:10:08 tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_ip_address_success PASSED [ 74%]
09:10:08 tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_localhost_success PASSED [ 75%]
09:10:08 tests/unit/swarm_test.py::SwarmTest::test_join_swarm PASSED              [ 75%]
09:10:08 tests/unit/swarm_test.py::SwarmTest::test_join_swarm_no_listen_address_takes_default PASSED [ 75%]
09:10:08 tests/unit/swarm_test.py::SwarmTest::test_node_update PASSED             [ 75%]
09:10:08 tests/unit/types_containers_test.py::test_uid_0_is_not_elided PASSED     [ 75%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_directory PASSED  [ 76%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_single_exception PASSED [ 76%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_subdir_exception PASSED [ 76%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_subdir_exception_win32_pathsep SKIPPED [ 76%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_trailing_slash PASSED [ 76%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_wildcard_exception PASSED [ 76%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_double_wildcard PASSED [ 77%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_double_wildcard_with_exception PASSED [ 77%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_custom_dockerfile PASSED [ 77%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_dockerfile_child PASSED [ 77%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_dockerfile_dockerignore PASSED [ 77%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_include_absolute_path PASSED [ 77%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_include_wildcard PASSED [ 78%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_last_line_precedence PASSED [ 78%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_no_dupes PASSED   [ 78%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_no_excludes PASSED [ 78%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_parent_directory PASSED [ 78%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_question_mark PASSED [ 78%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_and_double_wildcard PASSED [ 79%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_filename PASSED [ 79%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_filename_leading_dot_slash PASSED [ 79%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_filename_trailing_slash PASSED [ 79%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_single_filename PASSED [ 79%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_single_filename_leading_slash PASSED [ 80%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_wildcard_filename PASSED [ 80%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_with_path_traversal PASSED [ 80%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_subdirectory PASSED [ 80%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_subdirectory_win32_pathsep SKIPPED [ 80%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_trailing_double_wildcard PASSED [ 80%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_exclude PASSED [ 81%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_filename_end PASSED [ 81%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_filename_start PASSED [ 81%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_subdir_single_filename PASSED [ 81%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_subdir_wildcard_filename PASSED [ 81%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_with_exception PASSED [ 81%]
09:10:08 tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_with_wildcard_exception PASSED [ 82%]
09:10:08 tests/unit/utils_build_test.py::TarTest::test_tar_directory_link PASSED  [ 82%]
09:10:08 tests/unit/utils_build_test.py::TarTest::test_tar_socket_file PASSED     [ 82%]
09:10:08 tests/unit/utils_build_test.py::TarTest::test_tar_with_broken_symlinks PASSED [ 82%]
09:10:08 tests/unit/utils_build_test.py::TarTest::test_tar_with_directory_symlinks PASSED [ 82%]
09:10:09 tests/unit/utils_build_test.py::TarTest::test_tar_with_empty_directory PASSED [ 83%]
09:10:09 tests/unit/utils_build_test.py::TarTest::test_tar_with_excludes PASSED   [ 83%]
09:10:09 tests/unit/utils_build_test.py::TarTest::test_tar_with_file_symlinks PASSED [ 83%]
09:10:09 tests/unit/utils_build_test.py::TarTest::test_tar_with_inaccessible_file SKIPPED [ 83%]
09:10:09 tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_fallback PASSED [ 83%]
09:10:09 tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_environment PASSED [ 83%]
09:10:09 tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_explicit_path PASSED [ 84%]
09:10:09 tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_home_legacy_name PASSED [ 84%]
09:10:09 tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_home_posix PASSED [ 84%]
09:10:09 tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_home_windows SKIPPED [ 84%]
09:10:09 tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_custom_headers PASSED [ 84%]
09:10:09 tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_detach_keys PASSED [ 84%]
09:10:09 tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_from_env PASSED [ 85%]
09:10:09 tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_no_file PASSED [ 85%]
09:10:09 tests/unit/utils_json_stream_test.py::TestJsonSplitter::test_json_splitter_no_object PASSED [ 85%]
09:10:09 tests/unit/utils_json_stream_test.py::TestJsonSplitter::test_json_splitter_with_object PASSED [ 85%]
09:10:09 tests/unit/utils_json_stream_test.py::TestJsonSplitter::test_json_splitter_leading_whitespace PASSED [ 85%]
09:10:09 tests/unit/utils_json_stream_test.py::TestStreamAsText::test_stream_with_non_utf_unicode_character PASSED [ 85%]
09:10:09 tests/unit/utils_json_stream_test.py::TestStreamAsText::test_stream_with_utf_character PASSED [ 86%]
09:10:09 tests/unit/utils_json_stream_test.py::TestJsonStream::test_with_falsy_entries PASSED [ 86%]
09:10:09 tests/unit/utils_json_stream_test.py::TestJsonStream::test_with_leading_whitespace PASSED [ 86%]
09:10:09 tests/unit/utils_proxy_test.py::ProxyConfigTest::test_environment PASSED [ 86%]
09:10:09 tests/unit/utils_proxy_test.py::ProxyConfigTest::test_from_dict PASSED   [ 86%]
09:10:09 tests/unit/utils_proxy_test.py::ProxyConfigTest::test_inject_proxy_environment PASSED [ 87%]
09:10:09 tests/unit/utils_proxy_test.py::ProxyConfigTest::test_new PASSED         [ 87%]
09:10:09 tests/unit/utils_proxy_test.py::ProxyConfigTest::test_truthiness PASSED  [ 87%]
09:10:09 tests/unit/utils_test.py::DecoratorsTest::test_update_headers PASSED     [ 87%]
09:10:09 tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_alternate_env PASSED [ 87%]
09:10:09 tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_empty PASSED [ 87%]
09:10:09 tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_no_cert_path PASSED [ 88%]
09:10:09 tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_tls PASSED [ 88%]
09:10:09 tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_tls_verify_false PASSED [ 88%]
09:10:09 tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_tls_verify_false_no_cert PASSED [ 88%]
09:10:09 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_compact PASSED [ 88%]
09:10:09 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_complete PASSED [ 88%]
09:10:09 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_empty PASSED [ 89%]
09:10:09 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_list PASSED [ 89%]
09:10:09 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_no_mode PASSED [ 89%]
09:10:09 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_unicode_bytes_input PASSED [ 89%]
09:10:09 tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_unicode_unicode_input PASSED [ 89%]
09:10:09 tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_commented_line PASSED [ 90%]
09:10:09 tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_invalid_line PASSED [ 90%]
09:10:09 tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_newline PASSED [ 90%]
09:10:09 tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_proper PASSED [ 90%]
09:10:09 tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_with_equals_character PASSED [ 90%]
09:10:09 tests/unit/utils_test.py::ParseHostTest::test_parse_host PASSED          [ 90%]
09:10:09 tests/unit/utils_test.py::ParseHostTest::test_parse_host_empty_value PASSED [ 91%]
09:10:09 tests/unit/utils_test.py::ParseHostTest::test_parse_host_tls PASSED      [ 91%]
09:10:09 tests/unit/utils_test.py::ParseHostTest::test_parse_host_tls_tcp_proto PASSED [ 91%]
09:10:09 tests/unit/utils_test.py::ParseHostTest::test_parse_host_trailing_slash PASSED [ 91%]
09:10:09 tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_image_no_tag PASSED [ 91%]
09:10:09 tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_image_sha PASSED [ 91%]
09:10:09 tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_image_tag PASSED [ 92%]
09:10:09 tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_user_image_no_tag PASSED [ 92%]
09:10:09 tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_user_image_tag PASSED [ 92%]
09:10:09 tests/unit/utils_test.py::ParseRepositoryTagTest::test_private_reg_image_no_tag PASSED [ 92%]
09:10:09 tests/unit/utils_test.py::ParseRepositoryTagTest::test_private_reg_image_sha PASSED [ 92%]
09:10:09 tests/unit/utils_test.py::ParseRepositoryTagTest::test_private_reg_image_tag PASSED [ 92%]
09:10:09 tests/unit/utils_test.py::ParseDeviceTest::test_dict PASSED              [ 93%]
09:10:09 tests/unit/utils_test.py::ParseDeviceTest::test_full_string_definition PASSED [ 93%]
09:10:09 tests/unit/utils_test.py::ParseDeviceTest::test_hybrid_list PASSED       [ 93%]
09:10:09 tests/unit/utils_test.py::ParseDeviceTest::test_partial_string_definition PASSED [ 93%]
09:10:09 tests/unit/utils_test.py::ParseDeviceTest::test_permissionless_string_definition PASSED [ 93%]
09:10:09 tests/unit/utils_test.py::ParseBytesTest::test_parse_bytes_float PASSED  [ 94%]
09:10:09 tests/unit/utils_test.py::ParseBytesTest::test_parse_bytes_invalid PASSED [ 94%]
09:10:09 tests/unit/utils_test.py::ParseBytesTest::test_parse_bytes_valid PASSED  [ 94%]
09:10:09 tests/unit/utils_test.py::UtilsTest::test_convert_filters PASSED         [ 94%]
09:10:09 tests/unit/utils_test.py::UtilsTest::test_decode_json_header PASSED      [ 94%]
09:10:09 tests/unit/utils_test.py::SplitCommandTest::test_split_command_with_unicode PASSED [ 94%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_matching_internal_port_ranges PASSED [ 95%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_matching_internal_ports PASSED [ 95%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_nonmatching_internal_port_ranges PASSED [ 95%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_nonmatching_internal_ports PASSED [ 95%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_one_port PASSED [ 95%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_port_range PASSED [ 95%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_host_only_with_colon PASSED    [ 96%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_non_matching_length_port_ranges PASSED [ 96%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_port_and_range_invalid PASSED  [ 96%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_port_only_with_colon PASSED    [ 96%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_split_port_empty_string PASSED [ 96%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_split_port_invalid PASSED      [ 97%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_split_port_invalid_protocol PASSED [ 97%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_split_port_no_host_port PASSED [ 97%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_split_port_non_string PASSED   [ 97%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_split_port_random_port_range_with_host_port PASSED [ 97%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_split_port_range_no_host_port PASSED [ 97%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_split_port_range_with_host_ip_no_port PASSED [ 98%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_split_port_range_with_host_port PASSED [ 98%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_split_port_range_with_protocol PASSED [ 98%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_split_port_with_host_ip PASSED [ 98%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_split_port_with_host_ip_no_port PASSED [ 98%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_split_port_with_host_port PASSED [ 98%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_split_port_with_ipv6_address PASSED [ 99%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_split_port_with_ipv6_square_brackets_address PASSED [ 99%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_split_port_with_protocol PASSED [ 99%]
09:10:09 tests/unit/utils_test.py::PortsTest::test_with_no_container_port PASSED  [ 99%]
09:10:09 tests/unit/utils_test.py::FormatEnvironmentTest::test_format_env_binary_unicode_value PASSED [ 99%]
09:10:10 tests/unit/utils_test.py::FormatEnvironmentTest::test_format_env_no_value PASSED [100%]
09:10:10 
09:10:10 =================================== FAILURES ===================================
09:10:10 _____________________ ContainerTest.test_remove_container ______________________
09:10:10 tests/unit/api_container_test.py:1413: in test_remove_container
09:10:10     timeout=DEFAULT_TIMEOUT_SECONDS
09:10:10 /usr/local/lib/python3.7/unittest/mock.py:878: in assert_called_with
09:10:10     raise AssertionError(_error_message()) from cause
09:10:10 E   AssertionError: Expected call: mock('DELETE', 'http+docker://localhost/v1.41/containers/3cc2351ab11b', params={'v': False, 'link': False, 'force': False}, timeout=60)
09:10:10 E   Actual call: mock('DELETE', 'http+docker://localhost/v1.41/containers/3cc2351ab11b', params={'v': False, 'link': False, 'force': False}, timeout=70)
09:10:10 _________ ContainerTest.test_remove_container_with_dict_instead_of_id __________
09:10:10 tests/unit/api_container_test.py:1423: in test_remove_container_with_dict_instead_of_id
09:10:10     timeout=DEFAULT_TIMEOUT_SECONDS
09:10:10 /usr/local/lib/python3.7/unittest/mock.py:878: in assert_called_with
09:10:10     raise AssertionError(_error_message()) from cause
09:10:10 E   AssertionError: Expected call: mock('DELETE', 'http+docker://localhost/v1.41/containers/3cc2351ab11b', params={'v': False, 'link': False, 'force': False}, timeout=60)
09:10:10 E   Actual call: mock('DELETE', 'http+docker://localhost/v1.41/containers/3cc2351ab11b', params={'v': False, 'link': False, 'force': False}, timeout=70)
09:10:10 ________________________ DockerApiTest.test_remove_link ________________________
09:10:10 tests/unit/api_test.py:323: in test_remove_link
09:10:10     timeout=DEFAULT_TIMEOUT_SECONDS
09:10:10 /usr/local/lib/python3.7/unittest/mock.py:878: in assert_called_with
09:10:10     raise AssertionError(_error_message()) from cause
09:10:10 E   AssertionError: Expected call: mock('DELETE', 'http+docker://localhost/v1.41/containers/3cc2351ab11b', params={'v': False, 'link': True, 'force': False}, timeout=60)
09:10:10 E   Actual call: mock('DELETE', 'http+docker://localhost/v1.41/containers/3cc2351ab11b', params={'v': False, 'link': True, 'force': False}, timeout=70)
09:10:10 
09:10:10 ---------- coverage: platform linux, python 3.7.12-final-0 -----------
09:10:10 Name                                  Stmts   Miss Branch BrPart  Cover
09:10:10 -----------------------------------------------------------------------
09:10:10 docker/__init__.py                        8      0      0      0   100%
09:10:10 docker/api/__init__.py                    1      0      0      0   100%
09:10:10 docker/api/build.py                     126     41     92     21    62%
09:10:10 docker/api/client.py                    261     65     92     11    75%
09:10:10 docker/api/config.py                     29     18      4      0    33%
09:10:10 docker/api/container.py                 272     73    108     27    65%
09:10:10 docker/api/daemon.py                     39      4     14      4    85%
09:10:10 docker/api/exec_api.py                   45     11     22      9    67%
09:10:10 docker/api/image.py                     159     43     60     14    70%
09:10:10 docker/api/network.py                    90     35     48     11    51%
09:10:10 docker/api/plugin.py                     89     68     14      0    20%
09:10:10 docker/api/secret.py                     34     22      8      0    29%
09:10:10 docker/api/service.py                   200    176    149      0     7%
09:10:10 docker/api/swarm.py                     106     67     38      1    28%
09:10:10 docker/api/volume.py                     38      9     14      2    71%
09:10:10 docker/auth.py                          197     16     74     16    88%
09:10:10 docker/client.py                         69      9      2      0    87%
09:10:10 docker/constants.py                      21      0      0      0   100%
09:10:10 docker/context/__init__.py                2      0      0      0   100%
09:10:10 docker/context/api.py                    78     41     38      8    39%
09:10:10 docker/context/config.py                 61     33     16      2    42%
09:10:10 docker/context/context.py               154     96     64      6    29%
09:10:10 docker/credentials/__init__.py            3      0      0      0   100%
09:10:10 docker/credentials/constants.py           4      0      0      0   100%
09:10:10 docker/credentials/errors.py             11      4      2      0    54%
09:10:10 docker/credentials/store.py              44     30     12      0    25%
09:10:10 docker/credentials/utils.py              23     18     12      0    14%
09:10:10 docker/errors.py                        110     26     20      4    71%
09:10:10 docker/models/__init__.py                 0      0      0      0   100%
09:10:10 docker/models/configs.py                 21      8      2      0    57%
09:10:10 docker/models/containers.py             183     11     70      9    91%
09:10:10 docker/models/images.py                 136     55     56      4    52%
09:10:10 docker/models/networks.py                37      7     12      3    71%
09:10:10 docker/models/nodes.py                   15      5      2      0    59%
09:10:10 docker/models/plugins.py                 48     29      8      0    34%
09:10:10 docker/models/resource.py                41     10      6      3    72%
09:10:10 docker/models/secrets.py                 22      4      2      0    75%
09:10:10 docker/models/services.py                87     35     36      4    59%
09:10:10 docker/models/swarm.py                   39     21      6      0    40%
09:10:10 docker/models/volumes.py                 23     10      4      0    48%
09:10:10 docker/tls.py                            37      6     14      6    76%
09:10:10 docker/transport/__init__.py             11      3      0      0    73%
09:10:10 docker/transport/basehttpadapter.py       6      0      2      1    88%
09:10:10 docker/transport/npipeconn.py            57     52      8      0     8%
09:10:10 docker/transport/npipesocket.py         134    130     20      0     3%
09:10:10 docker/transport/sshconn.py             162    105     54      3    30%
09:10:10 docker/transport/ssladapter.py           36     10     10      4    65%
09:10:10 docker/transport/unixconn.py             54      3      6      1    93%
09:10:10 docker/types/__init__.py                  6      0      0      0   100%
09:10:10 docker/types/base.py                      4      0      2      0   100%
09:10:10 docker/types/containers.py              419     79    326     43    81%
09:10:10 docker/types/daemon.py                   36     24     14      0    24%
09:10:10 docker/types/healthcheck.py              33     20      4      0    35%
09:10:10 docker/types/networks.py                 41     11     28      9    65%
09:10:10 docker/types/services.py                321    146    216     41    50%
09:10:10 docker/types/swarm.py                    51     45     40      0     7%
09:10:10 docker/utils/__init__.py                  3      0      0      0   100%
09:10:10 docker/utils/build.py                   150     24     72     10    83%
09:10:10 docker/utils/config.py                   36      1     10      1    96%
09:10:10 docker/utils/decorators.py               32      1     12      1    95%
09:10:10 docker/utils/fnmatch.py                  55     18     28      2    61%
09:10:10 docker/utils/json_stream.py              40      8     14      2    78%
09:10:10 docker/utils/ports.py                    50      3     32      2    91%
09:10:10 docker/utils/proxy.py                    32      1     12      0    98%
09:10:10 docker/utils/socket.py                   85     10     40      8    84%
09:10:10 docker/utils/utils.py                   278     18    171     13    92%
09:10:10 docker/version.py                         2      0      2      0   100%
09:10:10 -----------------------------------------------------------------------
09:10:10 TOTAL                                  5097   1818   2244    306    60%
09:10:10 
09:10:10 =========================== short test summary info ============================
09:10:10 XFAIL tests/unit/dockertypes_test.py::MountTest::test_parse_mount_bind_windows
09:10:10 SKIPPED [1] tests/unit/api_build_test.py:169: Windows-specific syntax
09:10:10 SKIPPED [1] tests/unit/client_test.py:99: Npipe Connection Pool only on Windows
09:10:10 SKIPPED [1] tests/unit/client_test.py:138: Npipe Connection Pool only on Windows
09:10:10 SKIPPED [1] tests/unit/client_test.py:212: Npipe Connection Pool only on Windows
09:10:10 SKIPPED [1] tests/unit/client_test.py:249: Npipe Connection Pool only on Windows
09:10:10 SKIPPED [1] tests/unit/context_test.py:18: Windows specific path check
09:10:10 SKIPPED [1] tests/unit/utils_build_test.py:230: Backslash patterns only on Windows
09:10:10 SKIPPED [1] tests/unit/utils_build_test.py:252: Backslash patterns only on Windows
09:10:10 SKIPPED [1] tests/unit/utils_build_test.py:400: root user always has access ; no chmod on Windows
09:10:10 SKIPPED [1] tests/unit/utils_config_test.py:54: condition: sys.platform != 'win32'
09:10:10 ============= 3 failed, 557 passed, 10 skipped, 1 xfailed in 6.30s =============
[Pipeline] sh
09:10:10 + docker stop dpy-dind-2-0-py3.7-20.10.12
09:10:10 Error response from daemon: No such container: dpy-dind-2-0-py3.7-20.10.12
[Pipeline] }
[Pipeline] // withDockerRegistry
[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // withDockerRegistry
[Pipeline] }
[Pipeline] // node
[Pipeline] }
Failed in branch py3.7_20.10.12
[Pipeline] // parallel
[Pipeline] End of Pipeline

GitHub has been notified of this commit’s build result

ERROR: script returned exit code 1
Finished: FAILURE