Skip to content
Aborted

Console Output

Push event to branch ndeloof
07:50:49 Connecting to https://api.github.com using docker-jenkins/****** (docker-jenkins GitHub credentials)
Obtained Jenkinsfile from f0d8706f3473426bfcc85197834187726323acf2
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 26028d2ce48352c9b2c3f496e963b79a4944a426
using credential jps-reader
 > git rev-parse --is-inside-work-tree # timeout=10
Fetching changes from the remote Git repository
 > git config remote.origin.url https://github.com/docker/jps.git # timeout=10
Fetching without tags
Fetching upstream changes from https://github.com/docker/jps.git
 > git --version # timeout=10
using GIT_ASKPASS to set credentials GitHub credentials for docker/jps
 > git fetch --no-tags --progress -- https://github.com/docker/jps.git +refs/heads/master:refs/remotes/origin/master
Checking out Revision 26028d2ce48352c9b2c3f496e963b79a4944a426 (master)
 > git config core.sparsecheckout # timeout=10
 > git checkout -f 26028d2ce48352c9b2c3f496e963b79a4944a426
Commit message: "[TAR-1227] Run the sonar container as the current user (#17)"
 > git rev-list --no-walk 26028d2ce48352c9b2c3f496e963b79a4944a426 # timeout=10
[Pipeline] Start of Pipeline
[Pipeline] withEnv
[Pipeline] {
[Pipeline] timeout
Timeout set to expire in 1 hr 0 min
[Pipeline] {
[Pipeline] stage
[Pipeline] { (Build)
[Pipeline] parallel
[Pipeline] { (Branch: Debian)
[Pipeline] { (Branch: Alpine)
[Pipeline] { (Branch: Docker)
[Pipeline] stage
[Pipeline] { (Debian)
[Pipeline] stage
[Pipeline] { (Alpine)
[Pipeline] stage
[Pipeline] { (Docker)
[Pipeline] node
[Pipeline] node
[Pipeline] node
Running on ubuntu-1804-overlay2 (i-0c6fba1b854b76898) in /home/ubuntu/workspace/compose_ndeloof
[Pipeline] {
Running on ubuntu-1804-overlay2 (i-0b7615abd370358b1) in /home/ubuntu/workspace/compose_ndeloof
Running on ubuntu-1804-overlay2 (i-028a3a97362f019d1) in /home/ubuntu/workspace/compose_ndeloof
[Pipeline] {
[Pipeline] {
[Pipeline] checkout
[Pipeline] script
[Pipeline] {
[Pipeline] checkout
using credential sf-release-bot.github.ssh
[Pipeline] sh
using credential sf-release-bot.github.ssh
Fetching changes from the remote Git repository
Fetching changes from the remote Git repository
Fetching without tags
Fetching without tags
+ grep ^v[0-9\.]*$
+ jq -r .[].name
+ curl https://api.github.com/repos/docker/docker-ce/tags
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed

  0     0    0     0    0     0      0      0 --:--:-- --:--:-- --:--:--     0Checking out Revision f0d8706f3473426bfcc85197834187726323acf2 (ndeloof)
Checking out Revision f0d8706f3473426bfcc85197834187726323acf2 (ndeloof)
Commit message: "WiP"
Commit message: "WiP"
 > git rev-parse --is-inside-work-tree # timeout=10
 > git config remote.origin.url git@github.com:docker/compose.git # timeout=10
Fetching upstream changes from git@github.com:docker/compose.git
 > git --version # timeout=10
using GIT_SSH to set credentials docker-jenkins user on github.com
 > git fetch --no-tags --progress -- git@github.com:docker/compose.git +refs/heads/ndeloof:refs/remotes/origin/ndeloof
 > git config core.sparsecheckout # timeout=10
 > git checkout -f f0d8706f3473426bfcc85197834187726323acf2
 > git rev-list --no-walk 3711489452bc987dd7281e2005e875e91f0a78bb # timeout=10

  0     0    0     0    0     0      0      0 --:--:-- --:--:-- --:--:--     0 > git rev-parse --is-inside-work-tree # timeout=10
 > git config remote.origin.url git@github.com:docker/compose.git # timeout=10
Fetching upstream changes from git@github.com:docker/compose.git
 > git --version # timeout=10
using GIT_SSH to set credentials docker-jenkins user on github.com
 > git fetch --no-tags --progress -- git@github.com:docker/compose.git +refs/heads/ndeloof:refs/remotes/origin/ndeloof
 > git config core.sparsecheckout # timeout=10
 > git checkout -f f0d8706f3473426bfcc85197834187726323acf2
[Pipeline] sh
[Pipeline] sh
+ docker build -t compose:alpine --target build --build-arg BUILD_PLATFORM=alpine .
#2 [internal] load build definition from Dockerfile
#2 transferring dockerfile: 2.06kB done
#2 DONE 0.0s

#1 [internal] load .dockerignore
#1 transferring context: 151B done
#1 DONE 0.0s

#4 [internal] load metadata for docker.io/library/docker:18.09.7
+ docker build -t compose:debian --target build --build-arg BUILD_PLATFORM=debian .
#1 [internal] load build definition from Dockerfile
#1 transferring dockerfile: 38B done
#1 DONE 0.0s

#2 [internal] load .dockerignore
#2 transferring context: 34B done
#2 DONE 0.0s

#3 [internal] load metadata for docker.io/library/docker:18.09.7
#3 DONE 0.1s

#4 [internal] load metadata for docker.io/library/python:3.7.4-slim-stretch
#4 ...

#3 [internal] load metadata for docker.io/library/python:3.7.4-alpine3.10
#3 DONE 0.2s

#4 [internal] load metadata for docker.io/library/docker:18.09.7
#4 DONE 0.2s

#9 [docker-cli 1/1] FROM docker.io/library/docker:18.09.7@sha256:310156c950...
#9 resolve docker.io/library/docker:18.09.7@sha256:310156c95007d6cca1417d0692786fe4da816b886a08bc7de97edf02cab4db31 done
#4 DONE 0.3s
#9 extracting sha256:0503825856099e6adb39c8297af09547f69684b7016b7f3680ed801aa310baaa
#9 ...

#5 [build-alpine 1/2] FROM docker.io/library/python:3.7.4-alpine3.10@sha256...
#5 resolve docker.io/library/python:3.7.4-alpine3.10@sha256:6673d8ce9610d166b6d7d6abda21537ddcf30e6bc8c20ca86f17f1085e20ac95 done
#5 sha256:6673d8ce9610d166b6d7d6abda21537ddcf30e6bc8c20ca86f17f1085e20ac95 1.65kB / 1.65kB done
#5 sha256:ea73f28cc30917ec244b2e28c902fbe3aad1ee82f7f4a32bffaf36f81befee7f 1.37kB / 1.37kB done
#5 sha256:f309434dea3a159ad08ffa070b778ddb5cafbf88c45142710030ac29350e1f52 7.64kB / 7.64kB done
#5 DONE 0.3s

#9 [docker-cli 1/1] FROM docker.io/library/docker:18.09.7@sha256:310156c950...
#9 sha256:d812b212c86a201fce7542d605ee14463a90610e897f557adb4572109d4a0df5 1.57kB / 1.57kB done
#9 sha256:108a4437ed8ca450ea2c0456e3d08a36a3ce7934275bd9745741dad2e234b353 3.95kB / 3.95kB done
#9 sha256:0503825856099e6adb39c8297af09547f69684b7016b7f3680ed801aa310baaa 2.79MB / 2.79MB 0.1s done
#9 sha256:0bb4ee3360d7674b72befc5a29a65d17c2aad071dba363cedc48e21337e2f9fc 301.72kB / 301.72kB 0.1s done
#9 sha256:310156c95007d6cca1417d0692786fe4da816b886a08bc7de97edf02cab4db31 1.00kB / 1.00kB done
#9 sha256:893f09c2afb0995b31b535c5ef1e3e6baf15d6e3ba20cca23ab228dc23959bba 156B / 156B 0.1s done
#9 sha256:3204ba24bdf52ebe7a39dc027e9637ce1d11c81f836937e11ef7693ecc26d403 1.44MB / 48.56MB 0.2s
#9 sha256:c7a4c34d84a5f718ea45a6f9f46dbd3dafc00368f2cc9ff29e71b8142e586571 542B / 542B 0.2s done
#9 sha256:758ee1f25c3765ee0f756cfc943dc0c8111d29fd3c1374f06274bb282bd4f5c3 0B / 736B 0.2s

  0     0    0     0    0     0      0      0 --:--:--  0:00:01 --:--:--     0
#9 [docker-cli 1/1] FROM docker.io/library/docker:18.09.7@sha256:310156c950...
#9 CACHED

#5 [build-debian 1/2] FROM docker.io/library/python:3.7.4-slim-stretch@sha2...
#5 resolve docker.io/library/python:3.7.4-slim-stretch@sha256:34a714dec6e3387e964350dc09d9db95f16df3720d018c9ca024c1e4e20c118b done
#5 sha256:33536ac8210e6cc0b62674d718b81f8536e9d728b77b566cfa0d2987325d682a 156.20kB / 25.76MB 0.2s
#5 sha256:34a714dec6e3387e964350dc09d9db95f16df3720d018c9ca024c1e4e20c118b 1.65kB / 1.65kB done
#5 sha256:e6f8ec511aa991e58be3153c108aa6e432432d2253ea418e9ff56bc6ca4b2930 1.37kB / 1.37kB done
#5 sha256:fad2b9f06d3b899e3c7b04980d1cfb6d2c13f1ec3a9f487d7dc40bb96a77227b 8.14kB / 8.14kB done
#5 sha256:80369df487363e56aea88d4d41b61f1607fc2ec198e9327cfde36a5346c71bf2 11.09MB / 22.52MB 0.2s
#5 sha256:aaba0609d543071ad229fcea4efdc4aa8d3b4479443d214f89411d809631367f 2.53MB / 2.53MB 0.1s done
#5 sha256:35aa8bff600e884fa38dcd574f5af6df79b8d8111c04288fd6fd07cac0cbca39 0B / 241B 0.2s
#5 sha256:33536ac8210e6cc0b62674d718b81f8536e9d728b77b566cfa0d2987325d682a 10.59MB / 25.76MB 0.3s
#5 sha256:80369df487363e56aea88d4d41b61f1607fc2ec198e9327cfde36a5346c71bf2 19.88MB / 22.52MB 0.3s
#5 sha256:35aa8bff600e884fa38dcd574f5af6df79b8d8111c04288fd6fd07cac0cbca39 241B / 241B 0.2s done
#5 sha256:6e4c9666aa4ee2b1fefc6805ff197a9e6aabcb0a62401edba29430945302a83d 0B / 2.15MB 0.3s
#9 sha256:3204ba24bdf52ebe7a39dc027e9637ce1d11c81f836937e11ef7693ecc26d403 11.62MB / 48.56MB 0.4s
#9 sha256:758ee1f25c3765ee0f756cfc943dc0c8111d29fd3c1374f06274bb282bd4f5c3 736B / 736B 0.3s done
#9 sha256:3204ba24bdf52ebe7a39dc027e9637ce1d11c81f836937e11ef7693ecc26d403 15.17MB / 48.56MB 0.5s
#5 extracting sha256:80369df487363e56aea88d4d41b61f1607fc2ec198e9327cfde36a5346c71bf2
#5 sha256:33536ac8210e6cc0b62674d718b81f8536e9d728b77b566cfa0d2987325d682a 24.70MB / 25.76MB 0.5s
#5 sha256:80369df487363e56aea88d4d41b61f1607fc2ec198e9327cfde36a5346c71bf2 22.52MB / 22.52MB 0.4s done
#5 sha256:6e4c9666aa4ee2b1fefc6805ff197a9e6aabcb0a62401edba29430945302a83d 2.15MB / 2.15MB 0.4s done
#9 sha256:3204ba24bdf52ebe7a39dc027e9637ce1d11c81f836937e11ef7693ecc26d403 21.49MB / 48.56MB 0.6s
#9 extracting sha256:0503825856099e6adb39c8297af09547f69684b7016b7f3680ed801aa310baaa 0.5s done
#9 sha256:3204ba24bdf52ebe7a39dc027e9637ce1d11c81f836937e11ef7693ecc26d403 35.07MB / 48.56MB 0.8s
#5 sha256:33536ac8210e6cc0b62674d718b81f8536e9d728b77b566cfa0d2987325d682a 25.76MB / 25.76MB 0.6s done
#9 sha256:3204ba24bdf52ebe7a39dc027e9637ce1d11c81f836937e11ef7693ecc26d403 37.96MB / 48.56MB 0.9s
#9 extracting sha256:0bb4ee3360d7674b72befc5a29a65d17c2aad071dba363cedc48e21337e2f9fc
#9 sha256:3204ba24bdf52ebe7a39dc027e9637ce1d11c81f836937e11ef7693ecc26d403 41.94MB / 48.56MB 1.0s
#9 extracting sha256:0bb4ee3360d7674b72befc5a29a65d17c2aad071dba363cedc48e21337e2f9fc 0.3s done

  0     0    0     0    0     0      0      0 --:--:--  0:00:02 --:--:--     0#9 sha256:3204ba24bdf52ebe7a39dc027e9637ce1d11c81f836937e11ef7693ecc26d403 48.56MB / 48.56MB 1.3s
#9 sha256:3204ba24bdf52ebe7a39dc027e9637ce1d11c81f836937e11ef7693ecc26d403 48.56MB / 48.56MB 1.5s done
#9 extracting sha256:893f09c2afb0995b31b535c5ef1e3e6baf15d6e3ba20cca23ab228dc23959bba 0.0s done
#9 extracting sha256:3204ba24bdf52ebe7a39dc027e9637ce1d11c81f836937e11ef7693ecc26d403

  0     0    0     0    0     0      0      0 --:--:--  0:00:03 --:--:--     0#5 extracting sha256:80369df487363e56aea88d4d41b61f1607fc2ec198e9327cfde36a5346c71bf2 2.1s done
#5 extracting sha256:aaba0609d543071ad229fcea4efdc4aa8d3b4479443d214f89411d809631367f

  0     0    0     0    0     0      0      0 --:--:--  0:00:04 --:--:--     0#5 extracting sha256:aaba0609d543071ad229fcea4efdc4aa8d3b4479443d214f89411d809631367f 0.3s done
#5 extracting sha256:33536ac8210e6cc0b62674d718b81f8536e9d728b77b566cfa0d2987325d682a

  0     0    0     0    0     0      0      0 --:--:--  0:00:05 --:--:--     0
100 13723  100 13723    0     0   2437      0  0:00:05  0:00:05 --:--:--  3330
+ cut -f1 -d. /tmp/versions.txt
+ uniq
+ + cut -c2-grep
 -m 1 v19 /tmp/versions.txt
+ + cut -c2-
grep -m 1 v18 /tmp/versions.txt
[Pipeline] }
[Pipeline] // script
[Pipeline] echo
19.03.5
18.09.9

[Pipeline] }
[Pipeline] // node
[Pipeline] }
[Pipeline] // stage
[Pipeline] }
#5 extracting sha256:33536ac8210e6cc0b62674d718b81f8536e9d728b77b566cfa0d2987325d682a 1.9s done
#5 extracting sha256:35aa8bff600e884fa38dcd574f5af6df79b8d8111c04288fd6fd07cac0cbca39 done
#5 extracting sha256:6e4c9666aa4ee2b1fefc6805ff197a9e6aabcb0a62401edba29430945302a83d
#5 extracting sha256:6e4c9666aa4ee2b1fefc6805ff197a9e6aabcb0a62401edba29430945302a83d 0.4s done
#5 DONE 5.8s

#7 [internal] load build context
#7 transferring context: 423.69MB 6.0s
#9 extracting sha256:3204ba24bdf52ebe7a39dc027e9637ce1d11c81f836937e11ef7693ecc26d403 5.0s
#9 extracting sha256:3204ba24bdf52ebe7a39dc027e9637ce1d11c81f836937e11ef7693ecc26d403 5.6s done
#9 extracting sha256:c7a4c34d84a5f718ea45a6f9f46dbd3dafc00368f2cc9ff29e71b8142e586571 done
#7 transferring context: 590.71MB 8.0s done
#7 DONE 8.1s

#6 [build-debian 2/2] RUN apt-get update && apt-get install --no-install-re...
#6 1.113 Ign:1 http://deb.debian.org/debian stretch InRelease
#6 1.124 Get:2 http://deb.debian.org/debian stretch-updates InRelease [91.0 kB]
#6 1.137 Get:3 http://deb.debian.org/debian stretch Release [118 kB]
#6 1.145 Get:4 http://deb.debian.org/debian stretch Release.gpg [2365 B]
#6 1.382 Get:5 http://deb.debian.org/debian stretch-updates/main amd64 Packages [27.9 kB]
#6 1.451 Get:6 http://deb.debian.org/debian stretch/main amd64 Packages [7086 kB]
#6 2.132 Get:7 http://security.debian.org/debian-security stretch/updates InRelease [94.3 kB]
#6 2.292 Get:8 http://security.debian.org/debian-security stretch/updates/main amd64 Packages [508 kB]
#9 ...

#7 [internal] load build context
#7 transferring context: 399.84MB 8.4s
#7 ...

#9 [docker-cli 1/1] FROM docker.io/library/docker:18.09.7@sha256:310156c950...
#9 extracting sha256:758ee1f25c3765ee0f756cfc943dc0c8111d29fd3c1374f06274bb282bd4f5c3 done
#6 3.171 Fetched 7927 kB in 2s (3831 kB/s)
#6 3.171 Reading package lists...
#6 3.729 Reading package lists...#9 DONE 10.1s

#7 [internal] load build context

#7 transferring context: 592.26MB 10.3s done
#7 ...

#6 [build-alpine 2/2] RUN apk add --no-cache     bash     build-base     ca...
#6 1.337 fetch http://dl-cdn.alpinelinux.org/alpine/v3.10/main/x86_64/APKINDEX.tar.gz
#6 2.433 fetch http://dl-cdn.alpinelinux.org/alpine/v3.10/community/x86_64/APKINDEX.tar.gz
#6 2.550 (1/34) Upgrading libcrypto1.1 (1.1.1c-r0 -> 1.1.1d-r0)
#6 2.597 (2/34) Upgrading libssl1.1 (1.1.1c-r0 -> 1.1.1d-r0)
#6 2.621 (3/34) Installing bash (5.0.0-r0)
#6 2.664 Executing bash-5.0.0-r0.post-install
#6 2.668 (4/34) Installing binutils (2.32-r0)
#6 2.799 (5/34) Installing libmagic (5.37-r1)
#6 2.819 (6/34) Installing file (5.37-r1)
#6 2.819 (7/34) Installing gmp (6.1.2-r1)
#6 2.833 (8/34) Installing isl (0.18-r0)
#6 2.847 (9/34) Installing libgomp (8.3.0-r0)
#6 2.851 (10/34) Installing libatomic (8.3.0-r0)
#6 2.856 (11/34) Installing libgcc (8.3.0-r0)
#6 2.858 (12/34) Installing mpfr3 (3.1.5-r1)
#6 2.864 (13/34) Installing mpc1 (1.1.0-r0)
#6 2.866 (14/34) Installing libstdc++ (8.3.0-r0)
#6 2.892 (15/34) Installing gcc (8.3.0-r0)
#6 3.846 (16/34) Installing musl-dev (1.1.22-r3)
#6 3.954 (17/34) Installing libc-dev (0.7.1-r0)
#6 3.954 (18/34) Installing g++ (8.3.0-r0)
#6 4.586 (19/34) Installing make (4.2.1-r2)
#6 4.586 (20/34) Installing fortify-headers (1.1-r0)
#6 4.594 (21/34) Installing build-base (0.5-r1)
#6 4.594 (22/34) Installing nghttp2-libs (1.39.2-r0)
#6 4.598 (23/34) Installing libcurl (7.66.0-r0)
#6 4.613 (24/34) Installing curl (7.66.0-r0)
#6 4.614 (25/34) Installing pcre2 (10.33-r0)
#6 4.635 (26/34) Installing git (2.22.0-r0)
#6 4.867 (27/34) Installing linux-headers (4.19.36-r0)
#6 5.000 (28/34) Installing pkgconf (1.6.1-r1)
#6 5.000 (29/34) Installing libffi-dev (3.2.1-r6)
#6 5.015 (30/34) Installing openssl (1.1.1d-r0)
#6 5.015 (31/34) Installing openssl-dev (1.1.1d-r0)
#6 5.268 (32/34) Installing python2 (2.7.16-r1)
#6 5.872 (33/34) Installing python2-dev (2.7.16-r1)
#6 6.002 (34/34) Installing zlib-dev (1.2.11-r1)
#6 6.013 Executing busybox-1.30.1-r2.trigger
#6 6.018 Executing ca-certificates-20190108-r0.trigger
#6 6.082 OK: 266 MiB in 67 packages
#6 4.295 Building dependency tree...
#6 4.385 Reading state information...
#6 4.468 openssl is already the newest version (1.1.0l-1~deb9u1).
#6 4.468 openssl set to manually installed.
#6 4.468 The following additional packages will be installed:
#6 4.468   binutils cpp cpp-6 gcc-6 git-man libasan3 libatomic1 libc-dev-bin libcc1-0
#6 4.468   libcilkrts5 libcurl3 libcurl3-gnutls liberror-perl libexpat1-dev libgmp10
#6 4.468   libgnutls30 libgomp1 libgssapi-krb5-2 libhogweed4 libidn11 libidn2-0
#6 4.468   libisl15 libitm1 libk5crypto3 libkeyutils1 libkrb5-3 libkrb5support0
#6 4.468   libldap-2.4-2 libldap-common liblsan0 libmpc3 libmpfr4 libmpx2 libnettle6
#6 4.468   libnghttp2-14 libp11-kit0 libperl5.24 libpsl5 libpython2.7 libpython2.7-dev
#6 4.468   libpython2.7-minimal libpython2.7-stdlib libquadmath0 librtmp1 libsasl2-2
#6 4.468   libsasl2-modules-db libssh2-1 libssl1.0.2 libtasn1-6 libtsan0 libubsan0
#6 4.468   libunistring0 linux-libc-dev mime-support perl perl-modules-5.24 python2.7
#6 4.468   python2.7-minimal
#6 4.469 Suggested packages:
#6 4.469   binutils-doc cpp-doc gcc-6-locales gcc-multilib manpages-dev autoconf
#6 4.469   automake libtool flex bison gdb gcc-doc gcc-6-multilib gcc-6-doc libgcc1-dbg
#6 4.469   libgomp1-dbg libitm1-dbg libatomic1-dbg libasan3-dbg liblsan0-dbg
#6 4.469   libtsan0-dbg libubsan0-dbg libcilkrts5-dbg libmpx2-dbg libquadmath0-dbg
#6 4.469   gettext-base git-daemon-run | git-daemon-sysvinit git-doc git-el git-email
#6 4.469   git-gui gitk gitweb git-arch git-cvs git-mediawiki git-svn glibc-doc
#6 4.469   gnutls-bin krb5-doc krb5-user make-doc perl-doc libterm-readline-gnu-perl
#6 4.469   | libterm-readline-perl-perl python2.7-doc binfmt-support
#6 4.469 Recommended packages:
#6 4.469   patch less rsync ssh-client manpages manpages-dev krb5-locales publicsuffix
#6 4.469   libsasl2-modules libssl-doc bzip2 file xz-utils rename
#6 ...

#7 [internal] load build context
#7 DONE 10.4s

#6 [build-alpine 2/2] RUN apk add --no-cache     bash     build-base     ca...
#6 4.987 The following NEW packages will be installed:
#6 4.988   binutils cpp cpp-6 curl gcc gcc-6 git git-man libasan3 libatomic1
#6 4.988   libc-dev-bin libc6-dev libcc1-0 libcilkrts5 libcurl3 libcurl3-gnutls
#6 4.988   liberror-perl libexpat1-dev libffi-dev libgcc-6-dev libgmp10 libgnutls30
#6 4.988   libgomp1 libgssapi-krb5-2 libhogweed4 libidn11 libidn2-0 libisl15 libitm1
#6 4.988   libk5crypto3 libkeyutils1 libkrb5-3 libkrb5support0 libldap-2.4-2
#6 4.988   libldap-common liblsan0 libmpc3 libmpfr4 libmpx2 libnettle6 libnghttp2-14
#6 4.988   libp11-kit0 libperl5.24 libpsl5 libpython2.7 libpython2.7-dev
#6 4.988   libpython2.7-minimal libpython2.7-stdlib libquadmath0 librtmp1 libsasl2-2
#6 4.988   libsasl2-modules-db libssh2-1 libssl-dev libssl1.0.2 libtasn1-6 libtsan0
#6 4.988   libubsan0 libunistring0 linux-libc-dev make mime-support perl
#6 4.988   perl-modules-5.24 python2.7 python2.7-dev python2.7-minimal zlib1g-dev
#6 6.026 0 upgraded, 68 newly installed, 0 to remove and 0 not upgraded.
#6 6.026 Need to get 79.6 MB of archives.
#6 6.026 After this operation, 271 MB of additional disk space will be used.
#6 6.026 Get:1 http://deb.debian.org/debian stretch/main amd64 perl-modules-5.24 all 5.24.1-3+deb9u5 [2722 kB]
#6 6.026 Get:2 http://security.debian.org/debian-security stretch/updates/main amd64 libnghttp2-14 amd64 1.18.1-1+deb9u1 [79.2 kB]
#6 6.030 Get:3 http://security.debian.org/debian-security stretch/updates/main amd64 libssl1.0.2 amd64 1.0.2t-1~deb9u1 [1304 kB]
#6 6.058 Get:4 http://security.debian.org/debian-security stretch/updates/main amd64 linux-libc-dev amd64 4.9.189-3+deb9u2 [1447 kB]
#6 6.086 Get:5 http://deb.debian.org/debian stretch/main amd64 libperl5.24 amd64 5.24.1-3+deb9u5 [3501 kB]
#6 6.090 Get:6 http://security.debian.org/debian-security stretch/updates/main amd64 libexpat1-dev amd64 2.2.0-2+deb9u3 [134 kB]
#6 6.093 Get:7 http://security.debian.org/debian-security stretch/updates/main amd64 libssl-dev amd64 1.1.0l-1~deb9u1 [1594 kB]
#6 6.151 Get:8 http://deb.debian.org/debian stretch/main amd64 perl amd64 5.24.1-3+deb9u5 [219 kB]
#6 6.154 Get:9 http://deb.debian.org/debian stretch/main amd64 libgmp10 amd64 2:6.1.2+dfsg-1 [253 kB]
#6 6.157 Get:10 http://deb.debian.org/debian stretch/main amd64 libnettle6 amd64 3.3-1+b2 [192 kB]
#6 6.159 Get:11 http://deb.debian.org/debian stretch/main amd64 libhogweed4 amd64 3.3-1+b2 [136 kB]
#6 6.160 Get:12 http://deb.debian.org/debian stretch/main amd64 libidn11 amd64 1.33-1 [115 kB]
#6 6.162 Get:13 http://deb.debian.org/debian stretch/main amd64 libp11-kit0 amd64 0.23.3-2 [111 kB]
#6 6.163 Get:14 http://deb.debian.org/debian stretch/main amd64 libtasn1-6 amd64 4.10-1.1+deb9u1 [50.6 kB]
#6 6.164 Get:15 http://deb.debian.org/debian stretch/main amd64 libgnutls30 amd64 3.5.8-5+deb9u4 [896 kB]
#6 6.173 Get:16 http://deb.debian.org/debian stretch/main amd64 libkeyutils1 amd64 1.5.9-9 [12.4 kB]
#6 6.173 Get:17 http://deb.debian.org/debian stretch/main amd64 libkrb5support0 amd64 1.15-1+deb9u1 [61.9 kB]
#6 6.174 Get:18 http://deb.debian.org/debian stretch/main amd64 libk5crypto3 amd64 1.15-1+deb9u1 [119 kB]
#6 6.176 Get:19 http://deb.debian.org/debian stretch/main amd64 libkrb5-3 amd64 1.15-1+deb9u1 [311 kB]
#6 6.179 Get:20 http://deb.debian.org/debian stretch/main amd64 libgssapi-krb5-2 amd64 1.15-1+deb9u1 [155 kB]
#6 6.181 Get:21 http://deb.debian.org/debian stretch/main amd64 libunistring0 amd64 0.9.6+really0.9.3-0.1 [279 kB]
#6 6.184 Get:22 http://deb.debian.org/debian stretch/main amd64 libidn2-0 amd64 0.16-1+deb9u1 [60.7 kB]
#6 6.185 Get:23 http://deb.debian.org/debian stretch/main amd64 libsasl2-modules-db amd64 2.1.27~101-g0780600+dfsg-3 [68.2 kB]
#6 6.186 Get:24 http://deb.debian.org/debian stretch/main amd64 libsasl2-2 amd64 2.1.27~101-g0780600+dfsg-3 [105 kB]
#6 6.187 Get:25 http://deb.debian.org/debian stretch/main amd64 libldap-common all 2.4.44+dfsg-5+deb9u3 [85.7 kB]
#6 6.188 Get:26 http://deb.debian.org/debian stretch/main amd64 libldap-2.4-2 amd64 2.4.44+dfsg-5+deb9u3 [220 kB]
#6 6.191 Get:27 http://deb.debian.org/debian stretch/main amd64 libpsl5 amd64 0.17.0-3 [41.8 kB]
#6 6.191 Get:28 http://deb.debian.org/debian stretch/main amd64 librtmp1 amd64 2.4+20151223.gitfa8646d.1-1+b1 [60.4 kB]
#6 6.192 Get:29 http://deb.debian.org/debian stretch/main amd64 libssh2-1 amd64 1.7.0-1+deb9u1 [139 kB]
#6 6.194 Get:30 http://deb.debian.org/debian stretch/main amd64 libcurl3-gnutls amd64 7.52.1-5+deb9u9 [290 kB]
#6 6.197 Get:31 http://deb.debian.org/debian stretch/main amd64 liberror-perl all 0.17024-1 [26.9 kB]
#6 6.198 Get:32 http://deb.debian.org/debian stretch/main amd64 git-man all 1:2.11.0-3+deb9u4 [1433 kB]
#6 6.211 Get:33 http://deb.debian.org/debian stretch/main amd64 git amd64 1:2.11.0-3+deb9u4 [4167 kB]
#6 6.387 Get:34 http://deb.debian.org/debian stretch/main amd64 libpython2.7-minimal amd64 2.7.13-2+deb9u3 [389 kB]
#6 6.392 Get:35 http://deb.debian.org/debian stretch/main amd64 python2.7-minimal amd64 2.7.13-2+deb9u3 [1382 kB]
#6 6.406 Get:36 http://deb.debian.org/debian stretch/main amd64 mime-support all 3.60 [36.7 kB]
#6 6.406 Get:37 http://deb.debian.org/debian stretch/main amd64 libpython2.7-stdlib amd64 2.7.13-2+deb9u3 [1897 kB]
#6 6.425 Get:38 http://deb.debian.org/debian stretch/main amd64 python2.7 amd64 2.7.13-2+deb9u3 [285 kB]
#6 6.428 Get:39 http://deb.debian.org/debian stretch/main amd64 binutils amd64 2.28-5 [3770 kB]
#6 6.470 Get:40 http://deb.debian.org/debian stretch/main amd64 libisl15 amd64 0.18-1 [564 kB]
#6 6.477 Get:41 http://deb.debian.org/debian stretch/main amd64 libmpfr4 amd64 3.1.5-1 [556 kB]
#6 6.482 Get:42 http://deb.debian.org/debian stretch/main amd64 libmpc3 amd64 1.0.3-1+b2 [39.9 kB]
#6 6.483 Get:43 http://deb.debian.org/debian stretch/main amd64 cpp-6 amd64 6.3.0-18+deb9u1 [6584 kB]
#6 6.559 Get:44 http://deb.debian.org/debian stretch/main amd64 cpp amd64 4:6.3.0-4 [18.7 kB]
#6 6.560 Get:45 http://deb.debian.org/debian stretch/main amd64 libcurl3 amd64 7.52.1-5+deb9u9 [292 kB]
#6 6.563 Get:46 http://deb.debian.org/debian stretch/main amd64 curl amd64 7.52.1-5+deb9u9 [227 kB]
#6 6.566 Get:47 http://deb.debian.org/debian stretch/main amd64 libcc1-0 amd64 6.3.0-18+deb9u1 [30.6 kB]
#6 6.567 Get:48 http://deb.debian.org/debian stretch/main amd64 libgomp1 amd64 6.3.0-18+deb9u1 [73.3 kB]
#6 6.568 Get:49 http://deb.debian.org/debian stretch/main amd64 libitm1 amd64 6.3.0-18+deb9u1 [27.3 kB]
#6 6.569 Get:50 http://deb.debian.org/debian stretch/main amd64 libatomic1 amd64 6.3.0-18+deb9u1 [8966 B]
#6 6.569 Get:51 http://deb.debian.org/debian stretch/main amd64 libasan3 amd64 6.3.0-18+deb9u1 [311 kB]
#6 6.573 Get:52 http://deb.debian.org/debian stretch/main amd64 liblsan0 amd64 6.3.0-18+deb9u1 [115 kB]
#6 6.575 Get:53 http://deb.debian.org/debian stretch/main amd64 libtsan0 amd64 6.3.0-18+deb9u1 [257 kB]
#6 6.578 Get:54 http://deb.debian.org/debian stretch/main amd64 libubsan0 amd64 6.3.0-18+deb9u1 [107 kB]
#6 6.579 Get:55 http://deb.debian.org/debian stretch/main amd64 libcilkrts5 amd64 6.3.0-18+deb9u1 [40.5 kB]
#6 6.580 Get:56 http://deb.debian.org/debian stretch/main amd64 libmpx2 amd64 6.3.0-18+deb9u1 [11.2 kB]
#6 6.580 Get:57 http://deb.debian.org/debian stretch/main amd64 libquadmath0 amd64 6.3.0-18+deb9u1 [131 kB]
#6 6.582 Get:58 http://deb.debian.org/debian stretch/main amd64 libgcc-6-dev amd64 6.3.0-18+deb9u1 [2296 kB]
#6 6.606 Get:59 http://deb.debian.org/debian stretch/main amd64 gcc-6 amd64 6.3.0-18+deb9u1 [6900 kB]
#6 6.702 Get:60 http://deb.debian.org/debian stretch/main amd64 gcc amd64 4:6.3.0-4 [5196 B]
#6 6.703 Get:61 http://deb.debian.org/debian stretch/main amd64 libc-dev-bin amd64 2.24-11+deb9u4 [259 kB]
#6 6.706 Get:62 http://deb.debian.org/debian stretch/main amd64 libc6-dev amd64 2.24-11+deb9u4 [2364 kB]
#6 6.737 Get:63 http://deb.debian.org/debian stretch/main amd64 libffi-dev amd64 3.2.1-6 [161 kB]
#6 6.740 Get:64 http://deb.debian.org/debian stretch/main amd64 libpython2.7 amd64 2.7.13-2+deb9u3 [1071 kB]
#6 6.751 Get:65 http://deb.debian.org/debian stretch/main amd64 libpython2.7-dev amd64 2.7.13-2+deb9u3 [28.2 MB]
#6 DONE 12.9s

#8 [build 1/15] COPY docker-compose-entrypoint.sh /usr/local/bin/
#8 DONE 0.0s

#10 [build 2/15] COPY --from=docker-cli /usr/local/bin/docker /usr/local/bin...
#6 7.296 Get:66 http://deb.debian.org/debian stretch/main amd64 make amd64 4.1-9.1 [302 kB]
#6 7.308 Get:67 http://deb.debian.org/debian stretch/main amd64 python2.7-dev amd64 2.7.13-2+deb9u3 [290 kB]
#6 7.314 Get:68 http://deb.debian.org/debian stretch/main amd64 zlib1g-dev amd64 1:1.2.8.dfsg-5 [205 kB]
#6 7.487 debconf: delaying package configuration, since apt-utils is not installed
#6 7.561 Fetched 79.6 MB in 2s (34.4 MB/s)
#6 7.686 Selecting previously unselected package perl-modules-5.24.
#6 7.687 (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 ... 6710 files and directories currently installed.)
#6 7.692 Preparing to unpack .../00-perl-modules-5.24_5.24.1-3+deb9u5_all.deb ...
#6 7.738 Unpacking perl-modules-5.24 (5.24.1-3+deb9u5) ...
#10 DONE 0.5s

#11 [build 3/15] WORKDIR /code/
#11 DONE 0.0s

#12 [build 4/15] RUN pip install virtualenv==16.2.0
#6 9.310 Selecting previously unselected package libperl5.24:amd64.
#6 9.312 Preparing to unpack .../01-libperl5.24_5.24.1-3+deb9u5_amd64.deb ...
#6 9.320 Unpacking libperl5.24:amd64 (5.24.1-3+deb9u5) ...
#6 9.859 Selecting previously unselected package perl.
#6 9.859 Preparing to unpack .../02-perl_5.24.1-3+deb9u5_amd64.deb ...
#6 9.863 Unpacking perl (5.24.1-3+deb9u5) ...
#6 9.921 Selecting previously unselected package libgmp10:amd64.
#6 9.922 Preparing to unpack .../03-libgmp10_2%3a6.1.2+dfsg-1_amd64.deb ...
#6 9.928 Unpacking libgmp10:amd64 (2:6.1.2+dfsg-1) ...
#6 9.988 Selecting previously unselected package libnettle6:amd64.
#6 9.989 Preparing to unpack .../04-libnettle6_3.3-1+b2_amd64.deb ...
#6 9.993 Unpacking libnettle6:amd64 (3.3-1+b2) ...
#6 10.04 Selecting previously unselected package libhogweed4:amd64.
#6 10.04 Preparing to unpack .../05-libhogweed4_3.3-1+b2_amd64.deb ...
#6 10.04 Unpacking libhogweed4:amd64 (3.3-1+b2) ...
#6 10.09 Selecting previously unselected package libidn11:amd64.
#6 10.09 Preparing to unpack .../06-libidn11_1.33-1_amd64.deb ...
#6 10.09 Unpacking libidn11:amd64 (1.33-1) ...
#6 10.14 Selecting previously unselected package libp11-kit0:amd64.
#6 10.14 Preparing to unpack .../07-libp11-kit0_0.23.3-2_amd64.deb ...
#6 10.14 Unpacking libp11-kit0:amd64 (0.23.3-2) ...
#6 10.19 Selecting previously unselected package libtasn1-6:amd64.
#6 10.19 Preparing to unpack .../08-libtasn1-6_4.10-1.1+deb9u1_amd64.deb ...
#6 10.19 Unpacking libtasn1-6:amd64 (4.10-1.1+deb9u1) ...
#6 10.23 Selecting previously unselected package libgnutls30:amd64.
#6 10.23 Preparing to unpack .../09-libgnutls30_3.5.8-5+deb9u4_amd64.deb ...
#6 10.24 Unpacking libgnutls30:amd64 (3.5.8-5+deb9u4) ...
#6 10.35 Selecting previously unselected package libkeyutils1:amd64.
#6 10.35 Preparing to unpack .../10-libkeyutils1_1.5.9-9_amd64.deb ...
#6 10.35 Unpacking libkeyutils1:amd64 (1.5.9-9) ...
#6 10.38 Selecting previously unselected package libkrb5support0:amd64.
#6 10.39 Preparing to unpack .../11-libkrb5support0_1.15-1+deb9u1_amd64.deb ...
#6 10.39 Unpacking libkrb5support0:amd64 (1.15-1+deb9u1) ...
#6 10.43 Selecting previously unselected package libk5crypto3:amd64.
#6 10.43 Preparing to unpack .../12-libk5crypto3_1.15-1+deb9u1_amd64.deb ...
#6 10.43 Unpacking libk5crypto3:amd64 (1.15-1+deb9u1) ...
#6 10.48 Selecting previously unselected package libkrb5-3:amd64.
#6 10.48 Preparing to unpack .../13-libkrb5-3_1.15-1+deb9u1_amd64.deb ...
#6 10.48 Unpacking libkrb5-3:amd64 (1.15-1+deb9u1) ...
#6 10.55 Selecting previously unselected package libgssapi-krb5-2:amd64.
#6 10.55 Preparing to unpack .../14-libgssapi-krb5-2_1.15-1+deb9u1_amd64.deb ...
#6 10.55 Unpacking libgssapi-krb5-2:amd64 (1.15-1+deb9u1) ...
#6 10.60 Selecting previously unselected package libunistring0:amd64.
#6 10.60 Preparing to unpack .../15-libunistring0_0.9.6+really0.9.3-0.1_amd64.deb ...
#6 10.60 Unpacking libunistring0:amd64 (0.9.6+really0.9.3-0.1) ...
#6 10.71 Selecting previously unselected package libidn2-0:amd64.
#6 10.71 Preparing to unpack .../16-libidn2-0_0.16-1+deb9u1_amd64.deb ...
#6 10.72 Unpacking libidn2-0:amd64 (0.16-1+deb9u1) ...
#6 10.75 Selecting previously unselected package libsasl2-modules-db:amd64.
#6 10.75 Preparing to unpack .../17-libsasl2-modules-db_2.1.27~101-g0780600+dfsg-3_amd64.deb ...
#6 10.75 Unpacking libsasl2-modules-db:amd64 (2.1.27~101-g0780600+dfsg-3) ...
#6 10.79 Selecting previously unselected package libsasl2-2:amd64.
#6 10.79 Preparing to unpack .../18-libsasl2-2_2.1.27~101-g0780600+dfsg-3_amd64.deb ...
#6 10.80 Unpacking libsasl2-2:amd64 (2.1.27~101-g0780600+dfsg-3) ...
#6 10.84 Selecting previously unselected package libldap-common.
#6 10.84 Preparing to unpack .../19-libldap-common_2.4.44+dfsg-5+deb9u3_all.deb ...
#6 10.84 Unpacking libldap-common (2.4.44+dfsg-5+deb9u3) ...
#6 10.88 Selecting previously unselected package libldap-2.4-2:amd64.
#6 10.88 Preparing to unpack .../20-libldap-2.4-2_2.4.44+dfsg-5+deb9u3_amd64.deb ...
#6 10.88 Unpacking libldap-2.4-2:amd64 (2.4.44+dfsg-5+deb9u3) ...
#6 10.94 Selecting previously unselected package libnghttp2-14:amd64.
#6 10.94 Preparing to unpack .../21-libnghttp2-14_1.18.1-1+deb9u1_amd64.deb ...
#6 10.94 Unpacking libnghttp2-14:amd64 (1.18.1-1+deb9u1) ...
#6 10.98 Selecting previously unselected package libpsl5:amd64.
#6 10.98 Preparing to unpack .../22-libpsl5_0.17.0-3_amd64.deb ...
#6 10.98 Unpacking libpsl5:amd64 (0.17.0-3) ...
#6 11.02 Selecting previously unselected package librtmp1:amd64.
#6 11.02 Preparing to unpack .../23-librtmp1_2.4+20151223.gitfa8646d.1-1+b1_amd64.deb ...
#6 11.03 Unpacking librtmp1:amd64 (2.4+20151223.gitfa8646d.1-1+b1) ...
#6 11.06 Selecting previously unselected package libssh2-1:amd64.
#6 11.07 Preparing to unpack .../24-libssh2-1_1.7.0-1+deb9u1_amd64.deb ...
#6 11.07 Unpacking libssh2-1:amd64 (1.7.0-1+deb9u1) ...
#6 11.11 Selecting previously unselected package libcurl3-gnutls:amd64.
#6 11.11 Preparing to unpack .../25-libcurl3-gnutls_7.52.1-5+deb9u9_amd64.deb ...
#6 11.12 Unpacking libcurl3-gnutls:amd64 (7.52.1-5+deb9u9) ...
#6 11.17 Selecting previously unselected package liberror-perl.
#6 11.17 Preparing to unpack .../26-liberror-perl_0.17024-1_all.deb ...
#6 11.18 Unpacking liberror-perl (0.17024-1) ...
#6 11.20 Selecting previously unselected package git-man.
#6 11.20 Preparing to unpack .../27-git-man_1%3a2.11.0-3+deb9u4_all.deb ...
#6 11.21 Unpacking git-man (1:2.11.0-3+deb9u4) ...
#6 11.32 Selecting previously unselected package git.
#6 11.32 Preparing to unpack .../28-git_1%3a2.11.0-3+deb9u4_amd64.deb ...
#6 11.34 Unpacking git (1:2.11.0-3+deb9u4) ...
#6 11.78 Selecting previously unselected package libpython2.7-minimal:amd64.
#6 11.78 Preparing to unpack .../29-libpython2.7-minimal_2.7.13-2+deb9u3_amd64.deb ...
#6 11.78 Unpacking libpython2.7-minimal:amd64 (2.7.13-2+deb9u3) ...
#6 11.88 Selecting previously unselected package python2.7-minimal.
#6 11.88 Preparing to unpack .../30-python2.7-minimal_2.7.13-2+deb9u3_amd64.deb ...
#6 11.89 Unpacking python2.7-minimal (2.7.13-2+deb9u3) ...
#6 12.05 Selecting previously unselected package libssl1.0.2:amd64.
#6 12.05 Preparing to unpack .../31-libssl1.0.2_1.0.2t-1~deb9u1_amd64.deb ...
#6 12.06 Unpacking libssl1.0.2:amd64 (1.0.2t-1~deb9u1) ...
#6 12.20 Selecting previously unselected package mime-support.
#6 12.20 Preparing to unpack .../32-mime-support_3.60_all.deb ...
#6 12.20 Unpacking mime-support (3.60) ...
#6 12.24 Selecting previously unselected package libpython2.7-stdlib:amd64.
#6 12.24 Preparing to unpack .../33-libpython2.7-stdlib_2.7.13-2+deb9u3_amd64.deb ...
#6 12.24 Unpacking libpython2.7-stdlib:amd64 (2.7.13-2+deb9u3) ...
#6 12.47 Selecting previously unselected package python2.7.
#6 12.47 Preparing to unpack .../34-python2.7_2.7.13-2+deb9u3_amd64.deb ...
#6 12.47 Unpacking python2.7 (2.7.13-2+deb9u3) ...
#6 12.52 Selecting previously unselected package binutils.
#6 12.52 Preparing to unpack .../35-binutils_2.28-5_amd64.deb ...
#6 12.53 Unpacking binutils (2.28-5) ...
#6 12.97 Selecting previously unselected package libisl15:amd64.
#6 12.97 Preparing to unpack .../36-libisl15_0.18-1_amd64.deb ...
#6 12.98 Unpacking libisl15:amd64 (0.18-1) ...
#6 13.06 Selecting previously unselected package libmpfr4:amd64.
#6 13.06 Preparing to unpack .../37-libmpfr4_3.1.5-1_amd64.deb ...
#6 13.07 Unpacking libmpfr4:amd64 (3.1.5-1) ...
#6 13.12 Selecting previously unselected package libmpc3:amd64.
#6 13.12 Preparing to unpack .../38-libmpc3_1.0.3-1+b2_amd64.deb ...
#6 13.13 Unpacking libmpc3:amd64 (1.0.3-1+b2) ...
#6 13.16 Selecting previously unselected package cpp-6.
#6 13.16 Preparing to unpack .../39-cpp-6_6.3.0-18+deb9u1_amd64.deb ...
#6 13.16 Unpacking cpp-6 (6.3.0-18+deb9u1) ...
#6 13.91 Selecting previously unselected package cpp.
#6 13.91 Preparing to unpack .../40-cpp_4%3a6.3.0-4_amd64.deb ...
#6 13.91 Unpacking cpp (4:6.3.0-4) ...
#6 13.96 Selecting previously unselected package libcurl3:amd64.
#6 13.96 Preparing to unpack .../41-libcurl3_7.52.1-5+deb9u9_amd64.deb ...
#6 13.96 Unpacking libcurl3:amd64 (7.52.1-5+deb9u9) ...
#6 14.02 Selecting previously unselected package curl.
#6 14.02 Preparing to unpack .../42-curl_7.52.1-5+deb9u9_amd64.deb ...
#6 14.02 Unpacking curl (7.52.1-5+deb9u9) ...
#6 14.07 Selecting previously unselected package libcc1-0:amd64.
#6 14.07 Preparing to unpack .../43-libcc1-0_6.3.0-18+deb9u1_amd64.deb ...
#6 14.08 Unpacking libcc1-0:amd64 (6.3.0-18+deb9u1) ...
#6 14.11 Selecting previously unselected package libgomp1:amd64.
#6 14.11 Preparing to unpack .../44-libgomp1_6.3.0-18+deb9u1_amd64.deb ...
#6 14.12 Unpacking libgomp1:amd64 (6.3.0-18+deb9u1) ...
#6 14.16 Selecting previously unselected package libitm1:amd64.
#6 14.16 Preparing to unpack .../45-libitm1_6.3.0-18+deb9u1_amd64.deb ...
#6 14.17 Unpacking libitm1:amd64 (6.3.0-18+deb9u1) ...
#6 14.20 Selecting previously unselected package libatomic1:amd64.
#6 14.21 Preparing to unpack .../46-libatomic1_6.3.0-18+deb9u1_amd64.deb ...
#6 14.21 Unpacking libatomic1:amd64 (6.3.0-18+deb9u1) ...
#6 14.25 Selecting previously unselected package libasan3:amd64.
#6 14.25 Preparing to unpack .../47-libasan3_6.3.0-18+deb9u1_amd64.deb ...
#6 14.25 Unpacking libasan3:amd64 (6.3.0-18+deb9u1) ...
#6 14.32 Selecting previously unselected package liblsan0:amd64.
#6 14.32 Preparing to unpack .../48-liblsan0_6.3.0-18+deb9u1_amd64.deb ...
#6 14.33 Unpacking liblsan0:amd64 (6.3.0-18+deb9u1) ...
#6 14.37 Selecting previously unselected package libtsan0:amd64.
#6 14.37 Preparing to unpack .../49-libtsan0_6.3.0-18+deb9u1_amd64.deb ...
#12 5.846 Collecting virtualenv==16.2.0
#6 14.38 Unpacking libtsan0:amd64 (6.3.0-18+deb9u1) ...
#6 14.44 Selecting previously unselected package libubsan0:amd64.
#6 14.44 Preparing to unpack .../50-libubsan0_6.3.0-18+deb9u1_amd64.deb ...
#6 14.45 Unpacking libubsan0:amd64 (6.3.0-18+deb9u1) ...
#6 14.49 Selecting previously unselected package libcilkrts5:amd64.
#6 14.49 Preparing to unpack .../51-libcilkrts5_6.3.0-18+deb9u1_amd64.deb ...
#6 14.50 Unpacking libcilkrts5:amd64 (6.3.0-18+deb9u1) ...
#6 14.54 Selecting previously unselected package libmpx2:amd64.
#6 14.54 Preparing to unpack .../52-libmpx2_6.3.0-18+deb9u1_amd64.deb ...
#6 14.54 Unpacking libmpx2:amd64 (6.3.0-18+deb9u1) ...
#6 14.57 Selecting previously unselected package libquadmath0:amd64.
#6 14.57 Preparing to unpack .../53-libquadmath0_6.3.0-18+deb9u1_amd64.deb ...
#6 14.58 Unpacking libquadmath0:amd64 (6.3.0-18+deb9u1) ...
#6 14.62 Selecting previously unselected package libgcc-6-dev:amd64.
#6 14.62 Preparing to unpack .../54-libgcc-6-dev_6.3.0-18+deb9u1_amd64.deb ...
#12 6.901   Downloading https://files.pythonhosted.org/packages/6a/d1/e0d142ce7b8a5c76adbfad01d853bca84c7c0240e35577498e20bc2ade7d/virtualenv-16.2.0-py2.py3-none-any.whl (1.9MB)
#12 6.965 Requirement already satisfied: setuptools>=18.0.0 in /usr/local/lib/python3.7/site-packages (from virtualenv==16.2.0) (41.4.0)
#6 14.62 Unpacking libgcc-6-dev:amd64 (6.3.0-18+deb9u1) ...
#6 14.88 Selecting previously unselected package gcc-6.
#12 6.983 Installing collected packages: virtualenv
#12 7.005 Successfully installed virtualenv-16.2.0
#6 14.88 Preparing to unpack .../55-gcc-6_6.3.0-18+deb9u1_amd64.deb ...
#6 14.88 Unpacking gcc-6 (6.3.0-18+deb9u1) ...
#6 15.60 Selecting previously unselected package gcc.
#6 15.60 Preparing to unpack .../56-gcc_4%3a6.3.0-4_amd64.deb ...
#6 15.60 Unpacking gcc (4:6.3.0-4) ...
#6 15.63 Selecting previously unselected package libc-dev-bin.
#6 15.63 Preparing to unpack .../57-libc-dev-bin_2.24-11+deb9u4_amd64.deb ...
#6 15.64 Unpacking libc-dev-bin (2.24-11+deb9u4) ...
#6 15.68 Selecting previously unselected package linux-libc-dev:amd64.
#6 15.68 Preparing to unpack .../58-linux-libc-dev_4.9.189-3+deb9u2_amd64.deb ...
#6 15.68 Unpacking linux-libc-dev:amd64 (4.9.189-3+deb9u2) ...
#6 15.85 Selecting previously unselected package libc6-dev:amd64.
#6 15.85 Preparing to unpack .../59-libc6-dev_2.24-11+deb9u4_amd64.deb ...
#6 15.85 Unpacking libc6-dev:amd64 (2.24-11+deb9u4) ...
#6 16.16 Selecting previously unselected package libexpat1-dev:amd64.
#6 16.17 Preparing to unpack .../60-libexpat1-dev_2.2.0-2+deb9u3_amd64.deb ...
#6 16.17 Unpacking libexpat1-dev:amd64 (2.2.0-2+deb9u3) ...
#6 16.21 Selecting previously unselected package libffi-dev:amd64.
#6 16.21 Preparing to unpack .../61-libffi-dev_3.2.1-6_amd64.deb ...
#6 16.22 Unpacking libffi-dev:amd64 (3.2.1-6) ...
#6 16.26 Selecting previously unselected package libpython2.7:amd64.
#6 16.26 Preparing to unpack .../62-libpython2.7_2.7.13-2+deb9u3_amd64.deb ...
#6 16.27 Unpacking libpython2.7:amd64 (2.7.13-2+deb9u3) ...
#6 16.40 Selecting previously unselected package libpython2.7-dev:amd64.
#6 16.40 Preparing to unpack .../63-libpython2.7-dev_2.7.13-2+deb9u3_amd64.deb ...
#6 16.41 Unpacking libpython2.7-dev:amd64 (2.7.13-2+deb9u3) ...
#6 18.50 Selecting previously unselected package libssl-dev:amd64.
#6 18.50 Preparing to unpack .../64-libssl-dev_1.1.0l-1~deb9u1_amd64.deb ...
#6 18.50 Unpacking libssl-dev:amd64 (1.1.0l-1~deb9u1) ...
#12 11.16 WARNING: You are using pip version 19.3; however, version 19.3.1 is available.
#12 11.16 You should consider upgrading via the 'pip install --upgrade pip' command.
#12 DONE 11.3s

#13 [build 5/15] RUN pip install tox==2.9.1
#6 18.80 Selecting previously unselected package make.
#6 18.81 Preparing to unpack .../65-make_4.1-9.1_amd64.deb ...
#6 18.82 Unpacking make (4.1-9.1) ...
#6 18.88 Selecting previously unselected package python2.7-dev.
#6 18.88 Preparing to unpack .../66-python2.7-dev_2.7.13-2+deb9u3_amd64.deb ...
#6 18.89 Unpacking python2.7-dev (2.7.13-2+deb9u3) ...
#6 18.92 Selecting previously unselected package zlib1g-dev:amd64.
#6 18.93 Preparing to unpack .../67-zlib1g-dev_1%3a1.2.8.dfsg-5_amd64.deb ...
#6 18.93 Unpacking zlib1g-dev:amd64 (1:1.2.8.dfsg-5) ...
#6 18.99 Setting up libquadmath0:amd64 (6.3.0-18+deb9u1) ...
#6 19.00 Setting up libgomp1:amd64 (6.3.0-18+deb9u1) ...
#6 19.02 Setting up libatomic1:amd64 (6.3.0-18+deb9u1) ...
#6 19.03 Setting up perl-modules-5.24 (5.24.1-3+deb9u5) ...
#6 19.04 Setting up libperl5.24:amd64 (5.24.1-3+deb9u5) ...
#6 19.05 Setting up libnettle6:amd64 (3.3-1+b2) ...
#6 19.07 Setting up git-man (1:2.11.0-3+deb9u4) ...
#6 19.08 Setting up libcc1-0:amd64 (6.3.0-18+deb9u1) ...
#6 19.09 Setting up make (4.1-9.1) ...
#6 19.10 Setting up libasan3:amd64 (6.3.0-18+deb9u1) ...
#6 19.12 Setting up libnghttp2-14:amd64 (1.18.1-1+deb9u1) ...
#6 19.13 Setting up mime-support (3.60) ...
#6 19.16 Setting up libldap-common (2.4.44+dfsg-5+deb9u3) ...
#6 19.18 Setting up libcilkrts5:amd64 (6.3.0-18+deb9u1) ...
#6 19.19 Setting up libubsan0:amd64 (6.3.0-18+deb9u1) ...
#6 19.20 Setting up libtsan0:amd64 (6.3.0-18+deb9u1) ...
#6 19.22 Setting up libssl-dev:amd64 (1.1.0l-1~deb9u1) ...
#6 19.23 Setting up libsasl2-modules-db:amd64 (2.1.27~101-g0780600+dfsg-3) ...
#6 19.24 Setting up linux-libc-dev:amd64 (4.9.189-3+deb9u2) ...
#6 19.25 Setting up libsasl2-2:amd64 (2.1.27~101-g0780600+dfsg-3) ...
#6 19.27 Setting up libffi-dev:amd64 (3.2.1-6) ...
#6 19.28 Setting up libtasn1-6:amd64 (4.10-1.1+deb9u1) ...
#6 19.29 Setting up liblsan0:amd64 (6.3.0-18+deb9u1) ...
#6 19.31 Setting up perl (5.24.1-3+deb9u5) ...
#6 19.33 update-alternatives: using /usr/bin/prename to provide /usr/bin/rename (rename) in auto mode
#6 19.33 update-alternatives: warning: skip creation of /usr/share/man/man1/rename.1.gz because associated file /usr/share/man/man1/prename.1.gz (of link group rename) doesn't exist
#6 19.34 Setting up libssl1.0.2:amd64 (1.0.2t-1~deb9u1) ...
#6 19.41 debconf: unable to initialize frontend: Dialog
#6 19.41 debconf: (TERM is not set, so the dialog frontend is not usable.)
#6 19.41 debconf: falling back to frontend: Readline
#6 19.44 Setting up libmpx2:amd64 (6.3.0-18+deb9u1) ...
#6 19.46 Setting up libgmp10:amd64 (2:6.1.2+dfsg-1) ...
#6 19.47 Setting up libssh2-1:amd64 (1.7.0-1+deb9u1) ...
#6 19.48 Processing triggers for libc-bin (2.24-11+deb9u4) ...
#6 19.50 Setting up libunistring0:amd64 (0.9.6+really0.9.3-0.1) ...
#6 19.52 Setting up libp11-kit0:amd64 (0.23.3-2) ...
#6 19.54 Setting up libmpfr4:amd64 (3.1.5-1) ...
#6 19.55 Setting up libmpc3:amd64 (1.0.3-1+b2) ...
#6 19.56 Setting up binutils (2.28-5) ...
#6 19.57 Setting up libc-dev-bin (2.24-11+deb9u4) ...
#6 19.59 Setting up libkeyutils1:amd64 (1.5.9-9) ...
#6 19.60 Setting up libpython2.7-minimal:amd64 (2.7.13-2+deb9u3) ...
#6 19.62 Setting up libc6-dev:amd64 (2.24-11+deb9u4) ...
#6 19.63 Setting up libitm1:amd64 (6.3.0-18+deb9u1) ...
#6 19.64 Setting up libpython2.7-stdlib:amd64 (2.7.13-2+deb9u3) ...
#6 19.66 Setting up libidn11:amd64 (1.33-1) ...
#6 19.67 Setting up python2.7-minimal (2.7.13-2+deb9u3) ...
#6 19.93 Linking and byte-compiling packages for runtime python2.7...
#6 19.94 Setting up zlib1g-dev:amd64 (1:1.2.8.dfsg-5) ...
#6 19.97 Setting up libidn2-0:amd64 (0.16-1+deb9u1) ...
#6 19.99 Setting up libgcc-6-dev:amd64 (6.3.0-18+deb9u1) ...
#6 20.00 Setting up liberror-perl (0.17024-1) ...
#6 20.02 Setting up libpsl5:amd64 (0.17.0-3) ...
#6 20.03 Setting up python2.7 (2.7.13-2+deb9u3) ...
#6 20.69 Setting up libkrb5support0:amd64 (1.15-1+deb9u1) ...
#6 20.71 Setting up libhogweed4:amd64 (3.3-1+b2) ...
#6 20.72 Setting up libisl15:amd64 (0.18-1) ...
#6 20.73 Setting up libpython2.7:amd64 (2.7.13-2+deb9u3) ...
#6 20.74 Setting up libexpat1-dev:amd64 (2.2.0-2+deb9u3) ...
#6 20.75 Setting up libpython2.7-dev:amd64 (2.7.13-2+deb9u3) ...
#6 20.77 Setting up cpp-6 (6.3.0-18+deb9u1) ...
#6 20.79 Setting up python2.7-dev (2.7.13-2+deb9u3) ...
#6 20.80 Setting up cpp (4:6.3.0-4) ...
#6 20.82 Setting up libk5crypto3:amd64 (1.15-1+deb9u1) ...
#6 20.83 Setting up libgnutls30:amd64 (3.5.8-5+deb9u4) ...
#6 20.85 Setting up librtmp1:amd64 (2.4+20151223.gitfa8646d.1-1+b1) ...
#6 20.86 Setting up gcc-6 (6.3.0-18+deb9u1) ...
#6 20.88 Setting up libldap-2.4-2:amd64 (2.4.44+dfsg-5+deb9u3) ...
#6 20.89 Setting up libkrb5-3:amd64 (1.15-1+deb9u1) ...
#6 20.91 Setting up gcc (4:6.3.0-4) ...
#6 20.93 Setting up libgssapi-krb5-2:amd64 (1.15-1+deb9u1) ...
#6 20.95 Setting up libcurl3:amd64 (7.52.1-5+deb9u9) ...
#6 20.96 Setting up libcurl3-gnutls:amd64 (7.52.1-5+deb9u9) ...
#6 20.97 Setting up git (1:2.11.0-3+deb9u4) ...
#6 21.01 Setting up curl (7.52.1-5+deb9u9) ...
#6 21.02 Processing triggers for libc-bin (2.24-11+deb9u4) ...
#6 DONE 21.4s

#8 [build 1/15] COPY docker-compose-entrypoint.sh /usr/local/bin/
#8 DONE 0.1s

#10 [build 2/15] COPY --from=docker-cli /usr/local/bin/docker /usr/local/bin...
#10 DONE 0.2s

#11 [build 3/15] WORKDIR /code/
#11 DONE 0.0s

#12 [build 4/15] RUN pip install virtualenv==16.2.0
#13 5.059 Collecting tox==2.9.1
#13 6.116   Downloading https://files.pythonhosted.org/packages/1d/4e/20c679f8c5948f7c48591fde33d442e716af66a31a88f5791850a75041eb/tox-2.9.1-py2.py3-none-any.whl (73kB)
#13 6.156 Collecting pluggy<1.0,>=0.3.0
#13 6.159   Downloading https://files.pythonhosted.org/packages/a0/28/85c7aa31b80d150b772fbe4a229487bc6644da9ccb7e427dd8cc60cb8a62/pluggy-0.13.1-py2.py3-none-any.whl
#13 6.197 Collecting py>=1.4.17
#13 6.200   Downloading https://files.pythonhosted.org/packages/76/bc/394ad449851729244a97857ee14d7cba61ddb268dce3db538ba2f2ba1f0f/py-1.8.0-py2.py3-none-any.whl (83kB)
#13 6.216 Requirement already satisfied: virtualenv>=1.11.2; python_version != "3.2" in /usr/local/lib/python3.7/site-packages (from tox==2.9.1) (16.2.0)
#13 6.245 Collecting six
#13 6.248   Downloading https://files.pythonhosted.org/packages/65/26/32b8464df2a97e6dd1b656ed26b2c194606c16fe163c695a992b36c11cdf/six-1.13.0-py2.py3-none-any.whl
#13 6.299 Collecting importlib-metadata>=0.12; python_version < "3.8"
#13 6.302   Downloading https://files.pythonhosted.org/packages/ed/82/ebece33bc20b9097683d09e47563d487e411e2cf3a37789d7ec0a88c4ce4/importlib_metadata-1.1.0-py2.py3-none-any.whl
#13 6.320 Requirement already satisfied: setuptools>=18.0.0 in /usr/local/lib/python3.7/site-packages (from virtualenv>=1.11.2; python_version != "3.2"->tox==2.9.1) (41.4.0)
#13 6.339 Collecting zipp>=0.5
#13 6.341   Downloading https://files.pythonhosted.org/packages/74/3d/1ee25a26411ba0401b43c6376d2316a71addcc72ef8690b101b4ea56d76a/zipp-0.6.0-py2.py3-none-any.whl
#13 6.372 Collecting more-itertools
#13 6.376   Downloading https://files.pythonhosted.org/packages/5c/1d/3df99de956abb96305956e09e6a1fa955883295e1f28808f9c97b3d5364d/more_itertools-8.0.0-py3-none-any.whl (40kB)
#13 6.415 Installing collected packages: more-itertools, zipp, importlib-metadata, pluggy, py, six, tox
#13 6.572 Successfully installed importlib-metadata-1.1.0 more-itertools-8.0.0 pluggy-0.13.1 py-1.8.0 six-1.13.0 tox-2.9.1 zipp-0.6.0
#13 6.589 WARNING: You are using pip version 19.3; however, version 19.3.1 is available.
#13 6.589 You should consider upgrading via the 'pip install --upgrade pip' command.
#13 DONE 6.8s

#14 [build 6/15] COPY requirements.txt .
#14 DONE 0.1s

#15 [build 7/15] COPY requirements-dev.txt .
#15 DONE 0.1s

#16 [build 8/15] COPY .pre-commit-config.yaml .
#16 DONE 0.2s

#17 [build 9/15] COPY tox.ini .
#17 DONE 0.0s

#18 [build 10/15] COPY setup.py .
#18 DONE 0.1s

#19 [build 11/15] COPY README.md .
#19 DONE 0.0s

#20 [build 12/15] COPY compose compose/
#20 DONE 0.1s

#21 [build 13/15] RUN tox --notest
#21 0.797 py27 create: /code/.tox/py27
#12 5.823 Collecting virtualenv==16.2.0
#12 6.845   Downloading https://files.pythonhosted.org/packages/6a/d1/e0d142ce7b8a5c76adbfad01d853bca84c7c0240e35577498e20bc2ade7d/virtualenv-16.2.0-py2.py3-none-any.whl (1.9MB)
#12 6.912 Requirement already satisfied: setuptools>=18.0.0 in /usr/local/lib/python3.7/site-packages (from virtualenv==16.2.0) (41.4.0)
#12 6.929 Installing collected packages: virtualenv
#12 6.955 Successfully installed virtualenv-16.2.0
#12 11.11 WARNING: You are using pip version 19.3; however, version 19.3.1 is available.
#12 11.11 You should consider upgrading via the 'pip install --upgrade pip' command.
#12 DONE 11.3s

#13 [build 5/15] RUN pip install tox==2.9.1
#13 5.092 Collecting tox==2.9.1
#13 6.115   Downloading https://files.pythonhosted.org/packages/1d/4e/20c679f8c5948f7c48591fde33d442e716af66a31a88f5791850a75041eb/tox-2.9.1-py2.py3-none-any.whl (73kB)
#13 6.137 Requirement already satisfied: virtualenv>=1.11.2; python_version != "3.2" in /usr/local/lib/python3.7/site-packages (from tox==2.9.1) (16.2.0)
#13 6.178 Collecting py>=1.4.17
#13 6.182   Downloading https://files.pythonhosted.org/packages/76/bc/394ad449851729244a97857ee14d7cba61ddb268dce3db538ba2f2ba1f0f/py-1.8.0-py2.py3-none-any.whl (83kB)
#13 6.217 Collecting six
#21 12.33 py27 installdeps: -rrequirements.txt, -rrequirements-dev.txt
#13 6.220   Downloading https://files.pythonhosted.org/packages/65/26/32b8464df2a97e6dd1b656ed26b2c194606c16fe163c695a992b36c11cdf/six-1.13.0-py2.py3-none-any.whl
#13 6.250 Collecting pluggy<1.0,>=0.3.0
#13 6.253   Downloading https://files.pythonhosted.org/packages/a0/28/85c7aa31b80d150b772fbe4a229487bc6644da9ccb7e427dd8cc60cb8a62/pluggy-0.13.1-py2.py3-none-any.whl
#13 6.268 Requirement already satisfied: setuptools>=18.0.0 in /usr/local/lib/python3.7/site-packages (from virtualenv>=1.11.2; python_version != "3.2"->tox==2.9.1) (41.4.0)
#13 6.318 Collecting importlib-metadata>=0.12; python_version < "3.8"
#13 6.321   Downloading https://files.pythonhosted.org/packages/ed/82/ebece33bc20b9097683d09e47563d487e411e2cf3a37789d7ec0a88c4ce4/importlib_metadata-1.1.0-py2.py3-none-any.whl
#13 6.358 Collecting zipp>=0.5
#13 6.361   Downloading https://files.pythonhosted.org/packages/74/3d/1ee25a26411ba0401b43c6376d2316a71addcc72ef8690b101b4ea56d76a/zipp-0.6.0-py2.py3-none-any.whl
#13 6.395 Collecting more-itertools
#13 6.398   Downloading https://files.pythonhosted.org/packages/5c/1d/3df99de956abb96305956e09e6a1fa955883295e1f28808f9c97b3d5364d/more_itertools-8.0.0-py3-none-any.whl (40kB)
#13 6.435 Installing collected packages: py, six, more-itertools, zipp, importlib-metadata, pluggy, tox
#13 6.580 Successfully installed importlib-metadata-1.1.0 more-itertools-8.0.0 pluggy-0.13.1 py-1.8.0 six-1.13.0 tox-2.9.1 zipp-0.6.0
#13 6.597 WARNING: You are using pip version 19.3; however, version 19.3.1 is available.
#13 6.597 You should consider upgrading via the 'pip install --upgrade pip' command.
#13 DONE 6.7s

#14 [build 6/15] COPY requirements.txt .
#14 DONE 0.1s

#15 [build 7/15] COPY requirements-dev.txt .
#15 DONE 0.1s

#16 [build 8/15] COPY .pre-commit-config.yaml .
#16 DONE 0.0s

#17 [build 9/15] COPY tox.ini .
#17 DONE 0.1s

#18 [build 10/15] COPY setup.py .
#18 DONE 0.1s

#19 [build 11/15] COPY README.md .
#19 DONE 0.1s

#20 [build 12/15] COPY compose compose/
#20 DONE 0.1s

#21 [build 13/15] RUN tox --notest
#21 0.854 py27 create: /code/.tox/py27
#21 12.06 py27 installdeps: -rrequirements.txt, -rrequirements-dev.txt
#21 30.13 py27 develop-inst: /code
#21 38.27 py27 installed: DEPRECATION: Python 2.7 will reach the end of its life on January 1st, 2020. Please upgrade your Python as Python 2.7 won't be maintained after that date. A future version of pip will drop support for Python 2.7. More details about Python 2 support in pip, can be found at https://pip.pypa.io/en/latest/development/release-process/#python-2-support,atomicwrites==1.3.0,attrs==19.3.0,backports.shutil-get-terminal-size==1.0.0,backports.ssl-match-hostname==3.5.0.1,bcrypt==3.1.7,cached-property==1.3.0,certifi==2017.4.17,cffi==1.13.2,chardet==3.0.4,configparser==4.0.2,coverage==4.4.2,cryptography==2.8,ddt==1.2.0,docker==4.1.0,# Editable install with no version control (docker-compose==1.26.0.dev0),-e /code,docker-pycreds==0.4.0,dockerpty==0.4.1,docopt==0.6.2,enum34==1.1.6,flake8==3.5.0,funcsigs==1.0.2,functools32==3.2.3.post2,idna==2.5,ipaddress==1.0.18,jsonschema==3.0.1,mccabe==0.6.1,mock==3.0.5,more-itertools==5.0.0,paramiko==2.6.0,pluggy==0.6.0,py==1.8.0,pycodestyle==2.3.1,pycparser==2.19,pyflakes==1.6.0,PyNaCl==1.3.0,pyrsistent==0.15.6,PySocks==1.6.7,pytest==3.6.3,pytest-cov==2.5.1,PyYAML==4.2b1,requests==2.22.0,six==1.12.0,subprocess32==3.5.4,texttable==1.6.2,urllib3==1.25.7,websocket-client==0.32.0
#21 38.27 py37 create: /code/.tox/py37
#21 49.00 py37 installdeps: -rrequirements.txt, -rrequirements-dev.txt
#21 66.87 py37 develop-inst: /code
#21 68.13 py37 installed: atomicwrites==1.3.0,attrs==19.3.0,backports.shutil-get-terminal-size==1.0.0,bcrypt==3.1.7,cached-property==1.3.0,certifi==2017.4.17,cffi==1.13.2,chardet==3.0.4,coverage==4.4.2,cryptography==2.8,ddt==1.2.0,docker==4.1.0,# Editable install with no version control (docker-compose==1.26.0.dev0),-e /code,docker-pycreds==0.4.0,dockerpty==0.4.1,docopt==0.6.2,flake8==3.5.0,idna==2.5,ipaddress==1.0.18,jsonschema==3.0.1,mccabe==0.6.1,mock==3.0.5,more-itertools==8.0.0,paramiko==2.6.0,pluggy==0.6.0,py==1.8.0,pycodestyle==2.3.1,pycparser==2.19,pyflakes==1.6.0,PyNaCl==1.3.0,pyrsistent==0.15.6,PySocks==1.6.7,pytest==3.6.3,pytest-cov==2.5.1,PyYAML==4.2b1,requests==2.22.0,six==1.12.0,texttable==1.6.2,urllib3==1.25.7,websocket-client==0.32.0
#21 68.13 pre-commit create: /code/.tox/pre-commit
#21 78.81 pre-commit installdeps: pre-commit
#21 90.54 pre-commit installed: aspy.yaml==1.3.0,cfgv==2.0.1,identify==1.4.7,importlib-metadata==1.1.0,more-itertools==8.0.0,nodeenv==1.3.3,pre-commit==1.20.0,PyYAML==5.2,six==1.13.0,toml==0.10.0,virtualenv==16.7.8,zipp==0.6.0
#21 90.54 ___________________________________ summary ____________________________________
#21 90.54   py27: skipped tests
#21 90.54   py37: skipped tests
#21 90.54   pre-commit: skipped tests
#21 90.54   congratulations :)
#21 DONE 91.3s

#22 [build 14/15] COPY . .
#22 DONE 3.3s

#23 [build 15/15] RUN script/build/linux-entrypoint
#23 0.611 + CODE_PATH=/code
#23 0.611 + VENV=/code/.tox/py37
#23 0.611 + cd /code
#23 0.611 + mkdir -p dist
#23 0.614 + chmod 777 dist
#23 0.615 + /code/.tox/py37/bin/pip3 install -q -r requirements-build.txt
#23 18.60 + '[' -z unknown ']'
#23 18.60 + echo unknown
#23 18.60 + export PATH=/code/pyinstaller:/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
#23 18.60 + PATH=/code/pyinstaller:/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
#23 18.60 + '[' '!' -z '' ']'
#23 18.60 + echo 'NOT compiling bootloader!!!'
#23 18.60 NOT compiling bootloader!!!
#23 18.60 + /code/.tox/py37/bin/pyinstaller --exclude-module pycrypto --exclude-module PyInstaller docker-compose.spec
#23 18.75 41 INFO: PyInstaller: 3.5
#23 18.75 41 INFO: Python: 3.7.4
#23 18.75 42 INFO: Platform: Linux-4.15.0-1048-aws-x86_64-with-debian-9.11
#23 18.75 43 INFO: UPX is not available.
#23 18.76 45 INFO: Extending PYTHONPATH with paths
#23 18.76 ['/code/bin', '/code']
#23 18.76 45 INFO: checking Analysis
#23 18.76 45 INFO: Building Analysis because Analysis-00.toc is non existent
#23 18.76 45 INFO: Initializing module dependency graph...
#23 18.76 46 INFO: Initializing module graph hooks...
#23 18.76 47 INFO: Analyzing base_library.zip ...
#23 21.33 2617 INFO: running Analysis Analysis-00.toc
#23 21.34 2633 INFO: Caching module hooks...
#23 21.35 2638 INFO: Analyzing bin/docker-compose
#23 21.43 2719 INFO: Processing pre-find module path hook   distutils
#23 21.43 2719 INFO: distutils: retargeting to non-venv dir '/usr/local/lib/python3.7/distutils'
#23 21.61 2899 INFO: Processing pre-safe import module hook   urllib3.packages.six.moves
#23 22.47 3763 INFO: Processing pre-safe import module hook   six.moves
#23 24.88 6166 INFO: Loading module hooks...
#23 24.88 6166 INFO: Loading module hook "hook-certifi.py"...
#23 24.88 6167 INFO: Loading module hook "hook-jsonschema.py"...
#23 24.88 6169 INFO: Loading module hook "hook-xml.py"...
#23 24.92 6208 INFO: Loading module hook "hook-nacl.py"...
#23 24.92 6210 INFO: Loading module hook "hook-distutils.py"...
#23 24.92 6212 INFO: Loading module hook "hook-pkg_resources.py"...
#23 25.21 6503 INFO: Processing pre-safe import module hook   win32com
#23 25.25 6544 INFO: Loading module hook "hook-pydoc.py"...
#23 25.26 6544 INFO: Loading module hook "hook-sysconfig.py"...
#23 25.26 6552 INFO: Loading module hook "hook-encodings.py"...
#23 25.30 6593 INFO: Loading module hook "hook-cryptography.py"...
#23 25.45 6739 INFO: Looking for ctypes DLLs
#23 25.48 6768 INFO: Analyzing run-time hooks ...
#23 25.49 6776 INFO: Including run-time hook 'pyi_rth_certifi.py'
#23 25.49 6778 INFO: Including run-time hook 'pyi_rth_pkgres.py'
#23 25.50 6787 INFO: Looking for dynamic libraries
#23 26.02 7308 INFO: Looking for eggs
#23 26.02 7308 INFO: Using Python library /usr/local/lib/libpython3.7m.so.1.0
#23 26.03 7320 INFO: Warnings written to /code/build/docker-compose/warn-docker-compose.txt
#23 26.08 7372 INFO: Graph cross-reference written to /code/build/docker-compose/xref-docker-compose.html
#23 26.11 7395 INFO: checking PYZ
#23 26.11 7395 INFO: Building PYZ because PYZ-00.toc is non existent
#23 26.11 7395 INFO: Building PYZ (ZlibArchive) /code/build/docker-compose/PYZ-00.pyz
#23 26.80 8088 INFO: Building PYZ (ZlibArchive) /code/build/docker-compose/PYZ-00.pyz completed successfully.
#23 26.81 8099 INFO: checking PKG
#23 26.81 8100 INFO: Building PKG because PKG-00.toc is non existent
#23 26.81 8100 INFO: Building PKG (CArchive) PKG-00.pkg
#21 130.8 py27 develop-inst: /code
#21 138.8 py27 installed: DEPRECATION: Python 2.7 will reach the end of its life on January 1st, 2020. Please upgrade your Python as Python 2.7 won't be maintained after that date. A future version of pip will drop support for Python 2.7. More details about Python 2 support in pip, can be found at https://pip.pypa.io/en/latest/development/release-process/#python-2-support,atomicwrites==1.3.0,attrs==19.3.0,backports.shutil-get-terminal-size==1.0.0,backports.ssl-match-hostname==3.5.0.1,bcrypt==3.1.7,cached-property==1.3.0,certifi==2017.4.17,cffi==1.13.2,chardet==3.0.4,configparser==4.0.2,coverage==4.4.2,cryptography==2.8,ddt==1.2.0,docker==4.1.0,# Editable install with no version control (docker-compose==1.26.0.dev0),-e /code,docker-pycreds==0.4.0,dockerpty==0.4.1,docopt==0.6.2,enum34==1.1.6,flake8==3.5.0,funcsigs==1.0.2,functools32==3.2.3.post2,idna==2.5,ipaddress==1.0.18,jsonschema==3.0.1,mccabe==0.6.1,mock==3.0.5,more-itertools==5.0.0,paramiko==2.6.0,pluggy==0.6.0,py==1.8.0,pycodestyle==2.3.1,pycparser==2.19,pyflakes==1.6.0,PyNaCl==1.3.0,pyrsistent==0.15.6,PySocks==1.6.7,pytest==3.6.3,pytest-cov==2.5.1,PyYAML==4.2b1,requests==2.22.0,six==1.12.0,subprocess32==3.5.4,texttable==1.6.2,urllib3==1.25.7,websocket-client==0.32.0
#21 138.8 py37 create: /code/.tox/py37
#23 36.54 17827 INFO: Building PKG (CArchive) PKG-00.pkg completed successfully.
#23 36.54 17830 INFO: Bootloader /code/.tox/py37/lib/python3.7/site-packages/PyInstaller/bootloader/Linux-64bit/run
#23 36.54 17830 INFO: checking EXE
#23 36.54 17830 INFO: Building EXE because EXE-00.toc is non existent
#23 36.54 17830 INFO: Building EXE from EXE-00.toc
#23 36.54 17831 INFO: Appending archive to ELF section in EXE /code/dist/docker-compose
#23 36.60 17885 INFO: Building EXE from EXE-00.toc completed successfully.
#23 36.66 + ls -la dist/
#23 36.66 total 16652
#23 36.66 drwxrwxrwx 2 root root     4096 Dec  3 07:53 .
#23 36.66 drwxr-xr-x 1 root root     4096 Dec  3 07:53 ..
#23 36.66 -rwxr-xr-x 1 root root 17036848 Dec  3 07:53 docker-compose
#23 36.66 + ldd dist/docker-compose
#23 36.67 	linux-vdso.so.1 (0x00007ffd791ca000)
#23 36.67 	libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007fbd5a71b000)
#23 36.67 	libz.so.1 => /lib/x86_64-linux-gnu/libz.so.1 (0x00007fbd5a501000)
#23 36.67 	libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007fbd5a162000)
#23 36.67 	/lib64/ld-linux-x86-64.so.2 (0x00007fbd5a91f000)
#23 36.67 + mv dist/docker-compose /usr/local/bin
#23 36.67 + docker-compose version
#23 37.16 docker-compose version 1.26.0dev, build unknown
#23 37.16 docker-py version: 4.1.0
#23 37.16 CPython version: 3.7.4
#23 37.16 OpenSSL version: OpenSSL 1.1.0l  10 Sep 2019
#23 DONE 37.5s

#24 exporting to image
#24 exporting layers
#21 149.5 py37 installdeps: -rrequirements.txt, -rrequirements-dev.txt
#24 exporting layers 5.0s done
#24 writing image sha256:007d1204ebf547aaa45771b7603930491e1b08e469c864d7b74d31bd742f9253 done
#24 naming to docker.io/library/compose:debian done
#24 DONE 5.0s
[Pipeline] sh
+ docker save -o debian.tar compose:debian
[Pipeline] stash
Stashed 1 file(s) to https://corp-us-east-1-jenkins-k8s-maste-jenkinsartifacts-1lzm7adht5e1j.s3.amazonaws.com/public/compose/ndeloof/28/stashes/debian.tgz
[Pipeline] checkout
using credential sf-release-bot.github.ssh
Fetching changes from the remote Git repository
Fetching without tags
Checking out Revision f0d8706f3473426bfcc85197834187726323acf2 (ndeloof)
Commit message: "WiP"
 > git rev-parse --is-inside-work-tree # timeout=10
 > git config remote.origin.url git@github.com:docker/compose.git # timeout=10
Fetching upstream changes from git@github.com:docker/compose.git
 > git --version # timeout=10
using GIT_SSH to set credentials docker-jenkins user on github.com
 > git fetch --no-tags --progress -- git@github.com:docker/compose.git +refs/heads/ndeloof:refs/remotes/origin/ndeloof
 > git config core.sparsecheckout # timeout=10
 > git checkout -f f0d8706f3473426bfcc85197834187726323acf2
[Pipeline] sh
+ docker build -t compose:debian --target build --build-arg BUILD_PLATFORM=debian .
#2 [internal] load .dockerignore
#2 transferring context: 34B done
#2 DONE 0.0s

#1 [internal] load build definition from Dockerfile
#1 transferring dockerfile: 38B done
#1 DONE 0.0s

#4 [internal] load metadata for docker.io/library/python:3.7.4-slim-stretch
#4 DONE 0.1s

#3 [internal] load metadata for docker.io/library/docker:18.09.7
#3 DONE 0.1s

#5 [build-debian 1/2] FROM docker.io/library/python:3.7.4-slim-stretch@sha2...
#5 DONE 0.0s

#9 [docker-cli 1/1] FROM docker.io/library/docker:18.09.7@sha256:310156c950...
#9 DONE 0.0s

#7 [internal] load build context
#21 271.9 py37 develop-inst: /code
#21 273.1 py37 installed: atomicwrites==1.3.0,attrs==19.3.0,backports.shutil-get-terminal-size==1.0.0,bcrypt==3.1.7,cached-property==1.3.0,certifi==2017.4.17,cffi==1.13.2,chardet==3.0.4,coverage==4.4.2,cryptography==2.8,ddt==1.2.0,docker==4.1.0,# Editable install with no version control (docker-compose==1.26.0.dev0),-e /code,docker-pycreds==0.4.0,dockerpty==0.4.1,docopt==0.6.2,flake8==3.5.0,idna==2.5,ipaddress==1.0.18,jsonschema==3.0.1,mccabe==0.6.1,mock==3.0.5,more-itertools==8.0.0,paramiko==2.6.0,pluggy==0.6.0,py==1.8.0,pycodestyle==2.3.1,pycparser==2.19,pyflakes==1.6.0,PyNaCl==1.3.0,pyrsistent==0.15.6,PySocks==1.6.7,pytest==3.6.3,pytest-cov==2.5.1,PyYAML==4.2b1,requests==2.22.0,six==1.12.0,texttable==1.6.2,urllib3==1.25.7,websocket-client==0.32.0
#21 273.1 pre-commit create: /code/.tox/pre-commit
#7 transferring context: 617.20MB 5.0s
#7 transferring context: 1.25GB 10.1s
#7 transferring context: 1.26GB 10.2s done
#7 DONE 10.3s

#18 [build 10/15] COPY setup.py .
#18 CACHED

#6 [build-debian 2/2] RUN apt-get update && apt-get install --no-install-re...
#6 CACHED

#17 [build 9/15] COPY tox.ini .
#17 CACHED

#11 [build 3/15] WORKDIR /code/
#11 CACHED

#14 [build 6/15] COPY requirements.txt .
#14 CACHED

#16 [build 8/15] COPY .pre-commit-config.yaml .
#16 CACHED

#10 [build 2/15] COPY --from=docker-cli /usr/local/bin/docker /usr/local/bin...
#10 CACHED

#8 [build 1/15] COPY docker-compose-entrypoint.sh /usr/local/bin/
#8 CACHED

#12 [build 4/15] RUN pip install virtualenv==16.2.0
#12 CACHED

#19 [build 11/15] COPY README.md .
#19 CACHED

#20 [build 12/15] COPY compose compose/
#20 CACHED

#15 [build 7/15] COPY requirements-dev.txt .
#15 CACHED

#13 [build 5/15] RUN pip install tox==2.9.1
#13 CACHED

#21 [build 13/15] RUN tox --notest
#21 CACHED

#22 [build 14/15] COPY . .
#21 283.9 pre-commit installdeps: pre-commit
#22 DONE 7.8s

#23 [build 15/15] RUN script/build/linux-entrypoint
#23 0.822 + CODE_PATH=/code
#23 0.823 + VENV=/code/.tox/py37
#23 0.824 + cd /code
#23 0.824 + mkdir -p dist
#23 0.843 + chmod 777 dist
#23 0.845 + /code/.tox/py37/bin/pip3 install -q -r requirements-build.txt
#21 295.6 pre-commit installed: aspy.yaml==1.3.0,cfgv==2.0.1,identify==1.4.7,importlib-metadata==1.1.0,more-itertools==8.0.0,nodeenv==1.3.3,pre-commit==1.20.0,PyYAML==5.2,six==1.13.0,toml==0.10.0,virtualenv==16.7.8,zipp==0.6.0
#21 295.6 ___________________________________ summary ____________________________________
#21 295.6   py27: skipped tests
#21 295.6   py37: skipped tests
#21 295.6   pre-commit: skipped tests
#21 295.6   congratulations :)
#21 DONE 295.9s

#22 [build 14/15] COPY . .
#22 DONE 5.5s

#23 [build 15/15] RUN script/build/linux-entrypoint
#23 0.609 + CODE_PATH=/code
#23 0.609 + VENV=/code/.tox/py37
#23 0.609 + cd /code
#23 0.609 + mkdir -p dist
#23 0.613 + chmod 777 dist
#23 0.613 + /code/.tox/py37/bin/pip3 install -q -r requirements-build.txt
#23 19.34 + '[' -z unknown ']'
#23 19.34 + echo unknown
#23 19.34 + export PATH=/code/pyinstaller:/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
#23 19.34 + PATH=/code/pyinstaller:/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
#23 19.34 NOT compiling bootloader!!!
#23 19.34 + '[' '!' -z '' ']'
#23 19.34 + echo 'NOT compiling bootloader!!!'
#23 19.34 + /code/.tox/py37/bin/pyinstaller --exclude-module pycrypto --exclude-module PyInstaller docker-compose.spec
#23 19.50 38 INFO: PyInstaller: 3.5
#23 19.50 38 INFO: Python: 3.7.4
#23 19.50 39 INFO: Platform: Linux-4.15.0-1048-aws-x86_64-with-debian-9.11
#23 19.51 41 INFO: UPX is not available.
#23 19.51 42 INFO: Extending PYTHONPATH with paths
#23 19.51 ['/code/bin', '/code']
#23 19.51 42 INFO: checking Analysis
#23 19.51 42 INFO: Building Analysis because Analysis-00.toc is non existent
#23 19.51 42 INFO: Initializing module dependency graph...
#23 19.51 44 INFO: Initializing module graph hooks...
#23 19.51 45 INFO: Analyzing base_library.zip ...
#23 22.02 2556 INFO: running Analysis Analysis-00.toc
#23 22.04 2575 INFO: Caching module hooks...
#23 22.04 2579 INFO: Analyzing bin/docker-compose
#23 22.13 2662 INFO: Processing pre-find module path hook   distutils
#23 22.13 2662 INFO: distutils: retargeting to non-venv dir '/usr/local/lib/python3.7/distutils'
#23 22.31 2848 INFO: Processing pre-safe import module hook   urllib3.packages.six.moves
#23 23.25 3786 INFO: Processing pre-safe import module hook   six.moves
#23 25.80 6330 INFO: Loading module hooks...
#23 25.80 6331 INFO: Loading module hook "hook-certifi.py"...
#23 25.80 6332 INFO: Loading module hook "hook-jsonschema.py"...
#23 25.80 6334 INFO: Loading module hook "hook-xml.py"...
#23 25.84 6373 INFO: Loading module hook "hook-nacl.py"...
#23 25.84 6375 INFO: Loading module hook "hook-distutils.py"...
#23 25.84 6377 INFO: Loading module hook "hook-pkg_resources.py"...
#23 26.20 6731 INFO: Processing pre-safe import module hook   win32com
#23 26.20 6733 INFO: Loading module hook "hook-pydoc.py"...
#23 26.20 6733 INFO: Loading module hook "hook-sysconfig.py"...
#23 26.20 6740 INFO: Loading module hook "hook-encodings.py"...
#23 26.24 6778 INFO: Loading module hook "hook-cryptography.py"...
#23 26.47 7001 INFO: Looking for ctypes DLLs
#23 26.55 7088 INFO: Analyzing run-time hooks ...
#23 26.56 7097 INFO: Including run-time hook 'pyi_rth_certifi.py'
#23 26.56 7098 INFO: Including run-time hook 'pyi_rth_pkgres.py'
#23 26.57 7108 INFO: Looking for dynamic libraries
#23 27.14 7676 INFO: Looking for eggs
#23 27.14 7676 INFO: Using Python library /usr/local/lib/libpython3.7m.so.1.0
#23 27.15 7687 INFO: Warnings written to /code/build/docker-compose/warn-docker-compose.txt
#23 27.21 7740 INFO: Graph cross-reference written to /code/build/docker-compose/xref-docker-compose.html
#23 27.23 7763 INFO: checking PYZ
#23 27.23 7763 INFO: Building PYZ because PYZ-00.toc is non existent
#23 27.23 7763 INFO: Building PYZ (ZlibArchive) /code/build/docker-compose/PYZ-00.pyz
#23 27.91 8450 INFO: Building PYZ (ZlibArchive) /code/build/docker-compose/PYZ-00.pyz completed successfully.
#23 27.93 8461 INFO: checking PKG
#23 27.93 8461 INFO: Building PKG because PKG-00.toc is non existent
#23 27.93 8461 INFO: Building PKG (CArchive) PKG-00.pkg
#23 18.59 + '[' -z unknown ']'
#23 18.59 + echo unknown
#23 18.59 + export PATH=/code/pyinstaller:/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
#23 18.59 + PATH=/code/pyinstaller:/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
#23 18.59 + '[' '!' -z 1 ']'
#23 18.60 + git clone --single-branch --branch develop https://github.com/pyinstaller/pyinstaller.git /tmp/pyinstaller
#23 18.60 Cloning into '/tmp/pyinstaller'...
#23 21.82 + cd /tmp/pyinstaller/bootloader
#23 21.82 + git checkout v3.5
#23 21.84 Note: checking out 'v3.5'.
#23 21.84 
#23 21.84 You are in 'detached HEAD' state. You can look around, make experimental
#23 21.84 changes and commit them, and you can discard any commits you make in this
#23 21.84 state without impacting any branches by performing another checkout.
#23 21.84 
#23 21.84 If you want to create a new branch to retain commits you create, you may
#23 21.84 do so (now or later) by using -b with the checkout command again. Example:
#23 21.84 
#23 21.84   git checkout -b <new-branch-name>
#23 21.84 
#23 21.84 HEAD is now at 498e6ee0 Release 3.5.
#23 21.84 + /code/.tox/py37/bin/python3 ./waf configure --no-lsb all
#23 22.03 Setting top to                           : /tmp/pyinstaller/bootloader 
#23 22.03 Setting out to                           : /tmp/pyinstaller/bootloader/build 
#23 22.03 Python Version                           : 3.7.4 (default, Aug 21 2019, 00:19:59) [GCC 8.3.0] 
#23 22.03 Checking for 'gcc' (C compiler)          : /usr/bin/gcc 
#23 22.10 Checking size of pointer                 : 8 
#23 22.14 Platform                                 : Linux-64bit detected based on compiler 
#23 22.14 Checking for flags -m64                  : yes 
#23 22.18 Checking for program '/usr/bin/strip'    : /usr/bin/strip 
#23 22.18 Checking for program 'strip'             : /usr/bin/strip 
#23 22.18 Checking for library dl                  : yes 
#23 22.21 Checking for library m                   : yes 
#23 22.24 Checking for library z                   : yes 
#23 22.28 Checking for function unsetenv           : yes 
#23 22.31 Checking for function mkdtemp            : yes 
#23 22.34 Checking for flags -Wl,--as-needed       : yes 
#23 22.37 'configure' finished successfully (0.342s)
#23 22.37 'all' finished successfully (0.000s)
#23 22.38 'distclean' finished successfully (0.001s)
#23 22.38 Setting top to                           : /tmp/pyinstaller/bootloader 
#23 22.38 Setting out to                           : /tmp/pyinstaller/bootloader/build 
#23 22.38 Python Version                           : 3.7.4 (default, Aug 21 2019, 00:19:59) [GCC 8.3.0] 
#23 22.38 Checking for 'gcc' (C compiler)          : /usr/bin/gcc 
#23 22.42 Checking size of pointer                 : 8 
#23 22.46 Platform                                 : Linux-64bit detected based on compiler 
#23 22.46 Checking for flags -m64                  : yes 
#23 22.49 Checking for program '/usr/bin/strip'    : /usr/bin/strip 
#23 22.49 Checking for program 'strip'             : /usr/bin/strip 
#23 22.49 Checking for library dl                  : yes 
#23 22.53 Checking for library m                   : yes 
#23 22.56 Checking for library z                   : yes 
#23 22.59 Checking for function unsetenv           : yes 
#23 22.62 Checking for function mkdtemp            : yes 
#23 22.65 Checking for flags -Wl,--as-needed       : yes 
#23 22.69 'configure' finished successfully (0.308s)
#23 22.69 'make_all' finished successfully (0.003s)
#23 22.69 Waf: Entering directory `/tmp/pyinstaller/bootloader/build/debug'
#23 22.70 [ 1/13] Compiling src/pyi_python.c
#23 22.70 [ 2/13] Compiling src/pyi_global.c
#23 22.79 [ 3/13] Compiling src/main.c
#23 22.81 [ 4/13] Compiling src/pyi_utils.c
#23 22.83 [ 5/13] Compiling src/pyi_launch.c
#23 23.05 [ 6/13] Compiling src/pyi_win32_utils.c
#23 23.05 [ 7/13] Compiling src/pyi_main.c
#23 23.07 [ 8/13] Compiling src/pyi_pythonlib.c
#23 23.14 [ 9/13] Compiling src/pyi_python27_compat.c
#23 23.20 [10/13] Compiling src/pyi_archive.c
#23 23.27 [11/13] Compiling src/pyi_path.c
#23 23.40 [12/13] Linking build/debug/run_d
#23 23.41 [13/13] Processing build/debug/run_d
#23 23.42 Waf: Leaving directory `/tmp/pyinstaller/bootloader/build/debug'
#23 23.42 'build_debug' finished successfully (0.727s)
#23 23.42 Waf: Entering directory `/tmp/pyinstaller/bootloader/build/release'
#23 23.42 [ 1/13] Compiling src/pyi_python.c
#23 23.43 [ 2/13] Compiling src/pyi_global.c
#23 23.51 [ 3/13] Compiling src/main.c
#23 23.54 [ 4/13] Compiling src/pyi_archive.c
#23 23.56 [ 5/13] Compiling src/pyi_launch.c
#23 23.73 [ 6/13] Compiling src/pyi_win32_utils.c
#23 23.75 [ 7/13] Compiling src/pyi_main.c
#23 23.77 [ 8/13] Compiling src/pyi_pythonlib.c
#23 23.83 [ 9/13] Compiling src/pyi_python27_compat.c
#23 23.87 [10/13] Compiling src/pyi_utils.c
#23 23.95 [11/13] Compiling src/pyi_path.c
#23 24.08 [12/13] Linking build/release/run
#23 24.09 [13/13] Processing build/release/run
#23 24.10 Waf: Leaving directory `/tmp/pyinstaller/bootloader/build/release'
#23 24.10 'build_release' finished successfully (0.681s)
#23 24.10 Waf: Entering directory `/tmp/pyinstaller/bootloader/build/debug'
#23 24.11 [13/14] Processing build/debug/run_d
#23 24.11 + install /tmp/pyinstaller/PyInstaller/bootloader/Linux-64bit/run_d (from build/debug/run_d)
#23 24.11 Waf: Leaving directory `/tmp/pyinstaller/bootloader/build/debug'
#23 24.11 'install_debug' finished successfully (0.013s)
#23 24.11 Waf: Entering directory `/tmp/pyinstaller/bootloader/build/release'
#23 24.12 [14/14] Processing build/release/run
#23 24.12 + install /tmp/pyinstaller/PyInstaller/bootloader/Linux-64bit/run (from build/release/run)
#23 24.12 Waf: Leaving directory `/tmp/pyinstaller/bootloader/build/release'
#23 24.12 'install_release' finished successfully (0.011s)
#23 24.13 + /code/.tox/py37/bin/pip3 install ..
#23 24.39 Processing /tmp/pyinstaller
#23 24.58   Installing build dependencies: started
#23 37.67 18204 INFO: Building PKG (CArchive) PKG-00.pkg completed successfully.
#23 37.67 18208 INFO: Bootloader /code/.tox/py37/lib/python3.7/site-packages/PyInstaller/bootloader/Linux-64bit/run
#23 37.67 18208 INFO: checking EXE
#23 37.67 18208 INFO: Building EXE because EXE-00.toc is non existent
#23 37.67 18208 INFO: Building EXE from EXE-00.toc
#23 37.67 18209 INFO: Appending archive to ELF section in EXE /code/dist/docker-compose
#23 37.74 18280 INFO: Building EXE from EXE-00.toc completed successfully.
#23 37.81 + ls -la dist/
#23 37.81 total 16652
#23 37.81 drwxrwxrwx 2 root root     4096 Dec  3 07:56 .
#23 37.81 drwxr-xr-x 1 root root     4096 Dec  3 07:56 ..
#23 37.81 -rwxr-xr-x 1 root root 17037056 Dec  3 07:56 docker-compose
#23 37.81 + ldd dist/docker-compose
#23 37.82 	linux-vdso.so.1 (0x00007fff9cff1000)
#23 37.82 	libdl.so.2 => /lib/x86_64-linux-gnu/libdl.so.2 (0x00007fbd2d0dc000)
#23 37.82 	libz.so.1 => /lib/x86_64-linux-gnu/libz.so.1 (0x00007fbd2cec2000)
#23 37.82 	libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6 (0x00007fbd2cb23000)
#23 37.82 	/lib64/ld-linux-x86-64.so.2 (0x00007fbd2d2e0000)
#23 37.82 + mv dist/docker-compose /usr/local/bin
#23 37.82 + docker-compose version
#23 38.32 docker-compose version 1.26.0dev, build unknown
#23 38.32 docker-py version: 4.1.0
#23 38.32 CPython version: 3.7.4
#23 38.32 OpenSSL version: OpenSSL 1.1.0l  10 Sep 2019
#23 DONE 38.6s

#24 exporting to image
#24 exporting layers
#23 29.69   Installing build dependencies: finished with status 'done'
#23 29.69   Getting requirements to build wheel: started
#23 30.00   Getting requirements to build wheel: finished with status 'done'
#23 30.00     Preparing wheel metadata: started
#23 30.27     Preparing wheel metadata: finished with status 'done'
#23 30.28 Requirement already satisfied: altgraph in /code/.tox/py37/lib/python3.7/site-packages (from PyInstaller==3.5) (0.16.1)
#23 30.29 Requirement already satisfied: setuptools in /code/.tox/py37/lib/python3.7/site-packages (from PyInstaller==3.5) (42.0.2)
#23 30.29 Building wheels for collected packages: PyInstaller
#23 30.29   Building wheel for PyInstaller (PEP 517): started
#23 31.15   Building wheel for PyInstaller (PEP 517): finished with status 'done'
#23 31.16   Created wheel for PyInstaller: filename=PyInstaller-3.5-cp37-none-any.whl size=2879088 sha256=6fd098922860bd8564d30f491a119c4cf3958ff01fcf9da5b9e93d2920c16447
#23 31.16   Stored in directory: /tmp/pip-ephem-wheel-cache-czib27yh/wheels/87/26/52/6e71dbb2b6d73f545e70263c3d348435a974f03b1e9c578887
#23 31.30 Successfully built PyInstaller
#23 31.42 Installing collected packages: PyInstaller
#23 31.42   Found existing installation: PyInstaller 3.5
#23 31.58     Uninstalling PyInstaller-3.5:
#23 31.58       Successfully uninstalled PyInstaller-3.5
#23 31.92 Successfully installed PyInstaller-3.5
#23 31.99 + cd /code
#23 31.99 + rm -Rf /tmp/pyinstaller
#23 32.03 + /code/.tox/py37/bin/pyinstaller --exclude-module pycrypto --exclude-module PyInstaller docker-compose.spec
#23 32.18 36 INFO: PyInstaller: 3.5
#23 32.18 37 INFO: Python: 3.7.4
#23 32.18 40 INFO: Platform: Linux-4.15.0-1048-aws-x86_64-with
#23 32.19 41 INFO: UPX is not available.
#23 32.19 42 INFO: Extending PYTHONPATH with paths
#23 32.19 ['/code/bin', '/code']
#23 32.19 43 INFO: checking Analysis
#23 32.19 43 INFO: Building Analysis because Analysis-00.toc is non existent
#23 32.19 43 INFO: Initializing module dependency graph...
#23 32.19 44 INFO: Initializing module graph hooks...
#23 32.19 45 INFO: Analyzing base_library.zip ...
#23 34.67 2523 INFO: running Analysis Analysis-00.toc
#23 34.68 2534 INFO: Caching module hooks...
#23 34.68 2538 INFO: Analyzing bin/docker-compose
#23 34.76 2617 INFO: Processing pre-find module path hook   distutils
#23 34.76 2617 INFO: distutils: retargeting to non-venv dir '/usr/local/lib/python3.7/distutils'
#23 34.93 2786 INFO: Processing pre-safe import module hook   urllib3.packages.six.moves
#23 35.78 3639 INFO: Processing pre-safe import module hook   six.moves
#24 exporting layers 8.9s done
#24 writing image sha256:f0ce20a2c1b193208da460f2264b8df860af2c1386f3de107a5b0b6f8f65245f done
#24 naming to docker.io/library/compose:debian done
#24 DONE 9.0s
[Pipeline] sh
+ docker save -o debian.tar compose:debian
#23 38.09 5949 INFO: Loading module hooks...
#23 38.09 5949 INFO: Loading module hook "hook-certifi.py"...
#23 38.09 5950 INFO: Loading module hook "hook-jsonschema.py"...
#23 38.10 5952 INFO: Loading module hook "hook-xml.py"...
#23 38.13 5989 INFO: Loading module hook "hook-nacl.py"...
#23 38.14 5991 INFO: Loading module hook "hook-distutils.py"...
#23 38.14 5992 INFO: Loading module hook "hook-pkg_resources.py"...
#23 38.30 6159 INFO: Processing pre-safe import module hook   win32com
#23 38.46 6315 INFO: Loading module hook "hook-pydoc.py"...
#23 38.46 6315 INFO: Loading module hook "hook-sysconfig.py"...
#23 38.47 6322 INFO: Loading module hook "hook-encodings.py"...
#23 38.50 6358 INFO: Loading module hook "hook-cryptography.py"...
#23 38.65 6508 INFO: Looking for ctypes DLLs
#23 38.68 Illegal option -p
#23 38.68 6536 INFO: Analyzing run-time hooks ...
#23 38.69 6544 INFO: Including run-time hook 'pyi_rth_certifi.py'
#23 38.69 6545 INFO: Including run-time hook 'pyi_rth_pkgres.py'
#23 38.70 6554 INFO: Looking for dynamic libraries
#23 38.90 6759 INFO: Looking for eggs
#23 38.90 6759 INFO: Using Python library /usr/local/lib/libpython3.7m.so.1.0
#23 38.91 6769 INFO: Warnings written to /code/build/docker-compose/warn-docker-compose.txt
#23 38.97 6820 INFO: Graph cross-reference written to /code/build/docker-compose/xref-docker-compose.html
#23 38.99 6842 INFO: checking PYZ
#23 38.99 6843 INFO: Building PYZ because PYZ-00.toc is non existent
#23 38.99 6843 INFO: Building PYZ (ZlibArchive) /code/build/docker-compose/PYZ-00.pyz
#23 39.71 7567 INFO: Building PYZ (ZlibArchive) /code/build/docker-compose/PYZ-00.pyz completed successfully.
#23 39.72 7578 INFO: checking PKG
#23 39.72 7578 INFO: Building PKG because PKG-00.toc is non existent
#23 39.72 7578 INFO: Building PKG (CArchive) PKG-00.pkg
#23 50.77 18626 INFO: Building PKG (CArchive) PKG-00.pkg completed successfully.
#23 50.77 18630 INFO: Bootloader /code/.tox/py37/lib/python3.7/site-packages/PyInstaller/bootloader/Linux-64bit/run
#23 50.77 18630 INFO: checking EXE
#23 50.77 18630 INFO: Building EXE because EXE-00.toc is non existent
#23 50.77 18630 INFO: Building EXE from EXE-00.toc
#23 50.78 18630 INFO: Appending archive to ELF section in EXE /code/dist/docker-compose
#23 50.95 18806 INFO: Building EXE from EXE-00.toc completed successfully.
#23 51.01 + ls -la dist/
#23 51.01 total 17120
#23 51.01 drwxrwxrwx    2 root     root          4096 Dec  3 07:57 .
#23 51.01 drwxr-xr-x    1 root     root          4096 Dec  3 07:57 ..
#23 51.01 -rwxr-xr-x    1 root     root      17518032 Dec  3 07:57 docker-compose
#23 51.01 + ldd dist/docker-compose
#23 51.01 	/lib/ld-musl-x86_64.so.1 (0x7f151118f000)
#23 51.01 	libz.so.1 => /lib/libz.so.1 (0x7f1511159000)
#23 51.01 	libc.musl-x86_64.so.1 => /lib/ld-musl-x86_64.so.1 (0x7f151118f000)
#23 51.01 + mv dist/docker-compose /usr/local/bin
#23 51.01 + docker-compose version
#23 51.53 docker-compose version 1.26.0dev, build unknown
#23 51.53 docker-py version: 4.1.0
#23 51.53 CPython version: 3.7.4
#23 51.53 OpenSSL version: OpenSSL 1.1.1d  10 Sep 2019
#23 DONE 52.0s

#24 exporting to image
#24 exporting layers
#24 exporting layers 4.9s done
#24 writing image sha256:8c1c1d48ae6cdfd03aaab0d9365e4fce8aaf5ceb73a1cf9aa44c7231cec909a4 done
#24 naming to docker.io/library/compose:alpine done
#24 DONE 4.9s
[Pipeline] sh
+ docker save -o alpine.tar compose:alpine
[Pipeline] stash
[Pipeline] stash
Stashed 1 file(s) to https://corp-us-east-1-jenkins-k8s-maste-jenkinsartifacts-1lzm7adht5e1j.s3.amazonaws.com/public/compose/ndeloof/28/stashes/alpine.tgz
[Pipeline] }
[Pipeline] // node
[Pipeline] }
[Pipeline] // stage
[Pipeline] }
Stashed 1 file(s) to https://corp-us-east-1-jenkins-k8s-maste-jenkinsartifacts-1lzm7adht5e1j.s3.amazonaws.com/public/compose/ndeloof/28/stashes/debian.tgz
[Pipeline] }
[Pipeline] // node
[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // parallel
[Pipeline] }
[Pipeline] // stage
[Pipeline] stage
[Pipeline] { (Test)
[Pipeline] script
[Pipeline] {
expected to call java.lang.String.eachLine but wound up catching org.jenkinsci.plugins.workflow.cps.CpsClosure2.call; see: https://jenkins.io/redirect/pipeline-cps-method-mismatches/
[Pipeline] node
Running on ubuntu-1804-overlay2 (i-0b6eb4af357135099) in /home/ubuntu/workspace/compose_ndeloof
[Pipeline] {
[Pipeline] stage
[Pipeline] { (alpine 19.03.5 py27)
[Pipeline] checkout
using credential sf-release-bot.github.ssh
Cloning the remote Git repository
Cloning with configured refspecs honoured and without tags
Cloning repository git@github.com:docker/compose.git
 > git init /home/ubuntu/workspace/compose_ndeloof # timeout=10
Fetching upstream changes from git@github.com:docker/compose.git
 > git --version # timeout=10
using GIT_SSH to set credentials docker-jenkins user on github.com
 > git fetch --no-tags --progress -- git@github.com:docker/compose.git +refs/heads/ndeloof:refs/remotes/origin/ndeloof
Fetching without tags
Checking out Revision f0d8706f3473426bfcc85197834187726323acf2 (ndeloof)
Commit message: "WiP"
 > git config remote.origin.url git@github.com:docker/compose.git # timeout=10
 > git config --add remote.origin.fetch +refs/heads/ndeloof:refs/remotes/origin/ndeloof # timeout=10
 > git config remote.origin.url git@github.com:docker/compose.git # timeout=10
Fetching upstream changes from git@github.com:docker/compose.git
using GIT_SSH to set credentials docker-jenkins user on github.com
 > git fetch --no-tags --progress -- git@github.com:docker/compose.git +refs/heads/ndeloof:refs/remotes/origin/ndeloof
 > git config core.sparsecheckout # timeout=10
 > git checkout -f f0d8706f3473426bfcc85197834187726323acf2
[Pipeline] unstash
Unstashed file(s) from https://corp-us-east-1-jenkins-k8s-maste-jenkinsartifacts-1lzm7adht5e1j.s3.amazonaws.com/public/compose/ndeloof/28/stashes/alpine.tgz
[Pipeline] sh
+ docker load -i alpine.tar
Loaded image: compose:alpine
[Pipeline] sh
+ pwd
+ docker run -t --rm --privileged --volume=/home/ubuntu/workspace/compose_ndeloof/.git:/code/.git --volume=/var/run/docker.sock:/var/run/docker.sock -e TAG=compose:alpine -e DOCKER_VERSIONS=19.03.5 -e BUILD_NUMBER=jenkins-compose-ndeloof-28 -e PY_TEST_VERSIONS=py27 --entrypoint=script/test/ci compose:alpine --verbose
+ docker version
Client: Docker Engine - Community
 Version:           18.09.7
 API version:       1.39
 Go version:        go1.10.8
 Git commit:        2d0083d
 Built:             Thu Jun 27 17:54:15 2019
 OS/Arch:           linux/amd64
 Experimental:      false

Server: Docker Engine - Community
 Engine:
  Version:          19.03.2
  API version:      1.40 (minimum version 1.12)
  Go version:       go1.12.8
  Git commit:       6a30dfc
  Built:            Thu Aug 29 05:27:45 2019
  OS/Arch:          linux/amd64
  Experimental:     true
 containerd:
  Version:          1.2.6
  GitCommit:        894b81a4b802e4eb2a91d1ce216b8817763c29fb
 runc:
  Version:          1.0.0-rc8
  GitCommit:        425e105d5a03fabd737a126ad93d62a9eeede87f
 docker-init:
  Version:          0.18.0
  GitCommit:        fec3683
+ export DOCKER_VERSIONS=19.03.5
+ DOCKER_VERSIONS=19.03.5
+ STORAGE_DRIVER=overlay
+ export DOCKER_DAEMON_ARGS=--storage-driver=overlay
+ DOCKER_DAEMON_ARGS=--storage-driver=overlay
++ hostname
+ GIT_VOLUME=--volumes-from=e7e2b2727f4c
+ . script/test/all
++ set -e
++ echo 'Running lint checks'
Running lint checks
++ docker run --rm --tty --volumes-from=e7e2b2727f4c compose:alpine tox -e pre-commit
pre-commit installed: aspy.yaml==1.3.0,cfgv==2.0.1,identify==1.4.7,importlib-metadata==1.1.0,more-itertools==8.0.0,nodeenv==1.3.3,pre-commit==1.20.0,PyYAML==5.2,six==1.13.0,toml==0.10.0,virtualenv==16.7.8,zipp==0.6.0

pre-commit runtests: PYTHONHASHSEED='308081748'

pre-commit runtests: commands[0] | pre-commit install

pre-commit installed at .git/hooks/pre-commit

pre-commit runtests: commands[1] | pre-commit run --all-files

[WARNING] Unexpected key(s) present on git://github.com/pre-commit/pre-commit-hooks: sha

[WARNING] Unexpected key(s) present on git://github.com/asottile/reorder_python_imports: sha

[INFO] Initializing environment for git://github.com/pre-commit/pre-commit-hooks.

[INFO] Initializing environment for git://github.com/asottile/reorder_python_imports.

[INFO] Installing environment for git://github.com/pre-commit/pre-commit-hooks.

[INFO] Once installed this environment will be reused.

[INFO] This may take a few minutes...

[INFO] Installing environment for git://github.com/asottile/reorder_python_imports.

[INFO] Once installed this environment will be reused.

[INFO] This may take a few minutes...

Check for added large files..............................................Passed

Check docstring is first.................................................Passed

Check for merge conflicts................................................Passed

Check Yaml...............................................................Passed

Check JSON...............................................................Passed

Debug Statements (Python)................................................Passed

Fix End of Files.........................................................Passed

Flake8...................................................................Passed

Tests should end in _test.py.............................................Passed

Fix requirements.txt.....................................................Passed

Trim Trailing Whitespace.................................................Passed

Reorder python imports...................................................Passed

___________________________________ summary ____________________________________

  pre-commit: commands succeeded

  congratulations :)

++ get_versions='docker run --rm
    --entrypoint=/code/.tox/py27/bin/python
    compose:alpine
    /code/script/test/versions.py docker/docker-ce,moby/moby'
++ '[' 19.03.5 == '' ']'
++ '[' 19.03.5 == all ']'
++ BUILD_NUMBER=jenkins-compose-ndeloof-28
++ PY_TEST_VERSIONS=py27
++ for version in $DOCKER_VERSIONS
++ echo 'Running tests against Docker 19.03.5'
Running tests against Docker 19.03.5
++ daemon_container=compose-dind-19.03.5-jenkins-compose-ndeloof-28
++ trap on_exit EXIT
++ repo=dockerswarm/dind
++ docker run -d --name compose-dind-19.03.5-jenkins-compose-ndeloof-28 --privileged --volume=/var/lib/docker dockerswarm/dind:19.03.5 dockerd -H tcp://0.0.0.0:2375 --storage-driver=overlay
++ tail -n 10
2e2737f8aa12: Verifying Checksum
2e2737f8aa12: Download complete
779c3a25c03c: Pull complete
0f66cb6cb217: Pull complete
e244bd7d4480: Pull complete
2e2737f8aa12: Pull complete
4ac8ca253a47: Pull complete
Digest: sha256:8e1fd4e4546bd9e8d8194471d10fce55a570c05221110e00908e111e8ce38b7f
Status: Downloaded newer image for dockerswarm/dind:19.03.5
77912234b04332d978ac3caeab5178ce7a7205c927448f109eb69e1939a742db
++ docker run --rm --tty --link=compose-dind-19.03.5-jenkins-compose-ndeloof-28:docker --env=DOCKER_HOST=tcp://docker:2375 --env=DOCKER_VERSION=19.03.5 --entrypoint=tox compose:alpine -e py27 -- --verbose
py27 develop-inst-nodeps: /code

py27 installed: DEPRECATION: Python 2.7 will reach the end of its life on January 1st, 2020. Please upgrade your Python as Python 2.7 won't be maintained after that date. A future version of pip will drop support for Python 2.7. More details about Python 2 support in pip, can be found at https://pip.pypa.io/en/latest/development/release-process/#python-2-support,atomicwrites==1.3.0,attrs==19.3.0,backports.shutil-get-terminal-size==1.0.0,backports.ssl-match-hostname==3.5.0.1,bcrypt==3.1.7,cached-property==1.3.0,certifi==2017.4.17,cffi==1.13.2,chardet==3.0.4,configparser==4.0.2,coverage==4.4.2,cryptography==2.8,ddt==1.2.0,docker==4.1.0,# Editable install with no version control (docker-compose==1.26.0.dev0),-e /code,docker-pycreds==0.4.0,dockerpty==0.4.1,docopt==0.6.2,enum34==1.1.6,flake8==3.5.0,funcsigs==1.0.2,functools32==3.2.3.post2,idna==2.5,ipaddress==1.0.18,jsonschema==3.0.1,mccabe==0.6.1,mock==3.0.5,more-itertools==5.0.0,paramiko==2.6.0,pluggy==0.6.0,py==1.8.0,pycodestyle==2.3.1,pycparser==2.19,pyflakes==1.6.0,PyNaCl==1.3.0,pyrsistent==0.15.6,PySocks==1.6.7,pytest==3.6.3,pytest-cov==2.5.1,PyYAML==4.2b1,requests==2.22.0,six==1.12.0,subprocess32==3.5.4,texttable==1.6.2,urllib3==1.25.7,websocket-client==0.32.0

py27 runtests: PYTHONHASHSEED='1293899609'

py27 runtests: commands[0] | mkdir -p .coverage-binfiles

py27 runtests: commands[1] | py.test -v --cov=compose --cov-report html --cov-report term --cov-config=tox.ini --verbose

============================= test session starts ==============================

platform linux2 -- Python 2.7.16, pytest-3.6.3, py-1.8.0, pluggy-0.6.0 -- /code/.tox/py27/bin/python2.7

cachedir: .pytest_cache

rootdir: /code, inifile: tox.ini

plugins: cov-2.5.1


collecting 0 items                                                             
collecting 197 items                                                           
collecting 197 items                                                           
collecting 197 items                                                           
collecting 197 items                                                           
collecting 198 items                                                           
collecting 198 items                                                           
collecting 198 items                                                           
collecting 201 items                                                           
collecting 201 items                                                           
collecting 201 items                                                           
collecting 269 items                                                           
collecting 269 items                                                           
collecting 269 items                                                           
collecting 272 items                                                           
collecting 272 items                                                           
collecting 272 items                                                           
collecting 401 items                                                           
collecting 405 items                                                           
collecting 405 items                                                           
collecting 405 items                                                           
collecting 405 items                                                           
collecting 408 items                                                           
collecting 417 items                                                           
collecting 428 items                                                           
collecting 436 items                                                           
collecting 436 items                                                           
collecting 436 items                                                           
collecting 436 items                                                           
collecting 447 items                                                           
collecting 447 items                                                           
collecting 464 items                                                           
collecting 477 items                                                           
collecting 477 items                                                           
collecting 495 items                                                           
collecting 496 items                                                           
collecting 496 items                                                           
collecting 504 items                                                           
collecting 504 items                                                           
collecting 509 items                                                           
collecting 512 items                                                           
collecting 521 items                                                           
collecting 521 items                                                           
collecting 552 items                                                           
collecting 552 items                                                           
collecting 626 items                                                           
collecting 627 items                                                           
collecting 630 items                                                           
collecting 634 items                                                           
collecting 635 items                                                           
collecting 645 items                                                           
collecting 648 items                                                           
collecting 651 items                                                           
collecting 651 items                                                           
collecting 656 items                                                           
collecting 656 items                                                           
collecting 669 items                                                           
collecting 672 items                                                           
collecting 672 items                                                           
collecting 674 items                                                           
collecting 674 items                                                           
collecting 676 items                                                           
collecting 676 items                                                           
collecting 677 items                                                           
collecting 677 items                                                           
collecting 678 items                                                           
collecting 678 items                                                           
collecting 678 items                                                           
collecting 680 items                                                           
collecting 680 items                                                           
collecting 680 items                                                           
collecting 688 items                                                           
collecting 688 items                                                           
collecting 688 items                                                           
collecting 692 items                                                           
collecting 708 items                                                           
collecting 711 items                                                           
collecting 711 items                                                           
collecting 711 items                                                           
collecting 719 items                                                           
collecting 719 items                                                           
collecting 719 items                                                           
collecting 725 items                                                           
collecting 725 items                                                           
collecting 727 items                                                           
collecting 727 items                                                           
collecting 730 items                                                           
collecting 730 items                                                           
collecting 734 items                                                           
collecting 734 items                                                           
collecting 738 items                                                           
collecting 738 items                                                           
collecting 741 items                                                           
collecting 746 items                                                           
collecting 746 items                                                           
collecting 749 items                                                           
collecting 749 items                                                           
collecting 753 items                                                           
collecting 753 items                                                           
collecting 760 items                                                           
collecting 760 items                                                           
collecting 760 items                                                           
collecting 764 items                                                           
collecting 769 items                                                           
collecting 769 items                                                           
collecting 773 items                                                           
collecting 773 items                                                           
collecting 917 items                                                           
collecting 925 items                                                           
collecting 933 items                                                           
collecting 936 items                                                           
collecting 946 items                                                           
collecting 957 items                                                           
collecting 963 items                                                           
collecting 969 items                                                           
collecting 972 items                                                           
collecting 977 items                                                           
collecting 985 items                                                           
collecting 989 items                                                           
collecting 995 items                                                           
collecting 998 items                                                           
collecting 1001 items                                                          
collecting 1013 items                                                          
collecting 1044 items                                                          
collecting 1047 items                                                          
collecting 1050 items                                                          
collecting 1057 items                                                          
collecting 1061 items                                                          
collecting 1063 items                                                          
collecting 1078 items                                                          
collecting 1078 items                                                          
collecting 1083 items                                                          
collecting 1083 items                                                          
collecting 1104 items                                                          
collecting 1116 items                                                          
collecting 1116 items                                                          
collecting 1116 items                                                          
collecting 1125 items                                                          
collecting 1125 items                                                          
collecting 1137 items                                                          
collecting 1137 items                                                          
collecting 1146 items                                                          
collecting 1146 items                                                          
collecting 1148 items                                                          
collected 1148 items                                                           



tests/acceptance/cli_test.py::CLITestCase::test_build_failed PASSED      [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_failed_forcerm PASSED [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_log_level PASSED   [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_memory_build_option PASSED [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_no_cache PASSED    [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_no_cache_pull PASSED [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_override_dir PASSED [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_override_dir_invalid_path PASSED [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_parallel PASSED    [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_plain PASSED       [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_pull PASSED        [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_rm XPASS           [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_build_shm_size_build_option PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_build_with_buildarg_cli_override PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_build_with_buildarg_from_compose_file PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_build_with_buildarg_old_api_version PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_bundle_with_digests PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_config_compatibility_mode PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_config_default PASSED    [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_config_external_network PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_config_external_network_v3_5 PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_config_external_volume_v2 PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_config_external_volume_v2_x PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_external_volume_v3_4 PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_external_volume_v3_x PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_list_services PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_list_volumes PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_quiet PASSED      [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_quiet_with_error PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_restart PASSED    [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_stdin PASSED      [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_v1 PASSED         [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_v3 PASSED         [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_with_dot_env PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_with_dot_env_and_override_dir PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_config_with_env_file PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_config_with_hash_option PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_create PASSED            [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_create_with_force_recreate PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_create_with_force_recreate_and_no_recreate PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_create_with_no_recreate PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_down PASSED              [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_down_invalid_rmi_flag PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_down_signal PASSED       [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_down_timeout PASSED      [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_env_file_relative_to_compose_file PASSED [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_events_human_readable PASSED [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_events_json PASSED       [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_exec_custom_user PASSED  [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_exec_detach_long_form PASSED [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_exec_service_with_environment_overridden PASSED [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_exec_without_tty PASSED  [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_exec_workdir PASSED      [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_exit_code_from_signal_stop PASSED [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_expanded_port PASSED     [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_forward_exitval PASSED   [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_help PASSED              [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_help_nonexistent PASSED  [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_home_and_env_var_in_volume_path PASSED [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_host_not_reachable PASSED [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_host_not_reachable_volumes_from_container PASSED [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_images PASSED            [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_images_default_composefile PASSED [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_images_tagless_image PASSED [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_images_use_service_tag PASSED [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_kill PASSED              [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_kill_signal_sigstop PASSED [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_kill_stopped_service PASSED [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_logs_default SKIPPED     [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_logs_follow PASSED       [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_logs_follow_logs_from_new_containers SKIPPED [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_logs_follow_logs_from_restarted_containers SKIPPED [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_logs_invalid_service_name PASSED [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_logs_on_stopped_containers_exits PASSED [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_logs_tail PASSED         [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_logs_timestamps PASSED   [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_pause_no_containers PASSED [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_pause_unpause PASSED     [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_port PASSED              [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_port_with_scale PASSED   [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_ps PASSED                [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_ps_all PASSED            [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_ps_alternate_composefile PASSED [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_ps_default_composefile PASSED [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_ps_services_filter_option PASSED [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_ps_services_filter_status PASSED [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_pull PASSED              [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_pull_can_build PASSED    [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_pull_with_digest PASSED  [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_pull_with_ignore_pull_failures PASSED [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_pull_with_include_deps PASSED [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_pull_with_no_deps PASSED [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_pull_with_parallel_failure PASSED [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_pull_with_quiet PASSED   [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_quiet_build PASSED       [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_restart PASSED           [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_restart_no_containers PASSED [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_restart_stopped_container PASSED [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_rm PASSED                [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_rm_all PASSED            [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_rm_stop PASSED           [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_run_detached_connects_to_network PASSED [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_run_does_not_recreate_linked_containers PASSED [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_run_env_values_from_system PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_handles_sighup PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_handles_sigint PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_handles_sigterm PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_interactive_connects_to_network PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_label_flag PASSED    [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_one_off_with_multiple_volumes PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_one_off_with_volume PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_one_off_with_volume_merge PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_rm PASSED            [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint_and_command_overridden PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint_and_empty_string_command PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint_overridden PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dependencies PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dockerfile_entrypoint PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dockerfile_entrypoint_and_command_overridden PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dockerfile_entrypoint_overridden PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_environment_overridden PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_explicitly_mapped_ip_ports PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_explicitly_mapped_ports PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_links PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_map_ports PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_scaled_dependencies PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_unset_entrypoint PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_use_aliases PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_user_overridden PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_user_overridden_short_form PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_workdir_overridden PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_workdir_overridden_short_form PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_without_links PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_without_map_ports PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_unicode_env_values_from_system PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_with_custom_name PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_with_expose_ports PASSED [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_run_with_no_deps PASSED  [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_run_without_command PASSED [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_scale PASSED             [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_scale_v2_2 PASSED        [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_shorthand_host_opt PASSED [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_shorthand_host_opt_interactive PASSED [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_start_no_containers PASSED [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_stop PASSED              [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_stop_signal PASSED       [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_top_processes_running PASSED [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_top_services_not_running PASSED [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_top_services_running PASSED [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_unpause_no_containers PASSED [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up PASSED                [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_attached PASSED       [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_detached PASSED       [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_detached_long_form PASSED [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_external_networks PASSED [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_handles_abort_on_container_exit PASSED [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_handles_abort_on_container_exit_code PASSED [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_handles_force_shutdown PASSED [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_handles_sigint PASSED [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_handles_sigterm PASSED [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_logging PASSED        [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_logging_legacy PASSED [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_missing_network PASSED [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_no_ansi PASSED        [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_no_services PASSED    [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_no_start PASSED       [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_no_start_remove_orphans PASSED [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_scale_reset PASSED    [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_scale_scale_down PASSED [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_scale_scale_up PASSED [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_scale_to_zero PASSED  [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_default_network_config PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_default_override_file PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_duplicate_override_yaml_files PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_extends PASSED   [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_external_default_network PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_force_recreate PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_force_recreate_and_no_recreate PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_healthcheck PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_ignore_remove_orphans PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_links_v1 PASSED  [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_multiple_files PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_net_is_invalid PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_net_v1 <- tests/integration/testcases.py PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_aliases PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_internal PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_labels PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_mode <- tests/integration/testcases.py PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_static_addresses PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_networks PASSED  [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_no_deps PASSED   [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_no_recreate PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_override_yaml PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_pid_mode <- tests/integration/testcases.py PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_timeout PASSED   [ 17%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_volume_labels PASSED [ 17%]

tests/integration/environment_test.py::EnvironmentOverrideFileTest::test_env_file_override PASSED [ 17%]

tests/integration/network_test.py::NetworkTest::test_network_default_labels PASSED [ 17%]

tests/integration/network_test.py::NetworkTest::test_network_external_default_ensure PASSED [ 17%]

tests/integration/network_test.py::NetworkTest::test_network_external_overlay_ensure PASSED [ 17%]

tests/integration/project_test.py::ProjectTest::test_containers PASSED   [ 17%]

tests/integration/project_test.py::ProjectTest::test_containers_stopped PASSED [ 17%]

tests/integration/project_test.py::ProjectTest::test_containers_with_extra_service PASSED [ 17%]

tests/integration/project_test.py::ProjectTest::test_containers_with_service_names PASSED [ 17%]

tests/integration/project_test.py::ProjectTest::test_create PASSED       [ 17%]

tests/integration/project_test.py::ProjectTest::test_create_strategy_always PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_create_strategy_never PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_create_twice PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_create_with_links PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_initialize_volumes PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_initialize_volumes_external_volumes <- tests/integration/testcases.py PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_initialize_volumes_inexistent_external_volume PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_initialize_volumes_invalid_volume_driver PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_blank_driver PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_driver <- tests/integration/testcases.py PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_driver_opts <- tests/integration/testcases.py PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_net_from_container_v1 <- tests/integration/testcases.py PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_net_from_service_v1 <- tests/integration/testcases.py PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_network_mode_from_container <- tests/integration/testcases.py PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_network_mode_from_service <- tests/integration/testcases.py PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_parallel_pull_with_no_image PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_project_up PASSED   [ 19%]

tests/integration/project_test.py::ProjectTest::test_project_up_config_scale PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_project_up_healthy_dependency PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_project_up_ignore_orphans PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_project_up_implicit_volume_driver PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_project_up_logging_with_multiple_files PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_project_up_name_starts_with_illegal_char <- tests/integration/testcases.py PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_project_up_named_volumes_in_binds PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_networks PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_no_healthcheck_dependency PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_orphans PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_port_mappings_with_multiple_files PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_recreate_with_tmpfs_volume PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_seccomp_profile PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_starts_depends PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_starts_links PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_starts_uncreated_services PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_unhealthy_dependency PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_volumes PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_with_added_secrets PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_project_up_with_network_internal PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_project_up_with_network_label PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_project_up_with_no_deps PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_project_up_with_no_recreate_running PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_project_up_with_no_recreate_stopped PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_project_up_with_secrets PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_project_up_with_volume_labels PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_project_up_without_all_services PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_recreate_preserves_mounts PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_recreate_preserves_volumes PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_start_pause_unpause_stop_kill_remove PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_unscale_after_restart PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_custom_name_resources PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_enable_ipv6 PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_invalid_isolation PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_invalid_runtime PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_ipam_config PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_ipam_options PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_isolation PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_network_link_local_ips PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_network_priorities PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_network_static_addresses PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_network_static_addresses_missing_subnet PASSED [ 23%]

tests/integration/project_test.py::ProjectTest::test_up_with_nvidia_runtime <- tests/integration/testcases.py SKIPPED [ 23%]

tests/integration/project_test.py::ProjectTest::test_up_with_runtime <- tests/integration/testcases.py PASSED [ 23%]

tests/integration/project_test.py::ProjectTest::test_volumes_from_container PASSED [ 23%]

tests/integration/project_test.py::ProjectTest::test_volumes_from_service PASSED [ 23%]

tests/integration/resilience_test.py::ResilienceTest::test_create_failure PASSED [ 23%]

tests/integration/resilience_test.py::ResilienceTest::test_start_failure PASSED [ 23%]

tests/integration/resilience_test.py::ResilienceTest::test_successful_recreate PASSED [ 23%]

tests/integration/service_test.py::ServiceTest::test_build PASSED        [ 23%]

tests/integration/service_test.py::ServiceTest::test_build_cli PASSED    [ 23%]

tests/integration/service_test.py::ServiceTest::test_build_non_ascii_filename PASSED [ 23%]

tests/integration/service_test.py::ServiceTest::test_build_with_build_args PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_build_args_override PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_build_labels PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_cachefrom PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_extra_hosts PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_git_url PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_gzip PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_illegal_leading_chars PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_image_name PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_isolation PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_network <- tests/integration/testcases.py PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_target <- tests/integration/testcases.py PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_cap_add_list PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_cap_drop_list PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_containers PASSED   [ 25%]

tests/integration/service_test.py::ServiceTest::test_containers_one_off PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_blkio_config PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_count PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_percent SKIPPED [ 25%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_quota PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_rt xfail [ 25%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_set PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_shares PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_cpus PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_device_cgroup_rules PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_extra_hosts_dicts PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_extra_hosts_list PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_healthcheck_config PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_host_mount PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_init_bool PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_init_path XPASS [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_legacy_mount PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_legacy_tmpfs_mount PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_mac_address PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_one_off PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_one_off_when_existing_container_is_running PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_oom_kill_disable PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_pids_limit XPASS [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_read_only_root_fs PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_security_opt PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_shm_size PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_specified_volume PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_storage_opt xfail [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_tmpfs_mount PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_tmpfs_mount_tmpfs_size PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_unspecified_volume PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_volume_driver PASSED [ 28%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_volume_mount PASSED [ 28%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_volumes_from PASSED [ 28%]

tests/integration/service_test.py::ServiceTest::test_create_with_image_id PASSED [ 28%]

tests/integration/service_test.py::ServiceTest::test_custom_container_name PASSED [ 28%]

tests/integration/service_test.py::ServiceTest::test_devices PASSED      [ 28%]

tests/integration/service_test.py::ServiceTest::test_dns_list PASSED     [ 28%]

tests/integration/service_test.py::ServiceTest::test_dns_no_value PASSED [ 28%]

tests/integration/service_test.py::ServiceTest::test_dns_opt_value PASSED [ 28%]

tests/integration/service_test.py::ServiceTest::test_dns_search PASSED   [ 28%]

tests/integration/service_test.py::ServiceTest::test_duplicate_containers PASSED [ 28%]

tests/integration/service_test.py::ServiceTest::test_duplicate_volume_trailing_slash PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_empty_labels PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_env_from_file_combined_with_env PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_anonymous_volume_recreate_then_renew PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_anonymous_volume_renew PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_image_with_volume_is_removed PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_change_mount_target PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_twice PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_twice_with_mount PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_containers_are_stopped PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_host_volume_is_removed PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_image_volume_masks_config PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_with_image_declared_volume PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_with_image_declared_volume_renew PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_without_start PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_expose_does_not_publish_ports PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_group_add_value PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_labels PASSED       [ 30%]

tests/integration/service_test.py::ServiceTest::test_log_drive_empty_default_jsonfile PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_log_drive_invalid SKIPPED [ 30%]

tests/integration/service_test.py::ServiceTest::test_log_drive_none PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_mem_reservation PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_mem_swappiness PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_network_mode_bridged PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_network_mode_host PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_network_mode_none PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_oom_score_adj_value PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_pid_mode_host PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_pid_mode_none_defined PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_port_with_explicit_interface PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_project_is_added_to_container_name PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_recreate_preserves_volume_with_trailing_slash PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_recreate_volume_to_mount PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_resolve_env PASSED  [ 31%]

tests/integration/service_test.py::ServiceTest::test_restart_always_value PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_restart_on_failure_value PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale PASSED        [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale_sets_ports PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale_with_api_error PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale_with_custom_container_name_outputs_warning PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale_with_desired_number_already_achieved PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale_with_immediate_exit PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale_with_stopped_containers PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale_with_stopped_containers_and_needing_creation PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale_with_unexpected_exception PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_split_env PASSED    [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_becomes_privileged PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_builds_images PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_creates_fixed_external_ports PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_creates_fixed_external_ports_when_it_is_different_to_internal_port PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_creates_links <- tests/integration/testcases.py PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_creates_links_with_names <- tests/integration/testcases.py PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_creates_port_with_explicit_protocol PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_creates_ports PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_inherits_options_from_constructor PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_passes_through_options PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_stays_unprivileged PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_uses_tagged_image_if_it_exists PASSED [ 34%]

tests/integration/service_test.py::ServiceTest::test_start_container_with_external_links <- tests/integration/testcases.py PASSED [ 34%]

tests/integration/service_test.py::ServiceTest::test_start_normal_container_does_not_create_links_to_its_own_service <- tests/integration/testcases.py PASSED [ 34%]

tests/integration/service_test.py::ServiceTest::test_start_one_off_container_creates_links_to_its_own_service <- tests/integration/testcases.py PASSED [ 34%]

tests/integration/service_test.py::ServiceTest::test_stop_signal PASSED  [ 34%]

tests/integration/service_test.py::ServiceTest::test_tmpfs PASSED        [ 34%]

tests/integration/service_test.py::ServiceTest::test_up_build_cli PASSED [ 34%]

tests/integration/service_test.py::ServiceTest::test_userns_mode_host PASSED [ 34%]

tests/integration/service_test.py::ServiceTest::test_userns_mode_none_defined PASSED [ 34%]

tests/integration/service_test.py::ServiceTest::test_with_high_enough_api_version_we_get_default_network_mode PASSED [ 34%]

tests/integration/service_test.py::ServiceTest::test_working_dir_param PASSED [ 34%]

tests/integration/service_test.py::ConfigHashTest::test_config_hash_sticks_around PASSED [ 35%]

tests/integration/service_test.py::ConfigHashTest::test_config_hash_with_custom_labels PASSED [ 35%]

tests/integration/service_test.py::ConfigHashTest::test_no_config_hash_when_one_off PASSED [ 35%]

tests/integration/service_test.py::ConfigHashTest::test_no_config_hash_when_overriding_options PASSED [ 35%]

tests/integration/state_test.py::BasicProjectTest::test_all_change PASSED [ 35%]

tests/integration/state_test.py::BasicProjectTest::test_no_change PASSED [ 35%]

tests/integration/state_test.py::BasicProjectTest::test_partial_change PASSED [ 35%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_leaf PASSED [ 35%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_middle PASSED [ 35%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_middle_always_recreate_deps PASSED [ 35%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root PASSED [ 35%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root_always_recreate_deps PASSED [ 35%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root_no_recreate PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_service_recreated_when_dependency_created PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_service_removed_while_down PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_up PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_leaf PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_middle PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_middle_always_recreate_deps PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root_always_recreate_deps PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root_no_recreate PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_dependency_added PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_dependency_removed PASSED [ 37%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_service_removed_while_down PASSED [ 37%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_service_removed_while_up PASSED [ 37%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_up PASSED [ 37%]

tests/integration/state_test.py::ServiceStateTest::test_image_changed_to_build PASSED [ 37%]

tests/integration/state_test.py::ServiceStateTest::test_trigger_create PASSED [ 37%]

tests/integration/state_test.py::ServiceStateTest::test_trigger_noop PASSED [ 37%]

tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_build <- tests/integration/testcases.py PASSED [ 37%]

tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_config_change PASSED [ 37%]

tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_image_change PASSED [ 37%]

tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_nonexistent_image_tag PASSED [ 37%]

tests/integration/state_test.py::ServiceStateTest::test_trigger_start PASSED [ 37%]

tests/integration/volume_test.py::VolumeTest::test_create_volume PASSED  [ 38%]

tests/integration/volume_test.py::VolumeTest::test_create_volume_custom_name PASSED [ 38%]

tests/integration/volume_test.py::VolumeTest::test_exists <- tests/integration/testcases.py PASSED [ 38%]

tests/integration/volume_test.py::VolumeTest::test_exists_external <- tests/integration/testcases.py PASSED [ 38%]

tests/integration/volume_test.py::VolumeTest::test_exists_external_aliased <- tests/integration/testcases.py PASSED [ 38%]

tests/integration/volume_test.py::VolumeTest::test_external_aliased_volume <- tests/integration/testcases.py PASSED [ 38%]

tests/integration/volume_test.py::VolumeTest::test_external_volume <- tests/integration/testcases.py PASSED [ 38%]

tests/integration/volume_test.py::VolumeTest::test_inspect_volume <- tests/integration/testcases.py PASSED [ 38%]

tests/integration/volume_test.py::VolumeTest::test_recreate_existing_volume PASSED [ 38%]

tests/integration/volume_test.py::VolumeTest::test_remove_volume <- tests/integration/testcases.py PASSED [ 38%]

tests/integration/volume_test.py::VolumeTest::test_volume_default_labels <- tests/integration/testcases.py PASSED [ 38%]

tests/unit/bundle_test.py::test_get_image_digest_exists PASSED           [ 39%]

tests/unit/bundle_test.py::test_get_image_digest_image_uses_digest PASSED [ 39%]

tests/unit/bundle_test.py::test_get_image_digest_from_repository PASSED  [ 39%]

tests/unit/bundle_test.py::test_get_image_digest_no_image PASSED         [ 39%]

tests/unit/bundle_test.py::test_push_image_with_saved_digest PASSED      [ 39%]

tests/unit/bundle_test.py::test_push_image PASSED                        [ 39%]

tests/unit/bundle_test.py::test_to_bundle PASSED                         [ 39%]

tests/unit/bundle_test.py::test_convert_service_to_bundle PASSED         [ 39%]

tests/unit/bundle_test.py::test_set_command_and_args_none PASSED         [ 39%]

tests/unit/bundle_test.py::test_set_command_and_args_from_command PASSED [ 39%]

tests/unit/bundle_test.py::test_set_command_and_args_from_entrypoint PASSED [ 39%]

tests/unit/bundle_test.py::test_set_command_and_args_from_both PASSED    [ 39%]

tests/unit/bundle_test.py::test_make_service_networks_default PASSED     [ 40%]

tests/unit/bundle_test.py::test_make_service_networks PASSED             [ 40%]

tests/unit/bundle_test.py::test_make_port_specs PASSED                   [ 40%]

tests/unit/bundle_test.py::test_make_port_spec_with_protocol PASSED      [ 40%]

tests/unit/bundle_test.py::test_make_port_spec_default_protocol PASSED   [ 40%]

tests/unit/cli_test.py::CLITestCase::test_command_help PASSED            [ 40%]

tests/unit/cli_test.py::CLITestCase::test_command_help_nonexistent PASSED [ 40%]

tests/unit/cli_test.py::CLITestCase::test_command_manual_and_service_ports_together PASSED [ 40%]

tests/unit/cli_test.py::CLITestCase::test_default_project_name PASSED    [ 40%]

tests/unit/cli_test.py::CLITestCase::test_get_project PASSED             [ 40%]

tests/unit/cli_test.py::CLITestCase::test_project_name_from_environment_new_var PASSED [ 40%]

tests/unit/cli_test.py::CLITestCase::test_project_name_with_empty_environment_var PASSED [ 41%]

tests/unit/cli_test.py::CLITestCase::test_project_name_with_environment_file PASSED [ 41%]

tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_base_dir PASSED [ 41%]

tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_project_name PASSED [ 41%]

tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_uppercase_base_dir PASSED [ 41%]

tests/unit/cli_test.py::CLITestCase::test_run_interactive_passes_logs_false PASSED [ 41%]

tests/unit/cli_test.py::CLITestCase::test_run_service_with_restart_always PASSED [ 41%]

tests/unit/container_test.py::ContainerTest::test_environment PASSED     [ 41%]

tests/unit/container_test.py::ContainerTest::test_from_ps PASSED         [ 41%]

tests/unit/container_test.py::ContainerTest::test_from_ps_prefixed PASSED [ 41%]

tests/unit/container_test.py::ContainerTest::test_get PASSED             [ 41%]

tests/unit/container_test.py::ContainerTest::test_get_local_port PASSED  [ 41%]

tests/unit/container_test.py::ContainerTest::test_has_api_logs PASSED    [ 42%]

tests/unit/container_test.py::ContainerTest::test_human_readable_ports_none PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_human_readable_ports_public_and_private PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_human_readable_states_healthy PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_human_readable_states_no_health PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_human_readable_states_starting PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_inspect_if_not_inspected PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_name PASSED            [ 42%]

tests/unit/container_test.py::ContainerTest::test_name_without_project PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_name_without_project_custom_container_name PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_name_without_project_one_off PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_number PASSED          [ 43%]

tests/unit/container_test.py::ContainerTest::test_short_id PASSED        [ 43%]

tests/unit/container_test.py::GetContainerNameTestCase::test_get_container_name PASSED [ 43%]

tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_driver_mismatch PASSED [ 43%]

tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_null_remote PASSED [ 43%]

tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_null_remote_ipam_options PASSED [ 43%]

tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_options_mismatch PASSED [ 43%]

tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_success PASSED [ 43%]

tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_whitelist PASSED [ 43%]

tests/unit/network_test.py::NetworkTest::test_check_remote_network_labels_mismatch PASSED [ 43%]

tests/unit/network_test.py::NetworkTest::test_remote_config_labels_none PASSED [ 43%]

tests/unit/parallel_test.py::ParallelTest::test_parallel_execute PASSED  [ 43%]

tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_deps PASSED [ 44%]

tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_global_limit PASSED [ 44%]

tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_limit PASSED [ 44%]

tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_upstream_errors PASSED [ 44%]

tests/unit/parallel_test.py::test_parallel_execute_alignment PASSED      [ 44%]

tests/unit/parallel_test.py::test_parallel_execute_ansi PASSED           [ 44%]

tests/unit/parallel_test.py::test_parallel_execute_noansi PASSED         [ 44%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_get_digest_from_pull PASSED [ 44%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_get_digest_from_push PASSED [ 44%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_mismatched_encoding_stream_write PASSED [ 44%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output PASSED [ 44%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_div_zero PASSED [ 45%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_no_progress_event_no_tty PASSED [ 45%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_null_total PASSED [ 45%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_progress_event_no_tty PASSED [ 45%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_progress_event_tty PASSED [ 45%]

tests/unit/project_test.py::ProjectTest::test_avoid_multiple_push PASSED [ 45%]

tests/unit/project_test.py::ProjectTest::test_build_container_operation_with_timeout_func_does_not_mutate_options_with_timeout PASSED [ 45%]

tests/unit/project_test.py::ProjectTest::test_container_without_name PASSED [ 45%]

tests/unit/project_test.py::ProjectTest::test_down_with_no_resources PASSED [ 45%]

tests/unit/project_test.py::ProjectTest::test_error_parallel_pull PASSED [ 45%]

tests/unit/project_test.py::ProjectTest::test_events PASSED              [ 45%]

tests/unit/project_test.py::ProjectTest::test_events_legacy PASSED       [ 45%]

tests/unit/project_test.py::ProjectTest::test_from_config_v1 PASSED      [ 46%]

tests/unit/project_test.py::ProjectTest::test_from_config_v2 PASSED      [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_secrets_external_warning PASSED [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_secrets_no_secret_def PASSED [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_secrets_secret_file_warning PASSED [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_secrets_uid_gid_mode_warning PASSED [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_service PASSED         [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_services_removes_duplicates_following_links PASSED [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_services_returns_all_services_without_args PASSED [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_services_returns_listed_services_with_args PASSED [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_services_with_include_links PASSED [ 46%]

tests/unit/project_test.py::ProjectTest::test_net_unset PASSED           [ 47%]

tests/unit/project_test.py::ProjectTest::test_no_such_service_unicode PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_no_warning_in_normal_mode PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_no_warning_on_stop PASSED  [ 47%]

tests/unit/project_test.py::ProjectTest::test_no_warning_with_no_swarm_info PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_project_platform_value PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_use_net_from_container PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_use_net_from_service PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_use_volumes_from_container PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_use_volumes_from_service_container PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_use_volumes_from_service_no_container PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_uses_default_network_false PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_uses_default_network_true PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_build_does_not_pull PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_build_isolation_from_build_override_service_config PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_build_service_with_proxy_config PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_build_volume_options_duplicate_binds PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_build_with_default_platform PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_build_with_isolation_from_service_config PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_build_with_override_build_args PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_build_with_platform PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_cgroup_parent PASSED       [ 48%]

tests/unit/service_test.py::ServiceTest::test_config_dict PASSED         [ 48%]

tests/unit/service_test.py::ServiceTest::test_config_dict_with_network_mode_from_container PASSED [ 49%]

tests/unit/service_test.py::ServiceTest::test_config_hash_matches_label PASSED [ 49%]

tests/unit/service_test.py::ServiceTest::test_container_without_name PASSED [ 49%]

tests/unit/service_test.py::ServiceTest::test_containers PASSED          [ 49%]

tests/unit/service_test.py::ServiceTest::test_containers_with_containers PASSED [ 49%]

tests/unit/service_test.py::ServiceTest::test_create_container PASSED    [ 49%]

tests/unit/service_test.py::ServiceTest::test_create_when_removed_containers_are_listed PASSED [ 49%]

tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_force_build PASSED [ 49%]

tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_no_build PASSED [ 49%]

tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_no_build_but_needs_build PASSED [ 49%]

tests/unit/service_test.py::ServiceTest::test_get_container PASSED       [ 49%]

tests/unit/service_test.py::ServiceTest::test_get_container_create_options_does_not_mutate_options PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_container_create_options_no_affinity_without_binds PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_container_create_options_sets_affinity_with_binds PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_container_create_options_with_name_option PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_container_not_found PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_create_options_with_proxy_config PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_volumes_from_container PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_volumes_from_container_read_only PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_container_exists PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_container_exists_with_flags PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_no_container PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_image_name_default PASSED  [ 50%]

tests/unit/service_test.py::ServiceTest::test_image_name_from_config PASSED [ 51%]

tests/unit/service_test.py::ServiceTest::test_log_opt PASSED             [ 51%]

tests/unit/service_test.py::ServiceTest::test_mem_reservation PASSED     [ 51%]

tests/unit/service_test.py::ServiceTest::test_memory_swap_limit PASSED   [ 51%]

tests/unit/service_test.py::ServiceTest::test_no_default_hostname_when_not_using_networking PASSED [ 51%]

tests/unit/service_test.py::ServiceTest::test_only_log_warning_when_host_ports_clash PASSED [ 51%]

tests/unit/service_test.py::ServiceTest::test_parse_proxy_config PASSED  [ 51%]

tests/unit/service_test.py::ServiceTest::test_parse_proxy_config_per_host PASSED [ 51%]

tests/unit/service_test.py::ServiceTest::test_parse_repository_tag PASSED [ 51%]

tests/unit/service_test.py::ServiceTest::test_pull_image PASSED          [ 51%]

tests/unit/service_test.py::ServiceTest::test_pull_image_digest PASSED   [ 51%]

tests/unit/service_test.py::ServiceTest::test_pull_image_no_tag PASSED   [ 52%]

tests/unit/service_test.py::ServiceTest::test_pull_image_with_default_platform PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_pull_image_with_platform PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_pull_image_with_platform_unsupported_api PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_recreate_container PASSED  [ 52%]

tests/unit/service_test.py::ServiceTest::test_recreate_container_with_timeout PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_remove_image_all_does_remove PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_remove_image_local_with_image_name_doesnt_remove PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_remove_image_local_without_image_name_does_remove PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_remove_image_none PASSED   [ 52%]

tests/unit/service_test.py::ServiceTest::test_remove_image_with_error PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_remove_non_existing_image PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_self_reference_external_link PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_service_ignore_default_platform_with_unsupported_api PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_service_platform_precedence PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_container_port PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_container_port_range PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_and_port PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_and_port_range PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_no_port PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_no_port_range PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_port PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_port_range PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_no_ports PASSED [ 54%]

tests/unit/service_test.py::ServiceTest::test_split_domainname_both PASSED [ 54%]

tests/unit/service_test.py::ServiceTest::test_split_domainname_fqdn PASSED [ 54%]

tests/unit/service_test.py::ServiceTest::test_split_domainname_none PASSED [ 54%]

tests/unit/service_test.py::ServiceTest::test_split_domainname_weird PASSED [ 54%]

tests/unit/service_test.py::ServiceTest::test_stop_grace_period PASSED   [ 54%]

tests/unit/service_test.py::ServiceTest::test_volumes_order_is_preserved PASSED [ 54%]

tests/unit/service_test.py::TestServiceNetwork::test_connect_container_to_networks_short_aliase_exists PASSED [ 54%]

tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_dict PASSED [ 54%]

tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_integers_and_dicts PASSED [ 54%]

tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_ints PASSED [ 54%]

tests/unit/service_test.py::NetTestCase::test_network_mode PASSED        [ 54%]

tests/unit/service_test.py::NetTestCase::test_network_mode_container PASSED [ 55%]

tests/unit/service_test.py::NetTestCase::test_network_mode_service PASSED [ 55%]

tests/unit/service_test.py::NetTestCase::test_network_mode_service_no_containers PASSED [ 55%]

tests/unit/service_test.py::ServicePortsTest::test_formatted_ports PASSED [ 55%]

tests/unit/service_test.py::ServiceVolumesTest::test_build_volume_binding PASSED [ 55%]

tests/unit/service_test.py::ServiceVolumesTest::test_create_with_special_volume_mode PASSED [ 55%]

tests/unit/service_test.py::ServiceVolumesTest::test_get_container_create_options_with_different_host_path_in_container_json PASSED [ 55%]

tests/unit/service_test.py::ServiceVolumesTest::test_get_container_data_volumes PASSED [ 55%]

tests/unit/service_test.py::ServiceVolumesTest::test_merge_volume_bindings PASSED [ 55%]

tests/unit/service_test.py::ServiceVolumesTest::test_mount_same_host_path_to_two_volumes PASSED [ 55%]

tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_no_warning_with_container_only_option PASSED [ 55%]

tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_no_warning_with_same_path PASSED [ 56%]

tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_volume_no_warning_when_no_container_volumes PASSED [ 56%]

tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_volume_when_masked PASSED [ 56%]

tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes PASSED [ 56%]

tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes_abspath PASSED [ 56%]

tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes_no_target PASSED [ 56%]

tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_unix_path PASSED [ 56%]

tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_url_no_prefix PASSED [ 56%]

tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_windows_path PASSED [ 56%]

tests/unit/split_buffer_test.py::SplitBufferTest::test_chunked_line PASSED [ 56%]

tests/unit/split_buffer_test.py::SplitBufferTest::test_multiple_line_chunk PASSED [ 56%]

tests/unit/split_buffer_test.py::SplitBufferTest::test_no_end_separator PASSED [ 56%]

tests/unit/split_buffer_test.py::SplitBufferTest::test_preserves_unicode_sequences_within_lines PASSED [ 57%]

tests/unit/split_buffer_test.py::SplitBufferTest::test_single_line_chunks PASSED [ 57%]

tests/unit/timeparse_test.py::test_milli PASSED                          [ 57%]

tests/unit/timeparse_test.py::test_milli_float PASSED                    [ 57%]

tests/unit/timeparse_test.py::test_second_milli PASSED                   [ 57%]

tests/unit/timeparse_test.py::test_second_milli_micro PASSED             [ 57%]

tests/unit/timeparse_test.py::test_second PASSED                         [ 57%]

tests/unit/timeparse_test.py::test_second_as_float PASSED                [ 57%]

tests/unit/timeparse_test.py::test_minute PASSED                         [ 57%]

tests/unit/timeparse_test.py::test_hour_minute PASSED                    [ 57%]

tests/unit/timeparse_test.py::test_minute_as_float PASSED                [ 57%]

tests/unit/timeparse_test.py::test_hour_minute_second PASSED             [ 58%]

tests/unit/timeparse_test.py::test_invalid_with_space PASSED             [ 58%]

tests/unit/timeparse_test.py::test_invalid_with_comma PASSED             [ 58%]

tests/unit/timeparse_test.py::test_invalid_with_empty_string PASSED      [ 58%]

tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_no_object PASSED [ 58%]

tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_with_object PASSED [ 58%]

tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_leading_whitespace PASSED [ 58%]

tests/unit/utils_test.py::TestStreamAsText::test_stream_with_non_utf_unicode_character PASSED [ 58%]

tests/unit/utils_test.py::TestStreamAsText::test_stream_with_utf_character PASSED [ 58%]

tests/unit/utils_test.py::TestJsonStream::test_with_falsy_entries PASSED [ 58%]

tests/unit/utils_test.py::TestJsonStream::test_with_leading_whitespace PASSED [ 58%]

tests/unit/utils_test.py::TestParseBytes::test_parse_bytes PASSED        [ 58%]

tests/unit/utils_test.py::TestMoreItertools::test_unique_everseen PASSED [ 59%]

tests/unit/volume_test.py::TestVolume::test_remove_local_volume PASSED   [ 59%]

tests/unit/volume_test.py::TestVolume::test_remove_external_volume PASSED [ 59%]

tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_path_from_options PASSED [ 59%]

tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_single_path_from_env PASSED [ 59%]

tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env PASSED [ 59%]

tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env_windows SKIPPED [ 59%]

tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env_custom_separator PASSED [ 59%]

tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_no_path PASSED [ 59%]

tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_unicode_path_from_options PASSED [ 59%]

tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_unicode_path_from_env PASSED [ 59%]

tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_custom_timeout_error PASSED [ 60%]

tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_docker_client_no_home PASSED [ 60%]

tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_docker_client_with_custom_timeout PASSED [ 60%]

tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_user_agent PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_assert_hostname_explicit_skip PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_simple_tls PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_ca_cert PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_ca_cert_explicit PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca_explicit PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca_quoted_paths PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_cert PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_cert_explicit PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_missing_key PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_flags_override_environment PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_mixed_environment_and_flags PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_simple_with_tls_version PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_default_cert_path PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_env_falsy_value PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_flag_no_override PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_default PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_upgrade PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_unavailable PASSED [ 61%]

tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_generic_connection_error PASSED [ 62%]

tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_mismatch PASSED [ 62%]

tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_mismatch_unicode_explanation PASSED [ 62%]

tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_other PASSED [ 62%]

tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_other_unicode_explanation PASSED [ 62%]

tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_no_data SKIPPED [ 62%]

tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_misc SKIPPED [ 62%]

tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_encoding_issue SKIPPED [ 62%]

tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_error PASSED [ 62%]

tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_info PASSED [ 62%]

tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_error PASSED [ 62%]

tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_info PASSED [ 62%]

tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_warn PASSED [ 63%]

tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_warn PASSED [ 63%]

tests/unit/cli/log_printer_test.py::TestLogPresenter::test_monochrome PASSED [ 63%]

tests/unit/cli/log_printer_test.py::TestLogPresenter::test_polychrome PASSED [ 63%]

tests/unit/cli/log_printer_test.py::test_wait_on_exit PASSED             [ 63%]

tests/unit/cli/log_printer_test.py::test_wait_on_exit_raises PASSED      [ 63%]

tests/unit/cli/log_printer_test.py::test_build_no_log_generator PASSED   [ 63%]

tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_no_log_stream PASSED [ 63%]

tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_with_log_stream PASSED [ 63%]

tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_unicode PASSED [ 63%]

tests/unit/cli/log_printer_test.py::TestWatchEvents::test_stop_event PASSED [ 63%]

tests/unit/cli/log_printer_test.py::TestWatchEvents::test_start_event PASSED [ 64%]

tests/unit/cli/log_printer_test.py::TestWatchEvents::test_container_attach_event PASSED [ 64%]

tests/unit/cli/log_printer_test.py::TestWatchEvents::test_other_event PASSED [ 64%]

tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_an_exception PASSED [ 64%]

tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_stop_without_cascade_stop PASSED [ 64%]

tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_stop_with_cascade_stop PASSED [ 64%]

tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_none_when_timeout_is_hit PASSED [ 64%]

tests/unit/cli/main_test.py::TestCLIMainTestCase::test_filter_containers_to_service_names PASSED [ 64%]

tests/unit/cli/main_test.py::TestCLIMainTestCase::test_filter_containers_to_service_names_all PASSED [ 64%]

tests/unit/cli/main_test.py::TestCLIMainTestCase::test_warning_in_swarm_mode PASSED [ 64%]

tests/unit/cli/main_test.py::TestCLIMainTestCase::test_build_one_off_container_options PASSED [ 64%]

tests/unit/cli/main_test.py::TestCLIMainTestCase::test_get_docker_start_call PASSED [ 64%]

tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_tty_verbose PASSED [ 65%]

tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_tty_not_verbose PASSED [ 65%]

tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_not_a_tty PASSED [ 65%]

tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_invalid_opts PASSED [ 65%]

tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_always PASSED [ 65%]

tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_never PASSED [ 65%]

tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_changed PASSED [ 65%]

tests/unit/cli/main_test.py::TestCallDocker::test_simple_no_options PASSED [ 65%]

tests/unit/cli/main_test.py::TestCallDocker::test_simple_tls_option PASSED [ 65%]

tests/unit/cli/main_test.py::TestCallDocker::test_advanced_tls_options PASSED [ 65%]

tests/unit/cli/main_test.py::TestCallDocker::test_with_host_option PASSED [ 65%]

tests/unit/cli/main_test.py::TestCallDocker::test_with_http_host PASSED  [ 66%]

tests/unit/cli/main_test.py::TestCallDocker::test_with_host_option_shorthand_equal PASSED [ 66%]

tests/unit/cli/main_test.py::TestCallDocker::test_with_env PASSED        [ 66%]

tests/unit/cli/utils_test.py::UnquotePathTest::test_nested_quotes PASSED [ 66%]

tests/unit/cli/utils_test.py::UnquotePathTest::test_no_quotes PASSED     [ 66%]

tests/unit/cli/utils_test.py::UnquotePathTest::test_simple_quotes PASSED [ 66%]

tests/unit/cli/utils_test.py::UnquotePathTest::test_uneven_quotes PASSED [ 66%]

tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_100b PASSED [ 66%]

tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_1023b PASSED [ 66%]

tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_1kb PASSED [ 66%]

tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_999b PASSED [ 66%]

tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_units PASSED [ 66%]

tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_call PASSED [ 67%]

tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return PASSED [ 67%]

tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return_no_result PASSED [ 67%]

tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return_sequence PASSED [ 67%]

tests/unit/config/config_test.py::ConfigTest::test_build_args_allow_empty_properties PASSED [ 67%]

tests/unit/config/config_test.py::ConfigTest::test_build_args_check_zero_preserved PASSED [ 67%]

tests/unit/config/config_test.py::ConfigTest::test_config_build_configuration PASSED [ 67%]

tests/unit/config/config_test.py::ConfigTest::test_config_build_configuration_v2 PASSED [ 67%]

tests/unit/config/config_test.py::ConfigTest::test_config_convertible_label_types PASSED [ 67%]

tests/unit/config/config_test.py::ConfigTest::test_config_duplicate_cache_from_values_validation_error PASSED [ 67%]

tests/unit/config/config_test.py::ConfigTest::test_config_duplicate_mount_points PASSED [ 67%]

tests/unit/config/config_test.py::ConfigTest::test_config_extra_hosts_list_of_dicts_validation_error PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_extra_hosts_string_raises_validation_error PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_hint PASSED    [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error_v2 PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error_v2_when_no_interpolate PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_property_raise_validation_error PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_invalid_ipam_config PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_invalid_label_types PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_invalid_service_name_raise_validation_error PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_invalid_keys_validation_error PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_required_keys_validation_error PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_soft_greater_than_hard_error PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_config_valid_environment_dict_key_contains_dashes PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_config_valid_ipam_config PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_config_valid_service_label_validation PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_config_valid_service_names PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_depends_on_orders_services PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_depends_on_unknown_service_errors PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_dns_opt_option PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_empty_environment_key_allowed PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_external_volume_config PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_external_volume_invalid_config PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_group_add_option PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_invalid_config_build_and_image_specified_v1 PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_invalid_config_not_a_dictionary PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_invalid_config_not_unique_items PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_invalid_config_type_should_be_an_array PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_invalid_config_v1 PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_invalid_config_v2 PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_invalid_list_of_strings_format PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_isolation_option PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_linked_service_is_undefined PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_load PASSED           [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_load_bind_mount_relative_path PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_load_bind_mount_relative_path_with_tilde PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_build_labels_dict PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_build_labels_list PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_config_custom_resource_names PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_config_dockerfile_without_build_raises_error_v1 PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_config_invalid_service_names PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_config_invalid_service_names_v2 PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_config_link_local_ips_network PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_config_service_labels PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_config_volume_and_network_labels PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_configs PASSED   [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_configs_multi_file PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_dockerfile_without_context PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_errors_on_uppercase_with_no_image PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_invalid_service_definition PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_mixed_extends_resolution PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_secrets PASSED   [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_secrets_multi_file PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_service_with_name_version PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_sorts_in_dependency_order PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_when_not_dict PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_when_not_dict_v2 PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_with_invalid_network_fields PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_v2 PASSED        [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_buildargs PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_empty_build_args PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_extensions PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_invalid_field_name PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_invalid_field_name_v1 PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_base PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_base_v2 PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_override PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_override_v2 PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_extends_in_override_file PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_invalid_override PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_mismatched_networks_format PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_mismatched_networks_format_inverse_order PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v1 PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v2 PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v3_2 PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_load_yaml_with_bom PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_load_yaml_with_yaml_error PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_logs_warning_for_boolean_in_environment PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_merge_blkio_config PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_merge_configs_override PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_merge_credential_spec PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_depends_on_mixed_syntax PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_depends_on_no_override PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_deploy PASSED   [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_deploy_override PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_device_cgroup_rules PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_different_configs PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_different_secrets PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_extra_hosts PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_config PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_override_disables PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_override_enables PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_isolation PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v1 PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2 PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_base PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_base_driver PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_drivers PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_override PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_override_options PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_override_driver PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_mixed_ports PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_pid PASSED      [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_scale PASSED    [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_merge_secrets_override PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_from_files_with_extends_in_base PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_from_files_with_extends_in_override PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous_2 PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous_volumes PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_ports_sorting PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_merge_storage_opt PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_named_volume_config_empty PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_named_volume_invalid_type_list PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_named_volume_numeric_driver_opt PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_networks_invalid_type_list PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_normalize_dns_options PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_oom_score_adj_option PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_runtime_option PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_service_volume_invalid_config PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_swappiness_option PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_tmpfs_option PASSED   [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_undeclared_volume_v1 PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_undeclared_volume_v2 PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_unsupported_version PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_v1_file_version PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_v1_file_with_version_is_invalid PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_valid_config_oneof_string_or_list PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_valid_config_which_allows_two_type_definitions PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_valid_versions PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_validate_extra_hosts_invalid PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_validate_extra_hosts_invalid_list PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_version_1_is_invalid PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_volume_invalid_driver_opt PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_volume_mode_override PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_volumes_long_syntax PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_wrong_version_type PASSED [ 79%]

tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_container PASSED [ 79%]

tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_container_v1 PASSED [ 80%]

tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_plus_networks_is_invalid PASSED [ 80%]

tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service PASSED [ 80%]

tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service_nonexistent PASSED [ 80%]

tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service_v1 PASSED [ 80%]

tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_standard PASSED [ 80%]

tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_standard_v1 PASSED [ 80%]

tests/unit/config/config_test.py::PortsTest::test_config_invalid_expose_format_validation PASSED [ 80%]

tests/unit/config/config_test.py::PortsTest::test_config_invalid_expose_type_validation PASSED [ 80%]

tests/unit/config/config_test.py::PortsTest::test_config_invalid_ports_format_validation PASSED [ 80%]

tests/unit/config/config_test.py::PortsTest::test_config_invalid_ports_type_validation PASSED [ 80%]

tests/unit/config/config_test.py::PortsTest::test_config_non_unique_expose_validation PASSED [ 81%]

tests/unit/config/config_test.py::PortsTest::test_config_non_unique_ports_validation PASSED [ 81%]

tests/unit/config/config_test.py::PortsTest::test_config_valid_expose_format_validation PASSED [ 81%]

tests/unit/config/config_test.py::PortsTest::test_config_valid_ports_format_validation PASSED [ 81%]

tests/unit/config/config_test.py::SubnetTest::test_config_invalid_subnet_format_validation PASSED [ 81%]

tests/unit/config/config_test.py::SubnetTest::test_config_invalid_subnet_type_validation PASSED [ 81%]

tests/unit/config/config_test.py::SubnetTest::test_config_valid_subnet_format_validation PASSED [ 81%]

tests/unit/config/config_test.py::InterpolationTest::test_compatibility_mode_load PASSED [ 81%]

tests/unit/config/config_test.py::InterpolationTest::test_compatibility_mode_warnings PASSED [ 81%]

tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_file PASSED [ 81%]

tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_variable PASSED [ 81%]

tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_variable_with_defaults PASSED [ 81%]

tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_options_environment_file PASSED [ 82%]

tests/unit/config/config_test.py::InterpolationTest::test_interpolation_configs_section PASSED [ 82%]

tests/unit/config/config_test.py::InterpolationTest::test_interpolation_secrets_section PASSED [ 82%]

tests/unit/config/config_test.py::InterpolationTest::test_invalid_interpolation PASSED [ 82%]

tests/unit/config/config_test.py::InterpolationTest::test_unset_variable_produces_warning PASSED [ 82%]

tests/unit/config/config_test.py::VolumeConfigTest::test_absolute_posix_path_does_not_expand PASSED [ 82%]

tests/unit/config/config_test.py::VolumeConfigTest::test_absolute_windows_path_does_not_expand PASSED [ 82%]

tests/unit/config/config_test.py::VolumeConfigTest::test_home_directory_with_driver_does_not_expand PASSED [ 82%]

tests/unit/config/config_test.py::VolumeConfigTest::test_name_does_not_expand PASSED [ 82%]

tests/unit/config/config_test.py::VolumeConfigTest::test_no_binding PASSED [ 82%]

tests/unit/config/config_test.py::VolumeConfigTest::test_relative_path_does_expand_posix PASSED [ 82%]

tests/unit/config/config_test.py::VolumeConfigTest::test_relative_path_does_expand_windows SKIPPED [ 83%]

tests/unit/config/config_test.py::VolumeConfigTest::test_volume_binding_with_environment_variable PASSED [ 83%]

tests/unit/config/config_test.py::VolumeConfigTest::test_volume_binding_with_home PASSED [ 83%]

tests/unit/config/config_test.py::VolumeConfigTest::test_volume_path_with_non_ascii_directory PASSED [ 83%]

tests/unit/config/config_test.py::VolumeConfigTest::test_volumes_order_is_preserved PASSED [ 83%]

tests/unit/config/config_test.py::MergeVolumesTest::test_add_explicit_path PASSED [ 83%]

tests/unit/config/config_test.py::MergeVolumesTest::test_empty PASSED    [ 83%]

tests/unit/config/config_test.py::MergeVolumesTest::test_no_base PASSED  [ 83%]

tests/unit/config/config_test.py::MergeVolumesTest::test_no_override PASSED [ 83%]

tests/unit/config/config_test.py::MergeVolumesTest::test_override_explicit_path PASSED [ 83%]

tests/unit/config/config_test.py::MergeVolumesTest::test_remove_explicit_path PASSED [ 83%]

tests/unit/config/config_test.py::MergeDevicesTest::test_add_explicit_path PASSED [ 83%]

tests/unit/config/config_test.py::MergeDevicesTest::test_empty PASSED    [ 84%]

tests/unit/config/config_test.py::MergeDevicesTest::test_no_base PASSED  [ 84%]

tests/unit/config/config_test.py::MergeDevicesTest::test_no_override PASSED [ 84%]

tests/unit/config/config_test.py::MergeDevicesTest::test_override_explicit_path PASSED [ 84%]

tests/unit/config/config_test.py::MergeDevicesTest::test_remove_explicit_path PASSED [ 84%]

tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_no_override PASSED [ 84%]

tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_override_with_other PASSED [ 84%]

tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_override_with_same PASSED [ 84%]

tests/unit/config/config_test.py::MergePortsTest::test_add_item PASSED   [ 84%]

tests/unit/config/config_test.py::MergePortsTest::test_duplicate_port_mappings PASSED [ 84%]

tests/unit/config/config_test.py::MergePortsTest::test_empty PASSED      [ 84%]

tests/unit/config/config_test.py::MergePortsTest::test_no_base PASSED    [ 85%]

tests/unit/config/config_test.py::MergePortsTest::test_no_override PASSED [ 85%]

tests/unit/config/config_test.py::MergeNetworksTest::test_add_item PASSED [ 85%]

tests/unit/config/config_test.py::MergeNetworksTest::test_all_properties PASSED [ 85%]

tests/unit/config/config_test.py::MergeNetworksTest::test_empty PASSED   [ 85%]

tests/unit/config/config_test.py::MergeNetworksTest::test_network_has_none_value PASSED [ 85%]

tests/unit/config/config_test.py::MergeNetworksTest::test_no_base PASSED [ 85%]

tests/unit/config/config_test.py::MergeNetworksTest::test_no_network_name_overrides PASSED [ 85%]

tests/unit/config/config_test.py::MergeNetworksTest::test_no_network_overrides PASSED [ 85%]

tests/unit/config/config_test.py::MergeNetworksTest::test_no_override PASSED [ 85%]

tests/unit/config/config_test.py::MergeStringsOrListsTest::test_add_list PASSED [ 85%]

tests/unit/config/config_test.py::MergeStringsOrListsTest::test_add_string PASSED [ 85%]

tests/unit/config/config_test.py::MergeStringsOrListsTest::test_no_base PASSED [ 86%]

tests/unit/config/config_test.py::MergeStringsOrListsTest::test_no_override PASSED [ 86%]

tests/unit/config/config_test.py::MergeLabelsTest::test_add_explicit_value PASSED [ 86%]

tests/unit/config/config_test.py::MergeLabelsTest::test_empty PASSED     [ 86%]

tests/unit/config/config_test.py::MergeLabelsTest::test_no_base PASSED   [ 86%]

tests/unit/config/config_test.py::MergeLabelsTest::test_no_override PASSED [ 86%]

tests/unit/config/config_test.py::MergeLabelsTest::test_override_explicit_value PASSED [ 86%]

tests/unit/config/config_test.py::MergeLabelsTest::test_remove_explicit_value PASSED [ 86%]

tests/unit/config/config_test.py::MergeBuildTest::test_empty_base PASSED [ 86%]

tests/unit/config/config_test.py::MergeBuildTest::test_empty_override PASSED [ 86%]

tests/unit/config/config_test.py::MergeBuildTest::test_full PASSED       [ 86%]

tests/unit/config/config_test.py::MemoryOptionsTest::test_memswap_can_be_a_string PASSED [ 87%]

tests/unit/config/config_test.py::MemoryOptionsTest::test_validation_fails_with_just_memswap_limit PASSED [ 87%]

tests/unit/config/config_test.py::MemoryOptionsTest::test_validation_with_correct_memswap_values PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_environment_overrides_env_file PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_parse_environment_as_dict PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_parse_environment_as_list PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_parse_environment_empty PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_parse_environment_invalid PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_resolve_build_args PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_resolve_environment PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_resolve_environment_from_env_file PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_resolve_environment_from_env_file_with_empty_values PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_resolve_environment_nonexistent_file PASSED [ 88%]

tests/unit/config/config_test.py::EnvTest::test_resolve_environment_with_multiple_env_files PASSED [ 88%]

tests/unit/config/config_test.py::EnvTest::test_resolve_path PASSED      [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_circular PASSED      [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_invalid_config PASSED [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_valid_config PASSED [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_verbose_and_shorthand_way PASSED [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_extends PASSED       [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_file_defaults_to_self PASSED [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_same_file_optimization PASSED [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_empty_dictionary PASSED [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_invalid_key PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_missing_service_key PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_no_file_key_no_filename_set PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_sub_property_key PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_valid_config PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_with_defined_version_passes PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_with_depends_on PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_with_environment_and_env_files PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_with_healthcheck PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_with_mixed_versions_is_error PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_with_ports PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_with_security_opt PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_invalid_links_in_extended_service PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_invalid_net_in_extended_service PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_invalid_volumes_from_in_extended_service PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_load_config_runs_interpolation_in_extended_service PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_load_throws_error_when_base_service_does_not_exist PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_merging_env_labels_ulimits PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_nested PASSED        [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_parent_build_path_dne PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_partial_service_config_in_extends_is_still_valid PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_self_referencing_file PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_volume_path PASSED   [ 90%]

tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_absolute PASSED [ 91%]

tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_normal PASSED [ 91%]

tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_with_tilde PASSED [ 91%]

tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_root_mount PASSED [ 91%]

tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_windows_path PASSED [ 91%]

tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_windows_path_in_container PASSED [ 91%]

tests/unit/config/config_test.py::BuildPathTest::test_absolute_path PASSED [ 91%]

tests/unit/config/config_test.py::BuildPathTest::test_from_file PASSED   [ 91%]

tests/unit/config/config_test.py::BuildPathTest::test_from_file_override_dir PASSED [ 91%]

tests/unit/config/config_test.py::BuildPathTest::test_invalid_url_in_build_path PASSED [ 91%]

tests/unit/config/config_test.py::BuildPathTest::test_nonexistent_path PASSED [ 91%]

tests/unit/config/config_test.py::BuildPathTest::test_relative_path PASSED [ 91%]

tests/unit/config/config_test.py::BuildPathTest::test_valid_url_in_build_path PASSED [ 92%]

tests/unit/config/config_test.py::HealthcheckTest::test_disable PASSED   [ 92%]

tests/unit/config/config_test.py::HealthcheckTest::test_disable_with_other_config_is_invalid PASSED [ 92%]

tests/unit/config/config_test.py::HealthcheckTest::test_healthcheck PASSED [ 92%]

tests/unit/config/config_test.py::HealthcheckTest::test_healthcheck_with_invalid_test PASSED [ 92%]

tests/unit/config/config_test.py::GetDefaultConfigFilesTestCase::test_get_config_path_default_file_in_basedir PASSED [ 92%]

tests/unit/config/config_test.py::GetDefaultConfigFilesTestCase::test_get_config_path_default_file_in_parent_dir PASSED [ 92%]

tests/unit/config/config_test.py::SerializeTest::test_denormalize_depends_on_v2_1 PASSED [ 92%]

tests/unit/config/config_test.py::SerializeTest::test_denormalize_depends_on_v3 PASSED [ 92%]

tests/unit/config/config_test.py::SerializeTest::test_denormalize_healthcheck PASSED [ 92%]

tests/unit/config/config_test.py::SerializeTest::test_denormalize_image_has_digest PASSED [ 92%]

tests/unit/config/config_test.py::SerializeTest::test_denormalize_image_no_digest PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_bool_string PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_configs PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_escape_dollar_sign PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_escape_dont_interpolate PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_external_false PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_ports PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_ports_with_ext_ip PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_secrets PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_time PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_unicode_values PASSED [ 93%]

tests/unit/config/environment_test.py::EnvironmentTest::test_env_vars_from_file_bom PASSED [ 93%]

tests/unit/config/environment_test.py::EnvironmentTest::test_env_vars_from_file_whitespace PASSED [ 94%]

tests/unit/config/environment_test.py::EnvironmentTest::test_get_boolean PASSED [ 94%]

tests/unit/config/environment_test.py::EnvironmentTest::test_get_simple PASSED [ 94%]

tests/unit/config/environment_test.py::EnvironmentTest::test_get_undefined PASSED [ 94%]

tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_services PASSED [ 94%]

tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_volumes PASSED [ 94%]

tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_secrets PASSED [ 94%]

tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_v2 PASSED [ 94%]

tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_v3 PASSED [ 94%]

tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_invalid PASSED [ 94%]

tests/unit/config/interpolation_test.py::test_interpolate_environment_network_convert_types PASSED [ 94%]

tests/unit/config/interpolation_test.py::test_interpolate_environment_external_resource_convert_types PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_service_name_uses_dot PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_escaped_interpolation PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_invalid_interpolation PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_missing_no_default PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_with_value PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_missing_with_default PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_with_empty_and_default_value PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_mandatory_values PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_mandatory_no_err_msg PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_mixed_separators PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_unbraced_separators PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_unicode_values PASSED [ 96%]

tests/unit/config/interpolation_test.py::test_interpolate_no_fallthrough PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_1 PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_2 PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_3 PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_4 PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_5 PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_6 PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_7 PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports_2 PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports_3 PASSED [ 97%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_self_imports PASSED [ 97%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_depends_on_self PASSED [ 97%]

tests/unit/config/types_test.py::test_parse_extra_hosts_list PASSED      [ 97%]

tests/unit/config/types_test.py::test_parse_extra_hosts_dict PASSED      [ 97%]

tests/unit/config/types_test.py::TestServicePort::test_parse_dict PASSED [ 97%]

tests/unit/config/types_test.py::TestServicePort::test_parse_simple_target_port PASSED [ 97%]

tests/unit/config/types_test.py::TestServicePort::test_parse_complete_port_definition PASSED [ 97%]

tests/unit/config/types_test.py::TestServicePort::test_parse_ext_ip_no_published_port PASSED [ 97%]

tests/unit/config/types_test.py::TestServicePort::test_repr_published_port_0 PASSED [ 97%]

tests/unit/config/types_test.py::TestServicePort::test_parse_port_range PASSED [ 97%]

tests/unit/config/types_test.py::TestServicePort::test_parse_port_publish_range PASSED [ 97%]

tests/unit/config/types_test.py::TestServicePort::test_parse_invalid_port PASSED [ 98%]

tests/unit/config/types_test.py::TestServicePort::test_parse_invalid_publish_range PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_only_one_path PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_internal_and_external PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_with_mode PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_too_many_parts PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_absolute_path_normalized PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_absolute_path_native PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_internal_path_normalized PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_internal_path_native PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_just_drives_normalized PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_just_drives_native PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_mixed_notations_normalized PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_mixed_notations_native PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_from_service PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_from_container PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_invalid PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_service PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_service_with_mode PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_container PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_container_with_mode PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_invalid_type PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_invalid PASSED [100%]



---------- coverage: platform linux2, python 2.7.16-final-0 ----------

Name                              Stmts   Miss Branch BrPart  Cover   Missing

-----------------------------------------------------------------------------

compose/__init__.py                   3      0      0      0   100%

compose/__main__.py                   4      4      0      0     0%   1-6

compose/bundle.py                   144     21     60      5    84%   45, 50-51, 56-57, 75-78, 81, 103-109, 130-131, 141-146, 149, 80->81, 100->103, 118->135, 125->135, 148->149

compose/cli/__init__.py               0      0      0      0   100%

compose/cli/colors.py                23      2     10      2    88%   37-38, 36->37, 48->exit

compose/cli/command.py              104     14     32      5    83%   71-81, 121-126, 177, 200, 70->71, 120->121, 165->168, 176->177, 197->200

compose/cli/docker_client.py         75      5     24      2    93%   24, 98-99, 107, 123, 106->107, 122->123

compose/cli/docopt_command.py        38      4      8      2    87%   13-14, 29, 35, 28->29, 34->35

compose/cli/errors.py               100     26     34      6    67%   47-48, 62-65, 70-79, 105-106, 123, 125, 127-131, 136, 141-148, 46->47, 61->62, 103->105, 122->123, 124->125, 126->127

compose/cli/formatter.py             37      3      8      1    91%   13, 22-23, 12->13

compose/cli/log_printer.py          149     10     53      6    91%   76, 103, 110-115, 167, 176, 229-232, 262, 43->exit, 75->76, 98->103, 174->176, 228->229, 237->243

compose/cli/main.py                 696     91    290     41    84%   84-85, 87-88, 169, 330, 362-364, 447, 507, 511, 516-517, 527-556, 568, 586-588, 592, 659-660, 698-699, 717, 738-739, 751, 774, 792, 839, 1071, 1080, 1109-1118, 1158-1161, 1169-1173, 1175-1180, 1203, 1225-1254, 1261-1262, 1264-1266, 1281, 1287, 1471, 1489, 1505, 1509-1510, 1521, 1526, 1529, 1555, 1574-1576, 1586, 1597, 61->64, 83->84, 86->87, 168->169, 329->330, 361->362, 446->447, 506->507, 510->511, 521->527, 565->568, 585->586, 591->592, 657->659, 716->717, 737->738, 750->751, 773->774, 829->839, 831->exit, 1070->1071, 1079->1080, 1168->1169, 1174->1175, 1202->1203, 1260->1261, 1263->1264, 1280->1281, 1286->1287, 1470->1471, 1488->1489, 1504->1505, 1520->1521, 1525->1526, 1528->1529, 1547->exit, 1554->1555, 1568->1576, 1570->1574, 1585->1586, 1595->1597

compose/cli/signals.py               23      0      4      2    93%   36->exit, 43->exit

compose/cli/utils.py                 81     28     18      4    60%   36-45, 53-55, 62-68, 76, 90-103, 109, 127-128, 138, 151-154, 88->90, 108->109, 137->138, 150->151

compose/cli/verbose_proxy.py         35     12     10      0    69%   36-39, 42-47, 50-60

compose/config/__init__.py           13      0      0      0   100%

compose/config/config.py            826     28    388     18    95%   266, 508, 578, 714, 757, 812-830, 952-953, 959, 979, 982, 1335, 1366, 1412, 265->266, 577->578, 709->713, 713->714, 756->757, 778->exit, 809->812, 936->938, 938->942, 957->959, 978->979, 981->982, 993->1002, 1015->1017, 1017->1020, 1332->1335, 1365->1366, 1408->1412

compose/config/environment.py        96      7     34      4    92%   41, 98-101, 114, 121, 40->41, 97->98, 113->114, 120->121

compose/config/errors.py             25      2      0      0    92%   36-40

compose/config/interpolation.py     148      7     62      4    94%   66, 148, 196, 222, 227-229, 121->exit, 146->148, 195->196, 221->222

compose/config/serialize.py          97      1     50      2    98%   76, 75->76, 82->85

compose/config/sort_services.py      44      1     18      1    97%   57, 56->57

compose/config/types.py             291     22    112     17    90%   54, 90, 113, 149, 171, 258-259, 267, 286, 301, 363-364, 372-373, 377-378, 441, 445, 486, 493-494, 502, 53->54, 71->79, 89->90, 112->113, 118->exit, 148->149, 170->171, 257->258, 266->267, 285->286, 298->301, 361->366, 440->441, 444->445, 484->489, 485->486, 501->502

compose/config/validation.py        254     14    140     12    92%   219, 249, 299-300, 318-319, 341, 363, 469-471, 496-498, 525, 218->219, 248->249, 289->299, 317->318, 335->338, 338->341, 362->363, 404->377, 425->exit, 467->469, 495->496, 524->525

compose/const.py                     39      0      0      0   100%

compose/container.py                193      8     48      7    94%   98, 105, 151, 153, 262, 265, 297, 320, 97->98, 104->105, 150->151, 152->153, 236->235, 303->exit, 319->320

compose/errors.py                    17      1      0      0    94%   12

compose/network.py                  190     19     92      5    87%   184, 186-200, 206, 224, 226, 183->184, 185->186, 205->206, 223->224, 225->226

compose/parallel.py                 199      2     56      1    99%   187, 326, 325->326

compose/progress_stream.py           87     12     44     10    82%   40, 71, 74, 80, 85, 90-91, 116, 122-125, 39->40, 42->46, 53->57, 70->71, 73->74, 79->80, 84->85, 89->90, 112->116, 121->122

compose/project.py                  450     31    182     14    92%   64, 161, 217-218, 259-260, 370-371, 374-379, 393-396, 449, 500, 504, 531, 634-638, 641, 659, 790-791, 797-800, 855, 61->64, 157->161, 336->338, 368->370, 373->374, 392->393, 448->449, 499->500, 503->504, 530->531, 640->641, 658->659, 709->exit, 793->800

compose/service.py                  920     57    406     30    92%   67, 278-279, 300, 373-376, 424-429, 435-437, 477-478, 493, 496, 514, 581, 626-629, 737, 956-957, 977-978, 1079, 1126, 1187, 1251-1266, 1306, 1345-1349, 1537, 1541, 1699, 1785, 1826, 1839, 1843-1844, 1848-1849, 64->67, 223->exit, 276->278, 299->300, 434->435, 476->477, 492->493, 495->496, 513->514, 571->581, 732->737, 955->956, 976->977, 1078->1079, 1125->1126, 1186->1187, 1305->1306, 1342->1345, 1536->1537, 1540->1541, 1589->exit, 1597->1596, 1635->1632, 1698->1699, 1784->1785, 1810->1812, 1825->1826, 1838->1839, 1842->1843, 1847->1848

compose/state.py                      0      0      0      0   100%

compose/timeparse.py                 22      0      4      0   100%

compose/utils.py                    117      8     42      5    92%   26, 75-79, 125, 135, 161, 168, 171, 25->26, 124->125, 134->135, 167->168, 169->171

compose/version.py                    6      0      0      0   100%

compose/volume.py                   126      4     44      3    95%   150, 200, 211-212, 141->150, 199->200, 209->211

-----------------------------------------------------------------------------

TOTAL                              5672    444   2273    209    90%

Coverage HTML written to dir coverage-html



=========================== short test summary info ============================

XFAIL tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_rt

  not supported by kernel

XFAIL tests/integration/service_test.py::ServiceTest::test_create_container_with_storage_opt

  Not supported on most drivers

SKIP [1] tests/integration/service_test.py:150: cpu_percent is not supported for Linux

SKIP [1] tests/unit/cli/errors_test.py:90: Needs pywin32

SKIP [1] tests/acceptance/cli_test.py:2437: race condition between up and logs

SKIP [1] tests/unit/cli/errors_test.py:70: Needs pywin32

SKIP [1] tests/unit/config/config_test.py:3778: windows paths

SKIP [1] tests/unit/cli/errors_test.py:80: Needs pywin32

SKIP [1] /code/tests/integration/testcases.py:167: This daemon does not support the 'nvidia'' runtime

SKIP [1] tests/unit/cli/command_test.py:39: windows separator

SKIP [1] tests/acceptance/cli_test.py:2389: race condition between up and logs

SKIP [1] tests/acceptance/cli_test.py:2416: race condition between up and logs

SKIP [1] tests/integration/service_test.py:1674: Broken on 1.11.0 - 17.03.0



======= 1132 passed, 11 skipped, 2 xfailed, 3 xpassed in 843.08 seconds ========

___________________________________ summary ____________________________________

  py27: commands succeeded

  congratulations :)

+ on_exit
+ [[ 0 != \0 ]]
+ docker rm -vf compose-dind-19.03.5-jenkins-compose-ndeloof-28
compose-dind-19.03.5-jenkins-compose-ndeloof-28
[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // node
[Pipeline] node
Running on ubuntu-1804-overlay2 (i-0b6eb4af357135099) in /home/ubuntu/workspace/compose_ndeloof
[Pipeline] {
[Pipeline] stage
[Pipeline] { (alpine 19.03.5 py37)
[Pipeline] checkout
using credential sf-release-bot.github.ssh
Fetching changes from the remote Git repository
Fetching without tags
Checking out Revision f0d8706f3473426bfcc85197834187726323acf2 (ndeloof)
Commit message: "WiP"
 > git rev-parse --is-inside-work-tree # timeout=10
 > git config remote.origin.url git@github.com:docker/compose.git # timeout=10
Fetching upstream changes from git@github.com:docker/compose.git
 > git --version # timeout=10
using GIT_SSH to set credentials docker-jenkins user on github.com
 > git fetch --no-tags --progress -- git@github.com:docker/compose.git +refs/heads/ndeloof:refs/remotes/origin/ndeloof
 > git config core.sparsecheckout # timeout=10
 > git checkout -f f0d8706f3473426bfcc85197834187726323acf2
[Pipeline] unstash
Unstashed file(s) from https://corp-us-east-1-jenkins-k8s-maste-jenkinsartifacts-1lzm7adht5e1j.s3.amazonaws.com/public/compose/ndeloof/28/stashes/alpine.tgz
[Pipeline] sh
+ docker load -i alpine.tar
Loaded image: compose:alpine
[Pipeline] sh
+ pwd
+ docker run -t --rm --privileged --volume=/home/ubuntu/workspace/compose_ndeloof/.git:/code/.git --volume=/var/run/docker.sock:/var/run/docker.sock -e TAG=compose:alpine -e DOCKER_VERSIONS=19.03.5 -e BUILD_NUMBER=jenkins-compose-ndeloof-28 -e PY_TEST_VERSIONS=py37 --entrypoint=script/test/ci compose:alpine --verbose
+ docker version
Client: Docker Engine - Community
 Version:           18.09.7
 API version:       1.39
 Go version:        go1.10.8
 Git commit:        2d0083d
 Built:             Thu Jun 27 17:54:15 2019
 OS/Arch:           linux/amd64
 Experimental:      false

Server: Docker Engine - Community
 Engine:
  Version:          19.03.2
  API version:      1.40 (minimum version 1.12)
  Go version:       go1.12.8
  Git commit:       6a30dfc
  Built:            Thu Aug 29 05:27:45 2019
  OS/Arch:          linux/amd64
  Experimental:     true
 containerd:
  Version:          1.2.6
  GitCommit:        894b81a4b802e4eb2a91d1ce216b8817763c29fb
 runc:
  Version:          1.0.0-rc8
  GitCommit:        425e105d5a03fabd737a126ad93d62a9eeede87f
 docker-init:
  Version:          0.18.0
  GitCommit:        fec3683
+ export DOCKER_VERSIONS=19.03.5
+ DOCKER_VERSIONS=19.03.5
+ STORAGE_DRIVER=overlay
+ export DOCKER_DAEMON_ARGS=--storage-driver=overlay
+ DOCKER_DAEMON_ARGS=--storage-driver=overlay
++ hostname
+ GIT_VOLUME=--volumes-from=d6e06633ceb6
+ . script/test/all
++ set -e
++ echo 'Running lint checks'
Running lint checks
++ docker run --rm --tty --volumes-from=d6e06633ceb6 compose:alpine tox -e pre-commit
pre-commit installed: aspy.yaml==1.3.0,cfgv==2.0.1,identify==1.4.7,importlib-metadata==1.1.0,more-itertools==8.0.0,nodeenv==1.3.3,pre-commit==1.20.0,PyYAML==5.2,six==1.13.0,toml==0.10.0,virtualenv==16.7.8,zipp==0.6.0

pre-commit runtests: PYTHONHASHSEED='3561887802'

pre-commit runtests: commands[0] | pre-commit install

pre-commit installed at .git/hooks/pre-commit

pre-commit runtests: commands[1] | pre-commit run --all-files

[WARNING] Unexpected key(s) present on git://github.com/pre-commit/pre-commit-hooks: sha

[WARNING] Unexpected key(s) present on git://github.com/asottile/reorder_python_imports: sha

[INFO] Initializing environment for git://github.com/pre-commit/pre-commit-hooks.

[INFO] Initializing environment for git://github.com/asottile/reorder_python_imports.

[INFO] Installing environment for git://github.com/pre-commit/pre-commit-hooks.

[INFO] Once installed this environment will be reused.

[INFO] This may take a few minutes...

[INFO] Installing environment for git://github.com/asottile/reorder_python_imports.

[INFO] Once installed this environment will be reused.

[INFO] This may take a few minutes...

Check for added large files..............................................Passed

Check docstring is first.................................................Passed

Check for merge conflicts................................................Passed

Check Yaml...............................................................Passed

Check JSON...............................................................Passed

Debug Statements (Python)................................................Passed

Fix End of Files.........................................................Passed

Flake8...................................................................Passed

Tests should end in _test.py.............................................Passed

Fix requirements.txt.....................................................Passed

Trim Trailing Whitespace.................................................Passed

Reorder python imports...................................................Passed

___________________________________ summary ____________________________________

  pre-commit: commands succeeded

  congratulations :)

++ get_versions='docker run --rm
    --entrypoint=/code/.tox/py27/bin/python
    compose:alpine
    /code/script/test/versions.py docker/docker-ce,moby/moby'
++ '[' 19.03.5 == '' ']'
++ '[' 19.03.5 == all ']'
++ BUILD_NUMBER=jenkins-compose-ndeloof-28
++ PY_TEST_VERSIONS=py37
++ for version in $DOCKER_VERSIONS
++ echo 'Running tests against Docker 19.03.5'
Running tests against Docker 19.03.5
++ daemon_container=compose-dind-19.03.5-jenkins-compose-ndeloof-28
++ trap on_exit EXIT
++ repo=dockerswarm/dind
++ docker run -d --name compose-dind-19.03.5-jenkins-compose-ndeloof-28 --privileged --volume=/var/lib/docker dockerswarm/dind:19.03.5 dockerd -H tcp://0.0.0.0:2375 --storage-driver=overlay
++ tail -n 10
a42fdaffc1805bca3a56e8f80792c6e4c3cd062ff8e98955ba1f1f2ca0c65053
++ docker run --rm --tty --link=compose-dind-19.03.5-jenkins-compose-ndeloof-28:docker --env=DOCKER_HOST=tcp://docker:2375 --env=DOCKER_VERSION=19.03.5 --entrypoint=tox compose:alpine -e py37 -- --verbose
py37 develop-inst-nodeps: /code

py37 installed: altgraph==0.16.1,atomicwrites==1.3.0,attrs==19.3.0,backports.shutil-get-terminal-size==1.0.0,bcrypt==3.1.7,cached-property==1.3.0,certifi==2017.4.17,cffi==1.13.2,chardet==3.0.4,coverage==4.4.2,cryptography==2.8,ddt==1.2.0,docker==4.1.0,# Editable install with no version control (docker-compose==1.26.0.dev0),-e /code,docker-pycreds==0.4.0,dockerpty==0.4.1,docopt==0.6.2,flake8==3.5.0,idna==2.5,ipaddress==1.0.18,jsonschema==3.0.1,mccabe==0.6.1,mock==3.0.5,more-itertools==8.0.0,paramiko==2.6.0,pluggy==0.6.0,py==1.8.0,pycodestyle==2.3.1,pycparser==2.19,pyflakes==1.6.0,PyInstaller==3.5,PyNaCl==1.3.0,pyrsistent==0.15.6,PySocks==1.6.7,pytest==3.6.3,pytest-cov==2.5.1,PyYAML==4.2b1,requests==2.22.0,six==1.12.0,texttable==1.6.2,urllib3==1.25.7,websocket-client==0.32.0

py37 runtests: PYTHONHASHSEED='1719571777'

py37 runtests: commands[0] | mkdir -p .coverage-binfiles

py37 runtests: commands[1] | py.test -v --cov=compose --cov-report html --cov-report term --cov-config=tox.ini --verbose

============================= test session starts ==============================

platform linux -- Python 3.7.4, pytest-3.6.3, py-1.8.0, pluggy-0.6.0 -- /code/.tox/py37/bin/python3.7

cachedir: .pytest_cache

rootdir: /code, inifile: tox.ini

plugins: cov-2.5.1


collecting 0 items                                                             
collecting 197 items                                                           
collecting 197 items                                                           
collecting 197 items                                                           
collecting 197 items                                                           
collecting 198 items                                                           
collecting 198 items                                                           
collecting 198 items                                                           
collecting 201 items                                                           
collecting 201 items                                                           
collecting 201 items                                                           
collecting 269 items                                                           
collecting 269 items                                                           
collecting 269 items                                                           
collecting 272 items                                                           
collecting 272 items                                                           
collecting 272 items                                                           
collecting 401 items                                                           
collecting 405 items                                                           
collecting 405 items                                                           
collecting 405 items                                                           
collecting 405 items                                                           
collecting 408 items                                                           
collecting 417 items                                                           
collecting 428 items                                                           
collecting 436 items                                                           
collecting 436 items                                                           
collecting 436 items                                                           
collecting 436 items                                                           
collecting 447 items                                                           
collecting 447 items                                                           
collecting 464 items                                                           
collecting 477 items                                                           
collecting 477 items                                                           
collecting 495 items                                                           
collecting 496 items                                                           
collecting 496 items                                                           
collecting 504 items                                                           
collecting 504 items                                                           
collecting 509 items                                                           
collecting 512 items                                                           
collecting 521 items                                                           
collecting 521 items                                                           
collecting 552 items                                                           
collecting 552 items                                                           
collecting 626 items                                                           
collecting 627 items                                                           
collecting 630 items                                                           
collecting 634 items                                                           
collecting 635 items                                                           
collecting 645 items                                                           
collecting 648 items                                                           
collecting 651 items                                                           
collecting 651 items                                                           
collecting 656 items                                                           
collecting 656 items                                                           
collecting 669 items                                                           
collecting 672 items                                                           
collecting 672 items                                                           
collecting 674 items                                                           
collecting 674 items                                                           
collecting 676 items                                                           
collecting 676 items                                                           
collecting 677 items                                                           
collecting 677 items                                                           
collecting 678 items                                                           
collecting 678 items                                                           
collecting 678 items                                                           
collecting 680 items                                                           
collecting 680 items                                                           
collecting 680 items                                                           
collecting 688 items                                                           
collecting 688 items                                                           
collecting 688 items                                                           
collecting 692 items                                                           
collecting 708 items                                                           
collecting 711 items                                                           
collecting 711 items                                                           
collecting 711 items                                                           
collecting 719 items                                                           
collecting 719 items                                                           
collecting 719 items                                                           
collecting 725 items                                                           
collecting 725 items                                                           
collecting 727 items                                                           
collecting 727 items                                                           
collecting 730 items                                                           
collecting 730 items                                                           
collecting 734 items                                                           
collecting 734 items                                                           
collecting 738 items                                                           
collecting 738 items                                                           
collecting 741 items                                                           
collecting 746 items                                                           
collecting 746 items                                                           
collecting 749 items                                                           
collecting 749 items                                                           
collecting 753 items                                                           
collecting 753 items                                                           
collecting 760 items                                                           
collecting 760 items                                                           
collecting 760 items                                                           
collecting 764 items                                                           
collecting 769 items                                                           
collecting 769 items                                                           
collecting 773 items                                                           
collecting 773 items                                                           
collecting 917 items                                                           
collecting 925 items                                                           
collecting 933 items                                                           
collecting 936 items                                                           
collecting 946 items                                                           
collecting 957 items                                                           
collecting 963 items                                                           
collecting 969 items                                                           
collecting 972 items                                                           
collecting 977 items                                                           
collecting 985 items                                                           
collecting 989 items                                                           
collecting 995 items                                                           
collecting 998 items                                                           
collecting 1001 items                                                          
collecting 1013 items                                                          
collecting 1044 items                                                          
collecting 1047 items                                                          
collecting 1050 items                                                          
collecting 1057 items                                                          
collecting 1061 items                                                          
collecting 1063 items                                                          
collecting 1078 items                                                          
collecting 1078 items                                                          
collecting 1083 items                                                          
collecting 1083 items                                                          
collecting 1104 items                                                          
collecting 1116 items                                                          
collecting 1116 items                                                          
collecting 1116 items                                                          
collecting 1125 items                                                          
collecting 1125 items                                                          
collecting 1137 items                                                          
collecting 1137 items                                                          
collecting 1146 items                                                          
collecting 1146 items                                                          
collecting 1148 items                                                          
collected 1148 items                                                           



tests/acceptance/cli_test.py::CLITestCase::test_build_failed PASSED      [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_failed_forcerm PASSED [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_log_level PASSED   [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_memory_build_option PASSED [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_no_cache PASSED    [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_no_cache_pull PASSED [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_override_dir PASSED [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_override_dir_invalid_path PASSED [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_parallel PASSED    [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_plain PASSED       [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_pull PASSED        [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_rm XPASS           [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_build_shm_size_build_option PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_build_with_buildarg_cli_override PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_build_with_buildarg_from_compose_file PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_build_with_buildarg_old_api_version PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_bundle_with_digests PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_config_compatibility_mode PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_config_default PASSED    [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_config_external_network PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_config_external_network_v3_5 PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_config_external_volume_v2 PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_config_external_volume_v2_x PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_external_volume_v3_4 PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_external_volume_v3_x PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_list_services PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_list_volumes PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_quiet PASSED      [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_quiet_with_error PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_restart PASSED    [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_stdin PASSED      [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_v1 PASSED         [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_v3 PASSED         [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_with_dot_env PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_with_dot_env_and_override_dir PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_config_with_env_file PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_config_with_hash_option PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_create PASSED            [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_create_with_force_recreate PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_create_with_force_recreate_and_no_recreate PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_create_with_no_recreate PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_down PASSED              [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_down_invalid_rmi_flag PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_down_signal PASSED       [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_down_timeout PASSED      [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_env_file_relative_to_compose_file PASSED [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_events_human_readable PASSED [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_events_json PASSED       [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_exec_custom_user PASSED  [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_exec_detach_long_form PASSED [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_exec_service_with_environment_overridden PASSED [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_exec_without_tty PASSED  [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_exec_workdir PASSED      [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_exit_code_from_signal_stop PASSED [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_expanded_port PASSED     [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_forward_exitval PASSED   [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_help PASSED              [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_help_nonexistent PASSED  [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_home_and_env_var_in_volume_path PASSED [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_host_not_reachable PASSED [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_host_not_reachable_volumes_from_container PASSED [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_images PASSED            [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_images_default_composefile PASSED [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_images_tagless_image PASSED [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_images_use_service_tag PASSED [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_kill PASSED              [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_kill_signal_sigstop PASSED [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_kill_stopped_service PASSED [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_logs_default SKIPPED     [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_logs_follow PASSED       [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_logs_follow_logs_from_new_containers SKIPPED [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_logs_follow_logs_from_restarted_containers SKIPPED [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_logs_invalid_service_name PASSED [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_logs_on_stopped_containers_exits PASSED [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_logs_tail PASSED         [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_logs_timestamps PASSED   [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_pause_no_containers PASSED [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_pause_unpause PASSED     [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_port PASSED              [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_port_with_scale PASSED   [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_ps PASSED                [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_ps_all PASSED            [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_ps_alternate_composefile PASSED [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_ps_default_composefile PASSED [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_ps_services_filter_option PASSED [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_ps_services_filter_status PASSED [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_pull PASSED              [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_pull_can_build PASSED    [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_pull_with_digest PASSED  [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_pull_with_ignore_pull_failures PASSED [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_pull_with_include_deps PASSED [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_pull_with_no_deps PASSED [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_pull_with_parallel_failure PASSED [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_pull_with_quiet PASSED   [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_quiet_build PASSED       [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_restart PASSED           [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_restart_no_containers PASSED [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_restart_stopped_container PASSED [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_rm PASSED                [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_rm_all PASSED            [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_rm_stop PASSED           [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_run_detached_connects_to_network PASSED [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_run_does_not_recreate_linked_containers PASSED [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_run_env_values_from_system PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_handles_sighup PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_handles_sigint PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_handles_sigterm PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_interactive_connects_to_network PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_label_flag PASSED    [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_one_off_with_multiple_volumes PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_one_off_with_volume PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_one_off_with_volume_merge PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_rm PASSED            [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint_and_command_overridden PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint_and_empty_string_command PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint_overridden PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dependencies PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dockerfile_entrypoint PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dockerfile_entrypoint_and_command_overridden PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dockerfile_entrypoint_overridden PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_environment_overridden PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_explicitly_mapped_ip_ports PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_explicitly_mapped_ports PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_links PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_map_ports PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_scaled_dependencies PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_unset_entrypoint PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_use_aliases PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_user_overridden PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_user_overridden_short_form PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_workdir_overridden PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_workdir_overridden_short_form PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_without_links PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_without_map_ports PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_unicode_env_values_from_system PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_with_custom_name PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_with_expose_ports PASSED [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_run_with_no_deps PASSED  [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_run_without_command PASSED [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_scale PASSED             [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_scale_v2_2 PASSED        [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_shorthand_host_opt PASSED [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_shorthand_host_opt_interactive PASSED [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_start_no_containers PASSED [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_stop PASSED              [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_stop_signal PASSED       [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_top_processes_running PASSED [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_top_services_not_running PASSED [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_top_services_running PASSED [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_unpause_no_containers PASSED [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up PASSED                [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_attached PASSED       [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_detached PASSED       [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_detached_long_form PASSED [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_external_networks PASSED [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_handles_abort_on_container_exit PASSED [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_handles_abort_on_container_exit_code PASSED [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_handles_force_shutdown PASSED [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_handles_sigint PASSED [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_handles_sigterm PASSED [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_logging PASSED        [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_logging_legacy PASSED [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_missing_network PASSED [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_no_ansi PASSED        [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_no_services PASSED    [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_no_start PASSED       [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_no_start_remove_orphans PASSED [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_scale_reset PASSED    [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_scale_scale_down PASSED [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_scale_scale_up PASSED [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_scale_to_zero PASSED  [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_default_network_config PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_default_override_file PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_duplicate_override_yaml_files PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_extends PASSED   [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_external_default_network PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_force_recreate PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_force_recreate_and_no_recreate PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_healthcheck PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_ignore_remove_orphans PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_links_v1 PASSED  [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_multiple_files PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_net_is_invalid PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_net_v1 PASSED    [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_aliases PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_internal PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_labels PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_mode PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_static_addresses PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_networks PASSED  [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_no_deps PASSED   [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_no_recreate PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_override_yaml PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_pid_mode PASSED  [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_timeout PASSED   [ 17%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_volume_labels PASSED [ 17%]

tests/integration/environment_test.py::EnvironmentOverrideFileTest::test_env_file_override PASSED [ 17%]

tests/integration/network_test.py::NetworkTest::test_network_default_labels PASSED [ 17%]

tests/integration/network_test.py::NetworkTest::test_network_external_default_ensure PASSED [ 17%]

tests/integration/network_test.py::NetworkTest::test_network_external_overlay_ensure PASSED [ 17%]

tests/integration/project_test.py::ProjectTest::test_containers PASSED   [ 17%]

tests/integration/project_test.py::ProjectTest::test_containers_stopped PASSED [ 17%]

tests/integration/project_test.py::ProjectTest::test_containers_with_extra_service PASSED [ 17%]

tests/integration/project_test.py::ProjectTest::test_containers_with_service_names PASSED [ 17%]

tests/integration/project_test.py::ProjectTest::test_create PASSED       [ 17%]

tests/integration/project_test.py::ProjectTest::test_create_strategy_always PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_create_strategy_never PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_create_twice PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_create_with_links PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_initialize_volumes PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_initialize_volumes_external_volumes PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_initialize_volumes_inexistent_external_volume PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_initialize_volumes_invalid_volume_driver PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_blank_driver PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_driver PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_driver_opts PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_net_from_container_v1 PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_net_from_service_v1 PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_network_mode_from_container PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_network_mode_from_service PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_parallel_pull_with_no_image PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_project_up PASSED   [ 19%]

tests/integration/project_test.py::ProjectTest::test_project_up_config_scale PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_project_up_healthy_dependency PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_project_up_ignore_orphans PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_project_up_implicit_volume_driver PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_project_up_logging_with_multiple_files PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_project_up_name_starts_with_illegal_char PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_project_up_named_volumes_in_binds PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_networks PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_no_healthcheck_dependency PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_orphans PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_port_mappings_with_multiple_files PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_recreate_with_tmpfs_volume PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_seccomp_profile PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_starts_depends PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_starts_links PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_starts_uncreated_services PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_unhealthy_dependency PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_volumes PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_with_added_secrets PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_project_up_with_network_internal PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_project_up_with_network_label PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_project_up_with_no_deps PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_project_up_with_no_recreate_running PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_project_up_with_no_recreate_stopped PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_project_up_with_secrets PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_project_up_with_volume_labels PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_project_up_without_all_services PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_recreate_preserves_mounts PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_recreate_preserves_volumes PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_start_pause_unpause_stop_kill_remove PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_unscale_after_restart PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_custom_name_resources PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_enable_ipv6 PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_invalid_isolation PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_invalid_runtime PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_ipam_config PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_ipam_options PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_isolation PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_network_link_local_ips PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_network_priorities PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_network_static_addresses PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_network_static_addresses_missing_subnet PASSED [ 23%]

tests/integration/project_test.py::ProjectTest::test_up_with_nvidia_runtime SKIPPED [ 23%]

tests/integration/project_test.py::ProjectTest::test_up_with_runtime PASSED [ 23%]

tests/integration/project_test.py::ProjectTest::test_volumes_from_container PASSED [ 23%]

tests/integration/project_test.py::ProjectTest::test_volumes_from_service PASSED [ 23%]

tests/integration/resilience_test.py::ResilienceTest::test_create_failure PASSED [ 23%]

tests/integration/resilience_test.py::ResilienceTest::test_start_failure PASSED [ 23%]

tests/integration/resilience_test.py::ResilienceTest::test_successful_recreate PASSED [ 23%]

tests/integration/service_test.py::ServiceTest::test_build PASSED        [ 23%]

tests/integration/service_test.py::ServiceTest::test_build_cli PASSED    [ 23%]

tests/integration/service_test.py::ServiceTest::test_build_non_ascii_filename PASSED [ 23%]

tests/integration/service_test.py::ServiceTest::test_build_with_build_args PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_build_args_override PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_build_labels PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_cachefrom PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_extra_hosts PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_git_url PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_gzip PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_illegal_leading_chars PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_image_name PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_isolation PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_network PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_target PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_cap_add_list PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_cap_drop_list PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_containers PASSED   [ 25%]

tests/integration/service_test.py::ServiceTest::test_containers_one_off PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_blkio_config PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_count PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_percent SKIPPED [ 25%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_quota PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_rt xfail [ 25%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_set PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_shares PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_cpus PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_device_cgroup_rules PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_extra_hosts_dicts PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_extra_hosts_list PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_healthcheck_config PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_host_mount PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_init_bool PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_init_path XPASS [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_legacy_mount PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_legacy_tmpfs_mount PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_mac_address PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_one_off PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_one_off_when_existing_container_is_running PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_oom_kill_disable PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_pids_limit XPASS [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_read_only_root_fs PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_security_opt PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_shm_size PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_specified_volume PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_storage_opt xfail [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_tmpfs_mount PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_tmpfs_mount_tmpfs_size PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_unspecified_volume PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_volume_driver PASSED [ 28%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_volume_mount PASSED [ 28%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_volumes_from PASSED [ 28%]

tests/integration/service_test.py::ServiceTest::test_create_with_image_id PASSED [ 28%]

tests/integration/service_test.py::ServiceTest::test_custom_container_name PASSED [ 28%]

tests/integration/service_test.py::ServiceTest::test_devices PASSED      [ 28%]

tests/integration/service_test.py::ServiceTest::test_dns_list PASSED     [ 28%]

tests/integration/service_test.py::ServiceTest::test_dns_no_value PASSED [ 28%]

tests/integration/service_test.py::ServiceTest::test_dns_opt_value PASSED [ 28%]

tests/integration/service_test.py::ServiceTest::test_dns_search PASSED   [ 28%]

tests/integration/service_test.py::ServiceTest::test_duplicate_containers PASSED [ 28%]

tests/integration/service_test.py::ServiceTest::test_duplicate_volume_trailing_slash PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_empty_labels PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_env_from_file_combined_with_env PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_anonymous_volume_recreate_then_renew PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_anonymous_volume_renew PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_image_with_volume_is_removed PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_change_mount_target PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_twice PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_twice_with_mount PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_containers_are_stopped PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_host_volume_is_removed PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_image_volume_masks_config PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_with_image_declared_volume PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_with_image_declared_volume_renew PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_without_start PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_expose_does_not_publish_ports PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_group_add_value PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_labels PASSED       [ 30%]

tests/integration/service_test.py::ServiceTest::test_log_drive_empty_default_jsonfile PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_log_drive_invalid SKIPPED [ 30%]

tests/integration/service_test.py::ServiceTest::test_log_drive_none PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_mem_reservation PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_mem_swappiness PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_network_mode_bridged PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_network_mode_host PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_network_mode_none PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_oom_score_adj_value PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_pid_mode_host PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_pid_mode_none_defined PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_port_with_explicit_interface PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_project_is_added_to_container_name PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_recreate_preserves_volume_with_trailing_slash PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_recreate_volume_to_mount PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_resolve_env PASSED  [ 31%]

tests/integration/service_test.py::ServiceTest::test_restart_always_value PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_restart_on_failure_value PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale PASSED        [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale_sets_ports PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale_with_api_error PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale_with_custom_container_name_outputs_warning PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale_with_desired_number_already_achieved PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale_with_immediate_exit PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale_with_stopped_containers PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale_with_stopped_containers_and_needing_creation PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale_with_unexpected_exception PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_split_env PASSED    [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_becomes_privileged PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_builds_images PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_creates_fixed_external_ports PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_creates_fixed_external_ports_when_it_is_different_to_internal_port PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_creates_links PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_creates_links_with_names PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_creates_port_with_explicit_protocol PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_creates_ports PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_inherits_options_from_constructor PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_passes_through_options PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_stays_unprivileged PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_uses_tagged_image_if_it_exists PASSED [ 34%]

tests/integration/service_test.py::ServiceTest::test_start_container_with_external_links PASSED [ 34%]

tests/integration/service_test.py::ServiceTest::test_start_normal_container_does_not_create_links_to_its_own_service PASSED [ 34%]

tests/integration/service_test.py::ServiceTest::test_start_one_off_container_creates_links_to_its_own_service PASSED [ 34%]

tests/integration/service_test.py::ServiceTest::test_stop_signal PASSED  [ 34%]

tests/integration/service_test.py::ServiceTest::test_tmpfs PASSED        [ 34%]

tests/integration/service_test.py::ServiceTest::test_up_build_cli PASSED [ 34%]

tests/integration/service_test.py::ServiceTest::test_userns_mode_host PASSED [ 34%]

tests/integration/service_test.py::ServiceTest::test_userns_mode_none_defined PASSED [ 34%]

tests/integration/service_test.py::ServiceTest::test_with_high_enough_api_version_we_get_default_network_mode PASSED [ 34%]

tests/integration/service_test.py::ServiceTest::test_working_dir_param PASSED [ 34%]

tests/integration/service_test.py::ConfigHashTest::test_config_hash_sticks_around PASSED [ 35%]

tests/integration/service_test.py::ConfigHashTest::test_config_hash_with_custom_labels PASSED [ 35%]

tests/integration/service_test.py::ConfigHashTest::test_no_config_hash_when_one_off PASSED [ 35%]

tests/integration/service_test.py::ConfigHashTest::test_no_config_hash_when_overriding_options PASSED [ 35%]

tests/integration/state_test.py::BasicProjectTest::test_all_change PASSED [ 35%]

tests/integration/state_test.py::BasicProjectTest::test_no_change PASSED [ 35%]

tests/integration/state_test.py::BasicProjectTest::test_partial_change PASSED [ 35%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_leaf PASSED [ 35%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_middle PASSED [ 35%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_middle_always_recreate_deps PASSED [ 35%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root PASSED [ 35%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root_always_recreate_deps PASSED [ 35%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root_no_recreate PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_service_recreated_when_dependency_created PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_service_removed_while_down PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_up PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_leaf PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_middle PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_middle_always_recreate_deps PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root_always_recreate_deps PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root_no_recreate PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_dependency_added PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_dependency_removed PASSED [ 37%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_service_removed_while_down PASSED [ 37%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_service_removed_while_up PASSED [ 37%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_up PASSED [ 37%]

tests/integration/state_test.py::ServiceStateTest::test_image_changed_to_build PASSED [ 37%]

tests/integration/state_test.py::ServiceStateTest::test_trigger_create PASSED [ 37%]

tests/integration/state_test.py::ServiceStateTest::test_trigger_noop PASSED [ 37%]

tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_build PASSED [ 37%]

tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_config_change PASSED [ 37%]

tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_image_change PASSED [ 37%]

tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_nonexistent_image_tag PASSED [ 37%]

tests/integration/state_test.py::ServiceStateTest::test_trigger_start PASSED [ 37%]

tests/integration/volume_test.py::VolumeTest::test_create_volume PASSED  [ 38%]

tests/integration/volume_test.py::VolumeTest::test_create_volume_custom_name PASSED [ 38%]

tests/integration/volume_test.py::VolumeTest::test_exists PASSED         [ 38%]

tests/integration/volume_test.py::VolumeTest::test_exists_external PASSED [ 38%]

tests/integration/volume_test.py::VolumeTest::test_exists_external_aliased PASSED [ 38%]

tests/integration/volume_test.py::VolumeTest::test_external_aliased_volume PASSED [ 38%]

tests/integration/volume_test.py::VolumeTest::test_external_volume PASSED [ 38%]

tests/integration/volume_test.py::VolumeTest::test_inspect_volume PASSED [ 38%]

tests/integration/volume_test.py::VolumeTest::test_recreate_existing_volume PASSED [ 38%]

tests/integration/volume_test.py::VolumeTest::test_remove_volume PASSED  [ 38%]

tests/integration/volume_test.py::VolumeTest::test_volume_default_labels PASSED [ 38%]

tests/unit/bundle_test.py::test_get_image_digest_exists PASSED           [ 39%]

tests/unit/bundle_test.py::test_get_image_digest_image_uses_digest PASSED [ 39%]

tests/unit/bundle_test.py::test_get_image_digest_from_repository PASSED  [ 39%]

tests/unit/bundle_test.py::test_get_image_digest_no_image PASSED         [ 39%]

tests/unit/bundle_test.py::test_push_image_with_saved_digest PASSED      [ 39%]

tests/unit/bundle_test.py::test_push_image PASSED                        [ 39%]

tests/unit/bundle_test.py::test_to_bundle PASSED                         [ 39%]

tests/unit/bundle_test.py::test_convert_service_to_bundle PASSED         [ 39%]

tests/unit/bundle_test.py::test_set_command_and_args_none PASSED         [ 39%]

tests/unit/bundle_test.py::test_set_command_and_args_from_command PASSED [ 39%]

tests/unit/bundle_test.py::test_set_command_and_args_from_entrypoint PASSED [ 39%]

tests/unit/bundle_test.py::test_set_command_and_args_from_both PASSED    [ 39%]

tests/unit/bundle_test.py::test_make_service_networks_default PASSED     [ 40%]

tests/unit/bundle_test.py::test_make_service_networks PASSED             [ 40%]

tests/unit/bundle_test.py::test_make_port_specs PASSED                   [ 40%]

tests/unit/bundle_test.py::test_make_port_spec_with_protocol PASSED      [ 40%]

tests/unit/bundle_test.py::test_make_port_spec_default_protocol PASSED   [ 40%]

tests/unit/cli_test.py::CLITestCase::test_command_help PASSED            [ 40%]

tests/unit/cli_test.py::CLITestCase::test_command_help_nonexistent PASSED [ 40%]

tests/unit/cli_test.py::CLITestCase::test_command_manual_and_service_ports_together PASSED [ 40%]

tests/unit/cli_test.py::CLITestCase::test_default_project_name PASSED    [ 40%]

tests/unit/cli_test.py::CLITestCase::test_get_project PASSED             [ 40%]

tests/unit/cli_test.py::CLITestCase::test_project_name_from_environment_new_var PASSED [ 40%]

tests/unit/cli_test.py::CLITestCase::test_project_name_with_empty_environment_var PASSED [ 41%]

tests/unit/cli_test.py::CLITestCase::test_project_name_with_environment_file PASSED [ 41%]

tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_base_dir PASSED [ 41%]

tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_project_name PASSED [ 41%]

tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_uppercase_base_dir PASSED [ 41%]

tests/unit/cli_test.py::CLITestCase::test_run_interactive_passes_logs_false PASSED [ 41%]

tests/unit/cli_test.py::CLITestCase::test_run_service_with_restart_always PASSED [ 41%]

tests/unit/container_test.py::ContainerTest::test_environment PASSED     [ 41%]

tests/unit/container_test.py::ContainerTest::test_from_ps PASSED         [ 41%]

tests/unit/container_test.py::ContainerTest::test_from_ps_prefixed PASSED [ 41%]

tests/unit/container_test.py::ContainerTest::test_get PASSED             [ 41%]

tests/unit/container_test.py::ContainerTest::test_get_local_port PASSED  [ 41%]

tests/unit/container_test.py::ContainerTest::test_has_api_logs PASSED    [ 42%]

tests/unit/container_test.py::ContainerTest::test_human_readable_ports_none PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_human_readable_ports_public_and_private PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_human_readable_states_healthy PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_human_readable_states_no_health PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_human_readable_states_starting PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_inspect_if_not_inspected PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_name PASSED            [ 42%]

tests/unit/container_test.py::ContainerTest::test_name_without_project PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_name_without_project_custom_container_name PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_name_without_project_one_off PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_number PASSED          [ 43%]

tests/unit/container_test.py::ContainerTest::test_short_id PASSED        [ 43%]

tests/unit/container_test.py::GetContainerNameTestCase::test_get_container_name PASSED [ 43%]

tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_driver_mismatch PASSED [ 43%]

tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_null_remote PASSED [ 43%]

tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_null_remote_ipam_options PASSED [ 43%]

tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_options_mismatch PASSED [ 43%]

tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_success PASSED [ 43%]

tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_whitelist PASSED [ 43%]

tests/unit/network_test.py::NetworkTest::test_check_remote_network_labels_mismatch PASSED [ 43%]

tests/unit/network_test.py::NetworkTest::test_remote_config_labels_none PASSED [ 43%]

tests/unit/parallel_test.py::ParallelTest::test_parallel_execute PASSED  [ 43%]

tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_deps PASSED [ 44%]

tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_global_limit PASSED [ 44%]

tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_limit PASSED [ 44%]

tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_upstream_errors PASSED [ 44%]

tests/unit/parallel_test.py::test_parallel_execute_alignment PASSED      [ 44%]

tests/unit/parallel_test.py::test_parallel_execute_ansi PASSED           [ 44%]

tests/unit/parallel_test.py::test_parallel_execute_noansi PASSED         [ 44%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_get_digest_from_pull PASSED [ 44%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_get_digest_from_push PASSED [ 44%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_mismatched_encoding_stream_write PASSED [ 44%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output PASSED [ 44%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_div_zero PASSED [ 45%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_no_progress_event_no_tty PASSED [ 45%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_null_total PASSED [ 45%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_progress_event_no_tty PASSED [ 45%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_progress_event_tty PASSED [ 45%]

tests/unit/project_test.py::ProjectTest::test_avoid_multiple_push PASSED [ 45%]

tests/unit/project_test.py::ProjectTest::test_build_container_operation_with_timeout_func_does_not_mutate_options_with_timeout PASSED [ 45%]

tests/unit/project_test.py::ProjectTest::test_container_without_name PASSED [ 45%]

tests/unit/project_test.py::ProjectTest::test_down_with_no_resources PASSED [ 45%]

tests/unit/project_test.py::ProjectTest::test_error_parallel_pull PASSED [ 45%]

tests/unit/project_test.py::ProjectTest::test_events PASSED              [ 45%]

tests/unit/project_test.py::ProjectTest::test_events_legacy PASSED       [ 45%]

tests/unit/project_test.py::ProjectTest::test_from_config_v1 PASSED      [ 46%]

tests/unit/project_test.py::ProjectTest::test_from_config_v2 PASSED      [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_secrets_external_warning PASSED [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_secrets_no_secret_def PASSED [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_secrets_secret_file_warning PASSED [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_secrets_uid_gid_mode_warning PASSED [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_service PASSED         [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_services_removes_duplicates_following_links PASSED [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_services_returns_all_services_without_args PASSED [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_services_returns_listed_services_with_args PASSED [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_services_with_include_links PASSED [ 46%]

tests/unit/project_test.py::ProjectTest::test_net_unset PASSED           [ 47%]

tests/unit/project_test.py::ProjectTest::test_no_such_service_unicode PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_no_warning_in_normal_mode PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_no_warning_on_stop PASSED  [ 47%]

tests/unit/project_test.py::ProjectTest::test_no_warning_with_no_swarm_info PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_project_platform_value PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_use_net_from_container PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_use_net_from_service PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_use_volumes_from_container PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_use_volumes_from_service_container PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_use_volumes_from_service_no_container PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_uses_default_network_false PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_uses_default_network_true PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_build_does_not_pull PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_build_isolation_from_build_override_service_config PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_build_service_with_proxy_config PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_build_volume_options_duplicate_binds PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_build_with_default_platform PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_build_with_isolation_from_service_config PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_build_with_override_build_args PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_build_with_platform PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_cgroup_parent PASSED       [ 48%]

tests/unit/service_test.py::ServiceTest::test_config_dict PASSED         [ 48%]

tests/unit/service_test.py::ServiceTest::test_config_dict_with_network_mode_from_container PASSED [ 49%]

tests/unit/service_test.py::ServiceTest::test_config_hash_matches_label PASSED [ 49%]

tests/unit/service_test.py::ServiceTest::test_container_without_name PASSED [ 49%]

tests/unit/service_test.py::ServiceTest::test_containers PASSED          [ 49%]

tests/unit/service_test.py::ServiceTest::test_containers_with_containers PASSED [ 49%]

tests/unit/service_test.py::ServiceTest::test_create_container PASSED    [ 49%]

tests/unit/service_test.py::ServiceTest::test_create_when_removed_containers_are_listed PASSED [ 49%]

tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_force_build PASSED [ 49%]

tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_no_build PASSED [ 49%]

tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_no_build_but_needs_build PASSED [ 49%]

tests/unit/service_test.py::ServiceTest::test_get_container PASSED       [ 49%]

tests/unit/service_test.py::ServiceTest::test_get_container_create_options_does_not_mutate_options PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_container_create_options_no_affinity_without_binds PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_container_create_options_sets_affinity_with_binds PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_container_create_options_with_name_option PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_container_not_found PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_create_options_with_proxy_config PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_volumes_from_container PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_volumes_from_container_read_only PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_container_exists PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_container_exists_with_flags PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_no_container PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_image_name_default PASSED  [ 50%]

tests/unit/service_test.py::ServiceTest::test_image_name_from_config PASSED [ 51%]

tests/unit/service_test.py::ServiceTest::test_log_opt PASSED             [ 51%]

tests/unit/service_test.py::ServiceTest::test_mem_reservation PASSED     [ 51%]

tests/unit/service_test.py::ServiceTest::test_memory_swap_limit PASSED   [ 51%]

tests/unit/service_test.py::ServiceTest::test_no_default_hostname_when_not_using_networking PASSED [ 51%]

tests/unit/service_test.py::ServiceTest::test_only_log_warning_when_host_ports_clash PASSED [ 51%]

tests/unit/service_test.py::ServiceTest::test_parse_proxy_config PASSED  [ 51%]

tests/unit/service_test.py::ServiceTest::test_parse_proxy_config_per_host PASSED [ 51%]

tests/unit/service_test.py::ServiceTest::test_parse_repository_tag PASSED [ 51%]

tests/unit/service_test.py::ServiceTest::test_pull_image PASSED          [ 51%]

tests/unit/service_test.py::ServiceTest::test_pull_image_digest PASSED   [ 51%]

tests/unit/service_test.py::ServiceTest::test_pull_image_no_tag PASSED   [ 52%]

tests/unit/service_test.py::ServiceTest::test_pull_image_with_default_platform PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_pull_image_with_platform PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_pull_image_with_platform_unsupported_api PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_recreate_container PASSED  [ 52%]

tests/unit/service_test.py::ServiceTest::test_recreate_container_with_timeout PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_remove_image_all_does_remove PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_remove_image_local_with_image_name_doesnt_remove PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_remove_image_local_without_image_name_does_remove PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_remove_image_none PASSED   [ 52%]

tests/unit/service_test.py::ServiceTest::test_remove_image_with_error PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_remove_non_existing_image PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_self_reference_external_link PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_service_ignore_default_platform_with_unsupported_api PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_service_platform_precedence PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_container_port PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_container_port_range PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_and_port PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_and_port_range PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_no_port PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_no_port_range PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_port PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_port_range PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_no_ports PASSED [ 54%]

tests/unit/service_test.py::ServiceTest::test_split_domainname_both PASSED [ 54%]

tests/unit/service_test.py::ServiceTest::test_split_domainname_fqdn PASSED [ 54%]

tests/unit/service_test.py::ServiceTest::test_split_domainname_none PASSED [ 54%]

tests/unit/service_test.py::ServiceTest::test_split_domainname_weird PASSED [ 54%]

tests/unit/service_test.py::ServiceTest::test_stop_grace_period PASSED   [ 54%]

tests/unit/service_test.py::ServiceTest::test_volumes_order_is_preserved PASSED [ 54%]

tests/unit/service_test.py::TestServiceNetwork::test_connect_container_to_networks_short_aliase_exists PASSED [ 54%]

tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_dict PASSED [ 54%]

tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_integers_and_dicts PASSED [ 54%]

tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_ints PASSED [ 54%]

tests/unit/service_test.py::NetTestCase::test_network_mode PASSED        [ 54%]

tests/unit/service_test.py::NetTestCase::test_network_mode_container PASSED [ 55%]

tests/unit/service_test.py::NetTestCase::test_network_mode_service PASSED [ 55%]

tests/unit/service_test.py::NetTestCase::test_network_mode_service_no_containers PASSED [ 55%]

tests/unit/service_test.py::ServicePortsTest::test_formatted_ports PASSED [ 55%]

tests/unit/service_test.py::ServiceVolumesTest::test_build_volume_binding PASSED [ 55%]

tests/unit/service_test.py::ServiceVolumesTest::test_create_with_special_volume_mode PASSED [ 55%]

tests/unit/service_test.py::ServiceVolumesTest::test_get_container_create_options_with_different_host_path_in_container_json PASSED [ 55%]

tests/unit/service_test.py::ServiceVolumesTest::test_get_container_data_volumes PASSED [ 55%]

tests/unit/service_test.py::ServiceVolumesTest::test_merge_volume_bindings PASSED [ 55%]

tests/unit/service_test.py::ServiceVolumesTest::test_mount_same_host_path_to_two_volumes PASSED [ 55%]

tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_no_warning_with_container_only_option PASSED [ 55%]

tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_no_warning_with_same_path PASSED [ 56%]

tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_volume_no_warning_when_no_container_volumes PASSED [ 56%]

tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_volume_when_masked PASSED [ 56%]

tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes PASSED [ 56%]

tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes_abspath PASSED [ 56%]

tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes_no_target PASSED [ 56%]

tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_unix_path PASSED [ 56%]

tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_url_no_prefix PASSED [ 56%]

tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_windows_path PASSED [ 56%]

tests/unit/split_buffer_test.py::SplitBufferTest::test_chunked_line PASSED [ 56%]

tests/unit/split_buffer_test.py::SplitBufferTest::test_multiple_line_chunk PASSED [ 56%]

tests/unit/split_buffer_test.py::SplitBufferTest::test_no_end_separator PASSED [ 56%]

tests/unit/split_buffer_test.py::SplitBufferTest::test_preserves_unicode_sequences_within_lines PASSED [ 57%]

tests/unit/split_buffer_test.py::SplitBufferTest::test_single_line_chunks PASSED [ 57%]

tests/unit/timeparse_test.py::test_milli PASSED                          [ 57%]

tests/unit/timeparse_test.py::test_milli_float PASSED                    [ 57%]

tests/unit/timeparse_test.py::test_second_milli PASSED                   [ 57%]

tests/unit/timeparse_test.py::test_second_milli_micro PASSED             [ 57%]

tests/unit/timeparse_test.py::test_second PASSED                         [ 57%]

tests/unit/timeparse_test.py::test_second_as_float PASSED                [ 57%]

tests/unit/timeparse_test.py::test_minute PASSED                         [ 57%]

tests/unit/timeparse_test.py::test_hour_minute PASSED                    [ 57%]

tests/unit/timeparse_test.py::test_minute_as_float PASSED                [ 57%]

tests/unit/timeparse_test.py::test_hour_minute_second PASSED             [ 58%]

tests/unit/timeparse_test.py::test_invalid_with_space PASSED             [ 58%]

tests/unit/timeparse_test.py::test_invalid_with_comma PASSED             [ 58%]

tests/unit/timeparse_test.py::test_invalid_with_empty_string PASSED      [ 58%]

tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_no_object PASSED [ 58%]

tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_with_object PASSED [ 58%]

tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_leading_whitespace PASSED [ 58%]

tests/unit/utils_test.py::TestStreamAsText::test_stream_with_non_utf_unicode_character PASSED [ 58%]

tests/unit/utils_test.py::TestStreamAsText::test_stream_with_utf_character PASSED [ 58%]

tests/unit/utils_test.py::TestJsonStream::test_with_falsy_entries PASSED [ 58%]

tests/unit/utils_test.py::TestJsonStream::test_with_leading_whitespace PASSED [ 58%]

tests/unit/utils_test.py::TestParseBytes::test_parse_bytes PASSED        [ 58%]

tests/unit/utils_test.py::TestMoreItertools::test_unique_everseen PASSED [ 59%]

tests/unit/volume_test.py::TestVolume::test_remove_local_volume PASSED   [ 59%]

tests/unit/volume_test.py::TestVolume::test_remove_external_volume PASSED [ 59%]

tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_path_from_options PASSED [ 59%]

tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_single_path_from_env PASSED [ 59%]

tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env PASSED [ 59%]

tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env_windows SKIPPED [ 59%]

tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env_custom_separator PASSED [ 59%]

tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_no_path PASSED [ 59%]

tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_unicode_path_from_options PASSED [ 59%]

tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_unicode_path_from_env SKIPPED [ 59%]

tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_custom_timeout_error PASSED [ 60%]

tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_docker_client_no_home PASSED [ 60%]

tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_docker_client_with_custom_timeout PASSED [ 60%]

tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_user_agent PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_assert_hostname_explicit_skip PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_simple_tls PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_ca_cert PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_ca_cert_explicit PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca_explicit PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca_quoted_paths PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_cert PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_cert_explicit PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_missing_key PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_flags_override_environment PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_mixed_environment_and_flags PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_simple_with_tls_version PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_default_cert_path PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_env_falsy_value PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_flag_no_override PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_default PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_upgrade PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_unavailable PASSED [ 61%]

tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_generic_connection_error PASSED [ 62%]

tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_mismatch PASSED [ 62%]

tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_mismatch_unicode_explanation PASSED [ 62%]

tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_other PASSED [ 62%]

tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_other_unicode_explanation PASSED [ 62%]

tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_no_data SKIPPED [ 62%]

tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_misc SKIPPED [ 62%]

tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_encoding_issue SKIPPED [ 62%]

tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_error PASSED [ 62%]

tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_info PASSED [ 62%]

tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_error PASSED [ 62%]

tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_info PASSED [ 62%]

tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_warn PASSED [ 63%]

tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_warn PASSED [ 63%]

tests/unit/cli/log_printer_test.py::TestLogPresenter::test_monochrome PASSED [ 63%]

tests/unit/cli/log_printer_test.py::TestLogPresenter::test_polychrome PASSED [ 63%]

tests/unit/cli/log_printer_test.py::test_wait_on_exit PASSED             [ 63%]

tests/unit/cli/log_printer_test.py::test_wait_on_exit_raises PASSED      [ 63%]

tests/unit/cli/log_printer_test.py::test_build_no_log_generator PASSED   [ 63%]

tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_no_log_stream PASSED [ 63%]

tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_with_log_stream PASSED [ 63%]

tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_unicode PASSED [ 63%]

tests/unit/cli/log_printer_test.py::TestWatchEvents::test_stop_event PASSED [ 63%]

tests/unit/cli/log_printer_test.py::TestWatchEvents::test_start_event PASSED [ 64%]

tests/unit/cli/log_printer_test.py::TestWatchEvents::test_container_attach_event PASSED [ 64%]

tests/unit/cli/log_printer_test.py::TestWatchEvents::test_other_event PASSED [ 64%]

tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_an_exception PASSED [ 64%]

tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_stop_without_cascade_stop PASSED [ 64%]

tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_stop_with_cascade_stop PASSED [ 64%]

tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_none_when_timeout_is_hit PASSED [ 64%]

tests/unit/cli/main_test.py::TestCLIMainTestCase::test_filter_containers_to_service_names PASSED [ 64%]

tests/unit/cli/main_test.py::TestCLIMainTestCase::test_filter_containers_to_service_names_all PASSED [ 64%]

tests/unit/cli/main_test.py::TestCLIMainTestCase::test_warning_in_swarm_mode PASSED [ 64%]

tests/unit/cli/main_test.py::TestCLIMainTestCase::test_build_one_off_container_options PASSED [ 64%]

tests/unit/cli/main_test.py::TestCLIMainTestCase::test_get_docker_start_call PASSED [ 64%]

tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_tty_verbose PASSED [ 65%]

tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_tty_not_verbose PASSED [ 65%]

tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_not_a_tty PASSED [ 65%]

tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_invalid_opts PASSED [ 65%]

tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_always PASSED [ 65%]

tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_never PASSED [ 65%]

tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_changed PASSED [ 65%]

tests/unit/cli/main_test.py::TestCallDocker::test_simple_no_options PASSED [ 65%]

tests/unit/cli/main_test.py::TestCallDocker::test_simple_tls_option PASSED [ 65%]

tests/unit/cli/main_test.py::TestCallDocker::test_advanced_tls_options PASSED [ 65%]

tests/unit/cli/main_test.py::TestCallDocker::test_with_host_option PASSED [ 65%]

tests/unit/cli/main_test.py::TestCallDocker::test_with_http_host PASSED  [ 66%]

tests/unit/cli/main_test.py::TestCallDocker::test_with_host_option_shorthand_equal PASSED [ 66%]

tests/unit/cli/main_test.py::TestCallDocker::test_with_env PASSED        [ 66%]

tests/unit/cli/utils_test.py::UnquotePathTest::test_nested_quotes PASSED [ 66%]

tests/unit/cli/utils_test.py::UnquotePathTest::test_no_quotes PASSED     [ 66%]

tests/unit/cli/utils_test.py::UnquotePathTest::test_simple_quotes PASSED [ 66%]

tests/unit/cli/utils_test.py::UnquotePathTest::test_uneven_quotes PASSED [ 66%]

tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_100b PASSED [ 66%]

tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_1023b PASSED [ 66%]

tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_1kb PASSED [ 66%]

tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_999b PASSED [ 66%]

tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_units PASSED [ 66%]

tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_call PASSED [ 67%]

tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return PASSED [ 67%]

tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return_no_result PASSED [ 67%]

tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return_sequence PASSED [ 67%]

tests/unit/config/config_test.py::ConfigTest::test_build_args_allow_empty_properties PASSED [ 67%]

tests/unit/config/config_test.py::ConfigTest::test_build_args_check_zero_preserved PASSED [ 67%]

tests/unit/config/config_test.py::ConfigTest::test_config_build_configuration PASSED [ 67%]

tests/unit/config/config_test.py::ConfigTest::test_config_build_configuration_v2 PASSED [ 67%]

tests/unit/config/config_test.py::ConfigTest::test_config_convertible_label_types PASSED [ 67%]

tests/unit/config/config_test.py::ConfigTest::test_config_duplicate_cache_from_values_validation_error PASSED [ 67%]

tests/unit/config/config_test.py::ConfigTest::test_config_duplicate_mount_points PASSED [ 67%]

tests/unit/config/config_test.py::ConfigTest::test_config_extra_hosts_list_of_dicts_validation_error PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_extra_hosts_string_raises_validation_error PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_hint PASSED    [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error_v2 PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error_v2_when_no_interpolate PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_property_raise_validation_error PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_invalid_ipam_config PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_invalid_label_types PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_invalid_service_name_raise_validation_error PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_invalid_keys_validation_error PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_required_keys_validation_error PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_soft_greater_than_hard_error PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_config_valid_environment_dict_key_contains_dashes PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_config_valid_ipam_config PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_config_valid_service_label_validation PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_config_valid_service_names PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_depends_on_orders_services PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_depends_on_unknown_service_errors PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_dns_opt_option PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_empty_environment_key_allowed PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_external_volume_config PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_external_volume_invalid_config PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_group_add_option PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_invalid_config_build_and_image_specified_v1 PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_invalid_config_not_a_dictionary PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_invalid_config_not_unique_items PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_invalid_config_type_should_be_an_array PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_invalid_config_v1 PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_invalid_config_v2 PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_invalid_list_of_strings_format PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_isolation_option PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_linked_service_is_undefined PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_load PASSED           [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_load_bind_mount_relative_path PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_load_bind_mount_relative_path_with_tilde PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_build_labels_dict PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_build_labels_list PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_config_custom_resource_names PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_config_dockerfile_without_build_raises_error_v1 PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_config_invalid_service_names PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_config_invalid_service_names_v2 PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_config_link_local_ips_network PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_config_service_labels PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_config_volume_and_network_labels PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_configs PASSED   [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_configs_multi_file PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_dockerfile_without_context PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_errors_on_uppercase_with_no_image PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_invalid_service_definition PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_mixed_extends_resolution PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_secrets PASSED   [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_secrets_multi_file PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_service_with_name_version PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_sorts_in_dependency_order PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_when_not_dict PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_when_not_dict_v2 PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_with_invalid_network_fields PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_v2 PASSED        [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_buildargs PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_empty_build_args PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_extensions PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_invalid_field_name PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_invalid_field_name_v1 PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_base PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_base_v2 PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_override PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_override_v2 PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_extends_in_override_file PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_invalid_override PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_mismatched_networks_format PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_mismatched_networks_format_inverse_order PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v1 PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v2 PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v3_2 PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_load_yaml_with_bom PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_load_yaml_with_yaml_error PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_logs_warning_for_boolean_in_environment PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_merge_blkio_config PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_merge_configs_override PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_merge_credential_spec PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_depends_on_mixed_syntax PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_depends_on_no_override PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_deploy PASSED   [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_deploy_override PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_device_cgroup_rules PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_different_configs PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_different_secrets PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_extra_hosts PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_config PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_override_disables PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_override_enables PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_isolation PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v1 PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2 PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_base PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_base_driver PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_drivers PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_override PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_override_options PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_override_driver PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_mixed_ports PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_pid PASSED      [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_scale PASSED    [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_merge_secrets_override PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_from_files_with_extends_in_base PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_from_files_with_extends_in_override PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous_2 PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous_volumes PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_ports_sorting PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_merge_storage_opt PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_named_volume_config_empty PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_named_volume_invalid_type_list PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_named_volume_numeric_driver_opt PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_networks_invalid_type_list PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_normalize_dns_options PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_oom_score_adj_option PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_runtime_option PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_service_volume_invalid_config PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_swappiness_option PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_tmpfs_option PASSED   [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_undeclared_volume_v1 PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_undeclared_volume_v2 PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_unsupported_version PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_v1_file_version PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_v1_file_with_version_is_invalid PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_valid_config_oneof_string_or_list PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_valid_config_which_allows_two_type_definitions PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_valid_versions PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_validate_extra_hosts_invalid PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_validate_extra_hosts_invalid_list PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_version_1_is_invalid PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_volume_invalid_driver_opt PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_volume_mode_override PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_volumes_long_syntax PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_wrong_version_type PASSED [ 79%]

tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_container PASSED [ 79%]

tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_container_v1 PASSED [ 80%]

tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_plus_networks_is_invalid PASSED [ 80%]

tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service PASSED [ 80%]

tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service_nonexistent PASSED [ 80%]

tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service_v1 PASSED [ 80%]

tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_standard PASSED [ 80%]

tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_standard_v1 PASSED [ 80%]

tests/unit/config/config_test.py::PortsTest::test_config_invalid_expose_format_validation PASSED [ 80%]

tests/unit/config/config_test.py::PortsTest::test_config_invalid_expose_type_validation PASSED [ 80%]

tests/unit/config/config_test.py::PortsTest::test_config_invalid_ports_format_validation PASSED [ 80%]

tests/unit/config/config_test.py::PortsTest::test_config_invalid_ports_type_validation PASSED [ 80%]

tests/unit/config/config_test.py::PortsTest::test_config_non_unique_expose_validation PASSED [ 81%]

tests/unit/config/config_test.py::PortsTest::test_config_non_unique_ports_validation PASSED [ 81%]

tests/unit/config/config_test.py::PortsTest::test_config_valid_expose_format_validation PASSED [ 81%]

tests/unit/config/config_test.py::PortsTest::test_config_valid_ports_format_validation PASSED [ 81%]

tests/unit/config/config_test.py::SubnetTest::test_config_invalid_subnet_format_validation PASSED [ 81%]

tests/unit/config/config_test.py::SubnetTest::test_config_invalid_subnet_type_validation PASSED [ 81%]

tests/unit/config/config_test.py::SubnetTest::test_config_valid_subnet_format_validation PASSED [ 81%]

tests/unit/config/config_test.py::InterpolationTest::test_compatibility_mode_load PASSED [ 81%]

tests/unit/config/config_test.py::InterpolationTest::test_compatibility_mode_warnings PASSED [ 81%]

tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_file PASSED [ 81%]

tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_variable PASSED [ 81%]

tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_variable_with_defaults PASSED [ 81%]

tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_options_environment_file PASSED [ 82%]

tests/unit/config/config_test.py::InterpolationTest::test_interpolation_configs_section PASSED [ 82%]

tests/unit/config/config_test.py::InterpolationTest::test_interpolation_secrets_section PASSED [ 82%]

tests/unit/config/config_test.py::InterpolationTest::test_invalid_interpolation PASSED [ 82%]

tests/unit/config/config_test.py::InterpolationTest::test_unset_variable_produces_warning PASSED [ 82%]

tests/unit/config/config_test.py::VolumeConfigTest::test_absolute_posix_path_does_not_expand PASSED [ 82%]

tests/unit/config/config_test.py::VolumeConfigTest::test_absolute_windows_path_does_not_expand PASSED [ 82%]

tests/unit/config/config_test.py::VolumeConfigTest::test_home_directory_with_driver_does_not_expand PASSED [ 82%]

tests/unit/config/config_test.py::VolumeConfigTest::test_name_does_not_expand PASSED [ 82%]

tests/unit/config/config_test.py::VolumeConfigTest::test_no_binding PASSED [ 82%]

tests/unit/config/config_test.py::VolumeConfigTest::test_relative_path_does_expand_posix PASSED [ 82%]

tests/unit/config/config_test.py::VolumeConfigTest::test_relative_path_does_expand_windows SKIPPED [ 83%]

tests/unit/config/config_test.py::VolumeConfigTest::test_volume_binding_with_environment_variable PASSED [ 83%]

tests/unit/config/config_test.py::VolumeConfigTest::test_volume_binding_with_home PASSED [ 83%]

tests/unit/config/config_test.py::VolumeConfigTest::test_volume_path_with_non_ascii_directory PASSED [ 83%]

tests/unit/config/config_test.py::VolumeConfigTest::test_volumes_order_is_preserved PASSED [ 83%]

tests/unit/config/config_test.py::MergeVolumesTest::test_add_explicit_path PASSED [ 83%]

tests/unit/config/config_test.py::MergeVolumesTest::test_empty PASSED    [ 83%]

tests/unit/config/config_test.py::MergeVolumesTest::test_no_base PASSED  [ 83%]

tests/unit/config/config_test.py::MergeVolumesTest::test_no_override PASSED [ 83%]

tests/unit/config/config_test.py::MergeVolumesTest::test_override_explicit_path PASSED [ 83%]

tests/unit/config/config_test.py::MergeVolumesTest::test_remove_explicit_path PASSED [ 83%]

tests/unit/config/config_test.py::MergeDevicesTest::test_add_explicit_path PASSED [ 83%]

tests/unit/config/config_test.py::MergeDevicesTest::test_empty PASSED    [ 84%]

tests/unit/config/config_test.py::MergeDevicesTest::test_no_base PASSED  [ 84%]

tests/unit/config/config_test.py::MergeDevicesTest::test_no_override PASSED [ 84%]

tests/unit/config/config_test.py::MergeDevicesTest::test_override_explicit_path PASSED [ 84%]

tests/unit/config/config_test.py::MergeDevicesTest::test_remove_explicit_path PASSED [ 84%]

tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_no_override PASSED [ 84%]

tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_override_with_other PASSED [ 84%]

tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_override_with_same PASSED [ 84%]

tests/unit/config/config_test.py::MergePortsTest::test_add_item PASSED   [ 84%]

tests/unit/config/config_test.py::MergePortsTest::test_duplicate_port_mappings PASSED [ 84%]

tests/unit/config/config_test.py::MergePortsTest::test_empty PASSED      [ 84%]

tests/unit/config/config_test.py::MergePortsTest::test_no_base PASSED    [ 85%]

tests/unit/config/config_test.py::MergePortsTest::test_no_override PASSED [ 85%]

tests/unit/config/config_test.py::MergeNetworksTest::test_add_item PASSED [ 85%]

tests/unit/config/config_test.py::MergeNetworksTest::test_all_properties PASSED [ 85%]

tests/unit/config/config_test.py::MergeNetworksTest::test_empty PASSED   [ 85%]

tests/unit/config/config_test.py::MergeNetworksTest::test_network_has_none_value PASSED [ 85%]

tests/unit/config/config_test.py::MergeNetworksTest::test_no_base PASSED [ 85%]

tests/unit/config/config_test.py::MergeNetworksTest::test_no_network_name_overrides PASSED [ 85%]

tests/unit/config/config_test.py::MergeNetworksTest::test_no_network_overrides PASSED [ 85%]

tests/unit/config/config_test.py::MergeNetworksTest::test_no_override PASSED [ 85%]

tests/unit/config/config_test.py::MergeStringsOrListsTest::test_add_list PASSED [ 85%]

tests/unit/config/config_test.py::MergeStringsOrListsTest::test_add_string PASSED [ 85%]

tests/unit/config/config_test.py::MergeStringsOrListsTest::test_no_base PASSED [ 86%]

tests/unit/config/config_test.py::MergeStringsOrListsTest::test_no_override PASSED [ 86%]

tests/unit/config/config_test.py::MergeLabelsTest::test_add_explicit_value PASSED [ 86%]

tests/unit/config/config_test.py::MergeLabelsTest::test_empty PASSED     [ 86%]

tests/unit/config/config_test.py::MergeLabelsTest::test_no_base PASSED   [ 86%]

tests/unit/config/config_test.py::MergeLabelsTest::test_no_override PASSED [ 86%]

tests/unit/config/config_test.py::MergeLabelsTest::test_override_explicit_value PASSED [ 86%]

tests/unit/config/config_test.py::MergeLabelsTest::test_remove_explicit_value PASSED [ 86%]

tests/unit/config/config_test.py::MergeBuildTest::test_empty_base PASSED [ 86%]

tests/unit/config/config_test.py::MergeBuildTest::test_empty_override PASSED [ 86%]

tests/unit/config/config_test.py::MergeBuildTest::test_full PASSED       [ 86%]

tests/unit/config/config_test.py::MemoryOptionsTest::test_memswap_can_be_a_string PASSED [ 87%]

tests/unit/config/config_test.py::MemoryOptionsTest::test_validation_fails_with_just_memswap_limit PASSED [ 87%]

tests/unit/config/config_test.py::MemoryOptionsTest::test_validation_with_correct_memswap_values PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_environment_overrides_env_file PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_parse_environment_as_dict PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_parse_environment_as_list PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_parse_environment_empty PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_parse_environment_invalid PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_resolve_build_args PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_resolve_environment PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_resolve_environment_from_env_file PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_resolve_environment_from_env_file_with_empty_values PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_resolve_environment_nonexistent_file PASSED [ 88%]

tests/unit/config/config_test.py::EnvTest::test_resolve_environment_with_multiple_env_files PASSED [ 88%]

tests/unit/config/config_test.py::EnvTest::test_resolve_path PASSED      [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_circular PASSED      [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_invalid_config PASSED [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_valid_config PASSED [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_verbose_and_shorthand_way PASSED [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_extends PASSED       [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_file_defaults_to_self PASSED [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_same_file_optimization PASSED [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_empty_dictionary PASSED [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_invalid_key PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_missing_service_key PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_no_file_key_no_filename_set PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_sub_property_key PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_valid_config PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_with_defined_version_passes PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_with_depends_on PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_with_environment_and_env_files PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_with_healthcheck PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_with_mixed_versions_is_error PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_with_ports PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_with_security_opt PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_invalid_links_in_extended_service PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_invalid_net_in_extended_service PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_invalid_volumes_from_in_extended_service PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_load_config_runs_interpolation_in_extended_service PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_load_throws_error_when_base_service_does_not_exist PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_merging_env_labels_ulimits PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_nested PASSED        [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_parent_build_path_dne PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_partial_service_config_in_extends_is_still_valid PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_self_referencing_file PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_volume_path PASSED   [ 90%]

tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_absolute PASSED [ 91%]

tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_normal PASSED [ 91%]

tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_with_tilde PASSED [ 91%]

tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_root_mount PASSED [ 91%]

tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_windows_path PASSED [ 91%]

tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_windows_path_in_container PASSED [ 91%]

tests/unit/config/config_test.py::BuildPathTest::test_absolute_path PASSED [ 91%]

tests/unit/config/config_test.py::BuildPathTest::test_from_file PASSED   [ 91%]

tests/unit/config/config_test.py::BuildPathTest::test_from_file_override_dir PASSED [ 91%]

tests/unit/config/config_test.py::BuildPathTest::test_invalid_url_in_build_path PASSED [ 91%]

tests/unit/config/config_test.py::BuildPathTest::test_nonexistent_path PASSED [ 91%]

tests/unit/config/config_test.py::BuildPathTest::test_relative_path PASSED [ 91%]

tests/unit/config/config_test.py::BuildPathTest::test_valid_url_in_build_path PASSED [ 92%]

tests/unit/config/config_test.py::HealthcheckTest::test_disable PASSED   [ 92%]

tests/unit/config/config_test.py::HealthcheckTest::test_disable_with_other_config_is_invalid PASSED [ 92%]

tests/unit/config/config_test.py::HealthcheckTest::test_healthcheck PASSED [ 92%]

tests/unit/config/config_test.py::HealthcheckTest::test_healthcheck_with_invalid_test PASSED [ 92%]

tests/unit/config/config_test.py::GetDefaultConfigFilesTestCase::test_get_config_path_default_file_in_basedir PASSED [ 92%]

tests/unit/config/config_test.py::GetDefaultConfigFilesTestCase::test_get_config_path_default_file_in_parent_dir PASSED [ 92%]

tests/unit/config/config_test.py::SerializeTest::test_denormalize_depends_on_v2_1 PASSED [ 92%]

tests/unit/config/config_test.py::SerializeTest::test_denormalize_depends_on_v3 PASSED [ 92%]

tests/unit/config/config_test.py::SerializeTest::test_denormalize_healthcheck PASSED [ 92%]

tests/unit/config/config_test.py::SerializeTest::test_denormalize_image_has_digest PASSED [ 92%]

tests/unit/config/config_test.py::SerializeTest::test_denormalize_image_no_digest PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_bool_string PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_configs PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_escape_dollar_sign PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_escape_dont_interpolate PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_external_false PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_ports PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_ports_with_ext_ip PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_secrets PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_time PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_unicode_values PASSED [ 93%]

tests/unit/config/environment_test.py::EnvironmentTest::test_env_vars_from_file_bom PASSED [ 93%]

tests/unit/config/environment_test.py::EnvironmentTest::test_env_vars_from_file_whitespace PASSED [ 94%]

tests/unit/config/environment_test.py::EnvironmentTest::test_get_boolean PASSED [ 94%]

tests/unit/config/environment_test.py::EnvironmentTest::test_get_simple PASSED [ 94%]

tests/unit/config/environment_test.py::EnvironmentTest::test_get_undefined PASSED [ 94%]

tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_services PASSED [ 94%]

tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_volumes PASSED [ 94%]

tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_secrets PASSED [ 94%]

tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_v2 PASSED [ 94%]

tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_v3 PASSED [ 94%]

tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_invalid PASSED [ 94%]

tests/unit/config/interpolation_test.py::test_interpolate_environment_network_convert_types PASSED [ 94%]

tests/unit/config/interpolation_test.py::test_interpolate_environment_external_resource_convert_types PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_service_name_uses_dot PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_escaped_interpolation PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_invalid_interpolation PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_missing_no_default PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_with_value PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_missing_with_default PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_with_empty_and_default_value PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_mandatory_values PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_mandatory_no_err_msg PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_mixed_separators PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_unbraced_separators PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_unicode_values PASSED [ 96%]

tests/unit/config/interpolation_test.py::test_interpolate_no_fallthrough PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_1 PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_2 PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_3 PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_4 PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_5 PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_6 PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_7 PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports_2 PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports_3 PASSED [ 97%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_self_imports PASSED [ 97%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_depends_on_self PASSED [ 97%]

tests/unit/config/types_test.py::test_parse_extra_hosts_list PASSED      [ 97%]

tests/unit/config/types_test.py::test_parse_extra_hosts_dict PASSED      [ 97%]

tests/unit/config/types_test.py::TestServicePort::test_parse_dict PASSED [ 97%]

tests/unit/config/types_test.py::TestServicePort::test_parse_simple_target_port PASSED [ 97%]

tests/unit/config/types_test.py::TestServicePort::test_parse_complete_port_definition PASSED [ 97%]

tests/unit/config/types_test.py::TestServicePort::test_parse_ext_ip_no_published_port PASSED [ 97%]

tests/unit/config/types_test.py::TestServicePort::test_repr_published_port_0 PASSED [ 97%]

tests/unit/config/types_test.py::TestServicePort::test_parse_port_range PASSED [ 97%]

tests/unit/config/types_test.py::TestServicePort::test_parse_port_publish_range PASSED [ 97%]

tests/unit/config/types_test.py::TestServicePort::test_parse_invalid_port PASSED [ 98%]

tests/unit/config/types_test.py::TestServicePort::test_parse_invalid_publish_range PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_only_one_path PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_internal_and_external PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_with_mode PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_too_many_parts PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_absolute_path_normalized PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_absolute_path_native PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_internal_path_normalized PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_internal_path_native PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_just_drives_normalized PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_just_drives_native PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_mixed_notations_normalized PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_mixed_notations_native PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_from_service PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_from_container PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_invalid PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_service PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_service_with_mode PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_container PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_container_with_mode PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_invalid_type PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_invalid PASSED [100%]



----------- coverage: platform linux, python 3.7.4-final-0 -----------

Name                              Stmts   Miss Branch BrPart  Cover   Missing

-----------------------------------------------------------------------------

compose/__init__.py                   3      0      0      0   100%

compose/__main__.py                   4      4      0      0     0%   1-6

compose/bundle.py                   144     21     62      5    84%   45, 50-51, 56-57, 75-78, 81, 103-109, 130-131, 141-146, 149, 80->81, 100->103, 118->135, 125->135, 148->149

compose/cli/__init__.py               0      0      0      0   100%

compose/cli/colors.py                23      2     10      2    88%   37-38, 36->37, 48->exit

compose/cli/command.py              104     14     34      5    83%   71-81, 121-126, 177, 200, 70->71, 120->121, 165->168, 176->177, 197->200

compose/cli/docker_client.py         75      5     24      2    93%   24, 98-99, 107, 123, 106->107, 122->123

compose/cli/docopt_command.py        38      4      8      2    87%   13-14, 29, 35, 28->29, 34->35

compose/cli/errors.py               100     26     34      6    67%   47-48, 62-65, 70-79, 105-106, 123, 125, 127-131, 136, 141-148, 46->47, 61->62, 103->105, 122->123, 124->125, 126->127

compose/cli/formatter.py             37      3     10      1    91%   15, 22-23, 12->15

compose/cli/log_printer.py          149     10     55      6    91%   76, 103, 110-115, 167, 176, 229-232, 262, 43->exit, 75->76, 98->103, 174->176, 228->229, 237->243

compose/cli/main.py                 696     91    305     41    84%   84-85, 87-88, 169, 330, 362-364, 447, 507, 511, 516-517, 527-556, 568, 586-588, 592, 659-660, 698-699, 717, 738-739, 751, 774, 792, 839, 1071, 1080, 1109-1118, 1158-1161, 1169-1173, 1175-1180, 1203, 1225-1254, 1261-1262, 1264-1266, 1281, 1287, 1471, 1489, 1505, 1509-1510, 1521, 1526, 1529, 1555, 1574-1576, 1586, 1597, 61->64, 83->84, 86->87, 168->169, 329->330, 361->362, 446->447, 506->507, 510->511, 521->527, 565->568, 585->586, 591->592, 657->659, 716->717, 737->738, 750->751, 773->774, 829->839, 831->exit, 1070->1071, 1079->1080, 1168->1169, 1174->1175, 1202->1203, 1260->1261, 1263->1264, 1280->1281, 1286->1287, 1470->1471, 1488->1489, 1504->1505, 1520->1521, 1525->1526, 1528->1529, 1547->exit, 1554->1555, 1568->1576, 1570->1574, 1585->1586, 1595->1597

compose/cli/signals.py               23      0      4      2    93%   36->exit, 43->exit

compose/cli/utils.py                 81     28     18      4    60%   36-45, 53-55, 62-68, 76, 90-103, 109, 127-128, 138, 151-154, 88->90, 108->109, 137->138, 150->151

compose/cli/verbose_proxy.py         35     12     10      0    69%   36-39, 42-47, 50-60

compose/config/__init__.py           13      0      0      0   100%

compose/config/config.py            826     28    428     18    95%   266, 508, 578, 714, 757, 812-830, 952-953, 959, 979, 982, 1335, 1366, 1412, 265->266, 577->578, 709->713, 713->714, 756->757, 778->exit, 809->812, 936->938, 938->942, 957->959, 978->979, 981->982, 993->1002, 1015->1017, 1017->1020, 1332->1335, 1365->1366, 1408->1412

compose/config/environment.py        96      8     34      5    90%   21, 41, 98-101, 114, 121, 20->21, 40->41, 97->98, 113->114, 120->121

compose/config/errors.py             25      2      2      0    85%   36-40

compose/config/interpolation.py     148      6     64      3    95%   66, 148, 222, 227-229, 121->exit, 146->148, 221->222

compose/config/serialize.py          97      2     58      3    97%   31, 76, 30->31, 75->76, 82->85

compose/config/sort_services.py      44      1     24      1    97%   57, 56->57

compose/config/types.py             291     22    116     17    90%   54, 90, 113, 149, 171, 258-259, 267, 286, 301, 363-364, 372-373, 377-378, 441, 445, 486, 493-494, 502, 53->54, 71->79, 89->90, 112->113, 118->exit, 148->149, 170->171, 257->258, 266->267, 285->286, 298->301, 361->366, 440->441, 444->445, 484->489, 485->486, 501->502

compose/config/validation.py        254     14    141     12    92%   219, 249, 299-300, 318-319, 341, 363, 469-471, 496-498, 525, 218->219, 248->249, 289->299, 317->318, 335->338, 338->341, 362->363, 404->377, 425->exit, 467->469, 495->496, 524->525

compose/const.py                     39      0      0      0   100%

compose/container.py                193      8     50      7    94%   98, 105, 151, 153, 262, 265, 297, 320, 97->98, 104->105, 150->151, 152->153, 236->235, 303->exit, 319->320

compose/errors.py                    17      1      0      0    94%   12

compose/network.py                  190     19     95      5    87%   184, 186-200, 206, 224, 226, 183->184, 185->186, 205->206, 223->224, 225->226

compose/parallel.py                 199      2     58      1    99%   187, 326, 325->326

compose/progress_stream.py           87     12     44     10    82%   40, 71, 74, 80, 85, 90-91, 116, 122-125, 39->40, 42->46, 53->57, 70->71, 73->74, 79->80, 84->85, 89->90, 112->116, 121->122

compose/project.py                  450     31    211     14    92%   64, 161, 217-218, 259-260, 370-371, 374-379, 393-396, 449, 500, 504, 531, 634-638, 641, 659, 790-791, 797-800, 855, 61->64, 157->161, 336->338, 368->370, 373->374, 392->393, 448->449, 499->500, 503->504, 530->531, 640->641, 658->659, 709->exit, 793->800

compose/service.py                  920     60    459     32    92%   65, 278-279, 300, 373-376, 424-429, 435-437, 477-478, 493, 496, 514, 581, 626-629, 737, 956-957, 977-978, 1079, 1126, 1187, 1251-1266, 1306, 1345-1349, 1537, 1541, 1658, 1699, 1711, 1785, 1811, 1826, 1839, 1843-1844, 1848-1849, 64->65, 223->exit, 276->278, 299->300, 434->435, 476->477, 492->493, 495->496, 513->514, 571->581, 732->737, 955->956, 976->977, 1078->1079, 1125->1126, 1186->1187, 1305->1306, 1342->1345, 1536->1537, 1540->1541, 1589->exit, 1597->1596, 1635->1632, 1657->1658, 1698->1699, 1710->1711, 1784->1785, 1810->1811, 1825->1826, 1838->1839, 1842->1843, 1847->1848

compose/state.py                      0      0      0      0   100%

compose/timeparse.py                 22      0      4      0   100%

compose/utils.py                    117      8     42      5    92%   27, 75-79, 125, 135, 161, 168, 171, 25->27, 124->125, 134->135, 167->168, 169->171

compose/version.py                    6      0      0      0   100%

compose/volume.py                   126      4     44      3    95%   150, 200, 211-212, 141->150, 199->200, 209->211

-----------------------------------------------------------------------------

TOTAL                              5672    448   2448    212    90%

Coverage HTML written to dir coverage-html



=========================== short test summary info ============================

XFAIL tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_rt

  not supported by kernel

XFAIL tests/integration/service_test.py::ServiceTest::test_create_container_with_storage_opt

  Not supported on most drivers

SKIP [1] tests/acceptance/cli_test.py:2437: race condition between up and logs

SKIP [1] tests/acceptance/cli_test.py:2389: race condition between up and logs

SKIP [1] tests/acceptance/cli_test.py:2416: race condition between up and logs

SKIP [1] /code/tests/integration/testcases.py:167: This daemon does not support the 'nvidia'' runtime

SKIP [1] tests/integration/service_test.py:150: cpu_percent is not supported for Linux

SKIP [1] tests/integration/service_test.py:1674: Broken on 1.11.0 - 17.03.0

SKIP [1] tests/unit/cli/command_test.py:39: windows separator

SKIP [1] tests/unit/cli/command_test.py:69: Env values in Python 3 are already Unicode

SKIP [1] tests/unit/cli/errors_test.py:70: Needs pywin32

SKIP [1] tests/unit/cli/errors_test.py:80: Needs pywin32

SKIP [1] tests/unit/cli/errors_test.py:90: Needs pywin32

SKIP [1] tests/unit/config/config_test.py:3778: windows paths



======= 1131 passed, 12 skipped, 2 xfailed, 3 xpassed in 790.68 seconds ========

___________________________________ summary ____________________________________

  py37: commands succeeded

  congratulations :)

+ on_exit
+ [[ 0 != \0 ]]
+ docker rm -vf compose-dind-19.03.5-jenkins-compose-ndeloof-28
compose-dind-19.03.5-jenkins-compose-ndeloof-28
[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // node
expected to call java.lang.String.eachLine but wound up catching org.jenkinsci.plugins.workflow.cps.CpsClosure2.call; see: https://jenkins.io/redirect/pipeline-cps-method-mismatches/
[Pipeline] node
Running on ubuntu-1804-overlay2 (i-0b6eb4af357135099) in /home/ubuntu/workspace/compose_ndeloof
[Pipeline] {
[Pipeline] stage
[Pipeline] { (debian 19.03.5 py27)
[Pipeline] checkout
using credential sf-release-bot.github.ssh
Fetching changes from the remote Git repository
Fetching without tags
Checking out Revision f0d8706f3473426bfcc85197834187726323acf2 (ndeloof)
Commit message: "WiP"
 > git rev-parse --is-inside-work-tree # timeout=10
 > git config remote.origin.url git@github.com:docker/compose.git # timeout=10
Fetching upstream changes from git@github.com:docker/compose.git
 > git --version # timeout=10
using GIT_SSH to set credentials docker-jenkins user on github.com
 > git fetch --no-tags --progress -- git@github.com:docker/compose.git +refs/heads/ndeloof:refs/remotes/origin/ndeloof
 > git config core.sparsecheckout # timeout=10
 > git checkout -f f0d8706f3473426bfcc85197834187726323acf2
[Pipeline] unstash
Unstashed file(s) from https://corp-us-east-1-jenkins-k8s-maste-jenkinsartifacts-1lzm7adht5e1j.s3.amazonaws.com/public/compose/ndeloof/28/stashes/debian.tgz
[Pipeline] sh
+ docker load -i debian.tar
Loaded image: compose:debian
[Pipeline] sh
+ pwd
+ docker run -t --rm --privileged --volume=/home/ubuntu/workspace/compose_ndeloof/.git:/code/.git --volume=/var/run/docker.sock:/var/run/docker.sock -e TAG=compose:debian -e DOCKER_VERSIONS=19.03.5 -e BUILD_NUMBER=jenkins-compose-ndeloof-28 -e PY_TEST_VERSIONS=py27 --entrypoint=script/test/ci compose:debian --verbose
+ docker version
Client: Docker Engine - Community
 Version:           18.09.7
 API version:       1.39
 Go version:        go1.10.8
 Git commit:        2d0083d
 Built:             Thu Jun 27 17:54:15 2019
 OS/Arch:           linux/amd64
 Experimental:      false

Server: Docker Engine - Community
 Engine:
  Version:          19.03.2
  API version:      1.40 (minimum version 1.12)
  Go version:       go1.12.8
  Git commit:       6a30dfc
  Built:            Thu Aug 29 05:27:45 2019
  OS/Arch:          linux/amd64
  Experimental:     true
 containerd:
  Version:          1.2.6
  GitCommit:        894b81a4b802e4eb2a91d1ce216b8817763c29fb
 runc:
  Version:          1.0.0-rc8
  GitCommit:        425e105d5a03fabd737a126ad93d62a9eeede87f
 docker-init:
  Version:          0.18.0
  GitCommit:        fec3683
+ export DOCKER_VERSIONS=19.03.5
+ DOCKER_VERSIONS=19.03.5
+ STORAGE_DRIVER=overlay
+ export DOCKER_DAEMON_ARGS=--storage-driver=overlay
+ DOCKER_DAEMON_ARGS=--storage-driver=overlay
++ hostname
+ GIT_VOLUME=--volumes-from=a2205744b62d
+ . script/test/all
++ set -e
++ echo 'Running lint checks'
Running lint checks
++ docker run --rm --tty --volumes-from=a2205744b62d compose:debian tox -e pre-commit
pre-commit installed: aspy.yaml==1.3.0,cfgv==2.0.1,identify==1.4.7,importlib-metadata==1.1.0,more-itertools==8.0.0,nodeenv==1.3.3,pre-commit==1.20.0,PyYAML==5.2,six==1.13.0,toml==0.10.0,virtualenv==16.7.8,zipp==0.6.0

pre-commit runtests: PYTHONHASHSEED='2694573395'

pre-commit runtests: commands[0] | pre-commit install

pre-commit installed at .git/hooks/pre-commit

pre-commit runtests: commands[1] | pre-commit run --all-files

[WARNING] Unexpected key(s) present on git://github.com/pre-commit/pre-commit-hooks: sha

[WARNING] Unexpected key(s) present on git://github.com/asottile/reorder_python_imports: sha

[INFO] Initializing environment for git://github.com/pre-commit/pre-commit-hooks.

[INFO] Initializing environment for git://github.com/asottile/reorder_python_imports.

[INFO] Installing environment for git://github.com/pre-commit/pre-commit-hooks.

[INFO] Once installed this environment will be reused.

[INFO] This may take a few minutes...

[INFO] Installing environment for git://github.com/asottile/reorder_python_imports.

[INFO] Once installed this environment will be reused.

[INFO] This may take a few minutes...

Check for added large files..............................................Passed

Check docstring is first.................................................Passed

Check for merge conflicts................................................Passed

Check Yaml...............................................................Passed

Check JSON...............................................................Passed

Debug Statements (Python)................................................Passed

Fix End of Files.........................................................Passed

Flake8...................................................................Passed

Tests should end in _test.py.............................................Passed

Fix requirements.txt.....................................................Passed

Trim Trailing Whitespace.................................................Passed

Reorder python imports...................................................Passed

___________________________________ summary ____________________________________

  pre-commit: commands succeeded

  congratulations :)

++ get_versions='docker run --rm
    --entrypoint=/code/.tox/py27/bin/python
    compose:debian
    /code/script/test/versions.py docker/docker-ce,moby/moby'
++ '[' 19.03.5 == '' ']'
++ '[' 19.03.5 == all ']'
++ BUILD_NUMBER=jenkins-compose-ndeloof-28
++ PY_TEST_VERSIONS=py27
++ for version in $DOCKER_VERSIONS
++ echo 'Running tests against Docker 19.03.5'
Running tests against Docker 19.03.5
++ daemon_container=compose-dind-19.03.5-jenkins-compose-ndeloof-28
++ trap on_exit EXIT
++ repo=dockerswarm/dind
++ docker run -d --name compose-dind-19.03.5-jenkins-compose-ndeloof-28 --privileged --volume=/var/lib/docker dockerswarm/dind:19.03.5 dockerd -H tcp://0.0.0.0:2375 --storage-driver=overlay
++ tail -n 10
f02bdfbfb2b6b9281262dff184d03599f70bf1dbec49576006ec7e91e6a08920
++ docker run --rm --tty --link=compose-dind-19.03.5-jenkins-compose-ndeloof-28:docker --env=DOCKER_HOST=tcp://docker:2375 --env=DOCKER_VERSION=19.03.5 --entrypoint=tox compose:debian -e py27 -- --verbose
py27 develop-inst-nodeps: /code

py27 installed: DEPRECATION: Python 2.7 will reach the end of its life on January 1st, 2020. Please upgrade your Python as Python 2.7 won't be maintained after that date. A future version of pip will drop support for Python 2.7. More details about Python 2 support in pip, can be found at https://pip.pypa.io/en/latest/development/release-process/#python-2-support,atomicwrites==1.3.0,attrs==19.3.0,backports.shutil-get-terminal-size==1.0.0,backports.ssl-match-hostname==3.5.0.1,bcrypt==3.1.7,cached-property==1.3.0,certifi==2017.4.17,cffi==1.13.2,chardet==3.0.4,configparser==4.0.2,coverage==4.4.2,cryptography==2.8,ddt==1.2.0,docker==4.1.0,# Editable install with no version control (docker-compose==1.26.0.dev0),-e /code,docker-pycreds==0.4.0,dockerpty==0.4.1,docopt==0.6.2,enum34==1.1.6,flake8==3.5.0,funcsigs==1.0.2,functools32==3.2.3.post2,idna==2.5,ipaddress==1.0.18,jsonschema==3.0.1,mccabe==0.6.1,mock==3.0.5,more-itertools==5.0.0,paramiko==2.6.0,pluggy==0.6.0,py==1.8.0,pycodestyle==2.3.1,pycparser==2.19,pyflakes==1.6.0,PyNaCl==1.3.0,pyrsistent==0.15.6,PySocks==1.6.7,pytest==3.6.3,pytest-cov==2.5.1,PyYAML==4.2b1,requests==2.22.0,six==1.12.0,subprocess32==3.5.4,texttable==1.6.2,urllib3==1.25.7,websocket-client==0.32.0

py27 runtests: PYTHONHASHSEED='1498634845'

py27 runtests: commands[0] | mkdir -p .coverage-binfiles

py27 runtests: commands[1] | py.test -v --cov=compose --cov-report html --cov-report term --cov-config=tox.ini --verbose

============================= test session starts ==============================

platform linux2 -- Python 2.7.13, pytest-3.6.3, py-1.8.0, pluggy-0.6.0 -- /code/.tox/py27/bin/python2.7

cachedir: .pytest_cache

rootdir: /code, inifile: tox.ini

plugins: cov-2.5.1


collecting 0 items                                                             
collecting 197 items                                                           
collecting 197 items                                                           
collecting 197 items                                                           
collecting 197 items                                                           
collecting 198 items                                                           
collecting 198 items                                                           
collecting 198 items                                                           
collecting 201 items                                                           
collecting 201 items                                                           
collecting 201 items                                                           
collecting 269 items                                                           
collecting 269 items                                                           
collecting 269 items                                                           
collecting 272 items                                                           
collecting 272 items                                                           
collecting 272 items                                                           
collecting 401 items                                                           
collecting 405 items                                                           
collecting 405 items                                                           
collecting 405 items                                                           
collecting 405 items                                                           
collecting 408 items                                                           
collecting 417 items                                                           
collecting 428 items                                                           
collecting 436 items                                                           
collecting 436 items                                                           
collecting 436 items                                                           
collecting 436 items                                                           
collecting 447 items                                                           
collecting 447 items                                                           
collecting 464 items                                                           
collecting 477 items                                                           
collecting 477 items                                                           
collecting 495 items                                                           
collecting 496 items                                                           
collecting 496 items                                                           
collecting 504 items                                                           
collecting 504 items                                                           
collecting 509 items                                                           
collecting 512 items                                                           
collecting 521 items                                                           
collecting 521 items                                                           
collecting 552 items                                                           
collecting 552 items                                                           
collecting 626 items                                                           
collecting 627 items                                                           
collecting 630 items                                                           
collecting 634 items                                                           
collecting 635 items                                                           
collecting 645 items                                                           
collecting 648 items                                                           
collecting 651 items                                                           
collecting 651 items                                                           
collecting 656 items                                                           
collecting 656 items                                                           
collecting 669 items                                                           
collecting 672 items                                                           
collecting 672 items                                                           
collecting 674 items                                                           
collecting 674 items                                                           
collecting 676 items                                                           
collecting 676 items                                                           
collecting 677 items                                                           
collecting 677 items                                                           
collecting 678 items                                                           
collecting 678 items                                                           
collecting 678 items                                                           
collecting 680 items                                                           
collecting 680 items                                                           
collecting 680 items                                                           
collecting 688 items                                                           
collecting 688 items                                                           
collecting 688 items                                                           
collecting 692 items                                                           
collecting 708 items                                                           
collecting 711 items                                                           
collecting 711 items                                                           
collecting 711 items                                                           
collecting 719 items                                                           
collecting 719 items                                                           
collecting 719 items                                                           
collecting 725 items                                                           
collecting 725 items                                                           
collecting 727 items                                                           
collecting 727 items                                                           
collecting 730 items                                                           
collecting 730 items                                                           
collecting 734 items                                                           
collecting 734 items                                                           
collecting 738 items                                                           
collecting 738 items                                                           
collecting 741 items                                                           
collecting 746 items                                                           
collecting 746 items                                                           
collecting 749 items                                                           
collecting 749 items                                                           
collecting 753 items                                                           
collecting 753 items                                                           
collecting 760 items                                                           
collecting 760 items                                                           
collecting 760 items                                                           
collecting 764 items                                                           
collecting 769 items                                                           
collecting 769 items                                                           
collecting 773 items                                                           
collecting 773 items                                                           
collecting 917 items                                                           
collecting 925 items                                                           
collecting 933 items                                                           
collecting 936 items                                                           
collecting 946 items                                                           
collecting 957 items                                                           
collecting 963 items                                                           
collecting 969 items                                                           
collecting 972 items                                                           
collecting 977 items                                                           
collecting 985 items                                                           
collecting 989 items                                                           
collecting 995 items                                                           
collecting 998 items                                                           
collecting 1001 items                                                          
collecting 1013 items                                                          
collecting 1044 items                                                          
collecting 1047 items                                                          
collecting 1050 items                                                          
collecting 1057 items                                                          
collecting 1061 items                                                          
collecting 1063 items                                                          
collecting 1078 items                                                          
collecting 1078 items                                                          
collecting 1083 items                                                          
collecting 1083 items                                                          
collecting 1104 items                                                          
collecting 1116 items                                                          
collecting 1116 items                                                          
collecting 1116 items                                                          
collecting 1125 items                                                          
collecting 1125 items                                                          
collecting 1137 items                                                          
collecting 1137 items                                                          
collecting 1146 items                                                          
collecting 1146 items                                                          
collecting 1148 items                                                          
collected 1148 items                                                           



tests/acceptance/cli_test.py::CLITestCase::test_build_failed PASSED      [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_failed_forcerm PASSED [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_log_level PASSED   [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_memory_build_option PASSED [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_no_cache PASSED    [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_no_cache_pull PASSED [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_override_dir PASSED [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_override_dir_invalid_path PASSED [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_parallel PASSED    [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_plain PASSED       [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_pull PASSED        [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_rm XPASS           [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_build_shm_size_build_option PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_build_with_buildarg_cli_override PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_build_with_buildarg_from_compose_file PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_build_with_buildarg_old_api_version PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_bundle_with_digests PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_config_compatibility_mode PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_config_default PASSED    [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_config_external_network PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_config_external_network_v3_5 PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_config_external_volume_v2 PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_config_external_volume_v2_x PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_external_volume_v3_4 PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_external_volume_v3_x PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_list_services PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_list_volumes PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_quiet PASSED      [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_quiet_with_error PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_restart PASSED    [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_stdin PASSED      [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_v1 PASSED         [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_v3 PASSED         [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_with_dot_env PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_with_dot_env_and_override_dir PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_config_with_env_file PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_config_with_hash_option PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_create PASSED            [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_create_with_force_recreate PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_create_with_force_recreate_and_no_recreate PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_create_with_no_recreate PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_down PASSED              [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_down_invalid_rmi_flag PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_down_signal PASSED       [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_down_timeout PASSED      [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_env_file_relative_to_compose_file PASSED [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_events_human_readable PASSED [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_events_json PASSED       [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_exec_custom_user PASSED  [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_exec_detach_long_form PASSED [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_exec_service_with_environment_overridden PASSED [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_exec_without_tty PASSED  [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_exec_workdir PASSED      [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_exit_code_from_signal_stop PASSED [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_expanded_port PASSED     [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_forward_exitval PASSED   [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_help PASSED              [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_help_nonexistent PASSED  [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_home_and_env_var_in_volume_path PASSED [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_host_not_reachable PASSED [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_host_not_reachable_volumes_from_container PASSED [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_images PASSED            [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_images_default_composefile PASSED [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_images_tagless_image PASSED [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_images_use_service_tag PASSED [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_kill PASSED              [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_kill_signal_sigstop PASSED [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_kill_stopped_service PASSED [  5%]

tests/acceptance/cli_test.py::CLITestCase::test_logs_default SKIPPED     [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_logs_follow PASSED       [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_logs_follow_logs_from_new_containers SKIPPED [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_logs_follow_logs_from_restarted_containers SKIPPED [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_logs_invalid_service_name PASSED [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_logs_on_stopped_containers_exits PASSED [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_logs_tail PASSED         [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_logs_timestamps PASSED   [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_pause_no_containers PASSED [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_pause_unpause PASSED     [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_port PASSED              [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_port_with_scale PASSED   [  6%]

tests/acceptance/cli_test.py::CLITestCase::test_ps PASSED                [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_ps_all PASSED            [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_ps_alternate_composefile PASSED [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_ps_default_composefile PASSED [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_ps_services_filter_option PASSED [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_ps_services_filter_status PASSED [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_pull PASSED              [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_pull_can_build PASSED    [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_pull_with_digest PASSED  [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_pull_with_ignore_pull_failures PASSED [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_pull_with_include_deps PASSED [  7%]

tests/acceptance/cli_test.py::CLITestCase::test_pull_with_no_deps PASSED [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_pull_with_parallel_failure PASSED [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_pull_with_quiet PASSED   [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_quiet_build PASSED       [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_restart PASSED           [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_restart_no_containers PASSED [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_restart_stopped_container PASSED [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_rm PASSED                [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_rm_all PASSED            [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_rm_stop PASSED           [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_run_detached_connects_to_network PASSED [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_run_does_not_recreate_linked_containers PASSED [  8%]

tests/acceptance/cli_test.py::CLITestCase::test_run_env_values_from_system PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_handles_sighup PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_handles_sigint PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_handles_sigterm PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_interactive_connects_to_network PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_label_flag PASSED    [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_one_off_with_multiple_volumes PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_one_off_with_volume PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_one_off_with_volume_merge PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_rm PASSED            [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint PASSED [  9%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint_and_command_overridden PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint_and_empty_string_command PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint_overridden PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dependencies PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dockerfile_entrypoint PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dockerfile_entrypoint_and_command_overridden PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dockerfile_entrypoint_overridden PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_environment_overridden PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_explicitly_mapped_ip_ports PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_explicitly_mapped_ports PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_links PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_map_ports PASSED [ 10%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_scaled_dependencies PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_unset_entrypoint PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_use_aliases PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_user_overridden PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_user_overridden_short_form PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_workdir_overridden PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_workdir_overridden_short_form PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_without_links PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_service_without_map_ports PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_unicode_env_values_from_system PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_with_custom_name PASSED [ 11%]

tests/acceptance/cli_test.py::CLITestCase::test_run_with_expose_ports PASSED [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_run_with_no_deps PASSED  [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_run_without_command PASSED [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_scale PASSED             [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_scale_v2_2 PASSED        [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_shorthand_host_opt PASSED [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_shorthand_host_opt_interactive PASSED [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_start_no_containers PASSED [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_stop PASSED              [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_stop_signal PASSED       [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_top_processes_running PASSED [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_top_services_not_running PASSED [ 12%]

tests/acceptance/cli_test.py::CLITestCase::test_top_services_running PASSED [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_unpause_no_containers PASSED [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up PASSED                [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_attached PASSED       [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_detached PASSED       [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_detached_long_form PASSED [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_external_networks PASSED [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_handles_abort_on_container_exit PASSED [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_handles_abort_on_container_exit_code PASSED [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_handles_force_shutdown PASSED [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_handles_sigint PASSED [ 13%]

tests/acceptance/cli_test.py::CLITestCase::test_up_handles_sigterm PASSED [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_logging PASSED        [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_logging_legacy PASSED [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_missing_network PASSED [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_no_ansi PASSED        [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_no_services PASSED    [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_no_start PASSED       [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_no_start_remove_orphans PASSED [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_scale_reset PASSED    [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_scale_scale_down PASSED [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_scale_scale_up PASSED [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_scale_to_zero PASSED  [ 14%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_default_network_config PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_default_override_file PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_duplicate_override_yaml_files PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_extends PASSED   [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_external_default_network PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_force_recreate PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_force_recreate_and_no_recreate PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_healthcheck PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_ignore_remove_orphans PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_links_v1 PASSED  [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_multiple_files PASSED [ 15%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_net_is_invalid PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_net_v1 <- tests/integration/testcases.py PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_aliases PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_internal PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_labels PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_mode <- tests/integration/testcases.py PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_static_addresses PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_networks PASSED  [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_no_deps PASSED   [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_no_recreate PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_override_yaml PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_pid_mode <- tests/integration/testcases.py PASSED [ 16%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_timeout PASSED   [ 17%]

tests/acceptance/cli_test.py::CLITestCase::test_up_with_volume_labels PASSED [ 17%]

tests/integration/environment_test.py::EnvironmentOverrideFileTest::test_env_file_override PASSED [ 17%]

tests/integration/network_test.py::NetworkTest::test_network_default_labels PASSED [ 17%]

tests/integration/network_test.py::NetworkTest::test_network_external_default_ensure PASSED [ 17%]

tests/integration/network_test.py::NetworkTest::test_network_external_overlay_ensure PASSED [ 17%]

tests/integration/project_test.py::ProjectTest::test_containers PASSED   [ 17%]

tests/integration/project_test.py::ProjectTest::test_containers_stopped PASSED [ 17%]

tests/integration/project_test.py::ProjectTest::test_containers_with_extra_service PASSED [ 17%]

tests/integration/project_test.py::ProjectTest::test_containers_with_service_names PASSED [ 17%]

tests/integration/project_test.py::ProjectTest::test_create PASSED       [ 17%]

tests/integration/project_test.py::ProjectTest::test_create_strategy_always PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_create_strategy_never PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_create_twice PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_create_with_links PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_initialize_volumes PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_initialize_volumes_external_volumes <- tests/integration/testcases.py PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_initialize_volumes_inexistent_external_volume PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_initialize_volumes_invalid_volume_driver PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_blank_driver PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_driver <- tests/integration/testcases.py PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_driver_opts <- tests/integration/testcases.py PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_net_from_container_v1 <- tests/integration/testcases.py PASSED [ 18%]

tests/integration/project_test.py::ProjectTest::test_net_from_service_v1 <- tests/integration/testcases.py PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_network_mode_from_container <- tests/integration/testcases.py PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_network_mode_from_service <- tests/integration/testcases.py PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_parallel_pull_with_no_image PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_project_up PASSED   [ 19%]

tests/integration/project_test.py::ProjectTest::test_project_up_config_scale PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_project_up_healthy_dependency PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_project_up_ignore_orphans PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_project_up_implicit_volume_driver PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_project_up_logging_with_multiple_files PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_project_up_name_starts_with_illegal_char <- tests/integration/testcases.py PASSED [ 19%]

tests/integration/project_test.py::ProjectTest::test_project_up_named_volumes_in_binds PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_networks PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_no_healthcheck_dependency PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_orphans PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_port_mappings_with_multiple_files PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_recreate_with_tmpfs_volume PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_seccomp_profile PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_starts_depends PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_starts_links PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_starts_uncreated_services PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_unhealthy_dependency PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_volumes PASSED [ 20%]

tests/integration/project_test.py::ProjectTest::test_project_up_with_added_secrets PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_project_up_with_network_internal PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_project_up_with_network_label PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_project_up_with_no_deps PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_project_up_with_no_recreate_running PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_project_up_with_no_recreate_stopped PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_project_up_with_secrets PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_project_up_with_volume_labels PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_project_up_without_all_services PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_recreate_preserves_mounts PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_recreate_preserves_volumes PASSED [ 21%]

tests/integration/project_test.py::ProjectTest::test_start_pause_unpause_stop_kill_remove PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_unscale_after_restart PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_custom_name_resources PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_enable_ipv6 PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_invalid_isolation PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_invalid_runtime PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_ipam_config PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_ipam_options PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_isolation PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_network_link_local_ips PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_network_priorities PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_network_static_addresses PASSED [ 22%]

tests/integration/project_test.py::ProjectTest::test_up_with_network_static_addresses_missing_subnet PASSED [ 23%]

tests/integration/project_test.py::ProjectTest::test_up_with_nvidia_runtime <- tests/integration/testcases.py SKIPPED [ 23%]

tests/integration/project_test.py::ProjectTest::test_up_with_runtime <- tests/integration/testcases.py PASSED [ 23%]

tests/integration/project_test.py::ProjectTest::test_volumes_from_container PASSED [ 23%]

tests/integration/project_test.py::ProjectTest::test_volumes_from_service PASSED [ 23%]

tests/integration/resilience_test.py::ResilienceTest::test_create_failure PASSED [ 23%]

tests/integration/resilience_test.py::ResilienceTest::test_start_failure PASSED [ 23%]

tests/integration/resilience_test.py::ResilienceTest::test_successful_recreate PASSED [ 23%]

tests/integration/service_test.py::ServiceTest::test_build PASSED        [ 23%]

tests/integration/service_test.py::ServiceTest::test_build_cli PASSED    [ 23%]

tests/integration/service_test.py::ServiceTest::test_build_non_ascii_filename PASSED [ 23%]

tests/integration/service_test.py::ServiceTest::test_build_with_build_args PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_build_args_override PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_build_labels PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_cachefrom PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_extra_hosts PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_git_url PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_gzip PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_illegal_leading_chars PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_image_name PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_isolation PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_network <- tests/integration/testcases.py PASSED [ 24%]

tests/integration/service_test.py::ServiceTest::test_build_with_target <- tests/integration/testcases.py PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_cap_add_list PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_cap_drop_list PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_containers PASSED   [ 25%]

tests/integration/service_test.py::ServiceTest::test_containers_one_off PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_blkio_config PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_count PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_percent SKIPPED [ 25%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_quota PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_rt xfail [ 25%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_set PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_shares PASSED [ 25%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_cpus PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_device_cgroup_rules PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_extra_hosts_dicts PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_extra_hosts_list PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_healthcheck_config PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_host_mount PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_init_bool PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_init_path XPASS [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_legacy_mount PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_legacy_tmpfs_mount PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_mac_address PASSED [ 26%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_one_off PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_one_off_when_existing_container_is_running PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_oom_kill_disable PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_pids_limit XPASS [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_read_only_root_fs PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_security_opt PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_shm_size PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_specified_volume PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_storage_opt xfail [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_tmpfs_mount PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_tmpfs_mount_tmpfs_size PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_unspecified_volume PASSED [ 27%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_volume_driver PASSED [ 28%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_volume_mount PASSED [ 28%]

tests/integration/service_test.py::ServiceTest::test_create_container_with_volumes_from PASSED [ 28%]

tests/integration/service_test.py::ServiceTest::test_create_with_image_id PASSED [ 28%]

tests/integration/service_test.py::ServiceTest::test_custom_container_name PASSED [ 28%]

tests/integration/service_test.py::ServiceTest::test_devices PASSED      [ 28%]

tests/integration/service_test.py::ServiceTest::test_dns_list PASSED     [ 28%]

tests/integration/service_test.py::ServiceTest::test_dns_no_value PASSED [ 28%]

tests/integration/service_test.py::ServiceTest::test_dns_opt_value PASSED [ 28%]

tests/integration/service_test.py::ServiceTest::test_dns_search PASSED   [ 28%]

tests/integration/service_test.py::ServiceTest::test_duplicate_containers PASSED [ 28%]

tests/integration/service_test.py::ServiceTest::test_duplicate_volume_trailing_slash PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_empty_labels PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_env_from_file_combined_with_env PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_anonymous_volume_recreate_then_renew PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_anonymous_volume_renew PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_image_with_volume_is_removed PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_change_mount_target PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_twice PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_twice_with_mount PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_containers_are_stopped PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_host_volume_is_removed PASSED [ 29%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_image_volume_masks_config PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_with_image_declared_volume PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_with_image_declared_volume_renew PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_without_start PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_expose_does_not_publish_ports PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_group_add_value PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_labels PASSED       [ 30%]

tests/integration/service_test.py::ServiceTest::test_log_drive_empty_default_jsonfile PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_log_drive_invalid SKIPPED [ 30%]

tests/integration/service_test.py::ServiceTest::test_log_drive_none PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_mem_reservation PASSED [ 30%]

tests/integration/service_test.py::ServiceTest::test_mem_swappiness PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_network_mode_bridged PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_network_mode_host PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_network_mode_none PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_oom_score_adj_value PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_pid_mode_host PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_pid_mode_none_defined PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_port_with_explicit_interface PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_project_is_added_to_container_name PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_recreate_preserves_volume_with_trailing_slash PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_recreate_volume_to_mount PASSED [ 31%]

tests/integration/service_test.py::ServiceTest::test_resolve_env PASSED  [ 31%]

tests/integration/service_test.py::ServiceTest::test_restart_always_value PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_restart_on_failure_value PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale PASSED        [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale_sets_ports PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale_with_api_error PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale_with_custom_container_name_outputs_warning PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale_with_desired_number_already_achieved PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale_with_immediate_exit PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale_with_stopped_containers PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale_with_stopped_containers_and_needing_creation PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_scale_with_unexpected_exception PASSED [ 32%]

tests/integration/service_test.py::ServiceTest::test_split_env PASSED    [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_becomes_privileged PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_builds_images PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_creates_fixed_external_ports PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_creates_fixed_external_ports_when_it_is_different_to_internal_port PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_creates_links <- tests/integration/testcases.py PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_creates_links_with_names <- tests/integration/testcases.py PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_creates_port_with_explicit_protocol PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_creates_ports PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_inherits_options_from_constructor PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_passes_through_options PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_stays_unprivileged PASSED [ 33%]

tests/integration/service_test.py::ServiceTest::test_start_container_uses_tagged_image_if_it_exists PASSED [ 34%]

tests/integration/service_test.py::ServiceTest::test_start_container_with_external_links <- tests/integration/testcases.py PASSED [ 34%]

tests/integration/service_test.py::ServiceTest::test_start_normal_container_does_not_create_links_to_its_own_service <- tests/integration/testcases.py PASSED [ 34%]

tests/integration/service_test.py::ServiceTest::test_start_one_off_container_creates_links_to_its_own_service <- tests/integration/testcases.py PASSED [ 34%]

tests/integration/service_test.py::ServiceTest::test_stop_signal PASSED  [ 34%]

tests/integration/service_test.py::ServiceTest::test_tmpfs PASSED        [ 34%]

tests/integration/service_test.py::ServiceTest::test_up_build_cli PASSED [ 34%]

tests/integration/service_test.py::ServiceTest::test_userns_mode_host PASSED [ 34%]

tests/integration/service_test.py::ServiceTest::test_userns_mode_none_defined PASSED [ 34%]

tests/integration/service_test.py::ServiceTest::test_with_high_enough_api_version_we_get_default_network_mode PASSED [ 34%]

tests/integration/service_test.py::ServiceTest::test_working_dir_param PASSED [ 34%]

tests/integration/service_test.py::ConfigHashTest::test_config_hash_sticks_around PASSED [ 35%]

tests/integration/service_test.py::ConfigHashTest::test_config_hash_with_custom_labels PASSED [ 35%]

tests/integration/service_test.py::ConfigHashTest::test_no_config_hash_when_one_off PASSED [ 35%]

tests/integration/service_test.py::ConfigHashTest::test_no_config_hash_when_overriding_options PASSED [ 35%]

tests/integration/state_test.py::BasicProjectTest::test_all_change PASSED [ 35%]

tests/integration/state_test.py::BasicProjectTest::test_no_change PASSED [ 35%]

tests/integration/state_test.py::BasicProjectTest::test_partial_change PASSED [ 35%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_leaf PASSED [ 35%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_middle PASSED [ 35%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_middle_always_recreate_deps PASSED [ 35%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root PASSED [ 35%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root_always_recreate_deps PASSED [ 35%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root_no_recreate PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_service_recreated_when_dependency_created PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_service_removed_while_down PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependenciesTest::test_up PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_leaf PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_middle PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_middle_always_recreate_deps PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root_always_recreate_deps PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root_no_recreate PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_dependency_added PASSED [ 36%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_dependency_removed PASSED [ 37%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_service_removed_while_down PASSED [ 37%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_service_removed_while_up PASSED [ 37%]

tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_up PASSED [ 37%]

tests/integration/state_test.py::ServiceStateTest::test_image_changed_to_build PASSED [ 37%]

tests/integration/state_test.py::ServiceStateTest::test_trigger_create PASSED [ 37%]

tests/integration/state_test.py::ServiceStateTest::test_trigger_noop PASSED [ 37%]

tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_build <- tests/integration/testcases.py PASSED [ 37%]

tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_config_change PASSED [ 37%]

tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_image_change PASSED [ 37%]

tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_nonexistent_image_tag PASSED [ 37%]

tests/integration/state_test.py::ServiceStateTest::test_trigger_start PASSED [ 37%]

tests/integration/volume_test.py::VolumeTest::test_create_volume PASSED  [ 38%]

tests/integration/volume_test.py::VolumeTest::test_create_volume_custom_name PASSED [ 38%]

tests/integration/volume_test.py::VolumeTest::test_exists <- tests/integration/testcases.py PASSED [ 38%]

tests/integration/volume_test.py::VolumeTest::test_exists_external <- tests/integration/testcases.py PASSED [ 38%]

tests/integration/volume_test.py::VolumeTest::test_exists_external_aliased <- tests/integration/testcases.py PASSED [ 38%]

tests/integration/volume_test.py::VolumeTest::test_external_aliased_volume <- tests/integration/testcases.py PASSED [ 38%]

tests/integration/volume_test.py::VolumeTest::test_external_volume <- tests/integration/testcases.py PASSED [ 38%]

tests/integration/volume_test.py::VolumeTest::test_inspect_volume <- tests/integration/testcases.py PASSED [ 38%]

tests/integration/volume_test.py::VolumeTest::test_recreate_existing_volume PASSED [ 38%]

tests/integration/volume_test.py::VolumeTest::test_remove_volume <- tests/integration/testcases.py PASSED [ 38%]

tests/integration/volume_test.py::VolumeTest::test_volume_default_labels <- tests/integration/testcases.py PASSED [ 38%]

tests/unit/bundle_test.py::test_get_image_digest_exists PASSED           [ 39%]

tests/unit/bundle_test.py::test_get_image_digest_image_uses_digest PASSED [ 39%]

tests/unit/bundle_test.py::test_get_image_digest_from_repository PASSED  [ 39%]

tests/unit/bundle_test.py::test_get_image_digest_no_image PASSED         [ 39%]

tests/unit/bundle_test.py::test_push_image_with_saved_digest PASSED      [ 39%]

tests/unit/bundle_test.py::test_push_image PASSED                        [ 39%]

tests/unit/bundle_test.py::test_to_bundle PASSED                         [ 39%]

tests/unit/bundle_test.py::test_convert_service_to_bundle PASSED         [ 39%]

tests/unit/bundle_test.py::test_set_command_and_args_none PASSED         [ 39%]

tests/unit/bundle_test.py::test_set_command_and_args_from_command PASSED [ 39%]

tests/unit/bundle_test.py::test_set_command_and_args_from_entrypoint PASSED [ 39%]

tests/unit/bundle_test.py::test_set_command_and_args_from_both PASSED    [ 39%]

tests/unit/bundle_test.py::test_make_service_networks_default PASSED     [ 40%]

tests/unit/bundle_test.py::test_make_service_networks PASSED             [ 40%]

tests/unit/bundle_test.py::test_make_port_specs PASSED                   [ 40%]

tests/unit/bundle_test.py::test_make_port_spec_with_protocol PASSED      [ 40%]

tests/unit/bundle_test.py::test_make_port_spec_default_protocol PASSED   [ 40%]

tests/unit/cli_test.py::CLITestCase::test_command_help PASSED            [ 40%]

tests/unit/cli_test.py::CLITestCase::test_command_help_nonexistent PASSED [ 40%]

tests/unit/cli_test.py::CLITestCase::test_command_manual_and_service_ports_together PASSED [ 40%]

tests/unit/cli_test.py::CLITestCase::test_default_project_name PASSED    [ 40%]

tests/unit/cli_test.py::CLITestCase::test_get_project PASSED             [ 40%]

tests/unit/cli_test.py::CLITestCase::test_project_name_from_environment_new_var PASSED [ 40%]

tests/unit/cli_test.py::CLITestCase::test_project_name_with_empty_environment_var PASSED [ 41%]

tests/unit/cli_test.py::CLITestCase::test_project_name_with_environment_file PASSED [ 41%]

tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_base_dir PASSED [ 41%]

tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_project_name PASSED [ 41%]

tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_uppercase_base_dir PASSED [ 41%]

tests/unit/cli_test.py::CLITestCase::test_run_interactive_passes_logs_false PASSED [ 41%]

tests/unit/cli_test.py::CLITestCase::test_run_service_with_restart_always PASSED [ 41%]

tests/unit/container_test.py::ContainerTest::test_environment PASSED     [ 41%]

tests/unit/container_test.py::ContainerTest::test_from_ps PASSED         [ 41%]

tests/unit/container_test.py::ContainerTest::test_from_ps_prefixed PASSED [ 41%]

tests/unit/container_test.py::ContainerTest::test_get PASSED             [ 41%]

tests/unit/container_test.py::ContainerTest::test_get_local_port PASSED  [ 41%]

tests/unit/container_test.py::ContainerTest::test_has_api_logs PASSED    [ 42%]

tests/unit/container_test.py::ContainerTest::test_human_readable_ports_none PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_human_readable_ports_public_and_private PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_human_readable_states_healthy PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_human_readable_states_no_health PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_human_readable_states_starting PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_inspect_if_not_inspected PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_name PASSED            [ 42%]

tests/unit/container_test.py::ContainerTest::test_name_without_project PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_name_without_project_custom_container_name PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_name_without_project_one_off PASSED [ 42%]

tests/unit/container_test.py::ContainerTest::test_number PASSED          [ 43%]

tests/unit/container_test.py::ContainerTest::test_short_id PASSED        [ 43%]

tests/unit/container_test.py::GetContainerNameTestCase::test_get_container_name PASSED [ 43%]

tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_driver_mismatch PASSED [ 43%]

tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_null_remote PASSED [ 43%]

tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_null_remote_ipam_options PASSED [ 43%]

tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_options_mismatch PASSED [ 43%]

tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_success PASSED [ 43%]

tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_whitelist PASSED [ 43%]

tests/unit/network_test.py::NetworkTest::test_check_remote_network_labels_mismatch PASSED [ 43%]

tests/unit/network_test.py::NetworkTest::test_remote_config_labels_none PASSED [ 43%]

tests/unit/parallel_test.py::ParallelTest::test_parallel_execute PASSED  [ 43%]

tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_deps PASSED [ 44%]

tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_global_limit PASSED [ 44%]

tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_limit PASSED [ 44%]

tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_upstream_errors PASSED [ 44%]

tests/unit/parallel_test.py::test_parallel_execute_alignment PASSED      [ 44%]

tests/unit/parallel_test.py::test_parallel_execute_ansi PASSED           [ 44%]

tests/unit/parallel_test.py::test_parallel_execute_noansi PASSED         [ 44%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_get_digest_from_pull PASSED [ 44%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_get_digest_from_push PASSED [ 44%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_mismatched_encoding_stream_write PASSED [ 44%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output PASSED [ 44%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_div_zero PASSED [ 45%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_no_progress_event_no_tty PASSED [ 45%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_null_total PASSED [ 45%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_progress_event_no_tty PASSED [ 45%]

tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_progress_event_tty PASSED [ 45%]

tests/unit/project_test.py::ProjectTest::test_avoid_multiple_push PASSED [ 45%]

tests/unit/project_test.py::ProjectTest::test_build_container_operation_with_timeout_func_does_not_mutate_options_with_timeout PASSED [ 45%]

tests/unit/project_test.py::ProjectTest::test_container_without_name PASSED [ 45%]

tests/unit/project_test.py::ProjectTest::test_down_with_no_resources PASSED [ 45%]

tests/unit/project_test.py::ProjectTest::test_error_parallel_pull PASSED [ 45%]

tests/unit/project_test.py::ProjectTest::test_events PASSED              [ 45%]

tests/unit/project_test.py::ProjectTest::test_events_legacy PASSED       [ 45%]

tests/unit/project_test.py::ProjectTest::test_from_config_v1 PASSED      [ 46%]

tests/unit/project_test.py::ProjectTest::test_from_config_v2 PASSED      [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_secrets_external_warning PASSED [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_secrets_no_secret_def PASSED [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_secrets_secret_file_warning PASSED [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_secrets_uid_gid_mode_warning PASSED [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_service PASSED         [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_services_removes_duplicates_following_links PASSED [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_services_returns_all_services_without_args PASSED [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_services_returns_listed_services_with_args PASSED [ 46%]

tests/unit/project_test.py::ProjectTest::test_get_services_with_include_links PASSED [ 46%]

tests/unit/project_test.py::ProjectTest::test_net_unset PASSED           [ 47%]

tests/unit/project_test.py::ProjectTest::test_no_such_service_unicode PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_no_warning_in_normal_mode PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_no_warning_on_stop PASSED  [ 47%]

tests/unit/project_test.py::ProjectTest::test_no_warning_with_no_swarm_info PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_project_platform_value PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_use_net_from_container PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_use_net_from_service PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_use_volumes_from_container PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_use_volumes_from_service_container PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_use_volumes_from_service_no_container PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_uses_default_network_false PASSED [ 47%]

tests/unit/project_test.py::ProjectTest::test_uses_default_network_true PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_build_does_not_pull PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_build_isolation_from_build_override_service_config PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_build_service_with_proxy_config PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_build_volume_options_duplicate_binds PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_build_with_default_platform PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_build_with_isolation_from_service_config PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_build_with_override_build_args PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_build_with_platform PASSED [ 48%]

tests/unit/service_test.py::ServiceTest::test_cgroup_parent PASSED       [ 48%]

tests/unit/service_test.py::ServiceTest::test_config_dict PASSED         [ 48%]

tests/unit/service_test.py::ServiceTest::test_config_dict_with_network_mode_from_container PASSED [ 49%]

tests/unit/service_test.py::ServiceTest::test_config_hash_matches_label PASSED [ 49%]

tests/unit/service_test.py::ServiceTest::test_container_without_name PASSED [ 49%]

tests/unit/service_test.py::ServiceTest::test_containers PASSED          [ 49%]

tests/unit/service_test.py::ServiceTest::test_containers_with_containers PASSED [ 49%]

tests/unit/service_test.py::ServiceTest::test_create_container PASSED    [ 49%]

tests/unit/service_test.py::ServiceTest::test_create_when_removed_containers_are_listed PASSED [ 49%]

tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_force_build PASSED [ 49%]

tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_no_build PASSED [ 49%]

tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_no_build_but_needs_build PASSED [ 49%]

tests/unit/service_test.py::ServiceTest::test_get_container PASSED       [ 49%]

tests/unit/service_test.py::ServiceTest::test_get_container_create_options_does_not_mutate_options PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_container_create_options_no_affinity_without_binds PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_container_create_options_sets_affinity_with_binds PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_container_create_options_with_name_option PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_container_not_found PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_create_options_with_proxy_config PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_volumes_from_container PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_volumes_from_container_read_only PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_container_exists PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_container_exists_with_flags PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_no_container PASSED [ 50%]

tests/unit/service_test.py::ServiceTest::test_image_name_default PASSED  [ 50%]

tests/unit/service_test.py::ServiceTest::test_image_name_from_config PASSED [ 51%]

tests/unit/service_test.py::ServiceTest::test_log_opt PASSED             [ 51%]

tests/unit/service_test.py::ServiceTest::test_mem_reservation PASSED     [ 51%]

tests/unit/service_test.py::ServiceTest::test_memory_swap_limit PASSED   [ 51%]

tests/unit/service_test.py::ServiceTest::test_no_default_hostname_when_not_using_networking PASSED [ 51%]

tests/unit/service_test.py::ServiceTest::test_only_log_warning_when_host_ports_clash PASSED [ 51%]

tests/unit/service_test.py::ServiceTest::test_parse_proxy_config PASSED  [ 51%]

tests/unit/service_test.py::ServiceTest::test_parse_proxy_config_per_host PASSED [ 51%]

tests/unit/service_test.py::ServiceTest::test_parse_repository_tag PASSED [ 51%]

tests/unit/service_test.py::ServiceTest::test_pull_image PASSED          [ 51%]

tests/unit/service_test.py::ServiceTest::test_pull_image_digest PASSED   [ 51%]

tests/unit/service_test.py::ServiceTest::test_pull_image_no_tag PASSED   [ 52%]

tests/unit/service_test.py::ServiceTest::test_pull_image_with_default_platform PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_pull_image_with_platform PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_pull_image_with_platform_unsupported_api PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_recreate_container PASSED  [ 52%]

tests/unit/service_test.py::ServiceTest::test_recreate_container_with_timeout PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_remove_image_all_does_remove PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_remove_image_local_with_image_name_doesnt_remove PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_remove_image_local_without_image_name_does_remove PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_remove_image_none PASSED   [ 52%]

tests/unit/service_test.py::ServiceTest::test_remove_image_with_error PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_remove_non_existing_image PASSED [ 52%]

tests/unit/service_test.py::ServiceTest::test_self_reference_external_link PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_service_ignore_default_platform_with_unsupported_api PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_service_platform_precedence PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_container_port PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_container_port_range PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_and_port PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_and_port_range PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_no_port PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_no_port_range PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_port PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_port_range PASSED [ 53%]

tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_no_ports PASSED [ 54%]

tests/unit/service_test.py::ServiceTest::test_split_domainname_both PASSED [ 54%]

tests/unit/service_test.py::ServiceTest::test_split_domainname_fqdn PASSED [ 54%]

tests/unit/service_test.py::ServiceTest::test_split_domainname_none PASSED [ 54%]

tests/unit/service_test.py::ServiceTest::test_split_domainname_weird PASSED [ 54%]

tests/unit/service_test.py::ServiceTest::test_stop_grace_period PASSED   [ 54%]

tests/unit/service_test.py::ServiceTest::test_volumes_order_is_preserved PASSED [ 54%]

tests/unit/service_test.py::TestServiceNetwork::test_connect_container_to_networks_short_aliase_exists PASSED [ 54%]

tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_dict PASSED [ 54%]

tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_integers_and_dicts PASSED [ 54%]

tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_ints PASSED [ 54%]

tests/unit/service_test.py::NetTestCase::test_network_mode PASSED        [ 54%]

tests/unit/service_test.py::NetTestCase::test_network_mode_container PASSED [ 55%]

tests/unit/service_test.py::NetTestCase::test_network_mode_service PASSED [ 55%]

tests/unit/service_test.py::NetTestCase::test_network_mode_service_no_containers PASSED [ 55%]

tests/unit/service_test.py::ServicePortsTest::test_formatted_ports PASSED [ 55%]

tests/unit/service_test.py::ServiceVolumesTest::test_build_volume_binding PASSED [ 55%]

tests/unit/service_test.py::ServiceVolumesTest::test_create_with_special_volume_mode PASSED [ 55%]

tests/unit/service_test.py::ServiceVolumesTest::test_get_container_create_options_with_different_host_path_in_container_json PASSED [ 55%]

tests/unit/service_test.py::ServiceVolumesTest::test_get_container_data_volumes PASSED [ 55%]

tests/unit/service_test.py::ServiceVolumesTest::test_merge_volume_bindings PASSED [ 55%]

tests/unit/service_test.py::ServiceVolumesTest::test_mount_same_host_path_to_two_volumes PASSED [ 55%]

tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_no_warning_with_container_only_option PASSED [ 55%]

tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_no_warning_with_same_path PASSED [ 56%]

tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_volume_no_warning_when_no_container_volumes PASSED [ 56%]

tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_volume_when_masked PASSED [ 56%]

tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes PASSED [ 56%]

tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes_abspath PASSED [ 56%]

tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes_no_target PASSED [ 56%]

tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_unix_path PASSED [ 56%]

tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_url_no_prefix PASSED [ 56%]

tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_windows_path PASSED [ 56%]

tests/unit/split_buffer_test.py::SplitBufferTest::test_chunked_line PASSED [ 56%]

tests/unit/split_buffer_test.py::SplitBufferTest::test_multiple_line_chunk PASSED [ 56%]

tests/unit/split_buffer_test.py::SplitBufferTest::test_no_end_separator PASSED [ 56%]

tests/unit/split_buffer_test.py::SplitBufferTest::test_preserves_unicode_sequences_within_lines PASSED [ 57%]

tests/unit/split_buffer_test.py::SplitBufferTest::test_single_line_chunks PASSED [ 57%]

tests/unit/timeparse_test.py::test_milli PASSED                          [ 57%]

tests/unit/timeparse_test.py::test_milli_float PASSED                    [ 57%]

tests/unit/timeparse_test.py::test_second_milli PASSED                   [ 57%]

tests/unit/timeparse_test.py::test_second_milli_micro PASSED             [ 57%]

tests/unit/timeparse_test.py::test_second PASSED                         [ 57%]

tests/unit/timeparse_test.py::test_second_as_float PASSED                [ 57%]

tests/unit/timeparse_test.py::test_minute PASSED                         [ 57%]

tests/unit/timeparse_test.py::test_hour_minute PASSED                    [ 57%]

tests/unit/timeparse_test.py::test_minute_as_float PASSED                [ 57%]

tests/unit/timeparse_test.py::test_hour_minute_second PASSED             [ 58%]

tests/unit/timeparse_test.py::test_invalid_with_space PASSED             [ 58%]

tests/unit/timeparse_test.py::test_invalid_with_comma PASSED             [ 58%]

tests/unit/timeparse_test.py::test_invalid_with_empty_string PASSED      [ 58%]

tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_no_object PASSED [ 58%]

tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_with_object PASSED [ 58%]

tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_leading_whitespace PASSED [ 58%]

tests/unit/utils_test.py::TestStreamAsText::test_stream_with_non_utf_unicode_character PASSED [ 58%]

tests/unit/utils_test.py::TestStreamAsText::test_stream_with_utf_character PASSED [ 58%]

tests/unit/utils_test.py::TestJsonStream::test_with_falsy_entries PASSED [ 58%]

tests/unit/utils_test.py::TestJsonStream::test_with_leading_whitespace PASSED [ 58%]

tests/unit/utils_test.py::TestParseBytes::test_parse_bytes PASSED        [ 58%]

tests/unit/utils_test.py::TestMoreItertools::test_unique_everseen PASSED [ 59%]

tests/unit/volume_test.py::TestVolume::test_remove_local_volume PASSED   [ 59%]

tests/unit/volume_test.py::TestVolume::test_remove_external_volume PASSED [ 59%]

tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_path_from_options PASSED [ 59%]

tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_single_path_from_env PASSED [ 59%]

tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env PASSED [ 59%]

tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env_windows SKIPPED [ 59%]

tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env_custom_separator PASSED [ 59%]

tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_no_path PASSED [ 59%]

tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_unicode_path_from_options PASSED [ 59%]

tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_unicode_path_from_env PASSED [ 59%]

tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_custom_timeout_error PASSED [ 60%]

tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_docker_client_no_home PASSED [ 60%]

tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_docker_client_with_custom_timeout PASSED [ 60%]

tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_user_agent PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_assert_hostname_explicit_skip PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_simple_tls PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_ca_cert PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_ca_cert_explicit PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca_explicit PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca_quoted_paths PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_cert PASSED [ 60%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_cert_explicit PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_missing_key PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_flags_override_environment PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_mixed_environment_and_flags PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_simple_with_tls_version PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_default_cert_path PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_env_falsy_value PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_flag_no_override PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_default PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_upgrade PASSED [ 61%]

tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_unavailable PASSED [ 61%]

tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_generic_connection_error PASSED [ 62%]

tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_mismatch PASSED [ 62%]

tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_mismatch_unicode_explanation PASSED [ 62%]

tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_other PASSED [ 62%]

tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_other_unicode_explanation PASSED [ 62%]

tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_no_data SKIPPED [ 62%]

tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_misc SKIPPED [ 62%]

tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_encoding_issue SKIPPED [ 62%]

tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_error PASSED [ 62%]

tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_info PASSED [ 62%]

tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_error PASSED [ 62%]

tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_info PASSED [ 62%]

tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_warn PASSED [ 63%]

tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_warn PASSED [ 63%]

tests/unit/cli/log_printer_test.py::TestLogPresenter::test_monochrome PASSED [ 63%]

tests/unit/cli/log_printer_test.py::TestLogPresenter::test_polychrome PASSED [ 63%]

tests/unit/cli/log_printer_test.py::test_wait_on_exit PASSED             [ 63%]

tests/unit/cli/log_printer_test.py::test_wait_on_exit_raises PASSED      [ 63%]

tests/unit/cli/log_printer_test.py::test_build_no_log_generator PASSED   [ 63%]

tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_no_log_stream PASSED [ 63%]

tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_with_log_stream PASSED [ 63%]

tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_unicode PASSED [ 63%]

tests/unit/cli/log_printer_test.py::TestWatchEvents::test_stop_event PASSED [ 63%]

tests/unit/cli/log_printer_test.py::TestWatchEvents::test_start_event PASSED [ 64%]

tests/unit/cli/log_printer_test.py::TestWatchEvents::test_container_attach_event PASSED [ 64%]

tests/unit/cli/log_printer_test.py::TestWatchEvents::test_other_event PASSED [ 64%]

tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_an_exception PASSED [ 64%]

tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_stop_without_cascade_stop PASSED [ 64%]

tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_stop_with_cascade_stop PASSED [ 64%]

tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_none_when_timeout_is_hit PASSED [ 64%]

tests/unit/cli/main_test.py::TestCLIMainTestCase::test_filter_containers_to_service_names PASSED [ 64%]

tests/unit/cli/main_test.py::TestCLIMainTestCase::test_filter_containers_to_service_names_all PASSED [ 64%]

tests/unit/cli/main_test.py::TestCLIMainTestCase::test_warning_in_swarm_mode PASSED [ 64%]

tests/unit/cli/main_test.py::TestCLIMainTestCase::test_build_one_off_container_options PASSED [ 64%]

tests/unit/cli/main_test.py::TestCLIMainTestCase::test_get_docker_start_call PASSED [ 64%]

tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_tty_verbose PASSED [ 65%]

tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_tty_not_verbose PASSED [ 65%]

tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_not_a_tty PASSED [ 65%]

tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_invalid_opts PASSED [ 65%]

tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_always PASSED [ 65%]

tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_never PASSED [ 65%]

tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_changed PASSED [ 65%]

tests/unit/cli/main_test.py::TestCallDocker::test_simple_no_options PASSED [ 65%]

tests/unit/cli/main_test.py::TestCallDocker::test_simple_tls_option PASSED [ 65%]

tests/unit/cli/main_test.py::TestCallDocker::test_advanced_tls_options PASSED [ 65%]

tests/unit/cli/main_test.py::TestCallDocker::test_with_host_option PASSED [ 65%]

tests/unit/cli/main_test.py::TestCallDocker::test_with_http_host PASSED  [ 66%]

tests/unit/cli/main_test.py::TestCallDocker::test_with_host_option_shorthand_equal PASSED [ 66%]

tests/unit/cli/main_test.py::TestCallDocker::test_with_env PASSED        [ 66%]

tests/unit/cli/utils_test.py::UnquotePathTest::test_nested_quotes PASSED [ 66%]

tests/unit/cli/utils_test.py::UnquotePathTest::test_no_quotes PASSED     [ 66%]

tests/unit/cli/utils_test.py::UnquotePathTest::test_simple_quotes PASSED [ 66%]

tests/unit/cli/utils_test.py::UnquotePathTest::test_uneven_quotes PASSED [ 66%]

tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_100b PASSED [ 66%]

tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_1023b PASSED [ 66%]

tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_1kb PASSED [ 66%]

tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_999b PASSED [ 66%]

tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_units PASSED [ 66%]

tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_call PASSED [ 67%]

tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return PASSED [ 67%]

tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return_no_result PASSED [ 67%]

tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return_sequence PASSED [ 67%]

tests/unit/config/config_test.py::ConfigTest::test_build_args_allow_empty_properties PASSED [ 67%]

tests/unit/config/config_test.py::ConfigTest::test_build_args_check_zero_preserved PASSED [ 67%]

tests/unit/config/config_test.py::ConfigTest::test_config_build_configuration PASSED [ 67%]

tests/unit/config/config_test.py::ConfigTest::test_config_build_configuration_v2 PASSED [ 67%]

tests/unit/config/config_test.py::ConfigTest::test_config_convertible_label_types PASSED [ 67%]

tests/unit/config/config_test.py::ConfigTest::test_config_duplicate_cache_from_values_validation_error PASSED [ 67%]

tests/unit/config/config_test.py::ConfigTest::test_config_duplicate_mount_points PASSED [ 67%]

tests/unit/config/config_test.py::ConfigTest::test_config_extra_hosts_list_of_dicts_validation_error PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_extra_hosts_string_raises_validation_error PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_hint PASSED    [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error_v2 PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error_v2_when_no_interpolate PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_property_raise_validation_error PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_invalid_ipam_config PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_invalid_label_types PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_invalid_service_name_raise_validation_error PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_invalid_keys_validation_error PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_required_keys_validation_error PASSED [ 68%]

tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_soft_greater_than_hard_error PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_config_valid_environment_dict_key_contains_dashes PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_config_valid_ipam_config PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_config_valid_service_label_validation PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_config_valid_service_names PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_depends_on_orders_services PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_depends_on_unknown_service_errors PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_dns_opt_option PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_empty_environment_key_allowed PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_external_volume_config PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_external_volume_invalid_config PASSED [ 69%]

tests/unit/config/config_test.py::ConfigTest::test_group_add_option PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_invalid_config_build_and_image_specified_v1 PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_invalid_config_not_a_dictionary PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_invalid_config_not_unique_items PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_invalid_config_type_should_be_an_array PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_invalid_config_v1 PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_invalid_config_v2 PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_invalid_list_of_strings_format PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_isolation_option PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_linked_service_is_undefined PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_load PASSED           [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_load_bind_mount_relative_path PASSED [ 70%]

tests/unit/config/config_test.py::ConfigTest::test_load_bind_mount_relative_path_with_tilde PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_build_labels_dict PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_build_labels_list PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_config_custom_resource_names PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_config_dockerfile_without_build_raises_error_v1 PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_config_invalid_service_names PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_config_invalid_service_names_v2 PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_config_link_local_ips_network PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_config_service_labels PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_config_volume_and_network_labels PASSED [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_configs PASSED   [ 71%]

tests/unit/config/config_test.py::ConfigTest::test_load_configs_multi_file PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_dockerfile_without_context PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_errors_on_uppercase_with_no_image PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_invalid_service_definition PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_mixed_extends_resolution PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_secrets PASSED   [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_secrets_multi_file PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_service_with_name_version PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_sorts_in_dependency_order PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_when_not_dict PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_when_not_dict_v2 PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_with_invalid_network_fields PASSED [ 72%]

tests/unit/config/config_test.py::ConfigTest::test_load_v2 PASSED        [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_buildargs PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_empty_build_args PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_extensions PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_invalid_field_name PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_invalid_field_name_v1 PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_base PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_base_v2 PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_override PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_override_v2 PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_extends_in_override_file PASSED [ 73%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_invalid_override PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_mismatched_networks_format PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_mismatched_networks_format_inverse_order PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v1 PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v2 PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v3_2 PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_load_yaml_with_bom PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_load_yaml_with_yaml_error PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_logs_warning_for_boolean_in_environment PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_merge_blkio_config PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_merge_configs_override PASSED [ 74%]

tests/unit/config/config_test.py::ConfigTest::test_merge_credential_spec PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_depends_on_mixed_syntax PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_depends_on_no_override PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_deploy PASSED   [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_deploy_override PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_device_cgroup_rules PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_different_configs PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_different_secrets PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_extra_hosts PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_config PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_override_disables PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_override_enables PASSED [ 75%]

tests/unit/config/config_test.py::ConfigTest::test_merge_isolation PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v1 PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2 PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_base PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_base_driver PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_drivers PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_override PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_override_options PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_override_driver PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_mixed_ports PASSED [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_pid PASSED      [ 76%]

tests/unit/config/config_test.py::ConfigTest::test_merge_scale PASSED    [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_merge_secrets_override PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_from_files_with_extends_in_base PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_from_files_with_extends_in_override PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous_2 PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous_volumes PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_ports_sorting PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_merge_storage_opt PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_named_volume_config_empty PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_named_volume_invalid_type_list PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_named_volume_numeric_driver_opt PASSED [ 77%]

tests/unit/config/config_test.py::ConfigTest::test_networks_invalid_type_list PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_normalize_dns_options PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_oom_score_adj_option PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_runtime_option PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_service_volume_invalid_config PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_swappiness_option PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_tmpfs_option PASSED   [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_undeclared_volume_v1 PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_undeclared_volume_v2 PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_unsupported_version PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_v1_file_version PASSED [ 78%]

tests/unit/config/config_test.py::ConfigTest::test_v1_file_with_version_is_invalid PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_valid_config_oneof_string_or_list PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_valid_config_which_allows_two_type_definitions PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_valid_versions PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_validate_extra_hosts_invalid PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_validate_extra_hosts_invalid_list PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_version_1_is_invalid PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_volume_invalid_driver_opt PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_volume_mode_override PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_volumes_long_syntax PASSED [ 79%]

tests/unit/config/config_test.py::ConfigTest::test_wrong_version_type PASSED [ 79%]

tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_container PASSED [ 79%]

tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_container_v1 PASSED [ 80%]

tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_plus_networks_is_invalid PASSED [ 80%]

tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service PASSED [ 80%]

tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service_nonexistent PASSED [ 80%]

tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service_v1 PASSED [ 80%]

tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_standard PASSED [ 80%]

tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_standard_v1 PASSED [ 80%]

tests/unit/config/config_test.py::PortsTest::test_config_invalid_expose_format_validation PASSED [ 80%]

tests/unit/config/config_test.py::PortsTest::test_config_invalid_expose_type_validation PASSED [ 80%]

tests/unit/config/config_test.py::PortsTest::test_config_invalid_ports_format_validation PASSED [ 80%]

tests/unit/config/config_test.py::PortsTest::test_config_invalid_ports_type_validation PASSED [ 80%]

tests/unit/config/config_test.py::PortsTest::test_config_non_unique_expose_validation PASSED [ 81%]

tests/unit/config/config_test.py::PortsTest::test_config_non_unique_ports_validation PASSED [ 81%]

tests/unit/config/config_test.py::PortsTest::test_config_valid_expose_format_validation PASSED [ 81%]

tests/unit/config/config_test.py::PortsTest::test_config_valid_ports_format_validation PASSED [ 81%]

tests/unit/config/config_test.py::SubnetTest::test_config_invalid_subnet_format_validation PASSED [ 81%]

tests/unit/config/config_test.py::SubnetTest::test_config_invalid_subnet_type_validation PASSED [ 81%]

tests/unit/config/config_test.py::SubnetTest::test_config_valid_subnet_format_validation PASSED [ 81%]

tests/unit/config/config_test.py::InterpolationTest::test_compatibility_mode_load PASSED [ 81%]

tests/unit/config/config_test.py::InterpolationTest::test_compatibility_mode_warnings PASSED [ 81%]

tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_file PASSED [ 81%]

tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_variable PASSED [ 81%]

tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_variable_with_defaults PASSED [ 81%]

tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_options_environment_file PASSED [ 82%]

tests/unit/config/config_test.py::InterpolationTest::test_interpolation_configs_section PASSED [ 82%]

tests/unit/config/config_test.py::InterpolationTest::test_interpolation_secrets_section PASSED [ 82%]

tests/unit/config/config_test.py::InterpolationTest::test_invalid_interpolation PASSED [ 82%]

tests/unit/config/config_test.py::InterpolationTest::test_unset_variable_produces_warning PASSED [ 82%]

tests/unit/config/config_test.py::VolumeConfigTest::test_absolute_posix_path_does_not_expand PASSED [ 82%]

tests/unit/config/config_test.py::VolumeConfigTest::test_absolute_windows_path_does_not_expand PASSED [ 82%]

tests/unit/config/config_test.py::VolumeConfigTest::test_home_directory_with_driver_does_not_expand PASSED [ 82%]

tests/unit/config/config_test.py::VolumeConfigTest::test_name_does_not_expand PASSED [ 82%]

tests/unit/config/config_test.py::VolumeConfigTest::test_no_binding PASSED [ 82%]

tests/unit/config/config_test.py::VolumeConfigTest::test_relative_path_does_expand_posix PASSED [ 82%]

tests/unit/config/config_test.py::VolumeConfigTest::test_relative_path_does_expand_windows SKIPPED [ 83%]

tests/unit/config/config_test.py::VolumeConfigTest::test_volume_binding_with_environment_variable PASSED [ 83%]

tests/unit/config/config_test.py::VolumeConfigTest::test_volume_binding_with_home PASSED [ 83%]

tests/unit/config/config_test.py::VolumeConfigTest::test_volume_path_with_non_ascii_directory PASSED [ 83%]

tests/unit/config/config_test.py::VolumeConfigTest::test_volumes_order_is_preserved PASSED [ 83%]

tests/unit/config/config_test.py::MergeVolumesTest::test_add_explicit_path PASSED [ 83%]

tests/unit/config/config_test.py::MergeVolumesTest::test_empty PASSED    [ 83%]

tests/unit/config/config_test.py::MergeVolumesTest::test_no_base PASSED  [ 83%]

tests/unit/config/config_test.py::MergeVolumesTest::test_no_override PASSED [ 83%]

tests/unit/config/config_test.py::MergeVolumesTest::test_override_explicit_path PASSED [ 83%]

tests/unit/config/config_test.py::MergeVolumesTest::test_remove_explicit_path PASSED [ 83%]

tests/unit/config/config_test.py::MergeDevicesTest::test_add_explicit_path PASSED [ 83%]

tests/unit/config/config_test.py::MergeDevicesTest::test_empty PASSED    [ 84%]

tests/unit/config/config_test.py::MergeDevicesTest::test_no_base PASSED  [ 84%]

tests/unit/config/config_test.py::MergeDevicesTest::test_no_override PASSED [ 84%]

tests/unit/config/config_test.py::MergeDevicesTest::test_override_explicit_path PASSED [ 84%]

tests/unit/config/config_test.py::MergeDevicesTest::test_remove_explicit_path PASSED [ 84%]

tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_no_override PASSED [ 84%]

tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_override_with_other PASSED [ 84%]

tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_override_with_same PASSED [ 84%]

tests/unit/config/config_test.py::MergePortsTest::test_add_item PASSED   [ 84%]

tests/unit/config/config_test.py::MergePortsTest::test_duplicate_port_mappings PASSED [ 84%]

tests/unit/config/config_test.py::MergePortsTest::test_empty PASSED      [ 84%]

tests/unit/config/config_test.py::MergePortsTest::test_no_base PASSED    [ 85%]

tests/unit/config/config_test.py::MergePortsTest::test_no_override PASSED [ 85%]

tests/unit/config/config_test.py::MergeNetworksTest::test_add_item PASSED [ 85%]

tests/unit/config/config_test.py::MergeNetworksTest::test_all_properties PASSED [ 85%]

tests/unit/config/config_test.py::MergeNetworksTest::test_empty PASSED   [ 85%]

tests/unit/config/config_test.py::MergeNetworksTest::test_network_has_none_value PASSED [ 85%]

tests/unit/config/config_test.py::MergeNetworksTest::test_no_base PASSED [ 85%]

tests/unit/config/config_test.py::MergeNetworksTest::test_no_network_name_overrides PASSED [ 85%]

tests/unit/config/config_test.py::MergeNetworksTest::test_no_network_overrides PASSED [ 85%]

tests/unit/config/config_test.py::MergeNetworksTest::test_no_override PASSED [ 85%]

tests/unit/config/config_test.py::MergeStringsOrListsTest::test_add_list PASSED [ 85%]

tests/unit/config/config_test.py::MergeStringsOrListsTest::test_add_string PASSED [ 85%]

tests/unit/config/config_test.py::MergeStringsOrListsTest::test_no_base PASSED [ 86%]

tests/unit/config/config_test.py::MergeStringsOrListsTest::test_no_override PASSED [ 86%]

tests/unit/config/config_test.py::MergeLabelsTest::test_add_explicit_value PASSED [ 86%]

tests/unit/config/config_test.py::MergeLabelsTest::test_empty PASSED     [ 86%]

tests/unit/config/config_test.py::MergeLabelsTest::test_no_base PASSED   [ 86%]

tests/unit/config/config_test.py::MergeLabelsTest::test_no_override PASSED [ 86%]

tests/unit/config/config_test.py::MergeLabelsTest::test_override_explicit_value PASSED [ 86%]

tests/unit/config/config_test.py::MergeLabelsTest::test_remove_explicit_value PASSED [ 86%]

tests/unit/config/config_test.py::MergeBuildTest::test_empty_base PASSED [ 86%]

tests/unit/config/config_test.py::MergeBuildTest::test_empty_override PASSED [ 86%]

tests/unit/config/config_test.py::MergeBuildTest::test_full PASSED       [ 86%]

tests/unit/config/config_test.py::MemoryOptionsTest::test_memswap_can_be_a_string PASSED [ 87%]

tests/unit/config/config_test.py::MemoryOptionsTest::test_validation_fails_with_just_memswap_limit PASSED [ 87%]

tests/unit/config/config_test.py::MemoryOptionsTest::test_validation_with_correct_memswap_values PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_environment_overrides_env_file PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_parse_environment_as_dict PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_parse_environment_as_list PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_parse_environment_empty PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_parse_environment_invalid PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_resolve_build_args PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_resolve_environment PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_resolve_environment_from_env_file PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_resolve_environment_from_env_file_with_empty_values PASSED [ 87%]

tests/unit/config/config_test.py::EnvTest::test_resolve_environment_nonexistent_file PASSED [ 88%]

tests/unit/config/config_test.py::EnvTest::test_resolve_environment_with_multiple_env_files PASSED [ 88%]

tests/unit/config/config_test.py::EnvTest::test_resolve_path PASSED      [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_circular PASSED      [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_invalid_config PASSED [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_valid_config PASSED [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_verbose_and_shorthand_way PASSED [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_extends PASSED       [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_file_defaults_to_self PASSED [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_same_file_optimization PASSED [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_empty_dictionary PASSED [ 88%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_invalid_key PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_missing_service_key PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_no_file_key_no_filename_set PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_sub_property_key PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_valid_config PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_with_defined_version_passes PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_with_depends_on PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_with_environment_and_env_files PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_with_healthcheck PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_with_mixed_versions_is_error PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_with_ports PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_extends_with_security_opt PASSED [ 89%]

tests/unit/config/config_test.py::ExtendsTest::test_invalid_links_in_extended_service PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_invalid_net_in_extended_service PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_invalid_volumes_from_in_extended_service PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_load_config_runs_interpolation_in_extended_service PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_load_throws_error_when_base_service_does_not_exist PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_merging_env_labels_ulimits PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_nested PASSED        [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_parent_build_path_dne PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_partial_service_config_in_extends_is_still_valid PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_self_referencing_file PASSED [ 90%]

tests/unit/config/config_test.py::ExtendsTest::test_volume_path PASSED   [ 90%]

tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_absolute PASSED [ 91%]

tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_normal PASSED [ 91%]

tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_with_tilde PASSED [ 91%]

tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_root_mount PASSED [ 91%]

tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_windows_path PASSED [ 91%]

tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_windows_path_in_container PASSED [ 91%]

tests/unit/config/config_test.py::BuildPathTest::test_absolute_path PASSED [ 91%]

tests/unit/config/config_test.py::BuildPathTest::test_from_file PASSED   [ 91%]

tests/unit/config/config_test.py::BuildPathTest::test_from_file_override_dir PASSED [ 91%]

tests/unit/config/config_test.py::BuildPathTest::test_invalid_url_in_build_path PASSED [ 91%]

tests/unit/config/config_test.py::BuildPathTest::test_nonexistent_path PASSED [ 91%]

tests/unit/config/config_test.py::BuildPathTest::test_relative_path PASSED [ 91%]

tests/unit/config/config_test.py::BuildPathTest::test_valid_url_in_build_path PASSED [ 92%]

tests/unit/config/config_test.py::HealthcheckTest::test_disable PASSED   [ 92%]

tests/unit/config/config_test.py::HealthcheckTest::test_disable_with_other_config_is_invalid PASSED [ 92%]

tests/unit/config/config_test.py::HealthcheckTest::test_healthcheck PASSED [ 92%]

tests/unit/config/config_test.py::HealthcheckTest::test_healthcheck_with_invalid_test PASSED [ 92%]

tests/unit/config/config_test.py::GetDefaultConfigFilesTestCase::test_get_config_path_default_file_in_basedir PASSED [ 92%]

tests/unit/config/config_test.py::GetDefaultConfigFilesTestCase::test_get_config_path_default_file_in_parent_dir PASSED [ 92%]

tests/unit/config/config_test.py::SerializeTest::test_denormalize_depends_on_v2_1 PASSED [ 92%]

tests/unit/config/config_test.py::SerializeTest::test_denormalize_depends_on_v3 PASSED [ 92%]

tests/unit/config/config_test.py::SerializeTest::test_denormalize_healthcheck PASSED [ 92%]

tests/unit/config/config_test.py::SerializeTest::test_denormalize_image_has_digest PASSED [ 92%]

tests/unit/config/config_test.py::SerializeTest::test_denormalize_image_no_digest PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_bool_string PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_configs PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_escape_dollar_sign PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_escape_dont_interpolate PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_external_false PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_ports PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_ports_with_ext_ip PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_secrets PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_time PASSED [ 93%]

tests/unit/config/config_test.py::SerializeTest::test_serialize_unicode_values PASSED [ 93%]

tests/unit/config/environment_test.py::EnvironmentTest::test_env_vars_from_file_bom PASSED [ 93%]

tests/unit/config/environment_test.py::EnvironmentTest::test_env_vars_from_file_whitespace PASSED [ 94%]

tests/unit/config/environment_test.py::EnvironmentTest::test_get_boolean PASSED [ 94%]

tests/unit/config/environment_test.py::EnvironmentTest::test_get_simple PASSED [ 94%]

tests/unit/config/environment_test.py::EnvironmentTest::test_get_undefined PASSED [ 94%]

tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_services PASSED [ 94%]

tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_volumes PASSED [ 94%]

tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_secrets PASSED [ 94%]

tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_v2 PASSED [ 94%]

tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_v3 PASSED [ 94%]

tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_invalid PASSED [ 94%]

tests/unit/config/interpolation_test.py::test_interpolate_environment_network_convert_types PASSED [ 94%]

tests/unit/config/interpolation_test.py::test_interpolate_environment_external_resource_convert_types PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_service_name_uses_dot PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_escaped_interpolation PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_invalid_interpolation PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_missing_no_default PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_with_value PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_missing_with_default PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_with_empty_and_default_value PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_mandatory_values PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_mandatory_no_err_msg PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_mixed_separators PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_unbraced_separators PASSED [ 95%]

tests/unit/config/interpolation_test.py::test_interpolate_unicode_values PASSED [ 96%]

tests/unit/config/interpolation_test.py::test_interpolate_no_fallthrough PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_1 PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_2 PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_3 PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_4 PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_5 PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_6 PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_7 PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports_2 PASSED [ 96%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports_3 PASSED [ 97%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_self_imports PASSED [ 97%]

tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_depends_on_self PASSED [ 97%]

tests/unit/config/types_test.py::test_parse_extra_hosts_list PASSED      [ 97%]

tests/unit/config/types_test.py::test_parse_extra_hosts_dict PASSED      [ 97%]

tests/unit/config/types_test.py::TestServicePort::test_parse_dict PASSED [ 97%]

tests/unit/config/types_test.py::TestServicePort::test_parse_simple_target_port PASSED [ 97%]

tests/unit/config/types_test.py::TestServicePort::test_parse_complete_port_definition PASSED [ 97%]

tests/unit/config/types_test.py::TestServicePort::test_parse_ext_ip_no_published_port PASSED [ 97%]

tests/unit/config/types_test.py::TestServicePort::test_repr_published_port_0 PASSED [ 97%]

tests/unit/config/types_test.py::TestServicePort::test_parse_port_range PASSED [ 97%]

tests/unit/config/types_test.py::TestServicePort::test_parse_port_publish_range PASSED [ 97%]

tests/unit/config/types_test.py::TestServicePort::test_parse_invalid_port PASSED [ 98%]

tests/unit/config/types_test.py::TestServicePort::test_parse_invalid_publish_range PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_only_one_path PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_internal_and_external PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_with_mode PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_too_many_parts PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_absolute_path_normalized PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_absolute_path_native PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_internal_path_normalized PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_internal_path_native PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_just_drives_normalized PASSED [ 98%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_just_drives_native PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_mixed_notations_normalized PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_mixed_notations_native PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_from_service PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_from_container PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_invalid PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_service PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_service_with_mode PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_container PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_container_with_mode PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_invalid_type PASSED [ 99%]

tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_invalid PASSED [100%]



---------- coverage: platform linux2, python 2.7.13-final-0 ----------

Name                              Stmts   Miss Branch BrPart  Cover   Missing

-----------------------------------------------------------------------------

compose/__init__.py                   3      0      0      0   100%

compose/__main__.py                   4      4      0      0     0%   1-6

compose/bundle.py                   144     21     60      5    84%   45, 50-51, 56-57, 75-78, 81, 103-109, 130-131, 141-146, 149, 80->81, 100->103, 118->135, 125->135, 148->149

compose/cli/__init__.py               0      0      0      0   100%

compose/cli/colors.py                23      2     10      2    88%   37-38, 36->37, 48->exit

compose/cli/command.py              104     14     32      5    83%   71-81, 121-126, 177, 200, 70->71, 120->121, 165->168, 176->177, 197->200

compose/cli/docker_client.py         75      5     24      2    93%   24, 98-99, 107, 123, 106->107, 122->123

compose/cli/docopt_command.py        38      4      8      2    87%   13-14, 29, 35, 28->29, 34->35

compose/cli/errors.py               100     26     34      6    67%   47-48, 62-65, 70-79, 105-106, 123, 125, 127-131, 136, 141-148, 46->47, 61->62, 103->105, 122->123, 124->125, 126->127

compose/cli/formatter.py             37      3      8      1    91%   13, 22-23, 12->13

compose/cli/log_printer.py          149     10     53      6    91%   76, 103, 110-115, 167, 176, 229-232, 262, 43->exit, 75->76, 98->103, 174->176, 228->229, 237->243

compose/cli/main.py                 696     91    290     41    84%   84-85, 87-88, 169, 330, 362-364, 447, 507, 511, 516-517, 527-556, 568, 586-588, 592, 659-660, 698-699, 717, 738-739, 751, 774, 792, 839, 1071, 1080, 1109-1118, 1158-1161, 1169-1173, 1175-1180, 1203, 1225-1254, 1261-1262, 1264-1266, 1281, 1287, 1471, 1489, 1505, 1509-1510, 1521, 1526, 1529, 1555, 1574-1576, 1586, 1597, 61->64, 83->84, 86->87, 168->169, 329->330, 361->362, 446->447, 506->507, 510->511, 521->527, 565->568, 585->586, 591->592, 657->659, 716->717, 737->738, 750->751, 773->774, 829->839, 831->exit, 1070->1071, 1079->1080, 1168->1169, 1174->1175, 1202->1203, 1260->1261, 1263->1264, 1280->1281, 1286->1287, 1470->1471, 1488->1489, 1504->1505, 1520->1521, 1525->1526, 1528->1529, 1547->exit, 1554->1555, 1568->1576, 1570->1574, 1585->1586, 1595->1597

compose/cli/signals.py               23      0      4      2    93%   36->exit, 43->exit

compose/cli/utils.py                 81     28     18      4    60%   36-45, 53-55, 62-68, 76, 90-103, 109, 127-128, 138, 151-154, 88->90, 108->109, 137->138, 150->151

compose/cli/verbose_proxy.py         35     12     10      0    69%   36-39, 42-47, 50-60

compose/config/__init__.py           13      0      0      0   100%

compose/config/config.py            826     28    388     18    95%   266, 508, 578, 714, 757, 812-830, 952-953, 959, 979, 982, 1335, 1366, 1412, 265->266, 577->578, 709->713, 713->714, 756->757, 778->exit, 809->812, 936->938, 938->942, 957->959, 978->979, 981->982, 993->1002, 1015->1017, 1017->1020, 1332->1335, 1365->1366, 1408->1412

compose/config/environment.py        96      7     34      4    92%   41, 98-101, 114, 121, 40->41, 97->98, 113->114, 120->121

compose/config/errors.py             25      2      0      0    92%   36-40

compose/config/interpolation.py     148      7     62      4    94%   66, 148, 196, 222, 227-229, 121->exit, 146->148, 195->196, 221->222

compose/config/serialize.py          97      1     50      2    98%   76, 75->76, 82->85

compose/config/sort_services.py      44      1     18      1    97%   57, 56->57

compose/config/types.py             291     22    112     17    90%   54, 90, 113, 149, 171, 258-259, 267, 286, 301, 363-364, 372-373, 377-378, 441, 445, 486, 493-494, 502, 53->54, 71->79, 89->90, 112->113, 118->exit, 148->149, 170->171, 257->258, 266->267, 285->286, 298->301, 361->366, 440->441, 444->445, 484->489, 485->486, 501->502

compose/config/validation.py        254     14    140     12    92%   219, 249, 299-300, 318-319, 341, 363, 469-471, 496-498, 525, 218->219, 248->249, 289->299, 317->318, 335->338, 338->341, 362->363, 404->377, 425->exit, 467->469, 495->496, 524->525

compose/const.py                     39      0      0      0   100%

compose/container.py                193      8     48      7    94%   98, 105, 151, 153, 262, 265, 297, 320, 97->98, 104->105, 150->151, 152->153, 236->235, 303->exit, 319->320

compose/errors.py                    17      1      0      0    94%   12

compose/network.py                  190     19     92      5    87%   184, 186-200, 206, 224, 226, 183->184, 185->186, 205->206, 223->224, 225->226

compose/parallel.py                 199      2     56      1    99%   187, 326, 325->326

compose/progress_stream.py           87     12     44     10    82%   40, 71, 74, 80, 85, 90-91, 116, 122-125, 39->40, 42->46, 53->57, 70->71, 73->74, 79->80, 84->85, 89->90, 112->116, 121->122

compose/project.py                  450     31    182     14    92%   64, 161, 217-218, 259-260, 370-371, 374-379, 393-396, 449, 500, 504, 531, 634-638, 641, 659, 790-791, 797-800, 855, 61->64, 157->161, 336->338, 368->370, 373->374, 392->393, 448->449, 499->500, 503->504, 530->531, 640->641, 658->659, 709->exit, 793->800

compose/service.py                  920     57    406     30    92%   67, 278-279, 300, 373-376, 424-429, 435-437, 477-478, 493, 496, 514, 581, 626-629, 737, 956-957, 977-978, 1079, 1126, 1187, 1251-1266, 1306, 1345-1349, 1537, 1541, 1699, 1785, 1826, 1839, 1843-1844, 1848-1849, 64->67, 223->exit, 276->278, 299->300, 434->435, 476->477, 492->493, 495->496, 513->514, 571->581, 732->737, 955->956, 976->977, 1078->1079, 1125->1126, 1186->1187, 1305->1306, 1342->1345, 1536->1537, 1540->1541, 1589->exit, 1597->1596, 1635->1632, 1698->1699, 1784->1785, 1810->1812, 1825->1826, 1838->1839, 1842->1843, 1847->1848

compose/state.py                      0      0      0      0   100%

compose/timeparse.py                 22      0      4      0   100%

compose/utils.py                    117      8     42      5    92%   26, 75-79, 125, 135, 161, 168, 171, 25->26, 124->125, 134->135, 167->168, 169->171

compose/version.py                    6      0      0      0   100%

compose/volume.py                   126      4     44      3    95%   150, 200, 211-212, 141->150, 199->200, 209->211

-----------------------------------------------------------------------------

TOTAL                              5672    444   2273    209    90%

Coverage HTML written to dir coverage-html



=========================== short test summary info ============================

XFAIL tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_rt

  not supported by kernel

XFAIL tests/integration/service_test.py::ServiceTest::test_create_container_with_storage_opt

  Not supported on most drivers

SKIP [1] tests/acceptance/cli_test.py:2416: race condition between up and logs

SKIP [1] tests/unit/cli/command_test.py:39: windows separator

SKIP [1] tests/acceptance/cli_test.py:2389: race condition between up and logs

SKIP [1] tests/unit/cli/errors_test.py:80: Needs pywin32

SKIP [1] /code/tests/integration/testcases.py:167: This daemon does not support the 'nvidia'' runtime

SKIP [1] tests/unit/cli/errors_test.py:70: Needs pywin32

SKIP [1] tests/unit/cli/errors_test.py:90: Needs pywin32

SKIP [1] tests/integration/service_test.py:150: cpu_percent is not supported for Linux

SKIP [1] tests/acceptance/cli_test.py:2437: race condition between up and logs

SKIP [1] tests/unit/config/config_test.py:3778: windows paths

SKIP [1] tests/integration/service_test.py:1674: Broken on 1.11.0 - 17.03.0



======= 1132 passed, 11 skipped, 2 xfailed, 3 xpassed in 829.63 seconds ========

___________________________________ summary ____________________________________

  py27: commands succeeded

  congratulations :)

+ on_exit
+ [[ 0 != \0 ]]
+ docker rm -vf compose-dind-19.03.5-jenkins-compose-ndeloof-28
compose-dind-19.03.5-jenkins-compose-ndeloof-28
[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // node
[Pipeline] node
Running on ubuntu-1804-overlay2 (i-0b6eb4af357135099) in /home/ubuntu/workspace/compose_ndeloof
[Pipeline] {
[Pipeline] stage
[Pipeline] { (debian 19.03.5 py37)
[Pipeline] checkout
using credential sf-release-bot.github.ssh
Fetching changes from the remote Git repository
Fetching without tags
Checking out Revision f0d8706f3473426bfcc85197834187726323acf2 (ndeloof)
Commit message: "WiP"
 > git rev-parse --is-inside-work-tree # timeout=10
 > git config remote.origin.url git@github.com:docker/compose.git # timeout=10
Fetching upstream changes from git@github.com:docker/compose.git
 > git --version # timeout=10
using GIT_SSH to set credentials docker-jenkins user on github.com
 > git fetch --no-tags --progress -- git@github.com:docker/compose.git +refs/heads/ndeloof:refs/remotes/origin/ndeloof
 > git config core.sparsecheckout # timeout=10
 > git checkout -f f0d8706f3473426bfcc85197834187726323acf2
[Pipeline] unstash
Unstashed file(s) from https://corp-us-east-1-jenkins-k8s-maste-jenkinsartifacts-1lzm7adht5e1j.s3.amazonaws.com/public/compose/ndeloof/28/stashes/debian.tgz
[Pipeline] sh
+ docker load -i debian.tar
Loaded image: compose:debian
[Pipeline] sh
+ pwd
+ docker run -t --rm --privileged --volume=/home/ubuntu/workspace/compose_ndeloof/.git:/code/.git --volume=/var/run/docker.sock:/var/run/docker.sock -e TAG=compose:debian -e DOCKER_VERSIONS=19.03.5 -e BUILD_NUMBER=jenkins-compose-ndeloof-28 -e PY_TEST_VERSIONS=py37 --entrypoint=script/test/ci compose:debian --verbose
+ docker version
Client: Docker Engine - Community
 Version:           18.09.7
 API version:       1.39
 Go version:        go1.10.8
 Git commit:        2d0083d
 Built:             Thu Jun 27 17:54:15 2019
 OS/Arch:           linux/amd64
 Experimental:      false

Server: Docker Engine - Community
 Engine:
  Version:          19.03.2
  API version:      1.40 (minimum version 1.12)
  Go version:       go1.12.8
  Git commit:       6a30dfc
  Built:            Thu Aug 29 05:27:45 2019
  OS/Arch:          linux/amd64
  Experimental:     true
 containerd:
  Version:          1.2.6
  GitCommit:        894b81a4b802e4eb2a91d1ce216b8817763c29fb
 runc:
  Version:          1.0.0-rc8
  GitCommit:        425e105d5a03fabd737a126ad93d62a9eeede87f
 docker-init:
  Version:          0.18.0
  GitCommit:        fec3683
+ export DOCKER_VERSIONS=19.03.5
+ DOCKER_VERSIONS=19.03.5
+ STORAGE_DRIVER=overlay
+ export DOCKER_DAEMON_ARGS=--storage-driver=overlay
+ DOCKER_DAEMON_ARGS=--storage-driver=overlay
++ hostname
+ GIT_VOLUME=--volumes-from=837cd8e9d927
+ . script/test/all
++ set -e
++ echo 'Running lint checks'
Running lint checks
++ docker run --rm --tty --volumes-from=837cd8e9d927 compose:debian tox -e pre-commit
pre-commit installed: aspy.yaml==1.3.0,cfgv==2.0.1,identify==1.4.7,importlib-metadata==1.1.0,more-itertools==8.0.0,nodeenv==1.3.3,pre-commit==1.20.0,PyYAML==5.2,six==1.13.0,toml==0.10.0,virtualenv==16.7.8,zipp==0.6.0

pre-commit runtests: PYTHONHASHSEED='321158858'

pre-commit runtests: commands[0] | pre-commit install

pre-commit installed at .git/hooks/pre-commit

pre-commit runtests: commands[1] | pre-commit run --all-files

[WARNING] Unexpected key(s) present on git://github.com/pre-commit/pre-commit-hooks: sha

[WARNING] Unexpected key(s) present on git://github.com/asottile/reorder_python_imports: sha

[INFO] Initializing environment for git://github.com/pre-commit/pre-commit-hooks.

[INFO] Initializing environment for git://github.com/asottile/reorder_python_imports.

[INFO] Installing environment for git://github.com/pre-commit/pre-commit-hooks.

[INFO] Once installed this environment will be reused.

[INFO] This may take a few minutes...

[INFO] Installing environment for git://github.com/asottile/reorder_python_imports.

[INFO] Once installed this environment will be reused.

[INFO] This may take a few minutes...

Check for added large files..............................................Passed

Check docstring is first.................................................Passed

Check for merge conflicts................................................Passed

Check Yaml...............................................................Passed

Check JSON...............................................................Passed

Debug Statements (Python)................................................Passed

Fix End of Files.........................................................Passed

Flake8...................................................................Passed

Tests should end in _test.py.............................................Passed

Fix requirements.txt.....................................................Passed

Trim Trailing Whitespace.................................................Passed

Reorder python imports...................................................Passed

___________________________________ summary ____________________________________

  pre-commit: commands succeeded

  congratulations :)

++ get_versions='docker run --rm
    --entrypoint=/code/.tox/py27/bin/python
    compose:debian
    /code/script/test/versions.py docker/docker-ce,moby/moby'
++ '[' 19.03.5 == '' ']'
++ '[' 19.03.5 == all ']'
++ BUILD_NUMBER=jenkins-compose-ndeloof-28
++ PY_TEST_VERSIONS=py37
++ for version in $DOCKER_VERSIONS
++ echo 'Running tests against Docker 19.03.5'
Running tests against Docker 19.03.5
++ daemon_container=compose-dind-19.03.5-jenkins-compose-ndeloof-28
++ trap on_exit EXIT
++ repo=dockerswarm/dind
++ tail -n 10
++ docker run -d --name compose-dind-19.03.5-jenkins-compose-ndeloof-28 --privileged --volume=/var/lib/docker dockerswarm/dind:19.03.5 dockerd -H tcp://0.0.0.0:2375 --storage-driver=overlay
c3b56a2ea16718bfb8a934bbd4f7cc6762bc1a1539bbe5544264672bcc69a0d5
++ docker run --rm --tty --link=compose-dind-19.03.5-jenkins-compose-ndeloof-28:docker --env=DOCKER_HOST=tcp://docker:2375 --env=DOCKER_VERSION=19.03.5 --entrypoint=tox compose:debian -e py37 -- --verbose
py37 develop-inst-nodeps: /code

py37 installed: altgraph==0.16.1,atomicwrites==1.3.0,attrs==19.3.0,backports.shutil-get-terminal-size==1.0.0,bcrypt==3.1.7,cached-property==1.3.0,certifi==2017.4.17,cffi==1.13.2,chardet==3.0.4,coverage==4.4.2,cryptography==2.8,ddt==1.2.0,docker==4.1.0,# Editable install with no version control (docker-compose==1.26.0.dev0),-e /code,docker-pycreds==0.4.0,dockerpty==0.4.1,docopt==0.6.2,flake8==3.5.0,idna==2.5,ipaddress==1.0.18,jsonschema==3.0.1,mccabe==0.6.1,mock==3.0.5,more-itertools==8.0.0,paramiko==2.6.0,pluggy==0.6.0,py==1.8.0,pycodestyle==2.3.1,pycparser==2.19,pyflakes==1.6.0,PyInstaller==3.5,PyNaCl==1.3.0,pyrsistent==0.15.6,PySocks==1.6.7,pytest==3.6.3,pytest-cov==2.5.1,PyYAML==4.2b1,requests==2.22.0,six==1.12.0,texttable==1.6.2,urllib3==1.25.7,websocket-client==0.32.0

py37 runtests: PYTHONHASHSEED='96578805'

py37 runtests: commands[0] | mkdir -p .coverage-binfiles

py37 runtests: commands[1] | py.test -v --cov=compose --cov-report html --cov-report term --cov-config=tox.ini --verbose

============================= test session starts ==============================

platform linux -- Python 3.7.4, pytest-3.6.3, py-1.8.0, pluggy-0.6.0 -- /code/.tox/py37/bin/python3.7

cachedir: .pytest_cache

rootdir: /code, inifile: tox.ini

plugins: cov-2.5.1


collecting 0 items                                                             
collecting 197 items                                                           
collecting 197 items                                                           
collecting 197 items                                                           
collecting 197 items                                                           
collecting 198 items                                                           
collecting 198 items                                                           
collecting 198 items                                                           
collecting 201 items                                                           
collecting 201 items                                                           
collecting 201 items                                                           
collecting 269 items                                                           
collecting 269 items                                                           
collecting 269 items                                                           
collecting 272 items                                                           
collecting 272 items                                                           
collecting 272 items                                                           
collecting 401 items                                                           
collecting 405 items                                                           
collecting 405 items                                                           
collecting 405 items                                                           
collecting 405 items                                                           
collecting 408 items                                                           
collecting 417 items                                                           
collecting 428 items                                                           
collecting 436 items                                                           
collecting 436 items                                                           
collecting 436 items                                                           
collecting 436 items                                                           
collecting 447 items                                                           
collecting 447 items                                                           
collecting 464 items                                                           
collecting 477 items                                                           
collecting 477 items                                                           
collecting 495 items                                                           
collecting 496 items                                                           
collecting 496 items                                                           
collecting 504 items                                                           
collecting 504 items                                                           
collecting 509 items                                                           
collecting 512 items                                                           
collecting 521 items                                                           
collecting 521 items                                                           
collecting 552 items                                                           
collecting 552 items                                                           
collecting 626 items                                                           
collecting 627 items                                                           
collecting 630 items                                                           
collecting 634 items                                                           
collecting 635 items                                                           
collecting 645 items                                                           
collecting 648 items                                                           
collecting 651 items                                                           
collecting 651 items                                                           
collecting 656 items                                                           
collecting 656 items                                                           
collecting 669 items                                                           
collecting 672 items                                                           
collecting 672 items                                                           
collecting 674 items                                                           
collecting 674 items                                                           
collecting 676 items                                                           
collecting 676 items                                                           
collecting 677 items                                                           
collecting 677 items                                                           
collecting 678 items                                                           
collecting 678 items                                                           
collecting 678 items                                                           
collecting 680 items                                                           
collecting 680 items                                                           
collecting 680 items                                                           
collecting 688 items                                                           
collecting 688 items                                                           
collecting 688 items                                                           
collecting 692 items                                                           
collecting 708 items                                                           
collecting 711 items                                                           
collecting 711 items                                                           
collecting 711 items                                                           
collecting 719 items                                                           
collecting 719 items                                                           
collecting 719 items                                                           
collecting 725 items                                                           
collecting 725 items                                                           
collecting 727 items                                                           
collecting 727 items                                                           
collecting 730 items                                                           
collecting 730 items                                                           
collecting 734 items                                                           
collecting 734 items                                                           
collecting 738 items                                                           
collecting 738 items                                                           
collecting 741 items                                                           
collecting 746 items                                                           
collecting 746 items                                                           
collecting 749 items                                                           
collecting 749 items                                                           
collecting 753 items                                                           
collecting 753 items                                                           
collecting 760 items                                                           
collecting 760 items                                                           
collecting 760 items                                                           
collecting 764 items                                                           
collecting 769 items                                                           
collecting 769 items                                                           
collecting 773 items                                                           
collecting 773 items                                                           
collecting 917 items                                                           
collecting 925 items                                                           
collecting 933 items                                                           
collecting 936 items                                                           
collecting 946 items                                                           
collecting 957 items                                                           
collecting 963 items                                                           
collecting 969 items                                                           
collecting 972 items                                                           
collecting 977 items                                                           
collecting 985 items                                                           
collecting 989 items                                                           
collecting 995 items                                                           
collecting 998 items                                                           
collecting 1001 items                                                          
collecting 1013 items                                                          
collecting 1044 items                                                          
collecting 1047 items                                                          
collecting 1050 items                                                          
collecting 1057 items                                                          
collecting 1061 items                                                          
collecting 1063 items                                                          
collecting 1078 items                                                          
collecting 1078 items                                                          
collecting 1083 items                                                          
collecting 1083 items                                                          
collecting 1104 items                                                          
collecting 1116 items                                                          
collecting 1116 items                                                          
collecting 1116 items                                                          
collecting 1125 items                                                          
collecting 1125 items                                                          
collecting 1137 items                                                          
collecting 1137 items                                                          
collecting 1146 items                                                          
collecting 1146 items                                                          
collecting 1148 items                                                          
collected 1148 items                                                           



tests/acceptance/cli_test.py::CLITestCase::test_build_failed PASSED      [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_failed_forcerm PASSED [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_log_level PASSED   [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_memory_build_option PASSED [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_no_cache PASSED    [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_no_cache_pull PASSED [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_override_dir PASSED [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_override_dir_invalid_path PASSED [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_parallel PASSED    [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_plain PASSED       [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_pull PASSED        [  0%]

tests/acceptance/cli_test.py::CLITestCase::test_build_rm XPASS           [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_build_shm_size_build_option PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_build_with_buildarg_cli_override PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_build_with_buildarg_from_compose_file PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_build_with_buildarg_old_api_version PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_bundle_with_digests PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_config_compatibility_mode PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_config_default PASSED    [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_config_external_network PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_config_external_network_v3_5 PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_config_external_volume_v2 PASSED [  1%]

tests/acceptance/cli_test.py::CLITestCase::test_config_external_volume_v2_x PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_external_volume_v3_4 PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_external_volume_v3_x PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_list_services PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_list_volumes PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_quiet PASSED      [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_quiet_with_error PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_restart PASSED    [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_stdin PASSED      [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_v1 PASSED         [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_v3 PASSED         [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_with_dot_env PASSED [  2%]

tests/acceptance/cli_test.py::CLITestCase::test_config_with_dot_env_and_override_dir PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_config_with_env_file PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_config_with_hash_option PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_create PASSED            [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_create_with_force_recreate PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_create_with_force_recreate_and_no_recreate PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_create_with_no_recreate PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_down PASSED              [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_down_invalid_rmi_flag PASSED [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_down_signal PASSED       [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_down_timeout PASSED      [  3%]

tests/acceptance/cli_test.py::CLITestCase::test_env_file_relative_to_compose_file PASSED [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_events_human_readable PASSED [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_events_json PASSED       [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_exec_custom_user PASSED  [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_exec_detach_long_form PASSED [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_exec_service_with_environment_overridden PASSED [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_exec_without_tty PASSED  [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_exec_workdir PASSED      [  4%]

tests/acceptance/cli_test.py::CLITestCase::test_exit_code_from_signal_stop Cancelling nested steps due to timeout
Sending interrupt signal to process
Terminated
script returned exit code 143
[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // node
[Pipeline] }
[Pipeline] // script
[Pipeline] }
[Pipeline] // stage
[Pipeline] stage
[Pipeline] { (Binaries)
Stage "Binaries" skipped due to earlier failure(s)
[Pipeline] parallel
[Pipeline] { (Branch: macosx binary)
[Pipeline] { (Branch: linux binary)
[Pipeline] { (Branch: windows binary)
[Pipeline] { (Branch: alpine runtime images)
[Pipeline] { (Branch: debian runtime images)
[Pipeline] stage
[Pipeline] { (macosx binary)
[Pipeline] stage
[Pipeline] { (linux binary)
[Pipeline] stage
[Pipeline] { (windows binary)
[Pipeline] stage
[Pipeline] { (alpine runtime images)
[Pipeline] stage
[Pipeline] { (debian runtime images)
Stage "macosx binary" skipped due to earlier failure(s)
[Pipeline] }
Stage "linux binary" skipped due to earlier failure(s)
[Pipeline] }
Stage "windows binary" skipped due to earlier failure(s)
[Pipeline] }
Stage "alpine runtime images" skipped due to earlier failure(s)
[Pipeline] }
Stage "debian runtime images" skipped due to earlier failure(s)
[Pipeline] }
[Pipeline] // stage
[Pipeline] // stage
[Pipeline] // stage
[Pipeline] // stage
[Pipeline] // stage
[Pipeline] }
Failed in branch macosx binary
[Pipeline] }
Failed in branch linux binary
[Pipeline] }
Failed in branch windows binary
[Pipeline] }
Failed in branch alpine runtime images
[Pipeline] }
Failed in branch debian runtime images
[Pipeline] // parallel
[Pipeline] }
[Pipeline] // stage
[Pipeline] stage
[Pipeline] { (Release)
Stage "Release" skipped due to earlier failure(s)
[Pipeline] parallel
[Pipeline] { (Branch: Pushing images)
[Pipeline] { (Branch: Creating Github Release)
[Pipeline] { (Branch: Publishing Python packages)
[Pipeline] { (Branch: Publishing binaries to Bintray)
[Pipeline] stage
[Pipeline] { (Pushing images)
[Pipeline] stage
[Pipeline] { (Creating Github Release)
[Pipeline] stage
[Pipeline] { (Publishing Python packages)
[Pipeline] stage
[Pipeline] { (Publishing binaries to Bintray)
Stage "Pushing images" skipped due to earlier failure(s)
[Pipeline] }
Stage "Creating Github Release" skipped due to earlier failure(s)
[Pipeline] }
Stage "Publishing Python packages" skipped due to earlier failure(s)
[Pipeline] }
Stage "Publishing binaries to Bintray" skipped due to earlier failure(s)
[Pipeline] }
[Pipeline] // stage
[Pipeline] // stage
[Pipeline] // stage
[Pipeline] // stage
[Pipeline] }
Failed in branch Pushing images
[Pipeline] }
Failed in branch Creating Github Release
[Pipeline] }
Failed in branch Publishing Python packages
[Pipeline] }
Failed in branch Publishing binaries to Bintray
[Pipeline] // parallel
[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // timeout
[Pipeline] }
[Pipeline] // withEnv
[Pipeline] End of Pipeline

GitHub has been notified of this commit’s build result

Timeout has been exceeded
Finished: ABORTED