Pull request #2900 opened Connecting to https://api.github.com using docker-jenkins/****** (docker-jenkins GitHub credentials) Loading trusted files from base branch master at a48a5a9647761406d66e8271f19fab7fa0c5f582 rather than fa56109f6bab79f0e7f576bed2148bf5677090bd 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 Cloning the remote Git repository Cloning with configured refspecs honoured and without tags Cloning repository https://github.com/docker/jps.git > git init /var/cloudbees-jenkins-distribution/workspace/docker-py_PR-2900@libs/jps # timeout=10 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 > git config remote.origin.url https://github.com/docker/jps.git # timeout=10 > git config --add remote.origin.fetch +refs/heads/master:refs/remotes/origin/master # timeout=10 Avoid second fetch 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" First time build. Skipping changelog. > git --version # timeout=10 > git --version # 'git version 2.20.1' 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-0f67128ea07f9ebc7) in /home/ubuntu/workspace/docker-py_PR-2900 [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-2900@tmp/4b9f340f-4102-472d-be72-1d62a7f3affc/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 cleanWorkspace: Ensuring workspace is owned by ubuntu [Pipeline] echo chowning workspace [Pipeline] sh + pwd + id -u + id -g + docker run --rm -v /home/ubuntu/workspace/docker-py_PR-2900:/workspace busybox chown -R 1000:1000 /workspace Unable to find image 'busybox:latest' locally latest: Pulling from library/busybox 24fb2886d6f6: Pulling fs layer 24fb2886d6f6: Download complete 24fb2886d6f6: Pull complete Digest: sha256:f7ca5a32c10d51aeda3b4d01c61c6061f497893d7f6628b92f822f7117182a57 Status: Downloaded newer image for busybox:latest [Pipeline] echo Removing all docker containers [Pipeline] sh + docker container ls -aq [Pipeline] echo Docker containers have been removed [Pipeline] echo cleanWorkspace: Removing existing workspace [Pipeline] deleteDir [Pipeline] echo cleanWorkspace: Workspace is clean. [Pipeline] stage [Pipeline] { (build image) [Pipeline] checkout The recommended git tool is: git using credential docker-jenkins-github-credentials Cloning the remote Git repository Cloning with configured refspecs honoured and without tags Cloning repository https://github.com/docker/docker-py.git > git init /home/ubuntu/workspace/docker-py_PR-2900 # 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/2900/head:refs/remotes/origin/PR-2900 +refs/heads/master:refs/remotes/origin/master # timeout=10 Fetching without tags Merging remotes/origin/master commit a48a5a9647761406d66e8271f19fab7fa0c5f582 into PR head commit fa56109f6bab79f0e7f576bed2148bf5677090bd Merge succeeded, producing fa56109f6bab79f0e7f576bed2148bf5677090bd Checking out Revision fa56109f6bab79f0e7f576bed2148bf5677090bd (PR-2900) > git config remote.origin.url https://github.com/docker/docker-py.git # timeout=10 > git config --add remote.origin.fetch +refs/pull/2900/head:refs/remotes/origin/PR-2900 # 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/2900/head:refs/remotes/origin/PR-2900 +refs/heads/master:refs/remotes/origin/master # timeout=10 > git config core.sparsecheckout # timeout=10 > git checkout -f fa56109f6bab79f0e7f576bed2148bf5677090bd # 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 fa56109f6bab79f0e7f576bed2148bf5677090bd # timeout=10 Commit message: "Add remove() method to Image" First time build. Skipping changelog. [Pipeline] sh + git rev-parse HEAD [Pipeline] withDockerRegistry > git --version # timeout=10 > git --version # 'git version 2.25.1' fatal: bad object 5d8b74fd03a1c7cc00e1c1f32d100ed97a17f4f0 [Pipeline] { [Pipeline] isUnix [Pipeline] sh + docker pull dockerpinata/docker-py:sshdind-fa56109f6bab79f0e7f576bed2148bf5677090bd Error response from daemon: manifest for dockerpinata/docker-py:sshdind-fa56109f6bab79f0e7f576bed2148bf5677090bd not found: manifest unknown: manifest unknown [Pipeline] isUnix [Pipeline] sh + docker build -t dockerpinata/docker-py:sshdind-fa56109f6bab79f0e7f576bed2148bf5677090bd -f tests/Dockerfile-ssh-dind . Sending build context to Docker daemon 1.375MB Step 1/11 : ARG API_VERSION=1.39 Step 2/11 : ARG ENGINE_VERSION=19.03.12 Step 3/11 : FROM docker:${ENGINE_VERSION}-dind $ 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-2900@tmp/54a5850b-18cf-4034-bb51-590ded5fc6db/config.json. Configure a credential helper to remove this warning. See https://docs.docker.com/engine/reference/commandline/login/#credentials-store Login Succeeded 19.03.12-dind: Pulling from library/docker df20fa9351a1: Pulling fs layer 25ad7478873d: Pulling fs layer 4684f6177b5d: Pulling fs layer 46e300cec669: Pulling fs layer 63038576ad94: Pulling fs layer 0fdb76c4706c: Pulling fs layer cb7edeffdfd5: Pulling fs layer cc28bd76800f: Pulling fs layer 54196fe38f7e: Pulling fs layer ea71acc29633: Pulling fs layer 657cc4c15165: Pulling fs layer 46e300cec669: Waiting 63038576ad94: Waiting 0fdb76c4706c: Waiting cb7edeffdfd5: Waiting cc28bd76800f: Waiting 54196fe38f7e: Waiting ea71acc29633: Waiting 657cc4c15165: Waiting 4684f6177b5d: Verifying Checksum 4684f6177b5d: Download complete df20fa9351a1: Verifying Checksum df20fa9351a1: Download complete 25ad7478873d: Verifying Checksum 25ad7478873d: Download complete 63038576ad94: Verifying Checksum 63038576ad94: Download complete 0fdb76c4706c: Verifying Checksum 0fdb76c4706c: Download complete cb7edeffdfd5: Verifying Checksum cb7edeffdfd5: Download complete 54196fe38f7e: Verifying Checksum 54196fe38f7e: Download complete cc28bd76800f: Verifying Checksum cc28bd76800f: Download complete ea71acc29633: Verifying Checksum ea71acc29633: Download complete 657cc4c15165: Verifying Checksum 657cc4c15165: Download complete df20fa9351a1: Pull complete 46e300cec669: Verifying Checksum 46e300cec669: Download complete 25ad7478873d: Pull complete 4684f6177b5d: Pull complete 46e300cec669: Pull complete 63038576ad94: Pull complete 0fdb76c4706c: Pull complete cb7edeffdfd5: Pull complete cc28bd76800f: Pull complete 54196fe38f7e: Pull complete ea71acc29633: Pull complete 657cc4c15165: Pull complete Digest: sha256:674f1f40ff7c8ac14f5d8b6b28d8fb1f182647ff75304d018003f1e21a0d8771 Status: Downloaded newer image for docker:19.03.12-dind ---> 66dc2d45749a Step 4/11 : RUN apk add --no-cache openssh ---> Running in 12f9cf805afc fetch http://dl-cdn.alpinelinux.org/alpine/v3.12/main/x86_64/APKINDEX.tar.gz fetch http://dl-cdn.alpinelinux.org/alpine/v3.12/community/x86_64/APKINDEX.tar.gz (1/4) Installing openssh-sftp-server (8.3_p1-r3) (2/4) Installing openssh-server-common (8.3_p1-r3) (3/4) Installing openssh-server (8.3_p1-r3) (4/4) Installing openssh (8.3_p1-r3) Executing busybox-1.31.1-r16.trigger OK: 28 MiB in 51 packages Removing intermediate container 12f9cf805afc ---> 32db0f4c0934 Step 5/11 : RUN ssh-keygen -A ---> Running in 3e6c48c73b41 ssh-keygen: generating new host keys: RSA DSA ECDSA ED25519 Removing intermediate container 3e6c48c73b41 ---> 810303dc49c6 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 ---> Running in edcb97f633ca Removing intermediate container edcb97f633ca ---> df2512d50a82 Step 7/11 : COPY tests/ssh-keys/authorized_keys /root/.ssh/authorized_keys ---> 499aef0c9a3b Step 8/11 : RUN chmod 600 /root/.ssh/authorized_keys ---> Running in fa9f841b518b Removing intermediate container fa9f841b518b ---> 89c6b5244483 Step 9/11 : RUN echo "root:root" | chpasswd ---> Running in c0370e0b72bd chpasswd: password for 'root' changed Removing intermediate container c0370e0b72bd ---> 16a36a665921 Step 10/11 : RUN ln -s /usr/local/bin/docker /usr/bin/docker ---> Running in e6e408cf0783 Removing intermediate container e6e408cf0783 ---> 24e8c7d49289 Step 11/11 : EXPOSE 22 ---> Running in fb586db5fee6 Removing intermediate container fb586db5fee6 ---> da756bdfd80c Successfully built da756bdfd80c Successfully tagged dockerpinata/docker-py:sshdind-fa56109f6bab79f0e7f576bed2148bf5677090bd [Pipeline] isUnix [Pipeline] sh + docker tag dockerpinata/docker-py:sshdind-fa56109f6bab79f0e7f576bed2148bf5677090bd dockerpinata/docker-py:sshdind-fa56109f6bab79f0e7f576bed2148bf5677090bd [Pipeline] isUnix [Pipeline] sh + docker push dockerpinata/docker-py:sshdind-fa56109f6bab79f0e7f576bed2148bf5677090bd The push refers to repository [docker.io/dockerpinata/docker-py] 4f96667b1424: Preparing 196266020e5a: Preparing f3f2279c41b8: Preparing 4c1a2bd86ed0: Preparing 6bc7d284de0f: Preparing c312ecbb20de: Preparing 013b6a1e7cba: Preparing 1149e736aa92: Preparing 39e79983ac8b: Preparing da8c28465f82: Preparing d1292e236c36: Preparing 8890c171a12b: Preparing 4ae5bd84d450: Preparing 723a561964c8: Preparing 78764725b56c: Preparing 51d6d3d09136: Preparing 1507bc794612: Preparing 50644c29ef5a: Preparing c312ecbb20de: Waiting 013b6a1e7cba: Waiting 1149e736aa92: Waiting 39e79983ac8b: Waiting da8c28465f82: Waiting d1292e236c36: Waiting 8890c171a12b: Waiting 4ae5bd84d450: Waiting 723a561964c8: Waiting 78764725b56c: Waiting 51d6d3d09136: Waiting 1507bc794612: Waiting 50644c29ef5a: Waiting 4f96667b1424: Pushed 4c1a2bd86ed0: Pushed 6bc7d284de0f: Pushed 1149e736aa92: Layer already exists 39e79983ac8b: Layer already exists da8c28465f82: Layer already exists d1292e236c36: Layer already exists 8890c171a12b: Layer already exists 4ae5bd84d450: Layer already exists 196266020e5a: Pushed f3f2279c41b8: Pushed 723a561964c8: Layer already exists 78764725b56c: Layer already exists 51d6d3d09136: Layer already exists 1507bc794612: Layer already exists 50644c29ef5a: Layer already exists c312ecbb20de: Pushed 013b6a1e7cba: Pushed sshdind-fa56109f6bab79f0e7f576bed2148bf5677090bd: digest: sha256:208a9860573b2061725714687986d75aa36d22dd99de1e5d683e52d6017edee5 size: 4067 [Pipeline] isUnix [Pipeline] sh + docker pull dockerpinata/docker-py:py3-fa56109f6bab79f0e7f576bed2148bf5677090bd Error response from daemon: manifest for dockerpinata/docker-py:py3-fa56109f6bab79f0e7f576bed2148bf5677090bd not found: manifest unknown: manifest unknown [Pipeline] isUnix [Pipeline] sh + docker build -t dockerpinata/docker-py:py3-fa56109f6bab79f0e7f576bed2148bf5677090bd -f tests/Dockerfile --build-arg PYTHON_VERSION=3.7 . Sending build context to Docker daemon 1.375MB Step 1/21 : ARG PYTHON_VERSION=3.7 Step 2/21 : FROM python:${PYTHON_VERSION} 3.7: Pulling from library/python bb7d5a84853b: Pulling fs layer f02b617c6a8c: Pulling fs layer d32e17419b7e: Pulling fs layer c9d2d81226a4: Pulling fs layer 3c24ae8b6604: Pulling fs layer 8a4322d1621d: Pulling fs layer 637b803a116b: Pulling fs layer 3d1bee7e0864: Pulling fs layer c98ebb0625ce: Pulling fs layer c9d2d81226a4: Waiting 3c24ae8b6604: Waiting 8a4322d1621d: Waiting 637b803a116b: Waiting 3d1bee7e0864: Waiting c98ebb0625ce: Waiting f02b617c6a8c: Verifying Checksum f02b617c6a8c: Download complete d32e17419b7e: Verifying Checksum d32e17419b7e: Download complete bb7d5a84853b: Verifying Checksum bb7d5a84853b: Download complete 8a4322d1621d: Verifying Checksum 8a4322d1621d: Download complete c9d2d81226a4: Verifying Checksum c9d2d81226a4: Download complete 3d1bee7e0864: Verifying Checksum 3d1bee7e0864: Download complete 637b803a116b: Verifying Checksum 637b803a116b: Download complete c98ebb0625ce: Verifying Checksum c98ebb0625ce: Download complete 3c24ae8b6604: Verifying Checksum 3c24ae8b6604: Download complete bb7d5a84853b: Pull complete f02b617c6a8c: Pull complete d32e17419b7e: Pull complete c9d2d81226a4: Pull complete 3c24ae8b6604: Pull complete 8a4322d1621d: Pull complete 637b803a116b: Pull complete 3d1bee7e0864: Pull complete c98ebb0625ce: Pull complete Digest: sha256:2fb1f5e24f8866dea7568d1dc2c25d8dec1a1aba1c6831fc510eba030e560123 Status: Downloaded newer image for python:3.7 ---> e3db4b1108b4 Step 3/21 : ARG APT_MIRROR ---> Running in bddca4bdcac7 Removing intermediate container bddca4bdcac7 ---> 29494154d6fd 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 ---> Running in f039bb255bc5 Removing intermediate container f039bb255bc5 ---> 3248b50c7407 Step 5/21 : RUN apt-get update && apt-get -y install --no-install-recommends gnupg2 pass ---> Running in d85d62a10f05 Get:1 http://security.debian.org/debian-security bullseye-security InRelease [44.1 kB] Get:2 http://deb.debian.org/debian bullseye InRelease [116 kB] Get:3 http://deb.debian.org/debian bullseye-updates InRelease [39.4 kB] Get:4 http://security.debian.org/debian-security bullseye-security/main amd64 Packages [48.0 kB] Get:5 http://deb.debian.org/debian bullseye/main amd64 Packages [8180 kB] Get:6 http://deb.debian.org/debian bullseye-updates/main amd64 Packages [2300 B] Fetched 8430 kB in 2s (3435 kB/s) Reading package lists... Reading package lists... Building dependency tree... Reading state information... The following additional packages will be installed: tree Suggested packages: python libxml-simple-perl ruby Recommended packages: qrencode xclip The following NEW packages will be installed: gnupg2 pass tree 0 upgraded, 3 newly installed, 0 to remove and 0 not upgraded. Need to get 523 kB of archives. After this operation, 727 kB of additional disk space will be used. Get:1 http://deb.debian.org/debian bullseye/main amd64 gnupg2 all 2.2.27-2 [434 kB] Get:2 http://deb.debian.org/debian bullseye/main amd64 tree amd64 1.8.0-1+b1 [49.6 kB] Get:3 http://deb.debian.org/debian bullseye/main amd64 pass all 1.7.3-2 [39.2 kB] debconf: delaying package configuration, since apt-utils is not installed Fetched 523 kB in 0s (1922 kB/s) Selecting previously unselected package gnupg2. (Reading database ... (Reading database ... 5% (Reading database ... 10% (Reading database ... 15% (Reading database ... 20% (Reading database ... 25% (Reading database ... 30% (Reading database ... 35% (Reading database ... 40% (Reading database ... 45% (Reading database ... 50% (Reading database ... 55% (Reading database ... 60% (Reading database ... 65% (Reading database ... 70% (Reading database ... 75% (Reading database ... 80% (Reading database ... 85% (Reading database ... 90% (Reading database ... 95% (Reading database ... 100% (Reading database ... 23378 files and directories currently installed.) Preparing to unpack .../gnupg2_2.2.27-2_all.deb ... Unpacking gnupg2 (2.2.27-2) ... Selecting previously unselected package tree. Preparing to unpack .../tree_1.8.0-1+b1_amd64.deb ... Unpacking tree (1.8.0-1+b1) ... Selecting previously unselected package pass. Preparing to unpack .../archives/pass_1.7.3-2_all.deb ... Unpacking pass (1.7.3-2) ... Setting up gnupg2 (2.2.27-2) ... Setting up tree (1.8.0-1+b1) ... Setting up pass (1.7.3-2) ... Removing intermediate container d85d62a10f05 ---> f5f41dbf9629 Step 6/21 : COPY tests/ssh-keys /root/.ssh ---> e5ac5e2f889a Step 7/21 : RUN chmod -R 600 /root/.ssh ---> Running in f258d148e458 Removing intermediate container f258d148e458 ---> 148c77c61e8a Step 8/21 : COPY ./tests/gpg-keys /gpg-keys ---> b9fd5bb02add Step 9/21 : RUN gpg2 --import gpg-keys/secret ---> Running in f42f696106f1 gpg: directory '/root/.gnupg' created gpg: keybox '/root/.gnupg/pubring.kbx' created gpg: /root/.gnupg/trustdb.gpg: trustdb created gpg: key 464ED987A7B21401: public key "Sakuya Izayoi " imported gpg: key 464ED987A7B21401: secret key imported gpg: Total number processed: 1 gpg: imported: 1 gpg: secret keys read: 1 gpg: secret keys imported: 1 Removing intermediate container f42f696106f1 ---> 46c73bff5b89 Step 10/21 : RUN gpg2 --import-ownertrust gpg-keys/ownertrust ---> Running in f4b0c6990c28 gpg: inserting ownertrust of 6 Removing intermediate container f4b0c6990c28 ---> 7fe6a022c1b1 Step 11/21 : RUN yes | pass init $(gpg2 --no-auto-check-trustdb --list-secret-key | awk '/^sec/{getline; $1=$1; print}') ---> Running in d56255728b36 gpg: please do a --check-trustdb mkdir: created directory '/root/.password-store/' Password store initialized for 9781B87DAB042E6FD51388A5464ED987A7B21401 Removing intermediate container d56255728b36 ---> 466a8d59e36a Step 12/21 : RUN gpg2 --check-trustdb ---> Running in 5d7c734f38bd gpg: marginals needed: 3 completes needed: 1 trust model: pgp gpg: depth: 0 valid: 1 signed: 0 trust: 0-, 0q, 0n, 0m, 0f, 1u Removing intermediate container 5d7c734f38bd ---> c8cf152e8bd9 Step 13/21 : ARG CREDSTORE_VERSION=v0.6.3 ---> Running in e1ab9f058bb0 Removing intermediate container e1ab9f058bb0 ---> dedb99ef3986 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 ---> Running in ef3aa3e936e2 Removing intermediate container ef3aa3e936e2 ---> dce0e0afad1b Step 15/21 : WORKDIR /src ---> Running in d12bfa3810a2 Removing intermediate container d12bfa3810a2 ---> 373d30f51fbc Step 16/21 : COPY requirements.txt /src/requirements.txt ---> 9c27138e41e9 Step 17/21 : RUN pip install -r requirements.txt ---> Running in 2e2093d83281 Ignoring pywin32: markers 'sys_platform == "win32"' don't match your environment Collecting appdirs==1.4.3 Downloading appdirs-1.4.3-py2.py3-none-any.whl (12 kB) Collecting asn1crypto==0.22.0 Downloading asn1crypto-0.22.0-py2.py3-none-any.whl (97 kB) Collecting backports.ssl-match-hostname==3.5.0.1 Downloading backports.ssl_match_hostname-3.5.0.1.tar.gz (5.6 kB) Collecting cffi==1.14.4 Downloading cffi-1.14.4-cp37-cp37m-manylinux1_x86_64.whl (402 kB) Collecting cryptography==3.4.7 Downloading cryptography-3.4.7-cp36-abi3-manylinux2014_x86_64.whl (3.2 MB) Collecting enum34==1.1.6 Downloading enum34-1.1.6-py3-none-any.whl (12 kB) Collecting idna==2.5 Downloading idna-2.5-py2.py3-none-any.whl (55 kB) Collecting ipaddress==1.0.18 Downloading ipaddress-1.0.18.tar.gz (32 kB) Collecting packaging==16.8 Downloading packaging-16.8-py2.py3-none-any.whl (23 kB) Collecting paramiko==2.8.0 Downloading paramiko-2.8.0-py2.py3-none-any.whl (206 kB) Collecting pycparser==2.17 Downloading pycparser-2.17.tar.gz (231 kB) Collecting pyOpenSSL==18.0.0 Downloading pyOpenSSL-18.0.0-py2.py3-none-any.whl (53 kB) Collecting pyparsing==2.2.0 Downloading pyparsing-2.2.0-py2.py3-none-any.whl (56 kB) Collecting requests==2.26.0 Downloading requests-2.26.0-py2.py3-none-any.whl (62 kB) Collecting urllib3==1.26.5 Downloading urllib3-1.26.5-py2.py3-none-any.whl (138 kB) Collecting websocket-client==0.56.0 Downloading websocket_client-0.56.0-py2.py3-none-any.whl (200 kB) Collecting six Downloading six-1.16.0-py2.py3-none-any.whl (11 kB) Collecting bcrypt>=3.1.3 Downloading bcrypt-3.2.0-cp36-abi3-manylinux2010_x86_64.whl (63 kB) Collecting pynacl>=1.0.1 Downloading PyNaCl-1.4.0-cp35-abi3-manylinux1_x86_64.whl (961 kB) Collecting charset-normalizer~=2.0.0 Downloading charset_normalizer-2.0.7-py3-none-any.whl (38 kB) Collecting certifi>=2017.4.17 Downloading certifi-2021.10.8-py2.py3-none-any.whl (149 kB) Building wheels for collected packages: backports.ssl-match-hostname, ipaddress, pycparser Building wheel for backports.ssl-match-hostname (setup.py): started Building wheel for backports.ssl-match-hostname (setup.py): finished with status 'done' Created wheel for backports.ssl-match-hostname: filename=backports.ssl_match_hostname-3.5.0.1-py3-none-any.whl size=5206 sha256=6648fc5fc59328acbb179b5f6a4bab755abefe0ad2f5b7989a6285e5109b9a94 Stored in directory: /root/.cache/pip/wheels/93/72/f6/df894bfc7947d11f89dbdb4e9b786703a43cd547c1b5e8c738 Building wheel for ipaddress (setup.py): started Building wheel for ipaddress (setup.py): finished with status 'done' Created wheel for ipaddress: filename=ipaddress-1.0.18-py3-none-any.whl size=18124 sha256=966ee3b78678686992fba92ac94103375635fd1c86cce8439b2eef33d8b2b676 Stored in directory: /root/.cache/pip/wheels/54/90/bd/f99e221ab77ef8e6d65c14efe986cef3360da2990396093151 Building wheel for pycparser (setup.py): started Building wheel for pycparser (setup.py): finished with status 'done' Created wheel for pycparser: filename=pycparser-2.17-py2.py3-none-any.whl size=192898 sha256=961f5c77501a85cd12a74e19a10d7f319b611f64675e04573a3b72191460bcc1 Stored in directory: /root/.cache/pip/wheels/91/50/7a/9f94e39b01559aa44c3cefb775d7befcc01d0a6ed0093cab37 Successfully built backports.ssl-match-hostname ipaddress pycparser Installing collected packages: pycparser, six, cffi, urllib3, pyparsing, pynacl, idna, cryptography, charset-normalizer, certifi, bcrypt, websocket-client, requests, pyOpenSSL, paramiko, packaging, ipaddress, enum34, backports.ssl-match-hostname, asn1crypto, appdirs Successfully installed appdirs-1.4.3 asn1crypto-0.22.0 backports.ssl-match-hostname-3.5.0.1 bcrypt-3.2.0 certifi-2021.10.8 cffi-1.14.4 charset-normalizer-2.0.7 cryptography-3.4.7 enum34-1.1.6 idna-2.5 ipaddress-1.0.18 packaging-16.8 paramiko-2.8.0 pyOpenSSL-18.0.0 pycparser-2.17 pynacl-1.4.0 pyparsing-2.2.0 requests-2.26.0 six-1.16.0 urllib3-1.26.5 websocket-client-0.56.0 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 WARNING: You are using pip version 21.2.4; however, version 21.3 is available. You should consider upgrading via the '/usr/local/bin/python -m pip install --upgrade pip' command. Removing intermediate container 2e2093d83281 ---> a145848a7e70 Step 18/21 : COPY test-requirements.txt /src/test-requirements.txt ---> 32e02d75aa8b Step 19/21 : RUN pip install -r test-requirements.txt ---> Running in 02292c3568a3 Collecting setuptools==58.2.0 Downloading setuptools-58.2.0-py3-none-any.whl (946 kB) Collecting coverage==6.0.1 Downloading coverage-6.0.1-cp37-cp37m-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_12_x86_64.manylinux2010_x86_64.whl (252 kB) Collecting flake8==4.0.1 Downloading flake8-4.0.1-py2.py3-none-any.whl (64 kB) Collecting pytest==6.2.5 Downloading pytest-6.2.5-py3-none-any.whl (280 kB) Collecting pytest-cov==3.0.0 Downloading pytest_cov-3.0.0-py3-none-any.whl (20 kB) Collecting pytest-timeout==2.0.1 Downloading pytest_timeout-2.0.1-py3-none-any.whl (11 kB) Collecting mccabe<0.7.0,>=0.6.0 Downloading mccabe-0.6.1-py2.py3-none-any.whl (8.6 kB) Collecting pyflakes<2.5.0,>=2.4.0 Downloading pyflakes-2.4.0-py2.py3-none-any.whl (69 kB) Collecting pycodestyle<2.9.0,>=2.8.0 Downloading pycodestyle-2.8.0-py2.py3-none-any.whl (42 kB) Collecting importlib-metadata<4.3 Downloading importlib_metadata-4.2.0-py3-none-any.whl (16 kB) Collecting iniconfig Downloading iniconfig-1.1.1-py2.py3-none-any.whl (5.0 kB) Requirement already satisfied: packaging in /usr/local/lib/python3.7/site-packages (from pytest==6.2.5->-r test-requirements.txt (line 4)) (16.8) Collecting attrs>=19.2.0 Downloading attrs-21.2.0-py2.py3-none-any.whl (53 kB) Collecting py>=1.8.2 Downloading py-1.10.0-py2.py3-none-any.whl (97 kB) Collecting pluggy<2.0,>=0.12 Downloading pluggy-1.0.0-py2.py3-none-any.whl (13 kB) Collecting toml Downloading toml-0.10.2-py2.py3-none-any.whl (16 kB) Collecting coverage[toml]>=5.2.1 Downloading coverage-6.0.2-cp37-cp37m-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_12_x86_64.manylinux2010_x86_64.whl (253 kB) Collecting tomli Downloading tomli-1.2.1-py3-none-any.whl (11 kB) Collecting typing-extensions>=3.6.4 Downloading typing_extensions-3.10.0.2-py3-none-any.whl (26 kB) Collecting zipp>=0.5 Downloading zipp-3.6.0-py3-none-any.whl (5.3 kB) Requirement already satisfied: pyparsing in /usr/local/lib/python3.7/site-packages (from packaging->pytest==6.2.5->-r test-requirements.txt (line 4)) (2.2.0) Requirement already satisfied: six in /usr/local/lib/python3.7/site-packages (from packaging->pytest==6.2.5->-r test-requirements.txt (line 4)) (1.16.0) Installing collected packages: zipp, typing-extensions, importlib-metadata, tomli, toml, py, pluggy, iniconfig, coverage, attrs, pytest, pyflakes, pycodestyle, mccabe, setuptools, pytest-timeout, pytest-cov, flake8 Attempting uninstall: setuptools Found existing installation: setuptools 57.5.0 Uninstalling setuptools-57.5.0: Successfully uninstalled setuptools-57.5.0 Successfully installed attrs-21.2.0 coverage-6.0.1 flake8-4.0.1 importlib-metadata-4.2.0 iniconfig-1.1.1 mccabe-0.6.1 pluggy-1.0.0 py-1.10.0 pycodestyle-2.8.0 pyflakes-2.4.0 pytest-6.2.5 pytest-cov-3.0.0 pytest-timeout-2.0.1 setuptools-58.2.0 toml-0.10.2 tomli-1.2.1 typing-extensions-3.10.0.2 zipp-3.6.0 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 WARNING: You are using pip version 21.2.4; however, version 21.3 is available. You should consider upgrading via the '/usr/local/bin/python -m pip install --upgrade pip' command. Removing intermediate container 02292c3568a3 ---> afb97751a7e0 Step 20/21 : COPY . /src ---> 110aa83001d9 Step 21/21 : RUN pip install . ---> Running in 0cb7c66372b1 Processing /src  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. pip 21.3 will remove support for this functionality. You can find discussion regarding this at https://github.com/pypa/pip/issues/7555. 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) 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) 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.7) 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) 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) 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) 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) Building wheels for collected packages: docker Building wheel for docker (setup.py): started Building wheel for docker (setup.py): finished with status 'done' Created wheel for docker: filename=docker-5.1.0.dev0-py3-none-any.whl size=146382 sha256=34a00ab8f0ec7efe81822208541d4d1d911a34fbd2733058a1a41a1ea2f5e050 Stored in directory: /tmp/pip-ephem-wheel-cache-iamqycx5/wheels/6f/63/19/359cf44f647b75d0ea75ecc03aa429fec4c372b453eb4b6525 Successfully built docker Installing collected packages: docker Successfully installed docker-5.1.0.dev0 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 WARNING: You are using pip version 21.2.4; however, version 21.3 is available. You should consider upgrading via the '/usr/local/bin/python -m pip install --upgrade pip' command. Removing intermediate container 0cb7c66372b1 ---> 0470449f69ad Successfully built 0470449f69ad Successfully tagged dockerpinata/docker-py:py3-fa56109f6bab79f0e7f576bed2148bf5677090bd [Pipeline] isUnix [Pipeline] sh + docker tag dockerpinata/docker-py:py3-fa56109f6bab79f0e7f576bed2148bf5677090bd dockerpinata/docker-py:py3-fa56109f6bab79f0e7f576bed2148bf5677090bd [Pipeline] isUnix [Pipeline] sh + docker push dockerpinata/docker-py:py3-fa56109f6bab79f0e7f576bed2148bf5677090bd The push refers to repository [docker.io/dockerpinata/docker-py] 1098a78d8c74: Preparing 3f5425b4e82a: Preparing 030ab1963055: Preparing 1edce45135be: Preparing 74d6f46fdea8: Preparing 0787977867e9: Preparing 91d1ad744b91: Preparing a656e08d4b5f: Preparing 7bad1d971a9e: Preparing 68eb018ce1cb: Preparing 435731809274: Preparing b6994af890a6: Preparing 25b8f0f72f97: Preparing 7d53803cd8aa: Preparing a038058f428e: Preparing f2328a585173: Preparing e3baa66d5763: Preparing cd61869a0a0d: Preparing da8ee6936a47: Preparing 6ae392c466cc: Preparing 7fcd2600f5ad: Preparing 8f56c3340629: Preparing ba6e5ff31f23: Preparing 9f9f651e9303: Preparing 0b3c02b5d746: Preparing 62a747bf1719: Preparing 7d53803cd8aa: Waiting a038058f428e: Waiting f2328a585173: Waiting e3baa66d5763: Waiting cd61869a0a0d: Waiting da8ee6936a47: Waiting 6ae392c466cc: Waiting 7fcd2600f5ad: Waiting 8f56c3340629: Waiting ba6e5ff31f23: Waiting 9f9f651e9303: Waiting 0b3c02b5d746: Waiting 62a747bf1719: Waiting 0787977867e9: Waiting 91d1ad744b91: Waiting a656e08d4b5f: Waiting 7bad1d971a9e: Waiting 68eb018ce1cb: Waiting 435731809274: Waiting b6994af890a6: Waiting 25b8f0f72f97: Waiting 1098a78d8c74: Pushed 1edce45135be: Pushed 3f5425b4e82a: Pushed 91d1ad744b91: Pushed 0787977867e9: Pushed 030ab1963055: Pushed a656e08d4b5f: Pushed 7bad1d971a9e: Pushed 68eb018ce1cb: Pushed b6994af890a6: Pushed 74d6f46fdea8: Pushed 435731809274: Pushed 25b8f0f72f97: Pushed cd61869a0a0d: Layer already exists da8ee6936a47: Layer already exists 6ae392c466cc: Layer already exists a038058f428e: Pushed 7fcd2600f5ad: Layer already exists 8f56c3340629: Layer already exists ba6e5ff31f23: Layer already exists 9f9f651e9303: Layer already exists 0b3c02b5d746: Layer already exists 62a747bf1719: Layer already exists e3baa66d5763: Pushed 7d53803cd8aa: Pushed f2328a585173: Pushed py3-fa56109f6bab79f0e7f576bed2148bf5677090bd: digest: sha256:932f9b8cf60503c481157f2deb2bd1d1dbd39bd2bef3cc5af267e5a48da6c302 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-0c11ab9c1bbf4a16b) in /home/ubuntu/workspace/docker-py_PR-2900 [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-2900@tmp/69cd582a-667d-49fa-aebe-51e90990313b/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 + docker run --rm --entrypoint=python dockerpinata/docker-py:py3-fa56109f6bab79f0e7f576bed2148bf5677090bd /src/scripts/versions.py Unable to find image 'dockerpinata/docker-py:py3-fa56109f6bab79f0e7f576bed2148bf5677090bd' locally py3-fa56109f6bab79f0e7f576bed2148bf5677090bd: Pulling from dockerpinata/docker-py bb7d5a84853b: Already exists f02b617c6a8c: Already exists d32e17419b7e: Already exists c9d2d81226a4: Already exists 3c24ae8b6604: Already exists 8a4322d1621d: Already exists 637b803a116b: Already exists 3d1bee7e0864: Already exists c98ebb0625ce: Already exists 17ec2a9f8770: Pulling fs layer 5ecf0073da0e: Pulling fs layer fa0fb0a24794: Pulling fs layer 34affa70c927: Pulling fs layer 0e566ba6ce77: Pulling fs layer 69b1fa2b027c: Pulling fs layer 82d4a1ffa5fa: Pulling fs layer 6e8fbd055e90: Pulling fs layer 494ec8a0680c: Pulling fs layer 0ad16b3cf88d: Pulling fs layer 29db26f4cb69: Pulling fs layer d980bb33ad2b: Pulling fs layer 19c0f0444160: Pulling fs layer d227631b0a24: Pulling fs layer 441f6c5633e3: Pulling fs layer 63f63170add3: Pulling fs layer 068dd35dd78b: Pulling fs layer 34affa70c927: Waiting 0e566ba6ce77: Waiting 69b1fa2b027c: Waiting 82d4a1ffa5fa: Waiting 6e8fbd055e90: Waiting 494ec8a0680c: Waiting 0ad16b3cf88d: Waiting 29db26f4cb69: Waiting d980bb33ad2b: Waiting 19c0f0444160: Waiting d227631b0a24: Waiting 441f6c5633e3: Waiting 63f63170add3: Waiting 068dd35dd78b: Waiting 17ec2a9f8770: Verifying Checksum 17ec2a9f8770: Download complete fa0fb0a24794: Verifying Checksum fa0fb0a24794: Download complete 34affa70c927: Verifying Checksum 34affa70c927: Download complete 0e566ba6ce77: Verifying Checksum 0e566ba6ce77: Download complete 17ec2a9f8770: Pull complete 82d4a1ffa5fa: Verifying Checksum 82d4a1ffa5fa: Download complete 69b1fa2b027c: Verifying Checksum 69b1fa2b027c: Download complete 5ecf0073da0e: Verifying Checksum 5ecf0073da0e: Download complete 494ec8a0680c: Download complete 6e8fbd055e90: Verifying Checksum 6e8fbd055e90: Download complete 29db26f4cb69: Verifying Checksum 29db26f4cb69: Download complete 0ad16b3cf88d: Download complete d980bb33ad2b: Verifying Checksum d980bb33ad2b: Download complete d227631b0a24: Verifying Checksum d227631b0a24: Download complete 441f6c5633e3: Verifying Checksum 441f6c5633e3: Download complete 63f63170add3: Verifying Checksum 63f63170add3: Download complete 068dd35dd78b: Verifying Checksum 068dd35dd78b: Download complete 19c0f0444160: Verifying Checksum 19c0f0444160: Download complete 5ecf0073da0e: Pull complete fa0fb0a24794: Pull complete 34affa70c927: Pull complete 0e566ba6ce77: Pull complete 69b1fa2b027c: Pull complete 82d4a1ffa5fa: Pull complete 6e8fbd055e90: Pull complete 494ec8a0680c: Pull complete 0ad16b3cf88d: Pull complete 29db26f4cb69: Pull complete d980bb33ad2b: Pull complete 19c0f0444160: Pull complete d227631b0a24: Pull complete 441f6c5633e3: Pull complete 63f63170add3: Pull complete 068dd35dd78b: Pull complete Digest: sha256:932f9b8cf60503c481157f2deb2bd1d1dbd39bd2bef3cc5af267e5a48da6c302 Status: Downloaded newer image for dockerpinata/docker-py:py3-fa56109f6bab79f0e7f576bed2148bf5677090bd [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_20.10.9) [Pipeline] { (Branch: py3.7_19.03.13) [Pipeline] node [Pipeline] node [Pipeline] node Running on EC2 (managed-agents) - ubuntu-2004-cgroup1 (i-0c11ab9c1bbf4a16b) in /home/ubuntu/workspace/docker-py_PR-2900 Running on EC2 (managed-agents) - ubuntu-2004-cgroup1 (i-0f67128ea07f9ebc7) in /home/ubuntu/workspace/docker-py_PR-2900 [Pipeline] { [Pipeline] { [Pipeline] withDockerRegistry [Pipeline] withDockerRegistry $ docker login -u dockerbuildbot -p ******** https://index.docker.io/v1/ $ 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-2900@tmp/feeb4bc5-46d1-4937-afd5-2b3dadd706be/config.json. Configure a credential helper to remove this warning. See https://docs.docker.com/engine/reference/commandline/login/#credentials-store Login Succeeded 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-2900@tmp/e24c5240-dbed-4a09-8c99-3b29d982ea2b/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] { [Pipeline] wrap [Pipeline] wrap [Pipeline] { [Pipeline] { [Pipeline] wrap [Pipeline] wrap [Pipeline] { [Pipeline] { [Pipeline] echo cleanWorkspace: Ensuring workspace is owned by ubuntu [Pipeline] echo chowning workspace [Pipeline] sh [Pipeline] echo cleanWorkspace: Ensuring workspace is owned by ubuntu [Pipeline] echo chowning workspace [Pipeline] sh + pwd + id -u + id -g + docker run --rm -v /home/ubuntu/workspace/docker-py_PR-2900:/workspace busybox chown -R 1000:1000 /workspace + pwd + id -u + id -g + docker run --rm -v /home/ubuntu/workspace/docker-py_PR-2900:/workspace busybox chown -R 1000:1000 /workspace [Pipeline] echo Removing all docker containers [Pipeline] sh [Pipeline] echo Removing all docker containers [Pipeline] sh Running on EC2 (managed-agents) - ubuntu-2004-cgroup1 (i-05503d3ee65da17a3) in /home/ubuntu/workspace/docker-py_PR-2900 [Pipeline] { [Pipeline] withDockerRegistry $ docker login -u dockerbuildbot -p ******** https://index.docker.io/v1/ + docker container ls -aq [Pipeline] echo Docker containers have been removed [Pipeline] echo cleanWorkspace: Removing existing workspace [Pipeline] deleteDir 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-2900@tmp/f178c614-bcf6-4909-ae54-4a504b01b137/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 cleanWorkspace: Ensuring workspace is owned by ubuntu [Pipeline] echo chowning workspace [Pipeline] sh + docker container ls -aq [Pipeline] echo Docker containers have been removed [Pipeline] echo cleanWorkspace: Removing existing workspace [Pipeline] deleteDir [Pipeline] echo cleanWorkspace: Workspace is clean. [Pipeline] stage [Pipeline] { (test python=py3.7 / docker=20.10.9) [Pipeline] echo cleanWorkspace: Workspace is clean. [Pipeline] stage [Pipeline] { (test python=py3.7 / docker=19.03.12) [Pipeline] checkout The recommended git tool is: git [Pipeline] checkout using credential docker-jenkins-github-credentials The recommended git tool is: git Cloning the remote Git repository Cloning with configured refspecs honoured and without tags using credential docker-jenkins-github-credentials Cloning the remote Git repository Cloning with configured refspecs honoured and without tags + pwd + id -u + id -g + docker run --rm -v /home/ubuntu/workspace/docker-py_PR-2900:/workspace busybox chown -R 1000:1000 /workspace Cloning repository https://github.com/docker/docker-py.git > git init /home/ubuntu/workspace/docker-py_PR-2900 # 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/2900/head:refs/remotes/origin/PR-2900 +refs/heads/master:refs/remotes/origin/master # timeout=10 Cloning repository https://github.com/docker/docker-py.git > git init /home/ubuntu/workspace/docker-py_PR-2900 # 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/2900/head:refs/remotes/origin/PR-2900 +refs/heads/master:refs/remotes/origin/master # timeout=10 [Pipeline] echo Removing all docker containers [Pipeline] sh Fetching without tags Fetching without tags + docker container ls -aq [Pipeline] echo Docker containers have been removed [Pipeline] echo cleanWorkspace: Removing existing workspace [Pipeline] deleteDir [Pipeline] echo cleanWorkspace: Workspace is clean. [Pipeline] stage [Pipeline] { (test python=py3.7 / docker=19.03.13) [Pipeline] checkout The recommended git tool is: git using credential docker-jenkins-github-credentials Cloning the remote Git repository Cloning with configured refspecs honoured and without tags Merging remotes/origin/master commit a48a5a9647761406d66e8271f19fab7fa0c5f582 into PR head commit fa56109f6bab79f0e7f576bed2148bf5677090bd Merging remotes/origin/master commit a48a5a9647761406d66e8271f19fab7fa0c5f582 into PR head commit fa56109f6bab79f0e7f576bed2148bf5677090bd Merge succeeded, producing fa56109f6bab79f0e7f576bed2148bf5677090bd Checking out Revision fa56109f6bab79f0e7f576bed2148bf5677090bd (PR-2900) Commit message: "Add remove() method to Image" Merge succeeded, producing fa56109f6bab79f0e7f576bed2148bf5677090bd Checking out Revision fa56109f6bab79f0e7f576bed2148bf5677090bd (PR-2900) Commit message: "Add remove() method to Image" > git config remote.origin.url https://github.com/docker/docker-py.git # timeout=10 > git config --add remote.origin.fetch +refs/pull/2900/head:refs/remotes/origin/PR-2900 # 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/2900/head:refs/remotes/origin/PR-2900 +refs/heads/master:refs/remotes/origin/master # timeout=10 > git config core.sparsecheckout # timeout=10 > git checkout -f fa56109f6bab79f0e7f576bed2148bf5677090bd # 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 fa56109f6bab79f0e7f576bed2148bf5677090bd # timeout=10 > git config remote.origin.url https://github.com/docker/docker-py.git # timeout=10 > git config --add remote.origin.fetch +refs/pull/2900/head:refs/remotes/origin/PR-2900 # 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/2900/head:refs/remotes/origin/PR-2900 +refs/heads/master:refs/remotes/origin/master # timeout=10 > git config core.sparsecheckout # timeout=10 > git checkout -f fa56109f6bab79f0e7f576bed2148bf5677090bd # 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 fa56109f6bab79f0e7f576bed2148bf5677090bd # timeout=10 [Pipeline] withDockerRegistry Cloning repository https://github.com/docker/docker-py.git > git init /home/ubuntu/workspace/docker-py_PR-2900 # 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/2900/head:refs/remotes/origin/PR-2900 +refs/heads/master:refs/remotes/origin/master # timeout=10 [Pipeline] withDockerRegistry [Pipeline] { [Pipeline] sh [Pipeline] { [Pipeline] sh + docker run --rm -e DOCKER_TEST_API_VERSION=1.40 dockerpinata/docker-py:py3-fa56109f6bab79f0e7f576bed2148bf5677090bd py.test -v -rxs --cov=docker tests/unit > git --version # timeout=10 > git --version # 'git version 2.25.1' fatal: bad object 5d8b74fd03a1c7cc00e1c1f32d100ed97a17f4f0 + docker run --rm -e DOCKER_TEST_API_VERSION=1.40 dockerpinata/docker-py:py3-fa56109f6bab79f0e7f576bed2148bf5677090bd py.test -v -rxs --cov=docker tests/unit Fetching without tags > git --version # timeout=10 > git --version # 'git version 2.25.1' fatal: bad object 5d8b74fd03a1c7cc00e1c1f32d100ed97a17f4f0 Merging remotes/origin/master commit a48a5a9647761406d66e8271f19fab7fa0c5f582 into PR head commit fa56109f6bab79f0e7f576bed2148bf5677090bd Merge succeeded, producing fa56109f6bab79f0e7f576bed2148bf5677090bd Checking out Revision fa56109f6bab79f0e7f576bed2148bf5677090bd (PR-2900) Commit message: "Add remove() method to Image" $ 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-2900@tmp/5bf79c72-0853-45f7-8ead-be73fff88920/config.json. Configure a credential helper to remove this warning. See https://docs.docker.com/engine/reference/commandline/login/#credentials-store Login Succeeded $ 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-2900@tmp/41736cec-a9e0-4953-bcc7-54abf8453891/config.json. Configure a credential helper to remove this warning. See https://docs.docker.com/engine/reference/commandline/login/#credentials-store Login Succeeded > git config remote.origin.url https://github.com/docker/docker-py.git # timeout=10 > git config --add remote.origin.fetch +refs/pull/2900/head:refs/remotes/origin/PR-2900 # 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/2900/head:refs/remotes/origin/PR-2900 +refs/heads/master:refs/remotes/origin/master # timeout=10 > git config core.sparsecheckout # timeout=10 > git checkout -f fa56109f6bab79f0e7f576bed2148bf5677090bd # 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 fa56109f6bab79f0e7f576bed2148bf5677090bd # timeout=10 [Pipeline] withDockerRegistry [Pipeline] { [Pipeline] sh + docker run --rm -e DOCKER_TEST_API_VERSION=1.40 dockerpinata/docker-py:py3-fa56109f6bab79f0e7f576bed2148bf5677090bd py.test -v -rxs --cov=docker tests/unit Unable to find image 'dockerpinata/docker-py:py3-fa56109f6bab79f0e7f576bed2148bf5677090bd' locally py3-fa56109f6bab79f0e7f576bed2148bf5677090bd: Pulling from dockerpinata/docker-py bb7d5a84853b: Already exists f02b617c6a8c: Already exists d32e17419b7e: Already exists > git --version # timeout=10 > git --version # 'git version 2.25.1' fatal: bad object 5d8b74fd03a1c7cc00e1c1f32d100ed97a17f4f0 $ 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-2900@tmp/9e02b9e6-ec47-4f53-b1ca-c5bad83f7bb9/config.json. Configure a credential helper to remove this warning. See https://docs.docker.com/engine/reference/commandline/login/#credentials-store Login Succeeded ============================= test session starts ============================== platform linux -- Python 3.7.12, pytest-6.2.5, py-1.10.0, pluggy-1.0.0 -- /usr/local/bin/python cachedir: .pytest_cache rootdir: /src, configfile: pytest.ini plugins: timeout-2.0.1, cov-3.0.0 c9d2d81226a4: Already exists 3c24ae8b6604: Already exists 8a4322d1621d: Already exists 637b803a116b: Already exists 3d1bee7e0864: Already exists c98ebb0625ce: Already exists 17ec2a9f8770: Pulling fs layer 5ecf0073da0e: Pulling fs layer fa0fb0a24794: Pulling fs layer 34affa70c927: Pulling fs layer 0e566ba6ce77: Pulling fs layer 69b1fa2b027c: Pulling fs layer 82d4a1ffa5fa: Pulling fs layer 6e8fbd055e90: Pulling fs layer 494ec8a0680c: Pulling fs layer 0ad16b3cf88d: Pulling fs layer 29db26f4cb69: Pulling fs layer d980bb33ad2b: Pulling fs layer 19c0f0444160: Pulling fs layer d227631b0a24: Pulling fs layer 441f6c5633e3: Pulling fs layer 63f63170add3: Pulling fs layer 068dd35dd78b: Pulling fs layer 0e566ba6ce77: Waiting 69b1fa2b027c: Waiting 82d4a1ffa5fa: Waiting 6e8fbd055e90: Waiting 494ec8a0680c: Waiting 0ad16b3cf88d: Waiting 29db26f4cb69: Waiting d980bb33ad2b: Waiting 19c0f0444160: Waiting d227631b0a24: Waiting 441f6c5633e3: Waiting 63f63170add3: Waiting 068dd35dd78b: Waiting 34affa70c927: Waiting 17ec2a9f8770: Verifying Checksum 17ec2a9f8770: Download complete fa0fb0a24794: Download complete 0e566ba6ce77: Verifying Checksum 0e566ba6ce77: Download complete 34affa70c927: Verifying Checksum 34affa70c927: Download complete 17ec2a9f8770: Pull complete 82d4a1ffa5fa: Verifying Checksum 82d4a1ffa5fa: Download complete 69b1fa2b027c: Verifying Checksum 69b1fa2b027c: Download complete ============================= test session starts ============================== platform linux -- Python 3.7.12, pytest-6.2.5, py-1.10.0, pluggy-1.0.0 -- /usr/local/bin/python cachedir: .pytest_cache rootdir: /src, configfile: pytest.ini plugins: timeout-2.0.1, cov-3.0.0 5ecf0073da0e: Verifying Checksum 5ecf0073da0e: Download complete 494ec8a0680c: Download complete 6e8fbd055e90: Verifying Checksum 6e8fbd055e90: Download complete 29db26f4cb69: Verifying Checksum 29db26f4cb69: Download complete d980bb33ad2b: Verifying Checksum d980bb33ad2b: Download complete 0ad16b3cf88d: Verifying Checksum 0ad16b3cf88d: Download complete 441f6c5633e3: Verifying Checksum 441f6c5633e3: Download complete d227631b0a24: Verifying Checksum d227631b0a24: Download complete 63f63170add3: Verifying Checksum 63f63170add3: Download complete 068dd35dd78b: Verifying Checksum 068dd35dd78b: Download complete 19c0f0444160: Verifying Checksum 19c0f0444160: Download complete 5ecf0073da0e: Pull complete fa0fb0a24794: Pull complete 34affa70c927: Pull complete 0e566ba6ce77: Pull complete 69b1fa2b027c: Pull complete 82d4a1ffa5fa: Pull complete 6e8fbd055e90: Pull complete 494ec8a0680c: Pull complete 0ad16b3cf88d: Pull complete collecting ... collected 572 items tests/unit/api_build_test.py::BuildTest::test_build_container PASSED [ 0%] tests/unit/api_build_test.py::BuildTest::test_build_container_custom_context PASSED [ 0%] tests/unit/api_build_test.py::BuildTest::test_build_container_custom_context_gzip PASSED [ 0%] tests/unit/api_build_test.py::BuildTest::test_build_container_invalid_container_limits PASSED [ 0%] tests/unit/api_build_test.py::BuildTest::test_build_container_pull PASSED [ 0%] tests/unit/api_build_test.py::BuildTest::test_build_container_with_container_limits PASSED [ 1%] tests/unit/api_build_test.py::BuildTest::test_build_container_with_named_dockerfile PASSED [ 1%] tests/unit/api_build_test.py::BuildTest::test_build_remote_with_registry_auth PASSED [ 1%] tests/unit/api_build_test.py::BuildTest::test_process_dockerfile PASSED [ 1%] tests/unit/api_build_test.py::BuildTest::test_process_dockerfile_win_longpath_prefix SKIPPED [ 1%] tests/unit/api_build_test.py::BuildTest::test_set_auth_headers_with_dict_and_auth_configs PASSED [ 1%] tests/unit/api_build_test.py::BuildTest::test_set_auth_headers_with_dict_and_no_auth_configs PASSED [ 2%] tests/unit/api_build_test.py::BuildTest::test_set_auth_headers_with_empty_dict_and_auth_configs PASSED [ 2%] tests/unit/api_container_test.py::StartContainerTest::test_start_container PASSED [ 2%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_none PASSED [ 2%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_privileged PASSED [ 2%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_regression_573 PASSED [ 2%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_binds_ro PASSED [ 3%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_binds_rw PASSED [ 3%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_dict_instead_of_id PASSED [ 3%] 29db26f4cb69: Pull complete d980bb33ad2b: Pull complete collecting ... collected 572 items tests/unit/api_build_test.py::BuildTest::test_build_container PASSED [ 0%] tests/unit/api_build_test.py::BuildTest::test_build_container_custom_context PASSED [ 0%] tests/unit/api_build_test.py::BuildTest::test_build_container_custom_context_gzip PASSED [ 0%] tests/unit/api_build_test.py::BuildTest::test_build_container_invalid_container_limits PASSED [ 0%] tests/unit/api_build_test.py::BuildTest::test_build_container_pull PASSED [ 0%] tests/unit/api_build_test.py::BuildTest::test_build_container_with_container_limits PASSED [ 1%] tests/unit/api_build_test.py::BuildTest::test_build_container_with_named_dockerfile PASSED [ 1%] tests/unit/api_build_test.py::BuildTest::test_build_remote_with_registry_auth PASSED [ 1%] tests/unit/api_build_test.py::BuildTest::test_process_dockerfile PASSED [ 1%] tests/unit/api_build_test.py::BuildTest::test_process_dockerfile_win_longpath_prefix SKIPPED [ 1%] tests/unit/api_build_test.py::BuildTest::test_set_auth_headers_with_dict_and_auth_configs PASSED [ 1%] tests/unit/api_build_test.py::BuildTest::test_set_auth_headers_with_dict_and_no_auth_configs PASSED [ 2%] tests/unit/api_build_test.py::BuildTest::test_set_auth_headers_with_empty_dict_and_auth_configs PASSED [ 2%] tests/unit/api_container_test.py::StartContainerTest::test_start_container PASSED [ 2%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_none PASSED [ 2%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_privileged PASSED [ 2%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_regression_573 PASSED [ 2%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_binds_ro PASSED [ 3%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_binds_rw PASSED [ 3%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_dict_instead_of_id PASSED [ 3%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_links PASSED [ 3%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_links_as_list_of_tuples PASSED [ 3%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_lxc_conf PASSED [ 4%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_lxc_conf_compat PASSED [ 4%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_multiple_links PASSED [ 4%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_port_binds PASSED [ 4%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container PASSED [ 4%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_privileged PASSED [ 4%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_added_capabilities PASSED [ 5%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_aliases PASSED [ 5%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds PASSED [ 5%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_list PASSED [ 5%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_mode PASSED [ 5%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_mode_and_ro_error PASSED [ 5%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_ro PASSED [ 6%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_rw PASSED [ 6%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_cgroup_parent PASSED [ 6%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_device_requests PASSED [ 6%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_devices PASSED [ 6%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_dropped_capabilities PASSED [ 6%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_entrypoint PASSED [ 7%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_host_config_cpu_shares PASSED [ 7%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_host_config_cpus PASSED [ 7%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_host_config_cpuset PASSED [ 7%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_host_config_cpuset_mems PASSED [ 7%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_labels_dict PASSED [ 8%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_labels_list PASSED [ 8%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_links PASSED [ 3%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_links_as_list_of_tuples PASSED [ 3%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_lxc_conf PASSED [ 4%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_lxc_conf_compat PASSED [ 4%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_multiple_links PASSED [ 4%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_port_binds PASSED [ 4%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container PASSED [ 4%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_privileged PASSED [ 4%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_added_capabilities PASSED [ 5%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_aliases PASSED [ 5%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds PASSED [ 5%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_list PASSED [ 5%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_mode PASSED [ 5%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_mode_and_ro_error PASSED [ 5%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_ro PASSED [ 6%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_rw PASSED [ 6%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_cgroup_parent PASSED [ 6%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_device_requests PASSED [ 6%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_devices PASSED [ 6%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_dropped_capabilities PASSED [ 6%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_entrypoint PASSED [ 7%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_host_config_cpu_shares PASSED [ 7%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_host_config_cpus PASSED [ 7%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_host_config_cpuset PASSED [ 7%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_host_config_cpuset_mems PASSED [ 7%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_labels_dict PASSED [ 8%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_labels_list PASSED [ 8%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_links PASSED [ 8%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_links_as_list_of_tuples PASSED [ 8%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_lxc_conf PASSED [ 8%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_lxc_conf_compat PASSED [ 8%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mac_address PASSED [ 9%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_int PASSED [ 9%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string PASSED [ 9%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string_with_g_unit PASSED [ 9%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string_with_k_unit PASSED [ 9%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string_with_m_unit PASSED [ 9%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string_with_wrong_value PASSED [ 10%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_multiple_links PASSED [ 10%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_named_volume PASSED [ 10%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_port_binds PASSED [ 10%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_ports PASSED [ 10%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_restart_policy PASSED [ 11%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_stdin_open PASSED [ 11%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_stop_signal PASSED [ 11%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_sysctl PASSED [ 11%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_tmpfs_dict PASSED [ 11%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_tmpfs_list PASSED [ 11%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_unicode_envvars PASSED [ 12%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_volume_string PASSED [ 12%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_working_dir PASSED [ 12%] tests/unit/api_container_test.py::CreateContainerTest::test_create_named_container PASSED [ 12%] tests/unit/api_container_test.py::ContainerTest::test_container_stats PASSED [ 12%] tests/unit/api_container_test.py::ContainerTest::test_container_top PASSED [ 12%] tests/unit/api_container_test.py::ContainerTest::test_container_top_with_psargs PASSED [ 13%] tests/unit/api_container_test.py::ContainerTest::test_container_update PASSED [ 13%] tests/unit/api_container_test.py::ContainerTest::test_diff PASSED [ 13%] tests/unit/api_container_test.py::ContainerTest::test_diff_with_dict_instead_of_id PASSED [ 13%] tests/unit/api_container_test.py::ContainerTest::test_export PASSED [ 13%] tests/unit/api_container_test.py::ContainerTest::test_export_with_dict_instead_of_id PASSED [ 13%] tests/unit/api_container_test.py::ContainerTest::test_inspect_container PASSED [ 14%] tests/unit/api_container_test.py::ContainerTest::test_inspect_container_undefined_id PASSED [ 14%] tests/unit/api_container_test.py::ContainerTest::test_kill_container PASSED [ 14%] tests/unit/api_container_test.py::ContainerTest::test_kill_container_with_dict_instead_of_id PASSED [ 14%] tests/unit/api_container_test.py::ContainerTest::test_kill_container_with_signal PASSED [ 14%] tests/unit/api_container_test.py::ContainerTest::test_list_containers PASSED [ 15%] tests/unit/api_container_test.py::ContainerTest::test_log_following PASSED [ 15%] tests/unit/api_container_test.py::ContainerTest::test_log_following_backwards PASSED [ 15%] tests/unit/api_container_test.py::ContainerTest::test_log_since PASSED [ 15%] tests/unit/api_container_test.py::ContainerTest::test_log_since_with_datetime PASSED [ 15%] tests/unit/api_container_test.py::ContainerTest::test_log_since_with_invalid_value_raises_error PASSED [ 15%] tests/unit/api_container_test.py::ContainerTest::test_log_streaming PASSED [ 16%] tests/unit/api_container_test.py::ContainerTest::test_log_streaming_and_following PASSED [ 16%] tests/unit/api_container_test.py::ContainerTest::test_log_tail PASSED [ 16%] tests/unit/api_container_test.py::ContainerTest::test_log_tty PASSED [ 16%] tests/unit/api_container_test.py::ContainerTest::test_logs PASSED [ 16%] tests/unit/api_container_test.py::ContainerTest::test_logs_with_dict_instead_of_id PASSED [ 16%] tests/unit/api_container_test.py::ContainerTest::test_pause_container PASSED [ 17%] tests/unit/api_container_test.py::ContainerTest::test_port PASSED [ 17%] tests/unit/api_container_test.py::ContainerTest::test_remove_container PASSED [ 17%] tests/unit/api_container_test.py::ContainerTest::test_remove_container_with_dict_instead_of_id PASSED [ 17%] tests/unit/api_container_test.py::ContainerTest::test_rename_container PASSED [ 17%] tests/unit/api_container_test.py::ContainerTest::test_resize_container PASSED [ 18%] tests/unit/api_container_test.py::ContainerTest::test_restart_container PASSED [ 18%] tests/unit/api_container_test.py::ContainerTest::test_restart_container_with_dict_instead_of_id PASSED [ 18%] tests/unit/api_container_test.py::ContainerTest::test_stop_container PASSED [ 18%] tests/unit/api_container_test.py::ContainerTest::test_stop_container_with_dict_instead_of_id PASSED [ 18%] tests/unit/api_container_test.py::ContainerTest::test_unpause_container PASSED [ 18%] tests/unit/api_container_test.py::ContainerTest::test_wait PASSED [ 19%] tests/unit/api_container_test.py::ContainerTest::test_wait_with_dict_instead_of_id PASSED [ 19%] tests/unit/api_exec_test.py::ExecTest::test_exec_create PASSED [ 19%] tests/unit/api_exec_test.py::ExecTest::test_exec_inspect PASSED [ 19%] tests/unit/api_exec_test.py::ExecTest::test_exec_resize PASSED [ 19%] tests/unit/api_exec_test.py::ExecTest::test_exec_start PASSED [ 19%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_links PASSED [ 8%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_links_as_list_of_tuples PASSED [ 8%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_lxc_conf PASSED [ 8%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_lxc_conf_compat PASSED [ 8%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mac_address PASSED [ 9%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_int PASSED [ 9%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string PASSED [ 9%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string_with_g_unit PASSED [ 9%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string_with_k_unit PASSED [ 9%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string_with_m_unit PASSED [ 9%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string_with_wrong_value PASSED [ 10%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_multiple_links PASSED [ 10%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_named_volume PASSED [ 10%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_port_binds PASSED [ 10%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_ports PASSED [ 10%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_restart_policy PASSED [ 11%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_stdin_open PASSED [ 11%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_stop_signal PASSED [ 11%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_sysctl PASSED [ 11%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_tmpfs_dict PASSED [ 11%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_tmpfs_list PASSED [ 11%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_unicode_envvars PASSED [ 12%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_volume_string PASSED [ 12%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_working_dir PASSED [ 12%] tests/unit/api_container_test.py::CreateContainerTest::test_create_named_container PASSED [ 12%] tests/unit/api_container_test.py::ContainerTest::test_container_stats PASSED [ 12%] tests/unit/api_container_test.py::ContainerTest::test_container_top PASSED [ 12%] tests/unit/api_container_test.py::ContainerTest::test_container_top_with_psargs PASSED [ 13%] tests/unit/api_container_test.py::ContainerTest::test_container_update PASSED [ 13%] tests/unit/api_container_test.py::ContainerTest::test_diff PASSED [ 13%] tests/unit/api_container_test.py::ContainerTest::test_diff_with_dict_instead_of_id PASSED [ 13%] tests/unit/api_container_test.py::ContainerTest::test_export PASSED [ 13%] tests/unit/api_container_test.py::ContainerTest::test_export_with_dict_instead_of_id PASSED [ 13%] tests/unit/api_container_test.py::ContainerTest::test_inspect_container PASSED [ 14%] tests/unit/api_container_test.py::ContainerTest::test_inspect_container_undefined_id PASSED [ 14%] tests/unit/api_container_test.py::ContainerTest::test_kill_container PASSED [ 14%] tests/unit/api_container_test.py::ContainerTest::test_kill_container_with_dict_instead_of_id PASSED [ 14%] tests/unit/api_container_test.py::ContainerTest::test_kill_container_with_signal PASSED [ 14%] tests/unit/api_container_test.py::ContainerTest::test_list_containers PASSED [ 15%] tests/unit/api_container_test.py::ContainerTest::test_log_following PASSED [ 15%] tests/unit/api_container_test.py::ContainerTest::test_log_following_backwards PASSED [ 15%] tests/unit/api_container_test.py::ContainerTest::test_log_since PASSED [ 15%] tests/unit/api_container_test.py::ContainerTest::test_log_since_with_datetime PASSED [ 15%] tests/unit/api_container_test.py::ContainerTest::test_log_since_with_invalid_value_raises_error PASSED [ 15%] tests/unit/api_container_test.py::ContainerTest::test_log_streaming PASSED [ 16%] tests/unit/api_container_test.py::ContainerTest::test_log_streaming_and_following PASSED [ 16%] tests/unit/api_container_test.py::ContainerTest::test_log_tail PASSED [ 16%] tests/unit/api_container_test.py::ContainerTest::test_log_tty PASSED [ 16%] tests/unit/api_container_test.py::ContainerTest::test_logs PASSED [ 16%] tests/unit/api_container_test.py::ContainerTest::test_logs_with_dict_instead_of_id PASSED [ 16%] tests/unit/api_container_test.py::ContainerTest::test_pause_container PASSED [ 17%] tests/unit/api_container_test.py::ContainerTest::test_port PASSED [ 17%] tests/unit/api_container_test.py::ContainerTest::test_remove_container PASSED [ 17%] tests/unit/api_container_test.py::ContainerTest::test_remove_container_with_dict_instead_of_id PASSED [ 17%] tests/unit/api_container_test.py::ContainerTest::test_rename_container PASSED [ 17%] tests/unit/api_container_test.py::ContainerTest::test_resize_container PASSED [ 18%] tests/unit/api_container_test.py::ContainerTest::test_restart_container PASSED [ 18%] tests/unit/api_container_test.py::ContainerTest::test_restart_container_with_dict_instead_of_id PASSED [ 18%] tests/unit/api_container_test.py::ContainerTest::test_stop_container PASSED [ 18%] tests/unit/api_container_test.py::ContainerTest::test_stop_container_with_dict_instead_of_id PASSED [ 18%] tests/unit/api_container_test.py::ContainerTest::test_unpause_container PASSED [ 18%] tests/unit/api_container_test.py::ContainerTest::test_wait PASSED [ 19%] tests/unit/api_container_test.py::ContainerTest::test_wait_with_dict_instead_of_id PASSED [ 19%] tests/unit/api_exec_test.py::ExecTest::test_exec_create PASSED [ 19%] tests/unit/api_exec_test.py::ExecTest::test_exec_inspect PASSED [ 19%] tests/unit/api_exec_test.py::ExecTest::test_exec_resize PASSED [ 19%] tests/unit/api_exec_test.py::ExecTest::test_exec_start PASSED [ 19%] tests/unit/api_exec_test.py::ExecTest::test_exec_start_detached PASSED [ 20%] tests/unit/api_image_test.py::ImageTest::test_commit PASSED [ 20%] tests/unit/api_image_test.py::ImageTest::test_get_image PASSED [ 20%] tests/unit/api_image_test.py::ImageTest::test_image_history PASSED [ 20%] tests/unit/api_image_test.py::ImageTest::test_image_ids PASSED [ 20%] tests/unit/api_exec_test.py::ExecTest::test_exec_start_detached PASSED [ 20%] tests/unit/api_image_test.py::ImageTest::test_commit PASSED [ 20%] tests/unit/api_image_test.py::ImageTest::test_get_image PASSED [ 20%] tests/unit/api_image_test.py::ImageTest::test_image_history PASSED [ 20%] tests/unit/api_image_test.py::ImageTest::test_image_ids PASSED [ 20%] tests/unit/api_image_test.py::ImageTest::test_image_viz PASSED [ 20%] tests/unit/api_image_test.py::ImageTest::test_images PASSED [ 21%] tests/unit/api_image_test.py::ImageTest::test_images_filters PASSED [ 21%] tests/unit/api_image_test.py::ImageTest::test_images_name PASSED [ 21%] tests/unit/api_image_test.py::ImageTest::test_images_quiet PASSED [ 21%] tests/unit/api_image_test.py::ImageTest::test_import_image PASSED [ 21%] tests/unit/api_image_test.py::ImageTest::test_import_image_from_bytes PASSED [ 22%] tests/unit/api_image_test.py::ImageTest::test_import_image_from_image PASSED [ 22%] tests/unit/api_image_test.py::ImageTest::test_inspect_image PASSED [ 22%] tests/unit/api_image_test.py::ImageTest::test_inspect_image_undefined_id PASSED [ 22%] tests/unit/api_image_test.py::ImageTest::test_load_image PASSED [ 22%] tests/unit/api_image_test.py::ImageTest::test_load_image_quiet PASSED [ 22%] tests/unit/api_image_test.py::ImageTest::test_pull PASSED [ 23%] tests/unit/api_image_test.py::ImageTest::test_pull_stream PASSED [ 23%] tests/unit/api_image_test.py::ImageTest::test_push_image PASSED [ 23%] tests/unit/api_image_test.py::ImageTest::test_push_image_stream PASSED [ 23%] tests/unit/api_image_test.py::ImageTest::test_push_image_with_auth PASSED [ 23%] tests/unit/api_image_test.py::ImageTest::test_push_image_with_tag PASSED [ 23%] tests/unit/api_image_test.py::ImageTest::test_remove_image PASSED [ 24%] tests/unit/api_image_test.py::ImageTest::test_tag_image PASSED [ 24%] tests/unit/api_image_test.py::ImageTest::test_tag_image_force PASSED [ 24%] tests/unit/api_image_test.py::ImageTest::test_tag_image_tag PASSED [ 24%] tests/unit/api_network_test.py::NetworkTest::test_connect_container_to_network PASSED [ 24%] tests/unit/api_network_test.py::NetworkTest::test_create_network PASSED [ 25%] tests/unit/api_network_test.py::NetworkTest::test_disconnect_container_from_network PASSED [ 25%] tests/unit/api_network_test.py::NetworkTest::test_inspect_network PASSED [ 25%] tests/unit/api_network_test.py::NetworkTest::test_list_networks PASSED [ 25%] tests/unit/api_network_test.py::NetworkTest::test_remove_network PASSED [ 25%] tests/unit/api_test.py::DockerApiTest::test_auto_retrieve_server_version PASSED [ 25%] tests/unit/api_test.py::DockerApiTest::test_create_host_config_secopt PASSED [ 26%] tests/unit/api_test.py::DockerApiTest::test_ctor PASSED [ 26%] tests/unit/api_test.py::DockerApiTest::test_events PASSED [ 26%] tests/unit/api_test.py::DockerApiTest::test_events_with_filters PASSED [ 26%] tests/unit/api_test.py::DockerApiTest::test_events_with_since_until PASSED [ 26%] tests/unit/api_test.py::DockerApiTest::test_info PASSED [ 26%] tests/unit/api_test.py::DockerApiTest::test_login PASSED [ 27%] tests/unit/api_test.py::DockerApiTest::test_remove_link PASSED [ 27%] tests/unit/api_test.py::DockerApiTest::test_retrieve_server_version PASSED [ 27%] tests/unit/api_test.py::DockerApiTest::test_search PASSED [ 27%] tests/unit/api_test.py::DockerApiTest::test_stream_helper_decoding PASSED [ 27%] tests/unit/api_test.py::DockerApiTest::test_url_compatibility_http PASSED [ 27%] tests/unit/api_test.py::DockerApiTest::test_url_compatibility_http_unix_triple_slash PASSED [ 28%] tests/unit/api_test.py::DockerApiTest::test_url_compatibility_tcp PASSED [ 28%] tests/unit/api_test.py::DockerApiTest::test_url_compatibility_unix PASSED [ 28%] tests/unit/api_test.py::DockerApiTest::test_url_compatibility_unix_triple_slash PASSED [ 28%] tests/unit/api_test.py::DockerApiTest::test_url_invalid_resource PASSED [ 28%] tests/unit/api_test.py::DockerApiTest::test_url_no_resource PASSED [ 29%] tests/unit/api_test.py::DockerApiTest::test_url_unversioned_api PASSED [ 29%] tests/unit/api_test.py::DockerApiTest::test_url_valid_resource PASSED [ 29%] tests/unit/api_test.py::DockerApiTest::test_version PASSED [ 29%] tests/unit/api_test.py::DockerApiTest::test_version_no_api_version PASSED [ 29%] tests/unit/api_test.py::UnixSocketStreamTest::test_early_stream_response PASSED [ 29%] tests/unit/api_image_test.py::ImageTest::test_image_viz PASSED [ 20%] tests/unit/api_image_test.py::ImageTest::test_images PASSED [ 21%] tests/unit/api_image_test.py::ImageTest::test_images_filters PASSED [ 21%] tests/unit/api_image_test.py::ImageTest::test_images_name PASSED [ 21%] tests/unit/api_image_test.py::ImageTest::test_images_quiet PASSED [ 21%] tests/unit/api_image_test.py::ImageTest::test_import_image PASSED [ 21%] tests/unit/api_image_test.py::ImageTest::test_import_image_from_bytes PASSED [ 22%] tests/unit/api_image_test.py::ImageTest::test_import_image_from_image PASSED [ 22%] tests/unit/api_image_test.py::ImageTest::test_inspect_image PASSED [ 22%] tests/unit/api_image_test.py::ImageTest::test_inspect_image_undefined_id PASSED [ 22%] tests/unit/api_image_test.py::ImageTest::test_load_image PASSED [ 22%] tests/unit/api_image_test.py::ImageTest::test_load_image_quiet PASSED [ 22%] tests/unit/api_image_test.py::ImageTest::test_pull PASSED [ 23%] tests/unit/api_image_test.py::ImageTest::test_pull_stream PASSED [ 23%] tests/unit/api_image_test.py::ImageTest::test_push_image PASSED [ 23%] tests/unit/api_image_test.py::ImageTest::test_push_image_stream PASSED [ 23%] tests/unit/api_image_test.py::ImageTest::test_push_image_with_auth PASSED [ 23%] tests/unit/api_image_test.py::ImageTest::test_push_image_with_tag PASSED [ 23%] tests/unit/api_image_test.py::ImageTest::test_remove_image PASSED [ 24%] tests/unit/api_image_test.py::ImageTest::test_tag_image PASSED [ 24%] tests/unit/api_image_test.py::ImageTest::test_tag_image_force PASSED [ 24%] tests/unit/api_image_test.py::ImageTest::test_tag_image_tag PASSED [ 24%] tests/unit/api_network_test.py::NetworkTest::test_connect_container_to_network PASSED [ 24%] tests/unit/api_network_test.py::NetworkTest::test_create_network PASSED [ 25%] tests/unit/api_network_test.py::NetworkTest::test_disconnect_container_from_network PASSED [ 25%] tests/unit/api_network_test.py::NetworkTest::test_inspect_network PASSED [ 25%] tests/unit/api_network_test.py::NetworkTest::test_list_networks PASSED [ 25%] tests/unit/api_network_test.py::NetworkTest::test_remove_network PASSED [ 25%] tests/unit/api_test.py::DockerApiTest::test_auto_retrieve_server_version PASSED [ 25%] tests/unit/api_test.py::DockerApiTest::test_create_host_config_secopt PASSED [ 26%] tests/unit/api_test.py::DockerApiTest::test_ctor PASSED [ 26%] tests/unit/api_test.py::DockerApiTest::test_events PASSED [ 26%] tests/unit/api_test.py::DockerApiTest::test_events_with_filters PASSED [ 26%] tests/unit/api_test.py::DockerApiTest::test_events_with_since_until PASSED [ 26%] tests/unit/api_test.py::DockerApiTest::test_info PASSED [ 26%] tests/unit/api_test.py::DockerApiTest::test_login PASSED [ 27%] tests/unit/api_test.py::DockerApiTest::test_remove_link PASSED [ 27%] tests/unit/api_test.py::DockerApiTest::test_retrieve_server_version PASSED [ 27%] tests/unit/api_test.py::DockerApiTest::test_search PASSED [ 27%] tests/unit/api_test.py::DockerApiTest::test_stream_helper_decoding PASSED [ 27%] tests/unit/api_test.py::DockerApiTest::test_url_compatibility_http PASSED [ 27%] tests/unit/api_test.py::DockerApiTest::test_url_compatibility_http_unix_triple_slash PASSED [ 28%] tests/unit/api_test.py::DockerApiTest::test_url_compatibility_tcp PASSED [ 28%] tests/unit/api_test.py::DockerApiTest::test_url_compatibility_unix PASSED [ 28%] tests/unit/api_test.py::DockerApiTest::test_url_compatibility_unix_triple_slash PASSED [ 28%] tests/unit/api_test.py::DockerApiTest::test_url_invalid_resource PASSED [ 28%] tests/unit/api_test.py::DockerApiTest::test_url_no_resource PASSED [ 29%] tests/unit/api_test.py::DockerApiTest::test_url_unversioned_api PASSED [ 29%] tests/unit/api_test.py::DockerApiTest::test_url_valid_resource PASSED [ 29%] tests/unit/api_test.py::DockerApiTest::test_version PASSED [ 29%] tests/unit/api_test.py::DockerApiTest::test_version_no_api_version PASSED [ 29%] tests/unit/api_test.py::UnixSocketStreamTest::test_early_stream_response PASSED [ 29%] tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_stream_no_tty PASSED [ 30%] tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_stream_no_tty PASSED [ 30%] 19c0f0444160: Pull complete d227631b0a24: Pull complete tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_stream_no_tty_demux PASSED [ 30%] tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_stream_no_tty_demux PASSED [ 30%] tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_stream_tty PASSED [ 30%] 441f6c5633e3: Pull complete 63f63170add3: Pull complete tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_stream_tty PASSED [ 30%] tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_stream_tty_demux PASSED [ 30%] 068dd35dd78b: Pull complete Digest: sha256:932f9b8cf60503c481157f2deb2bd1d1dbd39bd2bef3cc5af267e5a48da6c302 Status: Downloaded newer image for dockerpinata/docker-py:py3-fa56109f6bab79f0e7f576bed2148bf5677090bd tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_stream_tty_demux PASSED [ 30%] tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_tty PASSED [ 30%] tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_tty PASSED [ 30%] tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_tty_demux PASSED [ 30%] tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_tty_demux PASSED [ 30%] tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_tty PASSED [ 31%] tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_tty PASSED [ 31%] tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_tty_demux PASSED [ 31%] tests/unit/api_test.py::UserAgentTest::test_custom_user_agent PASSED [ 31%] tests/unit/api_test.py::UserAgentTest::test_default_user_agent PASSED [ 31%] tests/unit/api_test.py::DisableSocketTest::test_disable_socket_timeout PASSED [ 31%] tests/unit/api_test.py::DisableSocketTest::test_disable_socket_timeout2 PASSED [ 31%] tests/unit/api_test.py::DisableSocketTest::test_disable_socket_timout_non_blocking PASSED [ 32%] tests/unit/api_volume_test.py::VolumeTest::test_create_volume PASSED [ 32%] tests/unit/api_volume_test.py::VolumeTest::test_create_volume_invalid_opts_type PASSED [ 32%] tests/unit/api_volume_test.py::VolumeTest::test_create_volume_with_driver PASSED [ 32%] tests/unit/api_volume_test.py::VolumeTest::test_create_volume_with_invalid_labels PASSED [ 32%] tests/unit/api_volume_test.py::VolumeTest::test_create_volume_with_labels PASSED [ 33%] tests/unit/api_volume_test.py::VolumeTest::test_create_volume_with_no_specified_name PASSED [ 33%] tests/unit/api_volume_test.py::VolumeTest::test_inspect_volume PASSED [ 33%] tests/unit/api_volume_test.py::VolumeTest::test_list_volumes PASSED [ 33%] tests/unit/api_volume_test.py::VolumeTest::test_list_volumes_and_filters PASSED [ 33%] tests/unit/api_volume_test.py::VolumeTest::test_remove_volume PASSED [ 33%] tests/unit/auth_test.py::RegressionTest::test_803_urlsafe_encode PASSED [ 34%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_explicit_hub_index_library_image PASSED [ 34%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_explicit_legacy_hub_index_library_image PASSED [ 34%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_invalid_index_name PASSED [ 34%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_dotted_hub_library_image PASSED [ 34%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_hub_image PASSED [ 34%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_hub_library_image PASSED [ 35%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_localhost PASSED [ 35%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_localhost_with_username PASSED [ 35%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_no_dots_but_port PASSED [ 35%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_no_dots_but_port_and_username PASSED [ 35%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_private_registry PASSED [ 36%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_private_registry_with_port PASSED [ 36%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_private_registry_with_username PASSED [ 36%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_auth_with_empty_credstore_and_auth_dict PASSED [ 36%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_default_explicit_none PASSED [ 36%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_default_registry PASSED [ 36%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_fully_explicit PASSED [ 37%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_hostname_only PASSED [ 37%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_legacy_config PASSED [ 37%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_match PASSED [ 37%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_path PASSED [ 37%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_path_trailing_slash PASSED [ 37%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_path_wrong_insecure_proto PASSED [ 38%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_path_wrong_secure_proto PASSED [ 38%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_protocol PASSED [ 38%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_path_wrong_proto PASSED [ 38%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_explicit_hub PASSED [ 38%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_explicit_legacy_hub PASSED [ 38%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_hub_image PASSED [ 39%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_library_image PASSED [ 39%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_private_registry PASSED [ 39%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_unauthenticated_registry PASSED [ 39%] tests/unit/auth_test.py::LoadConfigTest::test_load_config_custom_config_env PASSED [ 39%] tests/unit/auth_test.py::LoadConfigTest::test_load_config_custom_config_env_utf8 PASSED [ 40%] tests/unit/auth_test.py::LoadConfigTest::test_load_config_custom_config_env_with_auths PASSED [ 40%] tests/unit/auth_test.py::LoadConfigTest::test_load_config_identity_token PASSED [ 40%] tests/unit/auth_test.py::LoadConfigTest::test_load_config_invalid_auth_dict PASSED [ 40%] tests/unit/auth_test.py::LoadConfigTest::test_load_config_no_file PASSED [ 40%] tests/unit/auth_test.py::LoadConfigTest::test_load_config_unknown_keys PASSED [ 40%] tests/unit/auth_test.py::LoadConfigTest::test_load_config_with_random_name PASSED [ 41%] tests/unit/auth_test.py::LoadConfigTest::test_load_json_config PASSED [ 41%] tests/unit/auth_test.py::LoadConfigTest::test_load_legacy_config PASSED [ 41%] tests/unit/auth_test.py::LoadConfigTest::test_load_modern_json_config PASSED [ 41%] tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_3_sources PASSED [ 41%] tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_credstore_only PASSED [ 41%] tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_credstore_overrides_auth_entry PASSED [ 42%] tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_helpers_override_default PASSED [ 42%] tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_with_auths_entries PASSED [ 42%] tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_with_credhelpers_only PASSED [ 42%] tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_with_empty_auths_entry PASSED [ 42%] tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_with_empty_credhelper PASSED [ 43%] tests/unit/auth_test.py::CredstoreTest::test_get_credential_store PASSED [ 43%] tests/unit/auth_test.py::CredstoreTest::test_get_credential_store_default_index PASSED [ 43%] tests/unit/auth_test.py::CredstoreTest::test_get_credential_store_no_default PASSED [ 43%] tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_tty_demux PASSED [ 31%] tests/unit/api_test.py::UserAgentTest::test_custom_user_agent PASSED [ 31%] tests/unit/api_test.py::UserAgentTest::test_default_user_agent PASSED [ 31%] tests/unit/api_test.py::DisableSocketTest::test_disable_socket_timeout PASSED [ 31%] tests/unit/api_test.py::DisableSocketTest::test_disable_socket_timeout2 PASSED [ 31%] tests/unit/api_test.py::DisableSocketTest::test_disable_socket_timout_non_blocking PASSED [ 32%] tests/unit/api_volume_test.py::VolumeTest::test_create_volume PASSED [ 32%] tests/unit/api_volume_test.py::VolumeTest::test_create_volume_invalid_opts_type PASSED [ 32%] tests/unit/api_volume_test.py::VolumeTest::test_create_volume_with_driver PASSED [ 32%] tests/unit/api_volume_test.py::VolumeTest::test_create_volume_with_invalid_labels PASSED [ 32%] tests/unit/api_volume_test.py::VolumeTest::test_create_volume_with_labels PASSED [ 33%] tests/unit/api_volume_test.py::VolumeTest::test_create_volume_with_no_specified_name PASSED [ 33%] tests/unit/api_volume_test.py::VolumeTest::test_inspect_volume PASSED [ 33%] tests/unit/api_volume_test.py::VolumeTest::test_list_volumes PASSED [ 33%] tests/unit/api_volume_test.py::VolumeTest::test_list_volumes_and_filters PASSED [ 33%] tests/unit/api_volume_test.py::VolumeTest::test_remove_volume PASSED [ 33%] tests/unit/auth_test.py::RegressionTest::test_803_urlsafe_encode PASSED [ 34%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_explicit_hub_index_library_image PASSED [ 34%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_explicit_legacy_hub_index_library_image PASSED [ 34%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_invalid_index_name PASSED [ 34%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_dotted_hub_library_image PASSED [ 34%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_hub_image PASSED [ 34%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_hub_library_image PASSED [ 35%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_localhost PASSED [ 35%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_localhost_with_username PASSED [ 35%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_no_dots_but_port PASSED [ 35%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_no_dots_but_port_and_username PASSED [ 35%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_private_registry PASSED [ 36%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_private_registry_with_port PASSED [ 36%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_private_registry_with_username PASSED [ 36%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_auth_with_empty_credstore_and_auth_dict PASSED [ 36%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_default_explicit_none PASSED [ 36%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_default_registry PASSED [ 36%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_fully_explicit PASSED [ 37%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_hostname_only PASSED [ 37%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_legacy_config PASSED [ 37%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_match PASSED [ 37%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_path PASSED [ 37%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_path_trailing_slash PASSED [ 37%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_path_wrong_insecure_proto PASSED [ 38%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_path_wrong_secure_proto PASSED [ 38%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_protocol PASSED [ 38%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_path_wrong_proto PASSED [ 38%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_explicit_hub PASSED [ 38%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_explicit_legacy_hub PASSED [ 38%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_hub_image PASSED [ 39%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_library_image PASSED [ 39%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_private_registry PASSED [ 39%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_unauthenticated_registry PASSED [ 39%] tests/unit/auth_test.py::LoadConfigTest::test_load_config_custom_config_env PASSED [ 39%] tests/unit/auth_test.py::LoadConfigTest::test_load_config_custom_config_env_utf8 PASSED [ 40%] tests/unit/auth_test.py::LoadConfigTest::test_load_config_custom_config_env_with_auths PASSED [ 40%] tests/unit/auth_test.py::LoadConfigTest::test_load_config_identity_token PASSED [ 40%] tests/unit/auth_test.py::LoadConfigTest::test_load_config_invalid_auth_dict PASSED [ 40%] tests/unit/auth_test.py::LoadConfigTest::test_load_config_no_file PASSED [ 40%] tests/unit/auth_test.py::LoadConfigTest::test_load_config_unknown_keys PASSED [ 40%] tests/unit/auth_test.py::LoadConfigTest::test_load_config_with_random_name PASSED [ 41%] tests/unit/auth_test.py::LoadConfigTest::test_load_json_config PASSED [ 41%] tests/unit/auth_test.py::LoadConfigTest::test_load_legacy_config PASSED [ 41%] tests/unit/auth_test.py::LoadConfigTest::test_load_modern_json_config PASSED [ 41%] tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_3_sources PASSED [ 41%] tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_credstore_only PASSED [ 41%] tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_credstore_overrides_auth_entry PASSED [ 42%] tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_helpers_override_default PASSED [ 42%] tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_with_auths_entries PASSED [ 42%] tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_with_credhelpers_only PASSED [ 42%] tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_with_empty_auths_entry PASSED [ 42%] tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_with_empty_credhelper PASSED [ 43%] tests/unit/auth_test.py::CredstoreTest::test_get_credential_store PASSED [ 43%] tests/unit/auth_test.py::CredstoreTest::test_get_credential_store_default_index PASSED [ 43%] tests/unit/auth_test.py::CredstoreTest::test_get_credential_store_no_default PASSED [ 43%] tests/unit/auth_test.py::CredstoreTest::test_get_credential_store_with_plain_dict PASSED [ 43%] tests/unit/client_test.py::ClientTest::test_call_api_client_method PASSED [ 43%] tests/unit/client_test.py::ClientTest::test_call_containers PASSED [ 44%] tests/unit/client_test.py::ClientTest::test_default_pool_size_unix PASSED [ 44%] tests/unit/client_test.py::ClientTest::test_default_pool_size_win SKIPPED [ 44%] tests/unit/client_test.py::ClientTest::test_events PASSED [ 44%] tests/unit/client_test.py::ClientTest::test_info PASSED [ 44%] tests/unit/client_test.py::ClientTest::test_ping PASSED [ 44%] tests/unit/client_test.py::ClientTest::test_pool_size_unix PASSED [ 45%] tests/unit/client_test.py::ClientTest::test_pool_size_win SKIPPED (N...) [ 45%] tests/unit/client_test.py::ClientTest::test_version PASSED [ 45%] tests/unit/client_test.py::FromEnvTest::test_default_pool_size_from_env_unix PASSED [ 45%] tests/unit/client_test.py::FromEnvTest::test_default_pool_size_from_env_win SKIPPED [ 45%] tests/unit/client_test.py::FromEnvTest::test_from_env PASSED [ 45%] tests/unit/client_test.py::FromEnvTest::test_from_env_with_version PASSED [ 46%] tests/unit/client_test.py::FromEnvTest::test_from_env_without_timeout_uses_default PASSED [ 46%] tests/unit/client_test.py::FromEnvTest::test_from_env_without_version_uses_default PASSED [ 46%] tests/unit/client_test.py::FromEnvTest::test_pool_size_from_env_unix PASSED [ 46%] tests/unit/client_test.py::FromEnvTest::test_pool_size_from_env_win SKIPPED [ 46%] tests/unit/context_test.py::BaseContextTest::test_context_inspect_without_params PASSED [ 47%] tests/unit/context_test.py::BaseContextTest::test_default_in_context_list PASSED [ 47%] tests/unit/context_test.py::BaseContextTest::test_fail_on_default_context_create PASSED [ 47%] tests/unit/context_test.py::BaseContextTest::test_get_current_context PASSED [ 47%] tests/unit/context_test.py::BaseContextTest::test_https_host PASSED [ 47%] tests/unit/context_test.py::BaseContextTest::test_url_compatibility_on_linux PASSED [ 47%] tests/unit/context_test.py::BaseContextTest::test_url_compatibility_on_windows SKIPPED [ 48%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_cpu_cfs_types PASSED [ 48%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_cpu_count_types PASSED [ 48%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_cpu_percent_types PASSED [ 48%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_mem_swappiness PASSED [ 48%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_nano_cpus_types PASSED [ 48%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_no_options_newer_api_version PASSED [ 49%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_pid_mode PASSED [ 49%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_blkio_constraints PASSED [ 49%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_count PASSED [ 49%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_percent PASSED [ 49%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_period PASSED [ 50%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_quota PASSED [ 50%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_rt_period PASSED [ 50%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_rt_period_types PASSED [ 50%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_rt_runtime PASSED [ 50%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_dns_opt PASSED [ 50%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_isolation PASSED [ 51%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_kernel_memory PASSED [ 51%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_mem_reservation PASSED [ 51%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_nano_cpus PASSED [ 51%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_oom_kill_disable PASSED [ 51%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_oom_score_adj PASSED [ 51%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_pids_limit PASSED [ 52%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_shm_size PASSED [ 52%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_shm_size_in_mb PASSED [ 52%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_userns_mode PASSED [ 52%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_uts PASSED [ 52%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_volume_driver PASSED [ 52%] tests/unit/dockertypes_test.py::HostConfigTest::test_ctrate_host_config_with_cpu_rt_runtime_types PASSED [ 53%] tests/unit/dockertypes_test.py::ContainerSpecTest::test_parse_mounts PASSED [ 53%] tests/unit/dockertypes_test.py::UlimitTest::test_create_host_config_dict_ulimit PASSED [ 53%] tests/unit/dockertypes_test.py::UlimitTest::test_create_host_config_dict_ulimit_capitals PASSED [ 53%] tests/unit/dockertypes_test.py::UlimitTest::test_create_host_config_obj_ulimit PASSED [ 53%] tests/unit/dockertypes_test.py::UlimitTest::test_ulimit_invalid_type PASSED [ 54%] tests/unit/dockertypes_test.py::LogConfigTest::test_create_host_config_dict_logconfig PASSED [ 54%] tests/unit/dockertypes_test.py::LogConfigTest::test_create_host_config_obj_logconfig PASSED [ 54%] tests/unit/dockertypes_test.py::LogConfigTest::test_logconfig_invalid_config_type PASSED [ 54%] tests/unit/dockertypes_test.py::EndpointConfigTest::test_create_endpoint_config_with_aliases PASSED [ 54%] tests/unit/dockertypes_test.py::IPAMConfigTest::test_create_ipam_config PASSED [ 54%] tests/unit/dockertypes_test.py::ServiceModeTest::test_global_replicas_error PASSED [ 55%] tests/unit/dockertypes_test.py::ServiceModeTest::test_global_simple PASSED [ 55%] tests/unit/dockertypes_test.py::ServiceModeTest::test_invalid_mode PASSED [ 55%] tests/unit/dockertypes_test.py::ServiceModeTest::test_replicated_replicas PASSED [ 55%] tests/unit/dockertypes_test.py::ServiceModeTest::test_replicated_replicas_0 PASSED [ 55%] tests/unit/dockertypes_test.py::ServiceModeTest::test_replicated_simple PASSED [ 55%] tests/unit/dockertypes_test.py::MountTest::test_parse_mount_bind PASSED [ 56%] tests/unit/auth_test.py::CredstoreTest::test_get_credential_store_with_plain_dict PASSED [ 43%] tests/unit/client_test.py::ClientTest::test_call_api_client_method PASSED [ 43%] tests/unit/client_test.py::ClientTest::test_call_containers PASSED [ 44%] tests/unit/client_test.py::ClientTest::test_default_pool_size_unix PASSED [ 44%] tests/unit/client_test.py::ClientTest::test_default_pool_size_win SKIPPED [ 44%] tests/unit/client_test.py::ClientTest::test_events PASSED [ 44%] tests/unit/client_test.py::ClientTest::test_info PASSED [ 44%] tests/unit/client_test.py::ClientTest::test_ping PASSED [ 44%] tests/unit/client_test.py::ClientTest::test_pool_size_unix PASSED [ 45%] tests/unit/client_test.py::ClientTest::test_pool_size_win SKIPPED (N...) [ 45%] tests/unit/client_test.py::ClientTest::test_version PASSED [ 45%] tests/unit/client_test.py::FromEnvTest::test_default_pool_size_from_env_unix PASSED [ 45%] tests/unit/client_test.py::FromEnvTest::test_default_pool_size_from_env_win SKIPPED [ 45%] tests/unit/client_test.py::FromEnvTest::test_from_env PASSED [ 45%] tests/unit/client_test.py::FromEnvTest::test_from_env_with_version PASSED [ 46%] tests/unit/client_test.py::FromEnvTest::test_from_env_without_timeout_uses_default PASSED [ 46%] tests/unit/client_test.py::FromEnvTest::test_from_env_without_version_uses_default PASSED [ 46%] tests/unit/client_test.py::FromEnvTest::test_pool_size_from_env_unix PASSED [ 46%] tests/unit/client_test.py::FromEnvTest::test_pool_size_from_env_win SKIPPED [ 46%] tests/unit/context_test.py::BaseContextTest::test_context_inspect_without_params PASSED [ 47%] tests/unit/context_test.py::BaseContextTest::test_default_in_context_list PASSED [ 47%] tests/unit/context_test.py::BaseContextTest::test_fail_on_default_context_create PASSED [ 47%] tests/unit/context_test.py::BaseContextTest::test_get_current_context PASSED [ 47%] tests/unit/context_test.py::BaseContextTest::test_https_host PASSED [ 47%] tests/unit/context_test.py::BaseContextTest::test_url_compatibility_on_linux PASSED [ 47%] tests/unit/context_test.py::BaseContextTest::test_url_compatibility_on_windows SKIPPED [ 48%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_cpu_cfs_types PASSED [ 48%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_cpu_count_types PASSED [ 48%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_cpu_percent_types PASSED [ 48%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_mem_swappiness PASSED [ 48%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_nano_cpus_types PASSED [ 48%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_no_options_newer_api_version PASSED [ 49%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_pid_mode PASSED [ 49%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_blkio_constraints PASSED [ 49%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_count PASSED [ 49%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_percent PASSED [ 49%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_period PASSED [ 50%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_quota PASSED [ 50%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_rt_period PASSED [ 50%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_rt_period_types PASSED [ 50%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_rt_runtime PASSED [ 50%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_dns_opt PASSED [ 50%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_isolation PASSED [ 51%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_kernel_memory PASSED [ 51%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_mem_reservation PASSED [ 51%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_nano_cpus PASSED [ 51%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_oom_kill_disable PASSED [ 51%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_oom_score_adj PASSED [ 51%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_pids_limit PASSED [ 52%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_shm_size PASSED [ 52%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_shm_size_in_mb PASSED [ 52%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_userns_mode PASSED [ 52%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_uts PASSED [ 52%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_volume_driver PASSED [ 52%] tests/unit/dockertypes_test.py::HostConfigTest::test_ctrate_host_config_with_cpu_rt_runtime_types PASSED [ 53%] tests/unit/dockertypes_test.py::ContainerSpecTest::test_parse_mounts PASSED [ 53%] tests/unit/dockertypes_test.py::UlimitTest::test_create_host_config_dict_ulimit PASSED [ 53%] tests/unit/dockertypes_test.py::UlimitTest::test_create_host_config_dict_ulimit_capitals PASSED [ 53%] tests/unit/dockertypes_test.py::UlimitTest::test_create_host_config_obj_ulimit PASSED [ 53%] tests/unit/dockertypes_test.py::UlimitTest::test_ulimit_invalid_type PASSED [ 54%] tests/unit/dockertypes_test.py::LogConfigTest::test_create_host_config_dict_logconfig PASSED [ 54%] tests/unit/dockertypes_test.py::LogConfigTest::test_create_host_config_obj_logconfig PASSED [ 54%] tests/unit/dockertypes_test.py::LogConfigTest::test_logconfig_invalid_config_type PASSED [ 54%] tests/unit/dockertypes_test.py::EndpointConfigTest::test_create_endpoint_config_with_aliases PASSED [ 54%] tests/unit/dockertypes_test.py::IPAMConfigTest::test_create_ipam_config PASSED [ 54%] tests/unit/dockertypes_test.py::ServiceModeTest::test_global_replicas_error PASSED [ 55%] tests/unit/dockertypes_test.py::ServiceModeTest::test_global_simple PASSED [ 55%] tests/unit/dockertypes_test.py::ServiceModeTest::test_invalid_mode PASSED [ 55%] tests/unit/dockertypes_test.py::ServiceModeTest::test_replicated_replicas PASSED [ 55%] tests/unit/dockertypes_test.py::ServiceModeTest::test_replicated_replicas_0 PASSED [ 55%] tests/unit/dockertypes_test.py::ServiceModeTest::test_replicated_simple PASSED [ 55%] tests/unit/dockertypes_test.py::MountTest::test_parse_mount_bind PASSED [ 56%] tests/unit/dockertypes_test.py::MountTest::test_parse_mount_bind_windows XFAIL [ 56%] tests/unit/dockertypes_test.py::MountTest::test_parse_mount_named_volume PASSED [ 56%] tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_invalid PASSED [ 56%] tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_no_source PASSED [ 56%] tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_ro PASSED [ 56%] tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_rw PASSED [ 57%] tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_short_form PASSED [ 57%] tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_invalid PASSED [ 57%] tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_multiple PASSED [ 57%] tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_no_protocol_and_mode PASSED [ 57%] tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_simple PASSED [ 58%] tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_with_protocol PASSED [ 58%] tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_with_protocol_and_mode PASSED [ 58%] tests/unit/errors_test.py::APIErrorTest::test_api_error_is_caught_by_dockerexception PASSED [ 58%] tests/unit/errors_test.py::APIErrorTest::test_create_error_from_exception PASSED [ 58%] tests/unit/errors_test.py::APIErrorTest::test_is_client_error_400 PASSED [ 58%] tests/unit/errors_test.py::APIErrorTest::test_is_client_error_500 PASSED [ 59%] tests/unit/errors_test.py::APIErrorTest::test_is_error_300 PASSED [ 59%] tests/unit/errors_test.py::APIErrorTest::test_is_error_400 PASSED [ 59%] tests/unit/errors_test.py::APIErrorTest::test_is_error_500 PASSED [ 59%] tests/unit/errors_test.py::APIErrorTest::test_is_server_error_200 PASSED [ 59%] tests/unit/errors_test.py::APIErrorTest::test_is_server_error_300 PASSED [ 59%] tests/unit/errors_test.py::APIErrorTest::test_is_server_error_400 PASSED [ 60%] tests/unit/errors_test.py::APIErrorTest::test_is_server_error_500 PASSED [ 60%] ============================= test session starts ============================== platform linux -- Python 3.7.12, pytest-6.2.5, py-1.10.0, pluggy-1.0.0 -- /usr/local/bin/python cachedir: .pytest_cache rootdir: /src, configfile: pytest.ini plugins: timeout-2.0.1, cov-3.0.0 tests/unit/dockertypes_test.py::MountTest::test_parse_mount_bind_windows XFAIL [ 56%] tests/unit/dockertypes_test.py::MountTest::test_parse_mount_named_volume PASSED [ 56%] tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_invalid PASSED [ 56%] tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_no_source PASSED [ 56%] tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_ro PASSED [ 56%] tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_rw PASSED [ 57%] tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_short_form PASSED [ 57%] tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_invalid PASSED [ 57%] tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_multiple PASSED [ 57%] tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_no_protocol_and_mode PASSED [ 57%] tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_simple PASSED [ 58%] tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_with_protocol PASSED [ 58%] tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_with_protocol_and_mode PASSED [ 58%] tests/unit/errors_test.py::APIErrorTest::test_api_error_is_caught_by_dockerexception PASSED [ 58%] tests/unit/errors_test.py::APIErrorTest::test_create_error_from_exception PASSED [ 58%] tests/unit/errors_test.py::APIErrorTest::test_is_client_error_400 PASSED [ 58%] tests/unit/errors_test.py::APIErrorTest::test_is_client_error_500 PASSED [ 59%] tests/unit/errors_test.py::APIErrorTest::test_is_error_300 PASSED [ 59%] tests/unit/errors_test.py::APIErrorTest::test_is_error_400 PASSED [ 59%] tests/unit/errors_test.py::APIErrorTest::test_is_error_500 PASSED [ 59%] tests/unit/errors_test.py::APIErrorTest::test_is_server_error_200 PASSED [ 59%] tests/unit/errors_test.py::APIErrorTest::test_is_server_error_300 PASSED [ 59%] tests/unit/errors_test.py::APIErrorTest::test_is_server_error_400 PASSED [ 60%] tests/unit/errors_test.py::APIErrorTest::test_is_server_error_500 PASSED [ 60%] tests/unit/errors_test.py::APIErrorTest::test_status_code_200 PASSED [ 60%] tests/unit/errors_test.py::APIErrorTest::test_status_code_400 PASSED [ 60%] tests/unit/errors_test.py::APIErrorTest::test_status_code_500 PASSED [ 60%] tests/unit/errors_test.py::ContainerErrorTest::test_container_with_stderr PASSED [ 61%] tests/unit/errors_test.py::ContainerErrorTest::test_container_without_stderr PASSED [ 61%] tests/unit/errors_test.py::CreateUnexpectedKwargsErrorTest::test_create_unexpected_kwargs_error_multiple PASSED [ 61%] tests/unit/errors_test.py::CreateUnexpectedKwargsErrorTest::test_create_unexpected_kwargs_error_single PASSED [ 61%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_create PASSED [ 61%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_create_container_args PASSED [ 61%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_create_with_image_object PASSED [ 62%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_get PASSED [ 62%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_list PASSED [ 62%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_list_ignore_removed PASSED [ 62%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_run PASSED [ 62%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_detach PASSED [ 62%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_pull PASSED [ 63%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_remove PASSED [ 63%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_with_error PASSED [ 63%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_with_image_object PASSED [ 63%] tests/unit/models_containers_test.py::ContainerTest::test_attach PASSED [ 63%] tests/unit/models_containers_test.py::ContainerTest::test_commit PASSED [ 63%] tests/unit/models_containers_test.py::ContainerTest::test_diff PASSED [ 64%] tests/unit/models_containers_test.py::ContainerTest::test_exec_run PASSED [ 64%] tests/unit/models_containers_test.py::ContainerTest::test_exec_run_failure PASSED [ 64%] tests/unit/models_containers_test.py::ContainerTest::test_export PASSED [ 64%] tests/unit/errors_test.py::APIErrorTest::test_status_code_200 PASSED [ 60%] tests/unit/errors_test.py::APIErrorTest::test_status_code_400 PASSED [ 60%] tests/unit/errors_test.py::APIErrorTest::test_status_code_500 PASSED [ 60%] tests/unit/errors_test.py::ContainerErrorTest::test_container_with_stderr PASSED [ 61%] tests/unit/errors_test.py::ContainerErrorTest::test_container_without_stderr PASSED [ 61%] tests/unit/errors_test.py::CreateUnexpectedKwargsErrorTest::test_create_unexpected_kwargs_error_multiple PASSED [ 61%] tests/unit/errors_test.py::CreateUnexpectedKwargsErrorTest::test_create_unexpected_kwargs_error_single PASSED [ 61%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_create PASSED [ 61%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_create_container_args PASSED [ 61%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_create_with_image_object PASSED [ 62%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_get PASSED [ 62%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_list PASSED [ 62%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_list_ignore_removed PASSED [ 62%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_run PASSED [ 62%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_detach PASSED [ 62%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_pull PASSED [ 63%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_remove PASSED [ 63%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_with_error PASSED [ 63%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_with_image_object PASSED [ 63%] tests/unit/models_containers_test.py::ContainerTest::test_attach PASSED [ 63%] tests/unit/models_containers_test.py::ContainerTest::test_commit PASSED [ 63%] tests/unit/models_containers_test.py::ContainerTest::test_diff PASSED [ 64%] tests/unit/models_containers_test.py::ContainerTest::test_exec_run PASSED [ 64%] tests/unit/models_containers_test.py::ContainerTest::test_exec_run_failure PASSED [ 64%] tests/unit/models_containers_test.py::ContainerTest::test_export PASSED [ 64%] tests/unit/models_containers_test.py::ContainerTest::test_get_archive PASSED [ 64%] tests/unit/models_containers_test.py::ContainerTest::test_image PASSED [ 65%] tests/unit/models_containers_test.py::ContainerTest::test_kill PASSED [ 65%] tests/unit/models_containers_test.py::ContainerTest::test_labels PASSED [ 65%] tests/unit/models_containers_test.py::ContainerTest::test_logs PASSED [ 65%] tests/unit/models_containers_test.py::ContainerTest::test_name PASSED [ 65%] tests/unit/models_containers_test.py::ContainerTest::test_pause PASSED [ 65%] tests/unit/models_containers_test.py::ContainerTest::test_put_archive PASSED [ 66%] tests/unit/models_containers_test.py::ContainerTest::test_remove PASSED [ 66%] tests/unit/models_containers_test.py::ContainerTest::test_rename PASSED [ 66%] tests/unit/models_containers_test.py::ContainerTest::test_resize PASSED [ 66%] tests/unit/models_containers_test.py::ContainerTest::test_restart PASSED [ 66%] tests/unit/models_containers_test.py::ContainerTest::test_get_archive PASSED [ 64%] tests/unit/models_containers_test.py::ContainerTest::test_image PASSED [ 65%] tests/unit/models_containers_test.py::ContainerTest::test_kill PASSED [ 65%] tests/unit/models_containers_test.py::ContainerTest::test_labels PASSED [ 65%] tests/unit/models_containers_test.py::ContainerTest::test_logs PASSED [ 65%] tests/unit/models_containers_test.py::ContainerTest::test_name PASSED [ 65%] tests/unit/models_containers_test.py::ContainerTest::test_pause PASSED [ 65%] tests/unit/models_containers_test.py::ContainerTest::test_put_archive PASSED [ 66%] tests/unit/models_containers_test.py::ContainerTest::test_remove PASSED [ 66%] tests/unit/models_containers_test.py::ContainerTest::test_rename PASSED [ 66%] tests/unit/models_containers_test.py::ContainerTest::test_resize PASSED [ 66%] tests/unit/models_containers_test.py::ContainerTest::test_restart PASSED [ 66%] tests/unit/models_containers_test.py::ContainerTest::test_start PASSED [ 66%] tests/unit/models_containers_test.py::ContainerTest::test_stats PASSED [ 67%] tests/unit/models_containers_test.py::ContainerTest::test_status PASSED [ 67%] tests/unit/models_containers_test.py::ContainerTest::test_stop PASSED [ 67%] tests/unit/models_containers_test.py::ContainerTest::test_top PASSED [ 67%] tests/unit/models_containers_test.py::ContainerTest::test_unpause PASSED [ 67%] tests/unit/models_containers_test.py::ContainerTest::test_update PASSED [ 68%] tests/unit/models_containers_test.py::ContainerTest::test_wait PASSED [ 68%] tests/unit/models_images_test.py::ImageCollectionTest::test_build PASSED [ 68%] tests/unit/models_images_test.py::ImageCollectionTest::test_get PASSED [ 68%] tests/unit/models_images_test.py::ImageCollectionTest::test_labels PASSED [ 68%] tests/unit/models_images_test.py::ImageCollectionTest::test_list PASSED [ 68%] tests/unit/models_images_test.py::ImageCollectionTest::test_load PASSED [ 69%] tests/unit/models_images_test.py::ImageCollectionTest::test_pull PASSED [ 69%] tests/unit/models_images_test.py::ImageCollectionTest::test_pull_multiple PASSED [ 69%] tests/unit/models_images_test.py::ImageCollectionTest::test_pull_tag_precedence PASSED [ 69%] tests/unit/models_images_test.py::ImageCollectionTest::test_pull_with_stream_param PASSED [ 69%] tests/unit/models_images_test.py::ImageCollectionTest::test_push PASSED [ 69%] tests/unit/models_images_test.py::ImageCollectionTest::test_remove PASSED [ 70%] tests/unit/models_images_test.py::ImageCollectionTest::test_search PASSED [ 70%] tests/unit/models_images_test.py::ImageCollectionTest::test_search_limit PASSED [ 70%] tests/unit/models_images_test.py::ImageTest::test_history PASSED [ 70%] tests/unit/models_containers_test.py::ContainerTest::test_start PASSED [ 66%] tests/unit/models_containers_test.py::ContainerTest::test_stats PASSED [ 67%] tests/unit/models_containers_test.py::ContainerTest::test_status PASSED [ 67%] tests/unit/models_containers_test.py::ContainerTest::test_stop PASSED [ 67%] tests/unit/models_containers_test.py::ContainerTest::test_top PASSED [ 67%] tests/unit/models_containers_test.py::ContainerTest::test_unpause PASSED [ 67%] tests/unit/models_containers_test.py::ContainerTest::test_update PASSED [ 68%] tests/unit/models_containers_test.py::ContainerTest::test_wait PASSED [ 68%] tests/unit/models_images_test.py::ImageCollectionTest::test_build PASSED [ 68%] tests/unit/models_images_test.py::ImageCollectionTest::test_get PASSED [ 68%] tests/unit/models_images_test.py::ImageCollectionTest::test_labels PASSED [ 68%] tests/unit/models_images_test.py::ImageCollectionTest::test_list PASSED [ 68%] tests/unit/models_images_test.py::ImageCollectionTest::test_load PASSED [ 69%] tests/unit/models_images_test.py::ImageCollectionTest::test_pull PASSED [ 69%] tests/unit/models_images_test.py::ImageCollectionTest::test_pull_multiple PASSED [ 69%] tests/unit/models_images_test.py::ImageCollectionTest::test_pull_tag_precedence PASSED [ 69%] tests/unit/models_images_test.py::ImageCollectionTest::test_pull_with_stream_param PASSED [ 69%] tests/unit/models_images_test.py::ImageCollectionTest::test_push PASSED [ 69%] tests/unit/models_images_test.py::ImageCollectionTest::test_remove PASSED [ 70%] tests/unit/models_images_test.py::ImageCollectionTest::test_search PASSED [ 70%] tests/unit/models_images_test.py::ImageCollectionTest::test_search_limit PASSED [ 70%] tests/unit/models_images_test.py::ImageTest::test_history PASSED [ 70%] tests/unit/models_images_test.py::ImageTest::test_remove FAILED [ 70%] tests/unit/models_images_test.py::ImageTest::test_save PASSED [ 70%] tests/unit/models_images_test.py::ImageTest::test_short_id PASSED [ 71%] tests/unit/models_images_test.py::ImageTest::test_tag PASSED [ 71%] tests/unit/models_images_test.py::ImageTest::test_tags PASSED [ 71%] tests/unit/models_networks_test.py::NetworkCollectionTest::test_create PASSED [ 71%] tests/unit/models_images_test.py::ImageTest::test_remove FAILED [ 70%] tests/unit/models_images_test.py::ImageTest::test_save PASSED [ 70%] tests/unit/models_images_test.py::ImageTest::test_short_id PASSED [ 71%] tests/unit/models_images_test.py::ImageTest::test_tag PASSED [ 71%] tests/unit/models_images_test.py::ImageTest::test_tags PASSED [ 71%] tests/unit/models_networks_test.py::NetworkCollectionTest::test_create PASSED [ 71%] tests/unit/models_networks_test.py::NetworkCollectionTest::test_get PASSED [ 71%] tests/unit/models_networks_test.py::NetworkCollectionTest::test_list PASSED [ 72%] tests/unit/models_networks_test.py::NetworkTest::test_connect PASSED [ 72%] tests/unit/models_networks_test.py::NetworkTest::test_disconnect PASSED [ 72%] tests/unit/models_networks_test.py::NetworkTest::test_remove PASSED [ 72%] tests/unit/models_resources_test.py::ModelTest::test_hash PASSED [ 72%] tests/unit/models_resources_test.py::ModelTest::test_reload PASSED [ 72%] tests/unit/models_secrets_test.py::CreateServiceTest::test_secrets_repr PASSED [ 73%] tests/unit/models_services_test.py::CreateServiceKwargsTest::test_get_create_service_kwargs PASSED [ 73%] tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_hostname_prefix_trim PASSED [ 73%] tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_hostname_and_port PASSED [ 73%] tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_hostname_only PASSED [ 73%] tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_url PASSED [ 73%] tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_user_and_hostname PASSED [ 74%] tests/unit/ssladapter_test.py::SSLAdapterTest::test_only_uses_tls PASSED [ 74%] tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_dns_failure PASSED [ 74%] tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_dns_success PASSED [ 74%] tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_ip_address_failure PASSED [ 74%] tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_ip_address_success PASSED [ 75%] tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_localhost_success PASSED [ 75%] tests/unit/swarm_test.py::SwarmTest::test_join_swarm PASSED [ 75%] tests/unit/swarm_test.py::SwarmTest::test_join_swarm_no_listen_address_takes_default PASSED [ 75%] tests/unit/swarm_test.py::SwarmTest::test_node_update PASSED [ 75%] tests/unit/types_containers_test.py::test_uid_0_is_not_elided PASSED [ 75%] tests/unit/utils_build_test.py::ExcludePathsTest::test_directory PASSED [ 76%] tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_single_exception PASSED [ 76%] tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_subdir_exception PASSED [ 76%] tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_subdir_exception_win32_pathsep SKIPPED [ 76%] tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_trailing_slash PASSED [ 76%] tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_wildcard_exception PASSED [ 76%] tests/unit/utils_build_test.py::ExcludePathsTest::test_double_wildcard PASSED [ 77%] tests/unit/utils_build_test.py::ExcludePathsTest::test_double_wildcard_with_exception PASSED [ 77%] tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_custom_dockerfile PASSED [ 77%] tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_dockerfile_child PASSED [ 77%] tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_dockerfile_dockerignore PASSED [ 77%] tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_include_absolute_path PASSED [ 77%] tests/unit/utils_build_test.py::ExcludePathsTest::test_include_wildcard PASSED [ 78%] tests/unit/utils_build_test.py::ExcludePathsTest::test_last_line_precedence PASSED [ 78%] tests/unit/utils_build_test.py::ExcludePathsTest::test_no_dupes PASSED [ 78%] tests/unit/utils_build_test.py::ExcludePathsTest::test_no_excludes PASSED [ 78%] tests/unit/utils_build_test.py::ExcludePathsTest::test_parent_directory PASSED [ 78%] tests/unit/utils_build_test.py::ExcludePathsTest::test_question_mark PASSED [ 79%] tests/unit/utils_build_test.py::ExcludePathsTest::test_single_and_double_wildcard PASSED [ 79%] tests/unit/models_networks_test.py::NetworkCollectionTest::test_get PASSED [ 71%] tests/unit/models_networks_test.py::NetworkCollectionTest::test_list PASSED [ 72%] tests/unit/models_networks_test.py::NetworkTest::test_connect PASSED [ 72%] tests/unit/models_networks_test.py::NetworkTest::test_disconnect PASSED [ 72%] tests/unit/models_networks_test.py::NetworkTest::test_remove PASSED [ 72%] tests/unit/models_resources_test.py::ModelTest::test_hash PASSED [ 72%] tests/unit/models_resources_test.py::ModelTest::test_reload PASSED [ 72%] tests/unit/models_secrets_test.py::CreateServiceTest::test_secrets_repr PASSED [ 73%] tests/unit/models_services_test.py::CreateServiceKwargsTest::test_get_create_service_kwargs PASSED [ 73%] tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_hostname_prefix_trim PASSED [ 73%] tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_hostname_and_port PASSED [ 73%] tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_hostname_only PASSED [ 73%] tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_url PASSED [ 73%] tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_user_and_hostname PASSED [ 74%] tests/unit/ssladapter_test.py::SSLAdapterTest::test_only_uses_tls PASSED [ 74%] tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_dns_failure PASSED [ 74%] tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_dns_success PASSED [ 74%] tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_ip_address_failure PASSED [ 74%] tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_ip_address_success PASSED [ 75%] tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_localhost_success PASSED [ 75%] tests/unit/swarm_test.py::SwarmTest::test_join_swarm PASSED [ 75%] tests/unit/swarm_test.py::SwarmTest::test_join_swarm_no_listen_address_takes_default PASSED [ 75%] tests/unit/swarm_test.py::SwarmTest::test_node_update PASSED [ 75%] tests/unit/types_containers_test.py::test_uid_0_is_not_elided PASSED [ 75%] tests/unit/utils_build_test.py::ExcludePathsTest::test_directory PASSED [ 76%] tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_single_exception PASSED [ 76%] tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_subdir_exception PASSED [ 76%] tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_subdir_exception_win32_pathsep SKIPPED [ 76%] tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_trailing_slash PASSED [ 76%] tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_wildcard_exception PASSED [ 76%] tests/unit/utils_build_test.py::ExcludePathsTest::test_double_wildcard PASSED [ 77%] tests/unit/utils_build_test.py::ExcludePathsTest::test_double_wildcard_with_exception PASSED [ 77%] tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_custom_dockerfile PASSED [ 77%] tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_dockerfile_child PASSED [ 77%] tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_dockerfile_dockerignore PASSED [ 77%] tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_include_absolute_path PASSED [ 77%] tests/unit/utils_build_test.py::ExcludePathsTest::test_include_wildcard PASSED [ 78%] tests/unit/utils_build_test.py::ExcludePathsTest::test_last_line_precedence PASSED [ 78%] tests/unit/utils_build_test.py::ExcludePathsTest::test_no_dupes PASSED [ 78%] tests/unit/utils_build_test.py::ExcludePathsTest::test_no_excludes PASSED [ 78%] tests/unit/utils_build_test.py::ExcludePathsTest::test_parent_directory PASSED [ 78%] tests/unit/utils_build_test.py::ExcludePathsTest::test_question_mark PASSED [ 79%] tests/unit/utils_build_test.py::ExcludePathsTest::test_single_and_double_wildcard PASSED [ 79%] tests/unit/utils_build_test.py::ExcludePathsTest::test_single_filename PASSED [ 79%] tests/unit/utils_build_test.py::ExcludePathsTest::test_single_filename_leading_dot_slash PASSED [ 79%] tests/unit/utils_build_test.py::ExcludePathsTest::test_single_filename_trailing_slash PASSED [ 79%] tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_single_filename PASSED [ 79%] tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_single_filename_leading_slash PASSED [ 80%] tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_wildcard_filename PASSED [ 80%] tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_with_path_traversal PASSED [ 80%] tests/unit/utils_build_test.py::ExcludePathsTest::test_subdirectory PASSED [ 80%] tests/unit/utils_build_test.py::ExcludePathsTest::test_subdirectory_win32_pathsep SKIPPED [ 80%] tests/unit/utils_build_test.py::ExcludePathsTest::test_trailing_double_wildcard PASSED [ 80%] tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_exclude PASSED [ 81%] tests/unit/utils_build_test.py::ExcludePathsTest::test_single_filename PASSED [ 79%] tests/unit/utils_build_test.py::ExcludePathsTest::test_single_filename_leading_dot_slash PASSED [ 79%] tests/unit/utils_build_test.py::ExcludePathsTest::test_single_filename_trailing_slash PASSED [ 79%] tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_single_filename PASSED [ 79%] tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_single_filename_leading_slash PASSED [ 80%] tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_wildcard_filename PASSED [ 80%] tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_with_path_traversal PASSED [ 80%] tests/unit/utils_build_test.py::ExcludePathsTest::test_subdirectory PASSED [ 80%] tests/unit/utils_build_test.py::ExcludePathsTest::test_subdirectory_win32_pathsep SKIPPED [ 80%] tests/unit/utils_build_test.py::ExcludePathsTest::test_trailing_double_wildcard PASSED [ 80%] tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_exclude PASSED [ 81%] tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_filename_end PASSED [ 81%] tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_filename_start PASSED [ 81%] tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_subdir_single_filename PASSED [ 81%] tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_subdir_wildcard_filename PASSED [ 81%] tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_with_exception PASSED [ 81%] tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_with_wildcard_exception PASSED [ 82%] tests/unit/utils_build_test.py::TarTest::test_tar_directory_link PASSED [ 82%] tests/unit/utils_build_test.py::TarTest::test_tar_socket_file PASSED [ 82%] tests/unit/utils_build_test.py::TarTest::test_tar_with_broken_symlinks PASSED [ 82%] tests/unit/utils_build_test.py::TarTest::test_tar_with_directory_symlinks PASSED [ 82%] tests/unit/utils_build_test.py::TarTest::test_tar_with_empty_directory PASSED [ 83%] tests/unit/utils_build_test.py::TarTest::test_tar_with_excludes PASSED [ 83%] tests/unit/utils_build_test.py::TarTest::test_tar_with_file_symlinks PASSED [ 83%] tests/unit/utils_build_test.py::TarTest::test_tar_with_inaccessible_file SKIPPED [ 83%] tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_fallback PASSED [ 83%] tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_environment PASSED [ 83%] tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_explicit_path PASSED [ 84%] tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_home_legacy_name PASSED [ 84%] tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_home_posix PASSED [ 84%] tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_home_windows SKIPPED [ 84%] tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_custom_headers PASSED [ 84%] tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_detach_keys PASSED [ 84%] tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_from_env PASSED [ 85%] tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_no_file PASSED [ 85%] tests/unit/utils_json_stream_test.py::TestJsonSplitter::test_json_splitter_no_object PASSED [ 85%] tests/unit/utils_json_stream_test.py::TestJsonSplitter::test_json_splitter_with_object PASSED [ 85%] tests/unit/utils_json_stream_test.py::TestJsonSplitter::test_json_splitter_leading_whitespace PASSED [ 85%] tests/unit/utils_json_stream_test.py::TestStreamAsText::test_stream_with_non_utf_unicode_character PASSED [ 86%] tests/unit/utils_json_stream_test.py::TestStreamAsText::test_stream_with_utf_character PASSED [ 86%] tests/unit/utils_json_stream_test.py::TestJsonStream::test_with_falsy_entries PASSED [ 86%] tests/unit/utils_json_stream_test.py::TestJsonStream::test_with_leading_whitespace PASSED [ 86%] tests/unit/utils_proxy_test.py::ProxyConfigTest::test_environment PASSED [ 86%] tests/unit/utils_proxy_test.py::ProxyConfigTest::test_from_dict PASSED [ 86%] tests/unit/utils_proxy_test.py::ProxyConfigTest::test_inject_proxy_environment PASSED [ 87%] tests/unit/utils_proxy_test.py::ProxyConfigTest::test_new PASSED [ 87%] tests/unit/utils_proxy_test.py::ProxyConfigTest::test_truthiness PASSED [ 87%] tests/unit/utils_test.py::DecoratorsTest::test_update_headers PASSED [ 87%] tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_alternate_env PASSED [ 87%] tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_empty PASSED [ 87%] tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_no_cert_path PASSED [ 88%] tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_tls PASSED [ 88%] tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_tls_verify_false PASSED [ 88%] tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_tls_verify_false_no_cert PASSED [ 88%] tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_compact PASSED [ 88%] tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_complete PASSED [ 88%] tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_filename_end PASSED [ 81%] tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_filename_start PASSED [ 81%] tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_subdir_single_filename PASSED [ 81%] tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_subdir_wildcard_filename PASSED [ 81%] tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_with_exception PASSED [ 81%] tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_with_wildcard_exception PASSED [ 82%] tests/unit/utils_build_test.py::TarTest::test_tar_directory_link PASSED [ 82%] tests/unit/utils_build_test.py::TarTest::test_tar_socket_file PASSED [ 82%] tests/unit/utils_build_test.py::TarTest::test_tar_with_broken_symlinks PASSED [ 82%] tests/unit/utils_build_test.py::TarTest::test_tar_with_directory_symlinks PASSED [ 82%] tests/unit/utils_build_test.py::TarTest::test_tar_with_empty_directory PASSED [ 83%] tests/unit/utils_build_test.py::TarTest::test_tar_with_excludes PASSED [ 83%] tests/unit/utils_build_test.py::TarTest::test_tar_with_file_symlinks PASSED [ 83%] tests/unit/utils_build_test.py::TarTest::test_tar_with_inaccessible_file SKIPPED [ 83%] tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_fallback PASSED [ 83%] tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_environment PASSED [ 83%] tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_explicit_path PASSED [ 84%] tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_home_legacy_name PASSED [ 84%] tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_home_posix PASSED [ 84%] tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_home_windows SKIPPED [ 84%] tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_custom_headers PASSED [ 84%] tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_detach_keys PASSED [ 84%] tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_from_env PASSED [ 85%] tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_no_file PASSED [ 85%] tests/unit/utils_json_stream_test.py::TestJsonSplitter::test_json_splitter_no_object PASSED [ 85%] tests/unit/utils_json_stream_test.py::TestJsonSplitter::test_json_splitter_with_object PASSED [ 85%] tests/unit/utils_json_stream_test.py::TestJsonSplitter::test_json_splitter_leading_whitespace PASSED [ 85%] tests/unit/utils_json_stream_test.py::TestStreamAsText::test_stream_with_non_utf_unicode_character PASSED [ 86%] tests/unit/utils_json_stream_test.py::TestStreamAsText::test_stream_with_utf_character PASSED [ 86%] tests/unit/utils_json_stream_test.py::TestJsonStream::test_with_falsy_entries PASSED [ 86%] tests/unit/utils_json_stream_test.py::TestJsonStream::test_with_leading_whitespace PASSED [ 86%] tests/unit/utils_proxy_test.py::ProxyConfigTest::test_environment PASSED [ 86%] tests/unit/utils_proxy_test.py::ProxyConfigTest::test_from_dict PASSED [ 86%] tests/unit/utils_proxy_test.py::ProxyConfigTest::test_inject_proxy_environment PASSED [ 87%] tests/unit/utils_proxy_test.py::ProxyConfigTest::test_new PASSED [ 87%] tests/unit/utils_proxy_test.py::ProxyConfigTest::test_truthiness PASSED [ 87%] tests/unit/utils_test.py::DecoratorsTest::test_update_headers PASSED [ 87%] tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_alternate_env PASSED [ 87%] tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_empty PASSED [ 87%] tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_no_cert_path PASSED [ 88%] tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_tls PASSED [ 88%] tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_tls_verify_false PASSED [ 88%] tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_tls_verify_false_no_cert PASSED [ 88%] tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_compact PASSED [ 88%] tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_complete PASSED [ 88%] tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_empty PASSED [ 89%] tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_list PASSED [ 89%] tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_no_mode PASSED [ 89%] tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_unicode_bytes_input PASSED [ 89%] tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_unicode_unicode_input PASSED [ 89%] tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_commented_line PASSED [ 90%] tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_invalid_line PASSED [ 90%] tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_newline PASSED [ 90%] tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_proper PASSED [ 90%] tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_with_equals_character PASSED [ 90%] tests/unit/utils_test.py::ParseHostTest::test_parse_host PASSED [ 90%] tests/unit/utils_test.py::ParseHostTest::test_parse_host_empty_value PASSED [ 91%] tests/unit/utils_test.py::ParseHostTest::test_parse_host_tls PASSED [ 91%] tests/unit/utils_test.py::ParseHostTest::test_parse_host_tls_tcp_proto PASSED [ 91%] tests/unit/utils_test.py::ParseHostTest::test_parse_host_trailing_slash PASSED [ 91%] tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_image_no_tag PASSED [ 91%] tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_image_sha PASSED [ 91%] tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_image_tag PASSED [ 92%] tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_user_image_no_tag PASSED [ 92%] tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_user_image_tag PASSED [ 92%] tests/unit/utils_test.py::ParseRepositoryTagTest::test_private_reg_image_no_tag PASSED [ 92%] tests/unit/utils_test.py::ParseRepositoryTagTest::test_private_reg_image_sha PASSED [ 92%] tests/unit/utils_test.py::ParseRepositoryTagTest::test_private_reg_image_tag PASSED [ 93%] tests/unit/utils_test.py::ParseDeviceTest::test_dict PASSED [ 93%] tests/unit/utils_test.py::ParseDeviceTest::test_full_string_definition PASSED [ 93%] tests/unit/utils_test.py::ParseDeviceTest::test_hybrid_list PASSED [ 93%] tests/unit/utils_test.py::ParseDeviceTest::test_partial_string_definition PASSED [ 93%] tests/unit/utils_test.py::ParseDeviceTest::test_permissionless_string_definition PASSED [ 93%] tests/unit/utils_test.py::ParseBytesTest::test_parse_bytes_float PASSED [ 94%] tests/unit/utils_test.py::ParseBytesTest::test_parse_bytes_invalid PASSED [ 94%] tests/unit/utils_test.py::ParseBytesTest::test_parse_bytes_valid PASSED [ 94%] tests/unit/utils_test.py::UtilsTest::test_convert_filters PASSED [ 94%] tests/unit/utils_test.py::UtilsTest::test_decode_json_header PASSED [ 94%] tests/unit/utils_test.py::SplitCommandTest::test_split_command_with_unicode PASSED [ 94%] tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_matching_internal_port_ranges PASSED [ 95%] tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_matching_internal_ports PASSED [ 95%] tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_nonmatching_internal_port_ranges PASSED [ 95%] tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_nonmatching_internal_ports PASSED [ 95%] tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_one_port PASSED [ 95%] tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_port_range PASSED [ 95%] tests/unit/utils_test.py::PortsTest::test_host_only_with_colon PASSED [ 96%] tests/unit/utils_test.py::PortsTest::test_non_matching_length_port_ranges PASSED [ 96%] tests/unit/utils_test.py::PortsTest::test_port_and_range_invalid PASSED [ 96%] tests/unit/utils_test.py::PortsTest::test_port_only_with_colon PASSED [ 96%] tests/unit/utils_test.py::PortsTest::test_split_port_empty_string PASSED [ 96%] tests/unit/utils_test.py::PortsTest::test_split_port_invalid PASSED [ 97%] tests/unit/utils_test.py::PortsTest::test_split_port_invalid_protocol PASSED [ 97%] tests/unit/utils_test.py::PortsTest::test_split_port_no_host_port PASSED [ 97%] tests/unit/utils_test.py::PortsTest::test_split_port_non_string PASSED [ 97%] tests/unit/utils_test.py::PortsTest::test_split_port_random_port_range_with_host_port PASSED [ 97%] tests/unit/utils_test.py::PortsTest::test_split_port_range_no_host_port PASSED [ 97%] tests/unit/utils_test.py::PortsTest::test_split_port_range_with_host_ip_no_port PASSED [ 98%] tests/unit/utils_test.py::PortsTest::test_split_port_range_with_host_port PASSED [ 98%] tests/unit/utils_test.py::PortsTest::test_split_port_range_with_protocol PASSED [ 98%] tests/unit/utils_test.py::PortsTest::test_split_port_with_host_ip PASSED [ 98%] tests/unit/utils_test.py::PortsTest::test_split_port_with_host_ip_no_port PASSED [ 98%] tests/unit/utils_test.py::PortsTest::test_split_port_with_host_port PASSED [ 98%] tests/unit/utils_test.py::PortsTest::test_split_port_with_ipv6_address PASSED [ 99%] tests/unit/utils_test.py::PortsTest::test_split_port_with_ipv6_square_brackets_address PASSED [ 99%] tests/unit/utils_test.py::PortsTest::test_split_port_with_protocol PASSED [ 99%] tests/unit/utils_test.py::PortsTest::test_with_no_container_port PASSED [ 99%] tests/unit/utils_test.py::FormatEnvironmentTest::test_format_env_binary_unicode_value PASSED [ 99%] tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_empty PASSED [ 89%] tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_list PASSED [ 89%] tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_no_mode PASSED [ 89%] tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_unicode_bytes_input PASSED [ 89%] tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_unicode_unicode_input PASSED [ 89%] tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_commented_line PASSED [ 90%] tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_invalid_line PASSED [ 90%] tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_newline PASSED [ 90%] tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_proper PASSED [ 90%] tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_with_equals_character PASSED [ 90%] tests/unit/utils_test.py::ParseHostTest::test_parse_host PASSED [ 90%] tests/unit/utils_test.py::ParseHostTest::test_parse_host_empty_value PASSED [ 91%] tests/unit/utils_test.py::ParseHostTest::test_parse_host_tls PASSED [ 91%] tests/unit/utils_test.py::ParseHostTest::test_parse_host_tls_tcp_proto PASSED [ 91%] tests/unit/utils_test.py::ParseHostTest::test_parse_host_trailing_slash PASSED [ 91%] tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_image_no_tag PASSED [ 91%] tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_image_sha PASSED [ 91%] tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_image_tag PASSED [ 92%] tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_user_image_no_tag PASSED [ 92%] tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_user_image_tag PASSED [ 92%] tests/unit/utils_test.py::ParseRepositoryTagTest::test_private_reg_image_no_tag PASSED [ 92%] tests/unit/utils_test.py::ParseRepositoryTagTest::test_private_reg_image_sha PASSED [ 92%] tests/unit/utils_test.py::ParseRepositoryTagTest::test_private_reg_image_tag PASSED [ 93%] tests/unit/utils_test.py::ParseDeviceTest::test_dict PASSED [ 93%] tests/unit/utils_test.py::ParseDeviceTest::test_full_string_definition PASSED [ 93%] tests/unit/utils_test.py::ParseDeviceTest::test_hybrid_list PASSED [ 93%] tests/unit/utils_test.py::ParseDeviceTest::test_partial_string_definition PASSED [ 93%] tests/unit/utils_test.py::ParseDeviceTest::test_permissionless_string_definition PASSED [ 93%] tests/unit/utils_test.py::ParseBytesTest::test_parse_bytes_float PASSED [ 94%] tests/unit/utils_test.py::ParseBytesTest::test_parse_bytes_invalid PASSED [ 94%] tests/unit/utils_test.py::ParseBytesTest::test_parse_bytes_valid PASSED [ 94%] tests/unit/utils_test.py::UtilsTest::test_convert_filters PASSED [ 94%] tests/unit/utils_test.py::UtilsTest::test_decode_json_header PASSED [ 94%] tests/unit/utils_test.py::SplitCommandTest::test_split_command_with_unicode PASSED [ 94%] tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_matching_internal_port_ranges PASSED [ 95%] tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_matching_internal_ports PASSED [ 95%] tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_nonmatching_internal_port_ranges PASSED [ 95%] tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_nonmatching_internal_ports PASSED [ 95%] tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_one_port PASSED [ 95%] tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_port_range PASSED [ 95%] tests/unit/utils_test.py::PortsTest::test_host_only_with_colon PASSED [ 96%] tests/unit/utils_test.py::PortsTest::test_non_matching_length_port_ranges PASSED [ 96%] tests/unit/utils_test.py::PortsTest::test_port_and_range_invalid PASSED [ 96%] tests/unit/utils_test.py::PortsTest::test_port_only_with_colon PASSED [ 96%] tests/unit/utils_test.py::PortsTest::test_split_port_empty_string PASSED [ 96%] tests/unit/utils_test.py::PortsTest::test_split_port_invalid PASSED [ 97%] tests/unit/utils_test.py::PortsTest::test_split_port_invalid_protocol PASSED [ 97%] tests/unit/utils_test.py::PortsTest::test_split_port_no_host_port PASSED [ 97%] tests/unit/utils_test.py::PortsTest::test_split_port_non_string PASSED [ 97%] tests/unit/utils_test.py::PortsTest::test_split_port_random_port_range_with_host_port PASSED [ 97%] tests/unit/utils_test.py::PortsTest::test_split_port_range_no_host_port PASSED [ 97%] tests/unit/utils_test.py::PortsTest::test_split_port_range_with_host_ip_no_port PASSED [ 98%] tests/unit/utils_test.py::PortsTest::test_split_port_range_with_host_port PASSED [ 98%] tests/unit/utils_test.py::PortsTest::test_split_port_range_with_protocol PASSED [ 98%] tests/unit/utils_test.py::PortsTest::test_split_port_with_host_ip PASSED [ 98%] tests/unit/utils_test.py::PortsTest::test_split_port_with_host_ip_no_port PASSED [ 98%] tests/unit/utils_test.py::PortsTest::test_split_port_with_host_port PASSED [ 98%] tests/unit/utils_test.py::PortsTest::test_split_port_with_ipv6_address PASSED [ 99%] tests/unit/utils_test.py::PortsTest::test_split_port_with_ipv6_square_brackets_address PASSED [ 99%] tests/unit/utils_test.py::PortsTest::test_split_port_with_protocol PASSED [ 99%] tests/unit/utils_test.py::PortsTest::test_with_no_container_port PASSED [ 99%] tests/unit/utils_test.py::FormatEnvironmentTest::test_format_env_binary_unicode_value PASSED [ 99%] collecting ... collected 572 items tests/unit/api_build_test.py::BuildTest::test_build_container PASSED [ 0%] tests/unit/api_build_test.py::BuildTest::test_build_container_custom_context PASSED [ 0%] tests/unit/api_build_test.py::BuildTest::test_build_container_custom_context_gzip PASSED [ 0%] tests/unit/api_build_test.py::BuildTest::test_build_container_invalid_container_limits PASSED [ 0%] tests/unit/api_build_test.py::BuildTest::test_build_container_pull PASSED [ 0%] tests/unit/api_build_test.py::BuildTest::test_build_container_with_container_limits PASSED [ 1%] tests/unit/api_build_test.py::BuildTest::test_build_container_with_named_dockerfile PASSED [ 1%] tests/unit/api_build_test.py::BuildTest::test_build_remote_with_registry_auth PASSED [ 1%] tests/unit/api_build_test.py::BuildTest::test_process_dockerfile PASSED [ 1%] tests/unit/api_build_test.py::BuildTest::test_process_dockerfile_win_longpath_prefix SKIPPED [ 1%] tests/unit/api_build_test.py::BuildTest::test_set_auth_headers_with_dict_and_auth_configs PASSED [ 1%] tests/unit/api_build_test.py::BuildTest::test_set_auth_headers_with_dict_and_no_auth_configs PASSED [ 2%] tests/unit/api_build_test.py::BuildTest::test_set_auth_headers_with_empty_dict_and_auth_configs PASSED [ 2%] tests/unit/api_container_test.py::StartContainerTest::test_start_container PASSED [ 2%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_none PASSED [ 2%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_privileged PASSED [ 2%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_regression_573 PASSED [ 2%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_binds_ro PASSED [ 3%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_binds_rw PASSED [ 3%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_dict_instead_of_id PASSED [ 3%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_links PASSED [ 3%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_links_as_list_of_tuples PASSED [ 3%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_lxc_conf PASSED [ 4%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_lxc_conf_compat PASSED [ 4%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_multiple_links PASSED [ 4%] tests/unit/api_container_test.py::StartContainerTest::test_start_container_with_port_binds PASSED [ 4%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container PASSED [ 4%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_privileged PASSED [ 4%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_added_capabilities PASSED [ 5%] tests/unit/utils_test.py::FormatEnvironmentTest::test_format_env_no_value PASSED [100%] =================================== FAILURES =================================== ____________________________ ImageTest.test_remove _____________________________ tests/unit/models_images_test.py:157: in test_remove client.api.remove_image.assert_called_with(FAKE_IMAGE_ID) /usr/local/lib/python3.7/unittest/mock.py:878: in assert_called_with raise AssertionError(_error_message()) from cause E AssertionError: Expected call: remove_image('e9aa60c60128') E Actual call: remove_image('e9aa60c60128', force=False, noprune=False) ---------- coverage: platform linux, python 3.7.12-final-0 ----------- Name Stmts Miss Branch BrPart Cover ----------------------------------------------------------------------- docker/__init__.py 8 0 0 0 100% docker/api/__init__.py 1 0 0 0 100% docker/api/build.py 126 41 92 21 62% docker/api/client.py 261 65 92 11 75% docker/api/config.py 29 18 4 0 33% docker/api/container.py 265 72 104 25 65% docker/api/daemon.py 39 4 14 4 85% docker/api/exec_api.py 45 11 22 9 67% docker/api/image.py 159 43 60 14 70% docker/api/network.py 90 35 48 11 51% docker/api/plugin.py 89 68 14 0 20% docker/api/secret.py 34 22 8 0 29% docker/api/service.py 200 176 149 0 7% docker/api/swarm.py 106 67 38 1 28% docker/api/volume.py 38 9 14 2 71% docker/auth.py 197 16 74 16 88% docker/client.py 69 9 2 0 87% docker/constants.py 21 0 0 0 100% docker/context/__init__.py 2 0 0 0 100% docker/context/api.py 78 41 38 8 39% docker/context/config.py 61 33 16 2 42% docker/context/context.py 154 96 64 6 29% docker/credentials/__init__.py 3 0 0 0 100% docker/credentials/constants.py 4 0 0 0 100% docker/credentials/errors.py 11 4 2 0 54% docker/credentials/store.py 44 30 12 0 25% docker/credentials/utils.py 23 18 12 0 14% docker/errors.py 110 26 20 4 71% docker/models/__init__.py 0 0 0 0 100% docker/models/configs.py 21 8 2 0 57% docker/models/containers.py 183 11 70 9 91% docker/models/images.py 138 55 56 4 52% docker/models/networks.py 37 7 12 3 71% docker/models/nodes.py 15 5 2 0 59% docker/models/plugins.py 48 29 8 0 34% docker/models/resource.py 41 10 6 3 72% docker/models/secrets.py 22 4 2 0 75% docker/models/services.py 87 35 36 4 59% docker/models/swarm.py 39 21 6 0 40% docker/models/volumes.py 23 10 4 0 48% docker/tls.py 37 6 14 6 76% docker/transport/__init__.py 11 3 0 0 73% docker/transport/basehttpadapter.py 6 0 2 1 88% docker/transport/npipeconn.py 57 52 8 0 8% docker/transport/npipesocket.py 134 130 20 0 3% docker/transport/sshconn.py 162 105 54 3 30% docker/transport/ssladapter.py 36 10 10 4 65% docker/transport/unixconn.py 54 3 6 1 93% docker/types/__init__.py 6 0 0 0 100% docker/types/base.py 4 0 2 0 100% docker/types/containers.py 419 79 326 43 81% docker/types/daemon.py 36 24 14 0 24% docker/types/healthcheck.py 33 20 4 0 35% docker/types/networks.py 41 11 28 9 65% docker/types/services.py 321 146 216 41 50% docker/types/swarm.py 51 45 40 0 7% docker/utils/__init__.py 3 0 0 0 100% docker/utils/build.py 150 24 72 10 83% docker/utils/config.py 36 1 10 1 96% docker/utils/decorators.py 32 1 12 1 95% docker/utils/fnmatch.py 55 18 28 2 61% docker/utils/json_stream.py 40 8 14 2 78% docker/utils/ports.py 50 3 32 2 91% docker/utils/proxy.py 32 1 12 0 98% docker/utils/socket.py 85 10 40 8 84% docker/utils/utils.py 278 18 171 13 92% docker/version.py 2 0 2 0 100% ----------------------------------------------------------------------- TOTAL 5092 1817 2240 304 60% =========================== short test summary info ============================ XFAIL tests/unit/dockertypes_test.py::MountTest::test_parse_mount_bind_windows SKIPPED [1] tests/unit/api_build_test.py:169: Windows-specific syntax SKIPPED [1] tests/unit/client_test.py:99: Npipe Connection Pool only on Windows SKIPPED [1] tests/unit/client_test.py:138: Npipe Connection Pool only on Windows SKIPPED [1] tests/unit/client_test.py:212: Npipe Connection Pool only on Windows SKIPPED [1] tests/unit/client_test.py:249: Npipe Connection Pool only on Windows SKIPPED [1] tests/unit/context_test.py:18: Windows specific path check SKIPPED [1] tests/unit/utils_build_test.py:230: Backslash patterns only on Windows SKIPPED [1] tests/unit/utils_build_test.py:252: Backslash patterns only on Windows SKIPPED [1] tests/unit/utils_build_test.py:400: root user always has access ; no chmod on Windows SKIPPED [1] tests/unit/utils_config_test.py:54: condition: sys.platform != 'win32' ============= 1 failed, 560 passed, 10 skipped, 1 xfailed in 6.32s ============= tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_aliases PASSED [ 5%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds PASSED [ 5%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_list PASSED [ 5%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_mode PASSED [ 5%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_mode_and_ro_error PASSED [ 5%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_ro PASSED [ 6%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_binds_rw PASSED [ 6%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_cgroup_parent PASSED [ 6%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_device_requests PASSED [ 6%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_devices PASSED [ 6%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_dropped_capabilities PASSED [ 6%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_entrypoint PASSED [ 7%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_host_config_cpu_shares PASSED [ 7%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_host_config_cpus PASSED [ 7%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_host_config_cpuset PASSED [ 7%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_host_config_cpuset_mems PASSED [ 7%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_labels_dict PASSED [ 8%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_labels_list PASSED [ 8%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_links PASSED [ 8%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_links_as_list_of_tuples PASSED [ 8%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_lxc_conf PASSED [ 8%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_lxc_conf_compat PASSED [ 8%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mac_address PASSED [ 9%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_int PASSED [ 9%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string PASSED [ 9%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string_with_g_unit PASSED [ 9%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string_with_k_unit PASSED [ 9%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string_with_m_unit PASSED [ 9%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_mem_limit_as_string_with_wrong_value PASSED [ 10%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_multiple_links PASSED [ 10%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_named_volume PASSED [ 10%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_port_binds PASSED [ 10%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_ports PASSED [ 10%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_restart_policy PASSED [ 11%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_stdin_open PASSED [ 11%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_stop_signal PASSED [ 11%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_sysctl PASSED [ 11%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_tmpfs_dict PASSED [ 11%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_tmpfs_list PASSED [ 11%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_unicode_envvars PASSED [ 12%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_volume_string PASSED [ 12%] tests/unit/api_container_test.py::CreateContainerTest::test_create_container_with_working_dir PASSED [ 12%] tests/unit/api_container_test.py::CreateContainerTest::test_create_named_container PASSED [ 12%] tests/unit/api_container_test.py::ContainerTest::test_container_stats PASSED [ 12%] tests/unit/api_container_test.py::ContainerTest::test_container_top PASSED [ 12%] tests/unit/api_container_test.py::ContainerTest::test_container_top_with_psargs PASSED [ 13%] tests/unit/api_container_test.py::ContainerTest::test_container_update PASSED [ 13%] tests/unit/api_container_test.py::ContainerTest::test_diff PASSED [ 13%] tests/unit/api_container_test.py::ContainerTest::test_diff_with_dict_instead_of_id PASSED [ 13%] tests/unit/api_container_test.py::ContainerTest::test_export PASSED [ 13%] tests/unit/api_container_test.py::ContainerTest::test_export_with_dict_instead_of_id PASSED [ 13%] tests/unit/api_container_test.py::ContainerTest::test_inspect_container PASSED [ 14%] tests/unit/api_container_test.py::ContainerTest::test_inspect_container_undefined_id PASSED [ 14%] tests/unit/api_container_test.py::ContainerTest::test_kill_container PASSED [ 14%] tests/unit/api_container_test.py::ContainerTest::test_kill_container_with_dict_instead_of_id PASSED [ 14%] tests/unit/api_container_test.py::ContainerTest::test_kill_container_with_signal PASSED [ 14%] tests/unit/api_container_test.py::ContainerTest::test_list_containers PASSED [ 15%] tests/unit/api_container_test.py::ContainerTest::test_log_following PASSED [ 15%] tests/unit/api_container_test.py::ContainerTest::test_log_following_backwards PASSED [ 15%] tests/unit/api_container_test.py::ContainerTest::test_log_since PASSED [ 15%] tests/unit/api_container_test.py::ContainerTest::test_log_since_with_datetime PASSED [ 15%] tests/unit/api_container_test.py::ContainerTest::test_log_since_with_invalid_value_raises_error PASSED [ 15%] tests/unit/api_container_test.py::ContainerTest::test_log_streaming PASSED [ 16%] tests/unit/api_container_test.py::ContainerTest::test_log_streaming_and_following PASSED [ 16%] tests/unit/api_container_test.py::ContainerTest::test_log_tail PASSED [ 16%] tests/unit/api_container_test.py::ContainerTest::test_log_tty PASSED [ 16%] tests/unit/api_container_test.py::ContainerTest::test_logs PASSED [ 16%] tests/unit/api_container_test.py::ContainerTest::test_logs_with_dict_instead_of_id PASSED [ 16%] tests/unit/api_container_test.py::ContainerTest::test_pause_container PASSED [ 17%] tests/unit/api_container_test.py::ContainerTest::test_port PASSED [ 17%] tests/unit/api_container_test.py::ContainerTest::test_remove_container PASSED [ 17%] tests/unit/api_container_test.py::ContainerTest::test_remove_container_with_dict_instead_of_id PASSED [ 17%] tests/unit/api_container_test.py::ContainerTest::test_rename_container PASSED [ 17%] tests/unit/api_container_test.py::ContainerTest::test_resize_container PASSED [ 18%] tests/unit/api_container_test.py::ContainerTest::test_restart_container PASSED [ 18%] tests/unit/api_container_test.py::ContainerTest::test_restart_container_with_dict_instead_of_id PASSED [ 18%] tests/unit/api_container_test.py::ContainerTest::test_stop_container PASSED [ 18%] tests/unit/api_container_test.py::ContainerTest::test_stop_container_with_dict_instead_of_id PASSED [ 18%] tests/unit/api_container_test.py::ContainerTest::test_unpause_container PASSED [ 18%] tests/unit/api_container_test.py::ContainerTest::test_wait PASSED [ 19%] tests/unit/api_container_test.py::ContainerTest::test_wait_with_dict_instead_of_id PASSED [ 19%] tests/unit/api_exec_test.py::ExecTest::test_exec_create PASSED [ 19%] tests/unit/api_exec_test.py::ExecTest::test_exec_inspect PASSED [ 19%] tests/unit/api_exec_test.py::ExecTest::test_exec_resize PASSED [ 19%] tests/unit/api_exec_test.py::ExecTest::test_exec_start PASSED [ 19%] tests/unit/utils_test.py::FormatEnvironmentTest::test_format_env_no_value PASSED [100%] =================================== FAILURES =================================== ____________________________ ImageTest.test_remove _____________________________ tests/unit/models_images_test.py:157: in test_remove client.api.remove_image.assert_called_with(FAKE_IMAGE_ID) /usr/local/lib/python3.7/unittest/mock.py:878: in assert_called_with raise AssertionError(_error_message()) from cause E AssertionError: Expected call: remove_image('e9aa60c60128') E Actual call: remove_image('e9aa60c60128', force=False, noprune=False) ---------- coverage: platform linux, python 3.7.12-final-0 ----------- Name Stmts Miss Branch BrPart Cover ----------------------------------------------------------------------- docker/__init__.py 8 0 0 0 100% docker/api/__init__.py 1 0 0 0 100% docker/api/build.py 126 41 92 21 62% docker/api/client.py 261 65 92 11 75% docker/api/config.py 29 18 4 0 33% docker/api/container.py 265 72 104 25 65% docker/api/daemon.py 39 4 14 4 85% docker/api/exec_api.py 45 11 22 9 67% docker/api/image.py 159 43 60 14 70% docker/api/network.py 90 35 48 11 51% docker/api/plugin.py 89 68 14 0 20% docker/api/secret.py 34 22 8 0 29% docker/api/service.py 200 176 149 0 7% docker/api/swarm.py 106 67 38 1 28% docker/api/volume.py 38 9 14 2 71% docker/auth.py 197 16 74 16 88% docker/client.py 69 9 2 0 87% docker/constants.py 21 0 0 0 100% docker/context/__init__.py 2 0 0 0 100% docker/context/api.py 78 41 38 8 39% docker/context/config.py 61 33 16 2 42% docker/context/context.py 154 96 64 6 29% docker/credentials/__init__.py 3 0 0 0 100% docker/credentials/constants.py 4 0 0 0 100% docker/credentials/errors.py 11 4 2 0 54% docker/credentials/store.py 44 30 12 0 25% docker/credentials/utils.py 23 18 12 0 14% docker/errors.py 110 26 20 4 71% docker/models/__init__.py 0 0 0 0 100% docker/models/configs.py 21 8 2 0 57% docker/models/containers.py 183 11 70 9 91% docker/models/images.py 138 55 56 4 52% docker/models/networks.py 37 7 12 3 71% docker/models/nodes.py 15 5 2 0 59% docker/models/plugins.py 48 29 8 0 34% docker/models/resource.py 41 10 6 3 72% docker/models/secrets.py 22 4 2 0 75% docker/models/services.py 87 35 36 4 59% docker/models/swarm.py 39 21 6 0 40% docker/models/volumes.py 23 10 4 0 48% docker/tls.py 37 6 14 6 76% docker/transport/__init__.py 11 3 0 0 73% docker/transport/basehttpadapter.py 6 0 2 1 88% docker/transport/npipeconn.py 57 52 8 0 8% docker/transport/npipesocket.py 134 130 20 0 3% docker/transport/sshconn.py 162 105 54 3 30% docker/transport/ssladapter.py 36 10 10 4 65% docker/transport/unixconn.py 54 3 6 1 93% docker/types/__init__.py 6 0 0 0 100% docker/types/base.py 4 0 2 0 100% docker/types/containers.py 419 79 326 43 81% docker/types/daemon.py 36 24 14 0 24% docker/types/healthcheck.py 33 20 4 0 35% docker/types/networks.py 41 11 28 9 65% docker/types/services.py 321 146 216 41 50% docker/types/swarm.py 51 45 40 0 7% docker/utils/__init__.py 3 0 0 0 100% docker/utils/build.py 150 24 72 10 83% docker/utils/config.py 36 1 10 1 96% docker/utils/decorators.py 32 1 12 1 95% docker/utils/fnmatch.py 55 18 28 2 61% docker/utils/json_stream.py 40 8 14 2 78% docker/utils/ports.py 50 3 32 2 91% docker/utils/proxy.py 32 1 12 0 98% docker/utils/socket.py 85 10 40 8 84% docker/utils/utils.py 278 18 171 13 92% docker/version.py 2 0 2 0 100% ----------------------------------------------------------------------- TOTAL 5092 1817 2240 304 60% =========================== short test summary info ============================ XFAIL tests/unit/dockertypes_test.py::MountTest::test_parse_mount_bind_windows SKIPPED [1] tests/unit/api_build_test.py:169: Windows-specific syntax SKIPPED [1] tests/unit/client_test.py:99: Npipe Connection Pool only on Windows SKIPPED [1] tests/unit/client_test.py:138: Npipe Connection Pool only on Windows SKIPPED [1] tests/unit/client_test.py:212: Npipe Connection Pool only on Windows SKIPPED [1] tests/unit/client_test.py:249: Npipe Connection Pool only on Windows SKIPPED [1] tests/unit/context_test.py:18: Windows specific path check SKIPPED [1] tests/unit/utils_build_test.py:230: Backslash patterns only on Windows SKIPPED [1] tests/unit/utils_build_test.py:252: Backslash patterns only on Windows SKIPPED [1] tests/unit/utils_build_test.py:400: root user always has access ; no chmod on Windows SKIPPED [1] tests/unit/utils_config_test.py:54: condition: sys.platform != 'win32' ============= 1 failed, 560 passed, 10 skipped, 1 xfailed in 6.32s ============= [Pipeline] sh tests/unit/api_exec_test.py::ExecTest::test_exec_start_detached PASSED [ 20%] tests/unit/api_image_test.py::ImageTest::test_commit PASSED [ 20%] tests/unit/api_image_test.py::ImageTest::test_get_image PASSED [ 20%] tests/unit/api_image_test.py::ImageTest::test_image_history PASSED [ 20%] tests/unit/api_image_test.py::ImageTest::test_image_ids PASSED [ 20%] tests/unit/api_image_test.py::ImageTest::test_image_viz PASSED [ 20%] tests/unit/api_image_test.py::ImageTest::test_images PASSED [ 21%] tests/unit/api_image_test.py::ImageTest::test_images_filters PASSED [ 21%] tests/unit/api_image_test.py::ImageTest::test_images_name PASSED [ 21%] tests/unit/api_image_test.py::ImageTest::test_images_quiet PASSED [ 21%] tests/unit/api_image_test.py::ImageTest::test_import_image PASSED [ 21%] tests/unit/api_image_test.py::ImageTest::test_import_image_from_bytes PASSED [ 22%] tests/unit/api_image_test.py::ImageTest::test_import_image_from_image PASSED [ 22%] tests/unit/api_image_test.py::ImageTest::test_inspect_image PASSED [ 22%] tests/unit/api_image_test.py::ImageTest::test_inspect_image_undefined_id PASSED [ 22%] tests/unit/api_image_test.py::ImageTest::test_load_image PASSED [ 22%] tests/unit/api_image_test.py::ImageTest::test_load_image_quiet PASSED [ 22%] tests/unit/api_image_test.py::ImageTest::test_pull PASSED [ 23%] tests/unit/api_image_test.py::ImageTest::test_pull_stream PASSED [ 23%] tests/unit/api_image_test.py::ImageTest::test_push_image PASSED [ 23%] tests/unit/api_image_test.py::ImageTest::test_push_image_stream PASSED [ 23%] tests/unit/api_image_test.py::ImageTest::test_push_image_with_auth PASSED [ 23%] tests/unit/api_image_test.py::ImageTest::test_push_image_with_tag PASSED [ 23%] tests/unit/api_image_test.py::ImageTest::test_remove_image PASSED [ 24%] tests/unit/api_image_test.py::ImageTest::test_tag_image PASSED [ 24%] tests/unit/api_image_test.py::ImageTest::test_tag_image_force PASSED [ 24%] tests/unit/api_image_test.py::ImageTest::test_tag_image_tag PASSED [ 24%] tests/unit/api_network_test.py::NetworkTest::test_connect_container_to_network PASSED [ 24%] tests/unit/api_network_test.py::NetworkTest::test_create_network PASSED [ 25%] tests/unit/api_network_test.py::NetworkTest::test_disconnect_container_from_network PASSED [ 25%] tests/unit/api_network_test.py::NetworkTest::test_inspect_network PASSED [ 25%] tests/unit/api_network_test.py::NetworkTest::test_list_networks PASSED [ 25%] tests/unit/api_network_test.py::NetworkTest::test_remove_network PASSED [ 25%] tests/unit/api_test.py::DockerApiTest::test_auto_retrieve_server_version PASSED [ 25%] tests/unit/api_test.py::DockerApiTest::test_create_host_config_secopt PASSED [ 26%] tests/unit/api_test.py::DockerApiTest::test_ctor PASSED [ 26%] tests/unit/api_test.py::DockerApiTest::test_events PASSED [ 26%] tests/unit/api_test.py::DockerApiTest::test_events_with_filters PASSED [ 26%] tests/unit/api_test.py::DockerApiTest::test_events_with_since_until PASSED [ 26%] tests/unit/api_test.py::DockerApiTest::test_info PASSED [ 26%] tests/unit/api_test.py::DockerApiTest::test_login PASSED [ 27%] tests/unit/api_test.py::DockerApiTest::test_remove_link PASSED [ 27%] tests/unit/api_test.py::DockerApiTest::test_retrieve_server_version PASSED [ 27%] tests/unit/api_test.py::DockerApiTest::test_search PASSED [ 27%] tests/unit/api_test.py::DockerApiTest::test_stream_helper_decoding PASSED [ 27%] tests/unit/api_test.py::DockerApiTest::test_url_compatibility_http PASSED [ 27%] tests/unit/api_test.py::DockerApiTest::test_url_compatibility_http_unix_triple_slash PASSED [ 28%] tests/unit/api_test.py::DockerApiTest::test_url_compatibility_tcp PASSED [ 28%] tests/unit/api_test.py::DockerApiTest::test_url_compatibility_unix PASSED [ 28%] tests/unit/api_test.py::DockerApiTest::test_url_compatibility_unix_triple_slash PASSED [ 28%] tests/unit/api_test.py::DockerApiTest::test_url_invalid_resource PASSED [ 28%] tests/unit/api_test.py::DockerApiTest::test_url_no_resource PASSED [ 29%] tests/unit/api_test.py::DockerApiTest::test_url_unversioned_api PASSED [ 29%] tests/unit/api_test.py::DockerApiTest::test_url_valid_resource PASSED [ 29%] tests/unit/api_test.py::DockerApiTest::test_version PASSED [ 29%] tests/unit/api_test.py::DockerApiTest::test_version_no_api_version PASSED [ 29%] tests/unit/api_test.py::UnixSocketStreamTest::test_early_stream_response PASSED [ 29%] [Pipeline] sh tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_stream_no_tty PASSED [ 30%] + docker stop dpy-dind-1-0-py3.7-20.10.9 Error response from daemon: No such container: dpy-dind-1-0-py3.7-20.10.9 [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.9 + docker stop dpy-dind-1-0-py3.7-19.03.12 Error response from daemon: No such container: dpy-dind-1-0-py3.7-19.03.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_19.03.12 tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_stream_no_tty_demux PASSED [ 30%] tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_stream_tty PASSED [ 30%] tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_stream_tty_demux PASSED [ 30%] tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_tty PASSED [ 30%] tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_no_tty_demux PASSED [ 30%] tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_tty PASSED [ 31%] tests/unit/api_test.py::TCPSocketStreamTest::test_read_from_socket_tty_demux PASSED [ 31%] tests/unit/api_test.py::UserAgentTest::test_custom_user_agent PASSED [ 31%] tests/unit/api_test.py::UserAgentTest::test_default_user_agent PASSED [ 31%] tests/unit/api_test.py::DisableSocketTest::test_disable_socket_timeout PASSED [ 31%] tests/unit/api_test.py::DisableSocketTest::test_disable_socket_timeout2 PASSED [ 31%] tests/unit/api_test.py::DisableSocketTest::test_disable_socket_timout_non_blocking PASSED [ 32%] tests/unit/api_volume_test.py::VolumeTest::test_create_volume PASSED [ 32%] tests/unit/api_volume_test.py::VolumeTest::test_create_volume_invalid_opts_type PASSED [ 32%] tests/unit/api_volume_test.py::VolumeTest::test_create_volume_with_driver PASSED [ 32%] tests/unit/api_volume_test.py::VolumeTest::test_create_volume_with_invalid_labels PASSED [ 32%] tests/unit/api_volume_test.py::VolumeTest::test_create_volume_with_labels PASSED [ 33%] tests/unit/api_volume_test.py::VolumeTest::test_create_volume_with_no_specified_name PASSED [ 33%] tests/unit/api_volume_test.py::VolumeTest::test_inspect_volume PASSED [ 33%] tests/unit/api_volume_test.py::VolumeTest::test_list_volumes PASSED [ 33%] tests/unit/api_volume_test.py::VolumeTest::test_list_volumes_and_filters PASSED [ 33%] tests/unit/api_volume_test.py::VolumeTest::test_remove_volume PASSED [ 33%] tests/unit/auth_test.py::RegressionTest::test_803_urlsafe_encode PASSED [ 34%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_explicit_hub_index_library_image PASSED [ 34%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_explicit_legacy_hub_index_library_image PASSED [ 34%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_invalid_index_name PASSED [ 34%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_dotted_hub_library_image PASSED [ 34%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_hub_image PASSED [ 34%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_hub_library_image PASSED [ 35%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_localhost PASSED [ 35%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_localhost_with_username PASSED [ 35%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_no_dots_but_port PASSED [ 35%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_no_dots_but_port_and_username PASSED [ 35%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_private_registry PASSED [ 36%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_private_registry_with_port PASSED [ 36%] tests/unit/auth_test.py::ResolveRepositoryNameTest::test_resolve_repository_name_private_registry_with_username PASSED [ 36%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_auth_with_empty_credstore_and_auth_dict PASSED [ 36%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_default_explicit_none PASSED [ 36%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_default_registry PASSED [ 36%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_fully_explicit PASSED [ 37%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_hostname_only PASSED [ 37%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_legacy_config PASSED [ 37%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_match PASSED [ 37%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_path PASSED [ 37%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_path_trailing_slash PASSED [ 37%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_path_wrong_insecure_proto PASSED [ 38%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_path_wrong_secure_proto PASSED [ 38%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_no_protocol PASSED [ 38%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_authconfig_path_wrong_proto PASSED [ 38%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_explicit_hub PASSED [ 38%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_explicit_legacy_hub PASSED [ 38%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_hub_image PASSED [ 39%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_library_image PASSED [ 39%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_private_registry PASSED [ 39%] tests/unit/auth_test.py::ResolveAuthTest::test_resolve_registry_and_auth_unauthenticated_registry PASSED [ 39%] tests/unit/auth_test.py::LoadConfigTest::test_load_config_custom_config_env PASSED [ 39%] tests/unit/auth_test.py::LoadConfigTest::test_load_config_custom_config_env_utf8 PASSED [ 40%] tests/unit/auth_test.py::LoadConfigTest::test_load_config_custom_config_env_with_auths PASSED [ 40%] tests/unit/auth_test.py::LoadConfigTest::test_load_config_identity_token PASSED [ 40%] tests/unit/auth_test.py::LoadConfigTest::test_load_config_invalid_auth_dict PASSED [ 40%] tests/unit/auth_test.py::LoadConfigTest::test_load_config_no_file PASSED [ 40%] tests/unit/auth_test.py::LoadConfigTest::test_load_config_unknown_keys PASSED [ 40%] tests/unit/auth_test.py::LoadConfigTest::test_load_config_with_random_name PASSED [ 41%] tests/unit/auth_test.py::LoadConfigTest::test_load_json_config PASSED [ 41%] tests/unit/auth_test.py::LoadConfigTest::test_load_legacy_config PASSED [ 41%] tests/unit/auth_test.py::LoadConfigTest::test_load_modern_json_config PASSED [ 41%] tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_3_sources PASSED [ 41%] tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_credstore_only PASSED [ 41%] tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_credstore_overrides_auth_entry PASSED [ 42%] tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_helpers_override_default PASSED [ 42%] tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_with_auths_entries PASSED [ 42%] tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_with_credhelpers_only PASSED [ 42%] tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_with_empty_auths_entry PASSED [ 42%] tests/unit/auth_test.py::CredstoreTest::test_get_all_credentials_with_empty_credhelper PASSED [ 43%] tests/unit/auth_test.py::CredstoreTest::test_get_credential_store PASSED [ 43%] tests/unit/auth_test.py::CredstoreTest::test_get_credential_store_default_index PASSED [ 43%] tests/unit/auth_test.py::CredstoreTest::test_get_credential_store_no_default PASSED [ 43%] tests/unit/auth_test.py::CredstoreTest::test_get_credential_store_with_plain_dict PASSED [ 43%] tests/unit/client_test.py::ClientTest::test_call_api_client_method PASSED [ 43%] tests/unit/client_test.py::ClientTest::test_call_containers PASSED [ 44%] tests/unit/client_test.py::ClientTest::test_default_pool_size_unix PASSED [ 44%] tests/unit/client_test.py::ClientTest::test_default_pool_size_win SKIPPED [ 44%] tests/unit/client_test.py::ClientTest::test_events PASSED [ 44%] tests/unit/client_test.py::ClientTest::test_info PASSED [ 44%] tests/unit/client_test.py::ClientTest::test_ping PASSED [ 44%] tests/unit/client_test.py::ClientTest::test_pool_size_unix PASSED [ 45%] tests/unit/client_test.py::ClientTest::test_pool_size_win SKIPPED (N...) [ 45%] tests/unit/client_test.py::ClientTest::test_version PASSED [ 45%] tests/unit/client_test.py::FromEnvTest::test_default_pool_size_from_env_unix PASSED [ 45%] tests/unit/client_test.py::FromEnvTest::test_default_pool_size_from_env_win SKIPPED [ 45%] tests/unit/client_test.py::FromEnvTest::test_from_env PASSED [ 45%] tests/unit/client_test.py::FromEnvTest::test_from_env_with_version PASSED [ 46%] tests/unit/client_test.py::FromEnvTest::test_from_env_without_timeout_uses_default PASSED [ 46%] tests/unit/client_test.py::FromEnvTest::test_from_env_without_version_uses_default PASSED [ 46%] tests/unit/client_test.py::FromEnvTest::test_pool_size_from_env_unix PASSED [ 46%] tests/unit/client_test.py::FromEnvTest::test_pool_size_from_env_win SKIPPED [ 46%] tests/unit/context_test.py::BaseContextTest::test_context_inspect_without_params PASSED [ 47%] tests/unit/context_test.py::BaseContextTest::test_default_in_context_list PASSED [ 47%] tests/unit/context_test.py::BaseContextTest::test_fail_on_default_context_create PASSED [ 47%] tests/unit/context_test.py::BaseContextTest::test_get_current_context PASSED [ 47%] tests/unit/context_test.py::BaseContextTest::test_https_host PASSED [ 47%] tests/unit/context_test.py::BaseContextTest::test_url_compatibility_on_linux PASSED [ 47%] tests/unit/context_test.py::BaseContextTest::test_url_compatibility_on_windows SKIPPED [ 48%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_cpu_cfs_types PASSED [ 48%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_cpu_count_types PASSED [ 48%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_cpu_percent_types PASSED [ 48%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_mem_swappiness PASSED [ 48%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_invalid_nano_cpus_types PASSED [ 48%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_no_options_newer_api_version PASSED [ 49%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_pid_mode PASSED [ 49%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_blkio_constraints PASSED [ 49%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_count PASSED [ 49%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_percent PASSED [ 49%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_period PASSED [ 50%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_quota PASSED [ 50%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_rt_period PASSED [ 50%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_rt_period_types PASSED [ 50%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_cpu_rt_runtime PASSED [ 50%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_dns_opt PASSED [ 50%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_isolation PASSED [ 51%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_kernel_memory PASSED [ 51%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_mem_reservation PASSED [ 51%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_nano_cpus PASSED [ 51%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_oom_kill_disable PASSED [ 51%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_oom_score_adj PASSED [ 51%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_pids_limit PASSED [ 52%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_shm_size PASSED [ 52%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_shm_size_in_mb PASSED [ 52%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_userns_mode PASSED [ 52%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_uts PASSED [ 52%] tests/unit/dockertypes_test.py::HostConfigTest::test_create_host_config_with_volume_driver PASSED [ 52%] tests/unit/dockertypes_test.py::HostConfigTest::test_ctrate_host_config_with_cpu_rt_runtime_types PASSED [ 53%] tests/unit/dockertypes_test.py::ContainerSpecTest::test_parse_mounts PASSED [ 53%] tests/unit/dockertypes_test.py::UlimitTest::test_create_host_config_dict_ulimit PASSED [ 53%] tests/unit/dockertypes_test.py::UlimitTest::test_create_host_config_dict_ulimit_capitals PASSED [ 53%] tests/unit/dockertypes_test.py::UlimitTest::test_create_host_config_obj_ulimit PASSED [ 53%] tests/unit/dockertypes_test.py::UlimitTest::test_ulimit_invalid_type PASSED [ 54%] tests/unit/dockertypes_test.py::LogConfigTest::test_create_host_config_dict_logconfig PASSED [ 54%] tests/unit/dockertypes_test.py::LogConfigTest::test_create_host_config_obj_logconfig PASSED [ 54%] tests/unit/dockertypes_test.py::LogConfigTest::test_logconfig_invalid_config_type PASSED [ 54%] tests/unit/dockertypes_test.py::EndpointConfigTest::test_create_endpoint_config_with_aliases PASSED [ 54%] tests/unit/dockertypes_test.py::IPAMConfigTest::test_create_ipam_config PASSED [ 54%] tests/unit/dockertypes_test.py::ServiceModeTest::test_global_replicas_error PASSED [ 55%] tests/unit/dockertypes_test.py::ServiceModeTest::test_global_simple PASSED [ 55%] tests/unit/dockertypes_test.py::ServiceModeTest::test_invalid_mode PASSED [ 55%] tests/unit/dockertypes_test.py::ServiceModeTest::test_replicated_replicas PASSED [ 55%] tests/unit/dockertypes_test.py::ServiceModeTest::test_replicated_replicas_0 PASSED [ 55%] tests/unit/dockertypes_test.py::ServiceModeTest::test_replicated_simple PASSED [ 55%] tests/unit/dockertypes_test.py::MountTest::test_parse_mount_bind PASSED [ 56%] tests/unit/dockertypes_test.py::MountTest::test_parse_mount_bind_windows XFAIL [ 56%] tests/unit/dockertypes_test.py::MountTest::test_parse_mount_named_volume PASSED [ 56%] tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_invalid PASSED [ 56%] tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_no_source PASSED [ 56%] tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_ro PASSED [ 56%] tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_rw PASSED [ 57%] tests/unit/dockertypes_test.py::MountTest::test_parse_mount_string_short_form PASSED [ 57%] tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_invalid PASSED [ 57%] tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_multiple PASSED [ 57%] tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_no_protocol_and_mode PASSED [ 57%] tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_simple PASSED [ 58%] tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_with_protocol PASSED [ 58%] tests/unit/dockertypes_test.py::ServicePortsTest::test_convert_service_ports_with_protocol_and_mode PASSED [ 58%] tests/unit/errors_test.py::APIErrorTest::test_api_error_is_caught_by_dockerexception PASSED [ 58%] tests/unit/errors_test.py::APIErrorTest::test_create_error_from_exception PASSED [ 58%] tests/unit/errors_test.py::APIErrorTest::test_is_client_error_400 PASSED [ 58%] tests/unit/errors_test.py::APIErrorTest::test_is_client_error_500 PASSED [ 59%] tests/unit/errors_test.py::APIErrorTest::test_is_error_300 PASSED [ 59%] tests/unit/errors_test.py::APIErrorTest::test_is_error_400 PASSED [ 59%] tests/unit/errors_test.py::APIErrorTest::test_is_error_500 PASSED [ 59%] tests/unit/errors_test.py::APIErrorTest::test_is_server_error_200 PASSED [ 59%] tests/unit/errors_test.py::APIErrorTest::test_is_server_error_300 PASSED [ 59%] tests/unit/errors_test.py::APIErrorTest::test_is_server_error_400 PASSED [ 60%] tests/unit/errors_test.py::APIErrorTest::test_is_server_error_500 PASSED [ 60%] tests/unit/errors_test.py::APIErrorTest::test_status_code_200 PASSED [ 60%] tests/unit/errors_test.py::APIErrorTest::test_status_code_400 PASSED [ 60%] tests/unit/errors_test.py::APIErrorTest::test_status_code_500 PASSED [ 60%] tests/unit/errors_test.py::ContainerErrorTest::test_container_with_stderr PASSED [ 61%] tests/unit/errors_test.py::ContainerErrorTest::test_container_without_stderr PASSED [ 61%] tests/unit/errors_test.py::CreateUnexpectedKwargsErrorTest::test_create_unexpected_kwargs_error_multiple PASSED [ 61%] tests/unit/errors_test.py::CreateUnexpectedKwargsErrorTest::test_create_unexpected_kwargs_error_single PASSED [ 61%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_create PASSED [ 61%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_create_container_args PASSED [ 61%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_create_with_image_object PASSED [ 62%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_get PASSED [ 62%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_list PASSED [ 62%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_list_ignore_removed PASSED [ 62%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_run PASSED [ 62%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_detach PASSED [ 62%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_pull PASSED [ 63%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_remove PASSED [ 63%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_with_error PASSED [ 63%] tests/unit/models_containers_test.py::ContainerCollectionTest::test_run_with_image_object PASSED [ 63%] tests/unit/models_containers_test.py::ContainerTest::test_attach PASSED [ 63%] tests/unit/models_containers_test.py::ContainerTest::test_commit PASSED [ 63%] tests/unit/models_containers_test.py::ContainerTest::test_diff PASSED [ 64%] tests/unit/models_containers_test.py::ContainerTest::test_exec_run PASSED [ 64%] tests/unit/models_containers_test.py::ContainerTest::test_exec_run_failure PASSED [ 64%] tests/unit/models_containers_test.py::ContainerTest::test_export PASSED [ 64%] tests/unit/models_containers_test.py::ContainerTest::test_get_archive PASSED [ 64%] tests/unit/models_containers_test.py::ContainerTest::test_image PASSED [ 65%] tests/unit/models_containers_test.py::ContainerTest::test_kill PASSED [ 65%] tests/unit/models_containers_test.py::ContainerTest::test_labels PASSED [ 65%] tests/unit/models_containers_test.py::ContainerTest::test_logs PASSED [ 65%] tests/unit/models_containers_test.py::ContainerTest::test_name PASSED [ 65%] tests/unit/models_containers_test.py::ContainerTest::test_pause PASSED [ 65%] tests/unit/models_containers_test.py::ContainerTest::test_put_archive PASSED [ 66%] tests/unit/models_containers_test.py::ContainerTest::test_remove PASSED [ 66%] tests/unit/models_containers_test.py::ContainerTest::test_rename PASSED [ 66%] tests/unit/models_containers_test.py::ContainerTest::test_resize PASSED [ 66%] tests/unit/models_containers_test.py::ContainerTest::test_restart PASSED [ 66%] tests/unit/models_containers_test.py::ContainerTest::test_start PASSED [ 66%] tests/unit/models_containers_test.py::ContainerTest::test_stats PASSED [ 67%] tests/unit/models_containers_test.py::ContainerTest::test_status PASSED [ 67%] tests/unit/models_containers_test.py::ContainerTest::test_stop PASSED [ 67%] tests/unit/models_containers_test.py::ContainerTest::test_top PASSED [ 67%] tests/unit/models_containers_test.py::ContainerTest::test_unpause PASSED [ 67%] tests/unit/models_containers_test.py::ContainerTest::test_update PASSED [ 68%] tests/unit/models_containers_test.py::ContainerTest::test_wait PASSED [ 68%] tests/unit/models_images_test.py::ImageCollectionTest::test_build PASSED [ 68%] tests/unit/models_images_test.py::ImageCollectionTest::test_get PASSED [ 68%] tests/unit/models_images_test.py::ImageCollectionTest::test_labels PASSED [ 68%] tests/unit/models_images_test.py::ImageCollectionTest::test_list PASSED [ 68%] tests/unit/models_images_test.py::ImageCollectionTest::test_load PASSED [ 69%] tests/unit/models_images_test.py::ImageCollectionTest::test_pull PASSED [ 69%] tests/unit/models_images_test.py::ImageCollectionTest::test_pull_multiple PASSED [ 69%] tests/unit/models_images_test.py::ImageCollectionTest::test_pull_tag_precedence PASSED [ 69%] tests/unit/models_images_test.py::ImageCollectionTest::test_pull_with_stream_param PASSED [ 69%] tests/unit/models_images_test.py::ImageCollectionTest::test_push PASSED [ 69%] tests/unit/models_images_test.py::ImageCollectionTest::test_remove PASSED [ 70%] tests/unit/models_images_test.py::ImageCollectionTest::test_search PASSED [ 70%] tests/unit/models_images_test.py::ImageCollectionTest::test_search_limit PASSED [ 70%] tests/unit/models_images_test.py::ImageTest::test_history PASSED [ 70%] tests/unit/models_images_test.py::ImageTest::test_remove FAILED [ 70%] tests/unit/models_images_test.py::ImageTest::test_save PASSED [ 70%] tests/unit/models_images_test.py::ImageTest::test_short_id PASSED [ 71%] tests/unit/models_images_test.py::ImageTest::test_tag PASSED [ 71%] tests/unit/models_images_test.py::ImageTest::test_tags PASSED [ 71%] tests/unit/models_networks_test.py::NetworkCollectionTest::test_create PASSED [ 71%] tests/unit/models_networks_test.py::NetworkCollectionTest::test_get PASSED [ 71%] tests/unit/models_networks_test.py::NetworkCollectionTest::test_list PASSED [ 72%] tests/unit/models_networks_test.py::NetworkTest::test_connect PASSED [ 72%] tests/unit/models_networks_test.py::NetworkTest::test_disconnect PASSED [ 72%] tests/unit/models_networks_test.py::NetworkTest::test_remove PASSED [ 72%] tests/unit/models_resources_test.py::ModelTest::test_hash PASSED [ 72%] tests/unit/models_resources_test.py::ModelTest::test_reload PASSED [ 72%] tests/unit/models_secrets_test.py::CreateServiceTest::test_secrets_repr PASSED [ 73%] tests/unit/models_services_test.py::CreateServiceKwargsTest::test_get_create_service_kwargs PASSED [ 73%] tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_hostname_prefix_trim PASSED [ 73%] tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_hostname_and_port PASSED [ 73%] tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_hostname_only PASSED [ 73%] tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_url PASSED [ 73%] tests/unit/sshadapter_test.py::SSHAdapterTest::test_ssh_parse_user_and_hostname PASSED [ 74%] tests/unit/ssladapter_test.py::SSLAdapterTest::test_only_uses_tls PASSED [ 74%] tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_dns_failure PASSED [ 74%] tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_dns_success PASSED [ 74%] tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_ip_address_failure PASSED [ 74%] tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_ip_address_success PASSED [ 75%] tests/unit/ssladapter_test.py::MatchHostnameTest::test_match_localhost_success PASSED [ 75%] tests/unit/swarm_test.py::SwarmTest::test_join_swarm PASSED [ 75%] tests/unit/swarm_test.py::SwarmTest::test_join_swarm_no_listen_address_takes_default PASSED [ 75%] tests/unit/swarm_test.py::SwarmTest::test_node_update PASSED [ 75%] tests/unit/types_containers_test.py::test_uid_0_is_not_elided PASSED [ 75%] tests/unit/utils_build_test.py::ExcludePathsTest::test_directory PASSED [ 76%] tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_single_exception PASSED [ 76%] tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_subdir_exception PASSED [ 76%] tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_subdir_exception_win32_pathsep SKIPPED [ 76%] tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_trailing_slash PASSED [ 76%] tests/unit/utils_build_test.py::ExcludePathsTest::test_directory_with_wildcard_exception PASSED [ 76%] tests/unit/utils_build_test.py::ExcludePathsTest::test_double_wildcard PASSED [ 77%] tests/unit/utils_build_test.py::ExcludePathsTest::test_double_wildcard_with_exception PASSED [ 77%] tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_custom_dockerfile PASSED [ 77%] tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_dockerfile_child PASSED [ 77%] tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_dockerfile_dockerignore PASSED [ 77%] tests/unit/utils_build_test.py::ExcludePathsTest::test_exclude_include_absolute_path PASSED [ 77%] tests/unit/utils_build_test.py::ExcludePathsTest::test_include_wildcard PASSED [ 78%] tests/unit/utils_build_test.py::ExcludePathsTest::test_last_line_precedence PASSED [ 78%] tests/unit/utils_build_test.py::ExcludePathsTest::test_no_dupes PASSED [ 78%] tests/unit/utils_build_test.py::ExcludePathsTest::test_no_excludes PASSED [ 78%] tests/unit/utils_build_test.py::ExcludePathsTest::test_parent_directory PASSED [ 78%] tests/unit/utils_build_test.py::ExcludePathsTest::test_question_mark PASSED [ 79%] tests/unit/utils_build_test.py::ExcludePathsTest::test_single_and_double_wildcard PASSED [ 79%] tests/unit/utils_build_test.py::ExcludePathsTest::test_single_filename PASSED [ 79%] tests/unit/utils_build_test.py::ExcludePathsTest::test_single_filename_leading_dot_slash PASSED [ 79%] tests/unit/utils_build_test.py::ExcludePathsTest::test_single_filename_trailing_slash PASSED [ 79%] tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_single_filename PASSED [ 79%] tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_single_filename_leading_slash PASSED [ 80%] tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_wildcard_filename PASSED [ 80%] tests/unit/utils_build_test.py::ExcludePathsTest::test_single_subdir_with_path_traversal PASSED [ 80%] tests/unit/utils_build_test.py::ExcludePathsTest::test_subdirectory PASSED [ 80%] tests/unit/utils_build_test.py::ExcludePathsTest::test_subdirectory_win32_pathsep SKIPPED [ 80%] tests/unit/utils_build_test.py::ExcludePathsTest::test_trailing_double_wildcard PASSED [ 80%] tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_exclude PASSED [ 81%] tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_filename_end PASSED [ 81%] tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_filename_start PASSED [ 81%] tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_subdir_single_filename PASSED [ 81%] tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_subdir_wildcard_filename PASSED [ 81%] tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_with_exception PASSED [ 81%] tests/unit/utils_build_test.py::ExcludePathsTest::test_wildcard_with_wildcard_exception PASSED [ 82%] tests/unit/utils_build_test.py::TarTest::test_tar_directory_link PASSED [ 82%] tests/unit/utils_build_test.py::TarTest::test_tar_socket_file PASSED [ 82%] tests/unit/utils_build_test.py::TarTest::test_tar_with_broken_symlinks PASSED [ 82%] tests/unit/utils_build_test.py::TarTest::test_tar_with_directory_symlinks PASSED [ 82%] tests/unit/utils_build_test.py::TarTest::test_tar_with_empty_directory PASSED [ 83%] tests/unit/utils_build_test.py::TarTest::test_tar_with_excludes PASSED [ 83%] tests/unit/utils_build_test.py::TarTest::test_tar_with_file_symlinks PASSED [ 83%] tests/unit/utils_build_test.py::TarTest::test_tar_with_inaccessible_file SKIPPED [ 83%] tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_fallback PASSED [ 83%] tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_environment PASSED [ 83%] tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_explicit_path PASSED [ 84%] tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_home_legacy_name PASSED [ 84%] tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_home_posix PASSED [ 84%] tests/unit/utils_config_test.py::FindConfigFileTest::test_find_config_from_home_windows SKIPPED [ 84%] tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_custom_headers PASSED [ 84%] tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_detach_keys PASSED [ 84%] tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_from_env PASSED [ 85%] tests/unit/utils_config_test.py::LoadConfigTest::test_load_config_no_file PASSED [ 85%] tests/unit/utils_json_stream_test.py::TestJsonSplitter::test_json_splitter_no_object PASSED [ 85%] tests/unit/utils_json_stream_test.py::TestJsonSplitter::test_json_splitter_with_object PASSED [ 85%] tests/unit/utils_json_stream_test.py::TestJsonSplitter::test_json_splitter_leading_whitespace PASSED [ 85%] tests/unit/utils_json_stream_test.py::TestStreamAsText::test_stream_with_non_utf_unicode_character PASSED [ 86%] tests/unit/utils_json_stream_test.py::TestStreamAsText::test_stream_with_utf_character PASSED [ 86%] tests/unit/utils_json_stream_test.py::TestJsonStream::test_with_falsy_entries PASSED [ 86%] tests/unit/utils_json_stream_test.py::TestJsonStream::test_with_leading_whitespace PASSED [ 86%] tests/unit/utils_proxy_test.py::ProxyConfigTest::test_environment PASSED [ 86%] tests/unit/utils_proxy_test.py::ProxyConfigTest::test_from_dict PASSED [ 86%] tests/unit/utils_proxy_test.py::ProxyConfigTest::test_inject_proxy_environment PASSED [ 87%] tests/unit/utils_proxy_test.py::ProxyConfigTest::test_new PASSED [ 87%] tests/unit/utils_proxy_test.py::ProxyConfigTest::test_truthiness PASSED [ 87%] tests/unit/utils_test.py::DecoratorsTest::test_update_headers PASSED [ 87%] tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_alternate_env PASSED [ 87%] tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_empty PASSED [ 87%] tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_no_cert_path PASSED [ 88%] tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_tls PASSED [ 88%] tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_tls_verify_false PASSED [ 88%] tests/unit/utils_test.py::KwargsFromEnvTest::test_kwargs_from_env_tls_verify_false_no_cert PASSED [ 88%] tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_compact PASSED [ 88%] tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_complete PASSED [ 88%] tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_empty PASSED [ 89%] tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_list PASSED [ 89%] tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_no_mode PASSED [ 89%] tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_unicode_bytes_input PASSED [ 89%] tests/unit/utils_test.py::ConverVolumeBindsTest::test_convert_volume_binds_unicode_unicode_input PASSED [ 89%] tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_commented_line PASSED [ 90%] tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_invalid_line PASSED [ 90%] tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_newline PASSED [ 90%] tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_proper PASSED [ 90%] tests/unit/utils_test.py::ParseEnvFileTest::test_parse_env_file_with_equals_character PASSED [ 90%] tests/unit/utils_test.py::ParseHostTest::test_parse_host PASSED [ 90%] tests/unit/utils_test.py::ParseHostTest::test_parse_host_empty_value PASSED [ 91%] tests/unit/utils_test.py::ParseHostTest::test_parse_host_tls PASSED [ 91%] tests/unit/utils_test.py::ParseHostTest::test_parse_host_tls_tcp_proto PASSED [ 91%] tests/unit/utils_test.py::ParseHostTest::test_parse_host_trailing_slash PASSED [ 91%] tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_image_no_tag PASSED [ 91%] tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_image_sha PASSED [ 91%] tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_image_tag PASSED [ 92%] tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_user_image_no_tag PASSED [ 92%] tests/unit/utils_test.py::ParseRepositoryTagTest::test_index_user_image_tag PASSED [ 92%] tests/unit/utils_test.py::ParseRepositoryTagTest::test_private_reg_image_no_tag PASSED [ 92%] tests/unit/utils_test.py::ParseRepositoryTagTest::test_private_reg_image_sha PASSED [ 92%] tests/unit/utils_test.py::ParseRepositoryTagTest::test_private_reg_image_tag PASSED [ 93%] tests/unit/utils_test.py::ParseDeviceTest::test_dict PASSED [ 93%] tests/unit/utils_test.py::ParseDeviceTest::test_full_string_definition PASSED [ 93%] tests/unit/utils_test.py::ParseDeviceTest::test_hybrid_list PASSED [ 93%] tests/unit/utils_test.py::ParseDeviceTest::test_partial_string_definition PASSED [ 93%] tests/unit/utils_test.py::ParseDeviceTest::test_permissionless_string_definition PASSED [ 93%] tests/unit/utils_test.py::ParseBytesTest::test_parse_bytes_float PASSED [ 94%] tests/unit/utils_test.py::ParseBytesTest::test_parse_bytes_invalid PASSED [ 94%] tests/unit/utils_test.py::ParseBytesTest::test_parse_bytes_valid PASSED [ 94%] tests/unit/utils_test.py::UtilsTest::test_convert_filters PASSED [ 94%] tests/unit/utils_test.py::UtilsTest::test_decode_json_header PASSED [ 94%] tests/unit/utils_test.py::SplitCommandTest::test_split_command_with_unicode PASSED [ 94%] tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_matching_internal_port_ranges PASSED [ 95%] tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_matching_internal_ports PASSED [ 95%] tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_nonmatching_internal_port_ranges PASSED [ 95%] tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_nonmatching_internal_ports PASSED [ 95%] tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_one_port PASSED [ 95%] tests/unit/utils_test.py::PortsTest::test_build_port_bindings_with_port_range PASSED [ 95%] tests/unit/utils_test.py::PortsTest::test_host_only_with_colon PASSED [ 96%] tests/unit/utils_test.py::PortsTest::test_non_matching_length_port_ranges PASSED [ 96%] tests/unit/utils_test.py::PortsTest::test_port_and_range_invalid PASSED [ 96%] tests/unit/utils_test.py::PortsTest::test_port_only_with_colon PASSED [ 96%] tests/unit/utils_test.py::PortsTest::test_split_port_empty_string PASSED [ 96%] tests/unit/utils_test.py::PortsTest::test_split_port_invalid PASSED [ 97%] tests/unit/utils_test.py::PortsTest::test_split_port_invalid_protocol PASSED [ 97%] tests/unit/utils_test.py::PortsTest::test_split_port_no_host_port PASSED [ 97%] tests/unit/utils_test.py::PortsTest::test_split_port_non_string PASSED [ 97%] tests/unit/utils_test.py::PortsTest::test_split_port_random_port_range_with_host_port PASSED [ 97%] tests/unit/utils_test.py::PortsTest::test_split_port_range_no_host_port PASSED [ 97%] tests/unit/utils_test.py::PortsTest::test_split_port_range_with_host_ip_no_port PASSED [ 98%] tests/unit/utils_test.py::PortsTest::test_split_port_range_with_host_port PASSED [ 98%] tests/unit/utils_test.py::PortsTest::test_split_port_range_with_protocol PASSED [ 98%] tests/unit/utils_test.py::PortsTest::test_split_port_with_host_ip PASSED [ 98%] tests/unit/utils_test.py::PortsTest::test_split_port_with_host_ip_no_port PASSED [ 98%] tests/unit/utils_test.py::PortsTest::test_split_port_with_host_port PASSED [ 98%] tests/unit/utils_test.py::PortsTest::test_split_port_with_ipv6_address PASSED [ 99%] tests/unit/utils_test.py::PortsTest::test_split_port_with_ipv6_square_brackets_address PASSED [ 99%] tests/unit/utils_test.py::PortsTest::test_split_port_with_protocol PASSED [ 99%] tests/unit/utils_test.py::PortsTest::test_with_no_container_port PASSED [ 99%] tests/unit/utils_test.py::FormatEnvironmentTest::test_format_env_binary_unicode_value PASSED [ 99%] tests/unit/utils_test.py::FormatEnvironmentTest::test_format_env_no_value PASSED [100%] =================================== FAILURES =================================== ____________________________ ImageTest.test_remove _____________________________ tests/unit/models_images_test.py:157: in test_remove client.api.remove_image.assert_called_with(FAKE_IMAGE_ID) /usr/local/lib/python3.7/unittest/mock.py:878: in assert_called_with raise AssertionError(_error_message()) from cause E AssertionError: Expected call: remove_image('e9aa60c60128') E Actual call: remove_image('e9aa60c60128', force=False, noprune=False) ---------- coverage: platform linux, python 3.7.12-final-0 ----------- Name Stmts Miss Branch BrPart Cover ----------------------------------------------------------------------- docker/__init__.py 8 0 0 0 100% docker/api/__init__.py 1 0 0 0 100% docker/api/build.py 126 41 92 21 62% docker/api/client.py 261 65 92 11 75% docker/api/config.py 29 18 4 0 33% docker/api/container.py 265 72 104 25 65% docker/api/daemon.py 39 4 14 4 85% docker/api/exec_api.py 45 11 22 9 67% docker/api/image.py 159 43 60 14 70% docker/api/network.py 90 35 48 11 51% docker/api/plugin.py 89 68 14 0 20% docker/api/secret.py 34 22 8 0 29% docker/api/service.py 200 176 149 0 7% docker/api/swarm.py 106 67 38 1 28% docker/api/volume.py 38 9 14 2 71% docker/auth.py 197 16 74 16 88% docker/client.py 69 9 2 0 87% docker/constants.py 21 0 0 0 100% docker/context/__init__.py 2 0 0 0 100% docker/context/api.py 78 41 38 8 39% docker/context/config.py 61 33 16 2 42% docker/context/context.py 154 96 64 6 29% docker/credentials/__init__.py 3 0 0 0 100% docker/credentials/constants.py 4 0 0 0 100% docker/credentials/errors.py 11 4 2 0 54% docker/credentials/store.py 44 30 12 0 25% docker/credentials/utils.py 23 18 12 0 14% docker/errors.py 110 26 20 4 71% docker/models/__init__.py 0 0 0 0 100% docker/models/configs.py 21 8 2 0 57% docker/models/containers.py 183 11 70 9 91% docker/models/images.py 138 55 56 4 52% docker/models/networks.py 37 7 12 3 71% docker/models/nodes.py 15 5 2 0 59% docker/models/plugins.py 48 29 8 0 34% docker/models/resource.py 41 10 6 3 72% docker/models/secrets.py 22 4 2 0 75% docker/models/services.py 87 35 36 4 59% docker/models/swarm.py 39 21 6 0 40% docker/models/volumes.py 23 10 4 0 48% docker/tls.py 37 6 14 6 76% docker/transport/__init__.py 11 3 0 0 73% docker/transport/basehttpadapter.py 6 0 2 1 88% docker/transport/npipeconn.py 57 52 8 0 8% docker/transport/npipesocket.py 134 130 20 0 3% docker/transport/sshconn.py 162 105 54 3 30% docker/transport/ssladapter.py 36 10 10 4 65% docker/transport/unixconn.py 54 3 6 1 93% docker/types/__init__.py 6 0 0 0 100% docker/types/base.py 4 0 2 0 100% docker/types/containers.py 419 79 326 43 81% docker/types/daemon.py 36 24 14 0 24% docker/types/healthcheck.py 33 20 4 0 35% docker/types/networks.py 41 11 28 9 65% docker/types/services.py 321 146 216 41 50% docker/types/swarm.py 51 45 40 0 7% docker/utils/__init__.py 3 0 0 0 100% docker/utils/build.py 150 24 72 10 83% docker/utils/config.py 36 1 10 1 96% docker/utils/decorators.py 32 1 12 1 95% docker/utils/fnmatch.py 55 18 28 2 61% docker/utils/json_stream.py 40 8 14 2 78% docker/utils/ports.py 50 3 32 2 91% docker/utils/proxy.py 32 1 12 0 98% docker/utils/socket.py 85 10 40 8 84% docker/utils/utils.py 278 18 171 13 92% docker/version.py 2 0 2 0 100% ----------------------------------------------------------------------- TOTAL 5092 1817 2240 304 60% =========================== short test summary info ============================ XFAIL tests/unit/dockertypes_test.py::MountTest::test_parse_mount_bind_windows SKIPPED [1] tests/unit/api_build_test.py:169: Windows-specific syntax SKIPPED [1] tests/unit/client_test.py:99: Npipe Connection Pool only on Windows SKIPPED [1] tests/unit/client_test.py:138: Npipe Connection Pool only on Windows SKIPPED [1] tests/unit/client_test.py:212: Npipe Connection Pool only on Windows SKIPPED [1] tests/unit/client_test.py:249: Npipe Connection Pool only on Windows SKIPPED [1] tests/unit/context_test.py:18: Windows specific path check SKIPPED [1] tests/unit/utils_build_test.py:230: Backslash patterns only on Windows SKIPPED [1] tests/unit/utils_build_test.py:252: Backslash patterns only on Windows SKIPPED [1] tests/unit/utils_build_test.py:400: root user always has access ; no chmod on Windows SKIPPED [1] tests/unit/utils_config_test.py:54: condition: sys.platform != 'win32' ============= 1 failed, 560 passed, 10 skipped, 1 xfailed in 6.35s ============= [Pipeline] sh + docker stop dpy-dind-1-0-py3.7-19.03.13 Error response from daemon: No such container: dpy-dind-1-0-py3.7-19.03.13 [Pipeline] } [Pipeline] // withDockerRegistry [Pipeline] } [Pipeline] // stage [Pipeline] } [Pipeline] // wrap [Pipeline] } [Pipeline] // wrap [Pipeline] } [Pipeline] // withDockerRegistry [Pipeline] } [Pipeline] // node [Pipeline] } Failed in branch py3.7_19.03.13 [Pipeline] // parallel [Pipeline] End of Pipeline GitHub has been notified of this commit’s build result ERROR: script returned exit code 1 Finished: FAILURE