Skip to content
Success

Console Output

Started by user Peter Salvatore
01:13:30 Connecting to https://api.github.com using docker-jenkins/****** (docker-jenkins GitHub credentials)
Loading trusted files from base branch master at cf3c07d6ee15659ce079eaeafc11b63a034b4c3c rather than 04ce00a71373d402ca9ab2ea7a9f732eeab4778e
Obtained Jenkinsfile from cf3c07d6ee15659ce079eaeafc11b63a034b4c3c
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 ead69454b4062f17d1f8389642089a002b037213
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 ead69454b4062f17d1f8389642089a002b037213 (master)
 > git config core.sparsecheckout # timeout=10
 > git checkout -f ead69454b4062f17d1f8389642089a002b037213
Commit message: "Merge pull request #10 from russellcardullo/sonar-scan"
 > git rev-list --no-walk ead69454b4062f17d1f8389642089a002b037213 # timeout=10
[Pipeline] Start of Pipeline
[Pipeline] node
Running on ubuntu-1804-overlay2 (i-0669ad7ef1a92adaf) in /home/ubuntu/workspace/compose_PR-6850
[Pipeline] {
[Pipeline] withDockerRegistry
$ docker login -u dockerbuildbot -p ******** https://index.docker.io/v1/
WARNING! Using --password via the CLI is insecure. Use --password-stdin.
WARNING! Your password will be stored unencrypted in /home/ubuntu/workspace/compose_PR-6850@tmp/5d95b02e-ddf5-4431-bd38-bbbcfd933d8d/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store

Login Succeeded
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] echo
01:13:32 cleanWorkspace: Ensuring workspace is owned by ubuntu
[Pipeline] echo
01:13:32 chowning workspace
[Pipeline] sh
01:13:33 + uname -m
[Pipeline] sh
01:13:33 + pwd
01:13:33 + id -u
01:13:33 + id -g
01:13:33 + docker run --rm -v /home/ubuntu/workspace/compose_PR-6850:/workspace busybox chown -R 1000:1000 /workspace
[Pipeline] echo
01:13:34 Removing all docker containers
[Pipeline] sh
01:13:34 + docker container ls -aq
[Pipeline] echo
01:13:34 Docker containers have been removed
[Pipeline] echo
01:13:34 cleanWorkspace: Removing existing workspace
[Pipeline] deleteDir
[Pipeline] echo
01:13:34 cleanWorkspace: Workspace is clean.
[Pipeline] stage
[Pipeline] { (build image for "alpine")
[Pipeline] checkout
01:13:34 using credential sf-release-bot.github.ssh
01:13:34 Cloning the remote Git repository
01:13:34 Cloning with configured refspecs honoured and without tags
Cloning repository git@github.com:docker/compose.git
 > git init /home/ubuntu/workspace/compose_PR-6850 # 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/pull/6850/head:refs/remotes/origin/PR-6850
01:13:36 Fetching without tags
 > git config remote.origin.url git@github.com:docker/compose.git # timeout=10
 > git config --add remote.origin.fetch +refs/pull/6850/head:refs/remotes/origin/PR-6850 # 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/pull/6850/head:refs/remotes/origin/PR-6850
01:13:36 Checking out Revision 04ce00a71373d402ca9ab2ea7a9f732eeab4778e (PR-6850)
01:13:36 Commit message: "add --skip-env-file option"
01:13:36 First time build. Skipping changelog.
[Pipeline] sh
01:13:37 + git rev-parse HEAD
[Pipeline] sh
 > git config core.sparsecheckout # timeout=10
 > git checkout -f 04ce00a71373d402ca9ab2ea7a9f732eeab4778e
01:13:37 + docker pull dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e
01:13:37 alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e: Pulling from dockerbuildbot/compose
01:13:37 050382585609: Pulling fs layer
01:13:37 dac2222ca532: Pulling fs layer
01:13:37 29a7fe408caa: Pulling fs layer
01:13:37 6ad337b9b53f: Pulling fs layer
01:13:37 7ad6fc7f0fa9: Pulling fs layer
01:13:37 2099bcf0bd4a: Pulling fs layer
01:13:37 51b9ddb7198d: Pulling fs layer
01:13:37 6c8318350323: Pulling fs layer
01:13:37 9601eb373c5a: Pulling fs layer
01:13:37 259b78ba95b0: Pulling fs layer
01:13:37 4ec236b62c9b: Pulling fs layer
01:13:37 4f10d41363a8: Pulling fs layer
01:13:37 dfa88475ea08: Pulling fs layer
01:13:37 a11c274c0f9b: Pulling fs layer
01:13:37 42d83eff80c9: Pulling fs layer
01:13:37 8ceab1156925: Pulling fs layer
01:13:37 4600801c3d3a: Pulling fs layer
01:13:37 f423c3d5c2bb: Pulling fs layer
01:13:37 34181986d124: Pulling fs layer
01:13:37 00932efc1e1d: Pulling fs layer
01:13:37 a3c986dbc6a4: Pulling fs layer
01:13:37 4f10d41363a8: Waiting
01:13:37 dfa88475ea08: Waiting
01:13:37 a11c274c0f9b: Waiting
01:13:37 42d83eff80c9: Waiting
01:13:37 8ceab1156925: Waiting
01:13:37 4600801c3d3a: Waiting
01:13:37 6ad337b9b53f: Waiting
01:13:37 f423c3d5c2bb: Waiting
01:13:37 34181986d124: Waiting
01:13:37 7ad6fc7f0fa9: Waiting
01:13:37 2099bcf0bd4a: Waiting
01:13:37 00932efc1e1d: Waiting
01:13:37 51b9ddb7198d: Waiting
01:13:37 a3c986dbc6a4: Waiting
01:13:37 6c8318350323: Waiting
01:13:37 9601eb373c5a: Waiting
01:13:37 4ec236b62c9b: Waiting
01:13:37 259b78ba95b0: Waiting
01:13:38 dac2222ca532: Verifying Checksum
01:13:38 dac2222ca532: Download complete
01:13:38 050382585609: Verifying Checksum
01:13:38 050382585609: Download complete
01:13:38 6ad337b9b53f: Verifying Checksum
01:13:38 6ad337b9b53f: Download complete
01:13:38 7ad6fc7f0fa9: Verifying Checksum
01:13:38 7ad6fc7f0fa9: Download complete
01:13:38 29a7fe408caa: Verifying Checksum
01:13:38 29a7fe408caa: Download complete
01:13:38 050382585609: Pull complete
01:13:38 51b9ddb7198d: Verifying Checksum
01:13:38 51b9ddb7198d: Download complete
01:13:38 9601eb373c5a: Verifying Checksum
01:13:38 9601eb373c5a: Download complete
01:13:38 dac2222ca532: Pull complete
01:13:38 6c8318350323: Verifying Checksum
01:13:38 6c8318350323: Download complete
01:13:38 259b78ba95b0: Verifying Checksum
01:13:38 259b78ba95b0: Download complete
01:13:38 4ec236b62c9b: Verifying Checksum
01:13:38 4ec236b62c9b: Download complete
01:13:38 4f10d41363a8: Verifying Checksum
01:13:38 4f10d41363a8: Download complete
01:13:39 dfa88475ea08: Verifying Checksum
01:13:39 dfa88475ea08: Download complete
01:13:39 a11c274c0f9b: Verifying Checksum
01:13:39 a11c274c0f9b: Download complete
01:13:39 42d83eff80c9: Verifying Checksum
01:13:39 42d83eff80c9: Download complete
01:13:39 8ceab1156925: Verifying Checksum
01:13:39 8ceab1156925: Download complete
01:13:39 4600801c3d3a: Verifying Checksum
01:13:39 4600801c3d3a: Download complete
01:13:39 2099bcf0bd4a: Verifying Checksum
01:13:39 2099bcf0bd4a: Download complete
01:13:39 f423c3d5c2bb: Verifying Checksum
01:13:39 f423c3d5c2bb: Download complete
01:13:39 00932efc1e1d: Verifying Checksum
01:13:39 00932efc1e1d: Download complete
01:13:40 34181986d124: Verifying Checksum
01:13:40 34181986d124: Download complete
01:13:40 a3c986dbc6a4: Verifying Checksum
01:13:40 a3c986dbc6a4: Download complete
01:13:40 29a7fe408caa: Pull complete
01:13:41 6ad337b9b53f: Pull complete
01:13:41 7ad6fc7f0fa9: Pull complete
01:13:44 2099bcf0bd4a: Pull complete
01:13:44 51b9ddb7198d: Pull complete
01:13:45 6c8318350323: Pull complete
01:13:45 9601eb373c5a: Pull complete
01:13:45 259b78ba95b0: Pull complete
01:13:45 4ec236b62c9b: Pull complete
01:13:45 4f10d41363a8: Pull complete
01:13:45 dfa88475ea08: Pull complete
01:13:45 a11c274c0f9b: Pull complete
01:13:45 42d83eff80c9: Pull complete
01:13:45 8ceab1156925: Pull complete
01:13:46 4600801c3d3a: Pull complete
01:13:46 f423c3d5c2bb: Pull complete
01:13:48 34181986d124: Pull complete
01:13:48 00932efc1e1d: Pull complete
01:13:49 a3c986dbc6a4: Pull complete
01:13:49 Digest: sha256:8c6049026883a4e1422f4aab41226b903fb69db598a8e3bdff45679df802b11a
01:13:49 Status: Downloaded newer image for dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e
01:13:49 docker.io/dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e
[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // withDockerRegistry
[Pipeline] }
[Pipeline] // node
[Pipeline] echo
image.id: dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e
[Pipeline] node
Terminated
Running on ubuntu-1804-overlay2 (i-0547959de950e4ed8) in /home/ubuntu/workspace/compose_PR-6850
[Pipeline] {
[Pipeline] withDockerRegistry
$ docker login -u dockerbuildbot -p ******** https://index.docker.io/v1/
WARNING! Using --password via the CLI is insecure. Use --password-stdin.
WARNING! Your password will be stored unencrypted in /home/ubuntu/workspace/compose_PR-6850@tmp/83900757-b4bd-4837-86fe-7f9580884b63/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store

Login Succeeded
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] sh
01:13:50 + docker run --rm --entrypoint=/code/.tox/py27/bin/python dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e /code/script/test/versions.py -n 2 docker/docker-ce recent
01:13:50 Unable to find image 'dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e' locally
01:13:50 alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e: Pulling from dockerbuildbot/compose
01:13:50 050382585609: Pulling fs layer
01:13:50 dac2222ca532: Pulling fs layer
01:13:50 29a7fe408caa: Pulling fs layer
01:13:50 6ad337b9b53f: Pulling fs layer
01:13:50 7ad6fc7f0fa9: Pulling fs layer
01:13:50 2099bcf0bd4a: Pulling fs layer
01:13:50 51b9ddb7198d: Pulling fs layer
01:13:50 6c8318350323: Pulling fs layer
01:13:50 9601eb373c5a: Pulling fs layer
01:13:50 259b78ba95b0: Pulling fs layer
01:13:50 4ec236b62c9b: Pulling fs layer
01:13:50 4f10d41363a8: Pulling fs layer
01:13:50 dfa88475ea08: Pulling fs layer
01:13:50 a11c274c0f9b: Pulling fs layer
01:13:50 42d83eff80c9: Pulling fs layer
01:13:50 8ceab1156925: Pulling fs layer
01:13:50 4600801c3d3a: Pulling fs layer
01:13:50 f423c3d5c2bb: Pulling fs layer
01:13:50 34181986d124: Pulling fs layer
01:13:50 00932efc1e1d: Pulling fs layer
01:13:50 a3c986dbc6a4: Pulling fs layer
01:13:50 4f10d41363a8: Waiting
01:13:50 dfa88475ea08: Waiting
01:13:50 a11c274c0f9b: Waiting
01:13:50 42d83eff80c9: Waiting
01:13:50 8ceab1156925: Waiting
01:13:50 4600801c3d3a: Waiting
01:13:50 f423c3d5c2bb: Waiting
01:13:50 34181986d124: Waiting
01:13:50 00932efc1e1d: Waiting
01:13:50 a3c986dbc6a4: Waiting
01:13:50 6ad337b9b53f: Waiting
01:13:50 7ad6fc7f0fa9: Waiting
01:13:50 2099bcf0bd4a: Waiting
01:13:50 51b9ddb7198d: Waiting
01:13:50 6c8318350323: Waiting
01:13:50 9601eb373c5a: Waiting
01:13:50 259b78ba95b0: Waiting
01:13:50 4ec236b62c9b: Waiting
01:13:50 dac2222ca532: Verifying Checksum
01:13:50 dac2222ca532: Download complete
01:13:50 050382585609: Verifying Checksum
01:13:50 050382585609: Download complete
01:13:50 6ad337b9b53f: Verifying Checksum
01:13:50 6ad337b9b53f: Download complete
01:13:50 7ad6fc7f0fa9: Verifying Checksum
01:13:50 7ad6fc7f0fa9: Download complete
01:13:51 51b9ddb7198d: Verifying Checksum
01:13:51 51b9ddb7198d: Download complete
01:13:51 29a7fe408caa: Verifying Checksum
01:13:51 29a7fe408caa: Download complete
01:13:51 050382585609: Pull complete
01:13:51 9601eb373c5a: Verifying Checksum
01:13:51 9601eb373c5a: Download complete
01:13:51 6c8318350323: Verifying Checksum
01:13:51 6c8318350323: Download complete
01:13:51 dac2222ca532: Pull complete
01:13:51 259b78ba95b0: Verifying Checksum
01:13:51 259b78ba95b0: Download complete
01:13:51 4ec236b62c9b: Verifying Checksum
01:13:51 4ec236b62c9b: Download complete
01:13:51 4f10d41363a8: Verifying Checksum
01:13:51 4f10d41363a8: Download complete
01:13:51 dfa88475ea08: Verifying Checksum
01:13:51 dfa88475ea08: Download complete
01:13:52 42d83eff80c9: Verifying Checksum
01:13:52 42d83eff80c9: Download complete
01:13:52 a11c274c0f9b: Verifying Checksum
01:13:52 a11c274c0f9b: Download complete
01:13:52 8ceab1156925: Verifying Checksum
01:13:52 8ceab1156925: Download complete
01:13:52 4600801c3d3a: Verifying Checksum
01:13:52 4600801c3d3a: Download complete
01:13:52 f423c3d5c2bb: Verifying Checksum
01:13:52 f423c3d5c2bb: Download complete
01:13:52 2099bcf0bd4a: Verifying Checksum
01:13:52 2099bcf0bd4a: Download complete
01:13:52 00932efc1e1d: Verifying Checksum
01:13:52 00932efc1e1d: Download complete
01:13:53 34181986d124: Verifying Checksum
01:13:53 34181986d124: Download complete
01:13:53 a3c986dbc6a4: Verifying Checksum
01:13:53 a3c986dbc6a4: Download complete
01:13:53 29a7fe408caa: Pull complete
01:13:53 6ad337b9b53f: Pull complete
01:13:54 7ad6fc7f0fa9: Pull complete
01:13:57 2099bcf0bd4a: Pull complete
01:13:57 51b9ddb7198d: Pull complete
01:13:57 6c8318350323: Pull complete
01:13:57 9601eb373c5a: Pull complete
01:13:58 259b78ba95b0: Pull complete
01:13:58 4ec236b62c9b: Pull complete
01:13:58 4f10d41363a8: Pull complete
01:13:58 dfa88475ea08: Pull complete
01:13:58 a11c274c0f9b: Pull complete
01:13:58 42d83eff80c9: Pull complete
01:13:58 8ceab1156925: Pull complete
01:13:58 4600801c3d3a: Pull complete
01:13:58 f423c3d5c2bb: Pull complete
01:14:01 34181986d124: Pull complete
01:14:01 00932efc1e1d: Pull complete
01:14:02 a3c986dbc6a4: Pull complete
01:14:02 Digest: sha256:8c6049026883a4e1422f4aab41226b903fb69db598a8e3bdff45679df802b11a
01:14:02 Status: Downloaded newer image for dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // withDockerRegistry
[Pipeline] }
[Pipeline] // node
[Pipeline] node
Terminated
Running on ubuntu-1804-overlay2 (i-07ae1c6d1fe0e80f9) in /home/ubuntu/workspace/compose_PR-6850
[Pipeline] {
[Pipeline] withDockerRegistry
$ docker login -u dockerbuildbot -p ******** https://index.docker.io/v1/
WARNING! Using --password via the CLI is insecure. Use --password-stdin.
WARNING! Your password will be stored unencrypted in /home/ubuntu/workspace/compose_PR-6850@tmp/eac17089-24c9-4d26-b392-10cb2603a5f9/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store

Login Succeeded
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] echo
01:14:10 cleanWorkspace: Ensuring workspace is owned by ubuntu
[Pipeline] echo
01:14:10 chowning workspace
[Pipeline] sh
01:14:11 + uname -m
[Pipeline] sh
01:14:11 + pwd
01:14:11 + id -u
01:14:11 + id -g
01:14:11 + docker run --rm -v /home/ubuntu/workspace/compose_PR-6850:/workspace busybox chown -R 1000:1000 /workspace
[Pipeline] echo
01:14:14 Removing all docker containers
[Pipeline] sh
01:14:14 + docker container ls -aq
[Pipeline] echo
01:14:14 Docker containers have been removed
[Pipeline] echo
01:14:14 cleanWorkspace: Removing existing workspace
[Pipeline] deleteDir
[Pipeline] echo
01:14:14 cleanWorkspace: Workspace is clean.
[Pipeline] stage
[Pipeline] { (build image for "debian")
[Pipeline] checkout
01:14:14 using credential sf-release-bot.github.ssh
01:14:14 Cloning the remote Git repository
01:14:14 Cloning with configured refspecs honoured and without tags
Cloning repository git@github.com:docker/compose.git
 > git init /home/ubuntu/workspace/compose_PR-6850 # 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/pull/6850/head:refs/remotes/origin/PR-6850
01:14:16 Fetching without tags
01:14:16 Checking out Revision 04ce00a71373d402ca9ab2ea7a9f732eeab4778e (PR-6850)
01:14:16 Commit message: "add --skip-env-file option"
 > git config remote.origin.url git@github.com:docker/compose.git # timeout=10
 > git config --add remote.origin.fetch +refs/pull/6850/head:refs/remotes/origin/PR-6850 # 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/pull/6850/head:refs/remotes/origin/PR-6850
 > git config core.sparsecheckout # timeout=10
 > git checkout -f 04ce00a71373d402ca9ab2ea7a9f732eeab4778e
[Pipeline] sh
01:14:17 + docker pull dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e
01:14:17 debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e: Pulling from dockerbuildbot/compose
01:14:17 0a4690c5d889: Pulling fs layer
01:14:17 9ef510f4d0f7: Pulling fs layer
01:14:17 53fe96932e3f: Pulling fs layer
01:14:17 13d55380052c: Pulling fs layer
01:14:17 3102f4cc793a: Pulling fs layer
01:14:17 d320458ac7a5: Pulling fs layer
01:14:17 9f3ef983a669: Pulling fs layer
01:14:17 7d4fe19f703b: Pulling fs layer
01:14:17 a20184eb9807: Pulling fs layer
01:14:17 151fd087b5a9: Pulling fs layer
01:14:17 1639fd0d0dee: Pulling fs layer
01:14:17 8c3fcfeb31cb: Pulling fs layer
01:14:17 2bed9d31e3c9: Pulling fs layer
01:14:17 f69ce32ceba7: Pulling fs layer
01:14:17 a3bead48c3ea: Pulling fs layer
01:14:17 b40280e945e0: Pulling fs layer
01:14:17 c3ef7a730c92: Pulling fs layer
01:14:17 c65815eb55fa: Pulling fs layer
01:14:17 64f3aacfb141: Pulling fs layer
01:14:17 b6e24a215c19: Pulling fs layer
01:14:17 4d7a60876880: Pulling fs layer
01:14:17 13d55380052c: Waiting
01:14:17 3102f4cc793a: Waiting
01:14:17 d320458ac7a5: Waiting
01:14:17 9f3ef983a669: Waiting
01:14:17 7d4fe19f703b: Waiting
01:14:17 a20184eb9807: Waiting
01:14:17 8c3fcfeb31cb: Waiting
01:14:17 2bed9d31e3c9: Waiting
01:14:17 f69ce32ceba7: Waiting
01:14:17 a3bead48c3ea: Waiting
01:14:17 b40280e945e0: Waiting
01:14:17 c3ef7a730c92: Waiting
01:14:17 c65815eb55fa: Waiting
01:14:17 64f3aacfb141: Waiting
01:14:17 b6e24a215c19: Waiting
01:14:17 4d7a60876880: Waiting
01:14:17 151fd087b5a9: Waiting
01:14:17 1639fd0d0dee: Waiting
01:14:18 0a4690c5d889: Verifying Checksum
01:14:18 0a4690c5d889: Download complete
01:14:18 9ef510f4d0f7: Verifying Checksum
01:14:18 9ef510f4d0f7: Download complete
01:14:18 13d55380052c: Verifying Checksum
01:14:18 13d55380052c: Download complete
01:14:18 53fe96932e3f: Verifying Checksum
01:14:18 53fe96932e3f: Download complete
01:14:18 3102f4cc793a: Download complete
01:14:18 9f3ef983a669: Verifying Checksum
01:14:18 9f3ef983a669: Download complete
01:14:18 a20184eb9807: Verifying Checksum
01:14:18 a20184eb9807: Download complete
01:14:18 7d4fe19f703b: Verifying Checksum
01:14:18 7d4fe19f703b: Download complete
01:14:18 151fd087b5a9: Verifying Checksum
01:14:18 151fd087b5a9: Download complete
01:14:19 8c3fcfeb31cb: Verifying Checksum
01:14:19 8c3fcfeb31cb: Download complete
01:14:19 1639fd0d0dee: Verifying Checksum
01:14:19 1639fd0d0dee: Download complete
01:14:19 2bed9d31e3c9: Verifying Checksum
01:14:19 2bed9d31e3c9: Download complete
01:14:19 f69ce32ceba7: Verifying Checksum
01:14:19 f69ce32ceba7: Download complete
01:14:19 a3bead48c3ea: Verifying Checksum
01:14:19 a3bead48c3ea: Download complete
01:14:19 c3ef7a730c92: Verifying Checksum
01:14:19 c3ef7a730c92: Download complete
01:14:19 0a4690c5d889: Pull complete
01:14:19 c65815eb55fa: Verifying Checksum
01:14:19 c65815eb55fa: Download complete
01:14:19 b40280e945e0: Verifying Checksum
01:14:19 b40280e945e0: Download complete
01:14:19 9ef510f4d0f7: Pull complete
01:14:20 b6e24a215c19: Verifying Checksum
01:14:20 b6e24a215c19: Download complete
01:14:21 64f3aacfb141: Verifying Checksum
01:14:21 64f3aacfb141: Download complete
01:14:21 d320458ac7a5: Verifying Checksum
01:14:21 d320458ac7a5: Download complete
01:14:21 4d7a60876880: Verifying Checksum
01:14:21 4d7a60876880: Download complete
01:14:21 53fe96932e3f: Pull complete
01:14:21 13d55380052c: Pull complete
01:14:22 3102f4cc793a: Pull complete
01:14:25 d320458ac7a5: Pull complete
01:14:25 9f3ef983a669: Pull complete
01:14:26 7d4fe19f703b: Pull complete
01:14:26 a20184eb9807: Pull complete
01:14:26 151fd087b5a9: Pull complete
01:14:26 1639fd0d0dee: Pull complete
01:14:26 8c3fcfeb31cb: Pull complete
01:14:26 2bed9d31e3c9: Pull complete
01:14:26 f69ce32ceba7: Pull complete
01:14:26 a3bead48c3ea: Pull complete
01:14:27 b40280e945e0: Pull complete
01:14:27 c3ef7a730c92: Pull complete
01:14:27 c65815eb55fa: Pull complete
01:14:29 64f3aacfb141: Pull complete
01:14:29 b6e24a215c19: Pull complete
01:14:30 4d7a60876880: Pull complete
01:14:30 Digest: sha256:ec739b4cd5f5766868b7732ee60ae6e6ce65f5f937cb06e3339bc38627a53751
01:14:30 Status: Downloaded newer image for dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e
01:14:30 docker.io/dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e
[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // withDockerRegistry
[Pipeline] }
[Pipeline] // node
[Pipeline] echo
image.id: dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e
[Pipeline] node
Terminated
Still waiting to schedule task
Waiting for next available executor on ‘ubuntu&&!zfs’
Running on ubuntu-1804-overlay2 (i-0016180e46f01b4fe) in /home/ubuntu/workspace/compose_PR-6850
[Pipeline] {
[Pipeline] withDockerRegistry
$ docker login -u dockerbuildbot -p ******** https://index.docker.io/v1/
WARNING! Using --password via the CLI is insecure. Use --password-stdin.
WARNING! Your password will be stored unencrypted in /home/ubuntu/workspace/compose_PR-6850@tmp/1df1cb7a-31f9-459a-80d5-0543ddacade3/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store

Login Succeeded
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] sh
01:15:12 + docker run --rm --entrypoint=/code/.tox/py27/bin/python dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e /code/script/test/versions.py -n 2 docker/docker-ce recent
01:15:12 Unable to find image 'dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e' locally
01:15:12 debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e: Pulling from dockerbuildbot/compose
01:15:12 0a4690c5d889: Pulling fs layer
01:15:12 9ef510f4d0f7: Pulling fs layer
01:15:12 53fe96932e3f: Pulling fs layer
01:15:12 13d55380052c: Pulling fs layer
01:15:12 3102f4cc793a: Pulling fs layer
01:15:12 d320458ac7a5: Pulling fs layer
01:15:12 9f3ef983a669: Pulling fs layer
01:15:12 7d4fe19f703b: Pulling fs layer
01:15:12 a20184eb9807: Pulling fs layer
01:15:12 151fd087b5a9: Pulling fs layer
01:15:12 1639fd0d0dee: Pulling fs layer
01:15:12 8c3fcfeb31cb: Pulling fs layer
01:15:12 2bed9d31e3c9: Pulling fs layer
01:15:12 f69ce32ceba7: Pulling fs layer
01:15:12 a3bead48c3ea: Pulling fs layer
01:15:12 b40280e945e0: Pulling fs layer
01:15:12 c3ef7a730c92: Pulling fs layer
01:15:12 c65815eb55fa: Pulling fs layer
01:15:12 64f3aacfb141: Pulling fs layer
01:15:12 b6e24a215c19: Pulling fs layer
01:15:12 4d7a60876880: Pulling fs layer
01:15:12 8c3fcfeb31cb: Waiting
01:15:12 2bed9d31e3c9: Waiting
01:15:12 f69ce32ceba7: Waiting
01:15:12 a3bead48c3ea: Waiting
01:15:12 b40280e945e0: Waiting
01:15:12 c3ef7a730c92: Waiting
01:15:12 13d55380052c: Waiting
01:15:12 3102f4cc793a: Waiting
01:15:12 d320458ac7a5: Waiting
01:15:12 9f3ef983a669: Waiting
01:15:12 7d4fe19f703b: Waiting
01:15:12 a20184eb9807: Waiting
01:15:12 151fd087b5a9: Waiting
01:15:12 1639fd0d0dee: Waiting
01:15:12 c65815eb55fa: Waiting
01:15:12 64f3aacfb141: Waiting
01:15:12 b6e24a215c19: Waiting
01:15:12 4d7a60876880: Waiting
01:15:12 9ef510f4d0f7: Verifying Checksum
01:15:12 9ef510f4d0f7: Download complete
01:15:12 53fe96932e3f: Verifying Checksum
01:15:12 53fe96932e3f: Download complete
01:15:12 13d55380052c: Verifying Checksum
01:15:12 13d55380052c: Download complete
01:15:12 0a4690c5d889: Verifying Checksum
01:15:12 0a4690c5d889: Download complete
01:15:12 3102f4cc793a: Download complete
01:15:12 9f3ef983a669: Verifying Checksum
01:15:12 9f3ef983a669: Download complete
01:15:12 a20184eb9807: Verifying Checksum
01:15:12 a20184eb9807: Download complete
01:15:13 7d4fe19f703b: Verifying Checksum
01:15:13 7d4fe19f703b: Download complete
01:15:13 151fd087b5a9: Verifying Checksum
01:15:13 151fd087b5a9: Download complete
01:15:13 8c3fcfeb31cb: Verifying Checksum
01:15:13 8c3fcfeb31cb: Download complete
01:15:13 1639fd0d0dee: Verifying Checksum
01:15:13 1639fd0d0dee: Download complete
01:15:13 2bed9d31e3c9: Verifying Checksum
01:15:13 2bed9d31e3c9: Download complete
01:15:13 a3bead48c3ea: Verifying Checksum
01:15:13 a3bead48c3ea: Download complete
01:15:13 f69ce32ceba7: Verifying Checksum
01:15:13 f69ce32ceba7: Download complete
01:15:13 b40280e945e0: Verifying Checksum
01:15:13 b40280e945e0: Download complete
01:15:13 c3ef7a730c92: Verifying Checksum
01:15:13 c3ef7a730c92: Download complete
01:15:13 c65815eb55fa: Verifying Checksum
01:15:13 c65815eb55fa: Download complete
01:15:13 b6e24a215c19: Verifying Checksum
01:15:13 b6e24a215c19: Download complete
01:15:14 64f3aacfb141: Verifying Checksum
01:15:14 64f3aacfb141: Download complete
01:15:14 4d7a60876880: Verifying Checksum
01:15:14 4d7a60876880: Download complete
01:15:14 d320458ac7a5: Verifying Checksum
01:15:14 d320458ac7a5: Download complete
01:15:15 0a4690c5d889: Pull complete
01:15:15 9ef510f4d0f7: Pull complete
01:15:16 53fe96932e3f: Pull complete
01:15:16 13d55380052c: Pull complete
01:15:17 3102f4cc793a: Pull complete
01:15:20 d320458ac7a5: Pull complete
01:15:20 9f3ef983a669: Pull complete
01:15:21 7d4fe19f703b: Pull complete
01:15:21 a20184eb9807: Pull complete
01:15:21 151fd087b5a9: Pull complete
01:15:21 1639fd0d0dee: Pull complete
01:15:21 8c3fcfeb31cb: Pull complete
01:15:21 2bed9d31e3c9: Pull complete
01:15:21 f69ce32ceba7: Pull complete
01:15:21 a3bead48c3ea: Pull complete
01:15:21 b40280e945e0: Pull complete
01:15:22 c3ef7a730c92: Pull complete
01:15:22 c65815eb55fa: Pull complete
01:15:24 64f3aacfb141: Pull complete
01:15:24 b6e24a215c19: Pull complete
01:15:25 4d7a60876880: Pull complete
01:15:25 Digest: sha256:ec739b4cd5f5766868b7732ee60ae6e6ce65f5f937cb06e3339bc38627a53751
01:15:25 Status: Downloaded newer image for dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // withDockerRegistry
[Pipeline] }
[Pipeline] // node
[Pipeline] parallel
[Pipeline] { (Branch: alpine_19.03.2-rc1_py27)
[Pipeline] { (Branch: alpine_19.03.2-rc1_py37)
[Pipeline] { (Branch: alpine_18.09.9-rc1_py27)
[Pipeline] { (Branch: alpine_18.09.9-rc1_py37)
[Pipeline] { (Branch: debian_19.03.2-rc1_py27)
[Pipeline] { (Branch: debian_19.03.2-rc1_py37)
[Pipeline] { (Branch: debian_18.09.9-rc1_py27)
[Pipeline] { (Branch: debian_18.09.9-rc1_py37)
[Pipeline] node
[Pipeline] node
[Pipeline] node
[Pipeline] node
[Pipeline] node
[Pipeline] node
[Pipeline] node
[Pipeline] node
Terminated
Still waiting to schedule task
Waiting for next available executor on ‘ubuntu&&!zfs’
Still waiting to schedule task
Waiting for next available executor on ‘ubuntu&&!zfs’
Still waiting to schedule task
Waiting for next available executor on ‘ubuntu&&!zfs’
Still waiting to schedule task
Waiting for next available executor on ‘ubuntu&&!zfs’
Still waiting to schedule task
Waiting for next available executor on ‘ubuntu&&!zfs’
Still waiting to schedule task
Waiting for next available executor on ‘ubuntu&&!zfs’
Still waiting to schedule task
Waiting for next available executor on ‘ubuntu&&!zfs’
Still waiting to schedule task
Waiting for next available executor on ‘ubuntu&&!zfs’
Running on ubuntu-1604-aufs (i-0d29a4940423fcdfc) in /home/ubuntu/workspace/compose_PR-6850
[Pipeline] {
[Pipeline] withDockerRegistry
$ docker login -u dockerbuildbot -p ******** https://index.docker.io/v1/
WARNING! Using --password via the CLI is insecure. Use --password-stdin.
WARNING! Your password will be stored unencrypted in /home/ubuntu/workspace/compose_PR-6850@tmp/4e77b31e-d8dc-4831-9869-2b47a607667f/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store

Login Succeeded
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] echo
01:23:04 cleanWorkspace: Ensuring workspace is owned by ubuntu
[Pipeline] echo
01:23:04 chowning workspace
[Pipeline] sh
01:23:05 + uname -m
[Pipeline] sh
01:23:05 + pwd
01:23:05 + id -u
01:23:05 + id -g
01:23:05 + docker run --rm -v /home/ubuntu/workspace/compose_PR-6850:/workspace busybox chown -R 1000:1000 /workspace
01:23:05 Unable to find image 'busybox:latest' locally
01:23:05 latest: Pulling from library/busybox
01:23:05 ee153a04d683: Pulling fs layer
01:23:05 ee153a04d683: Download complete
01:23:05 ee153a04d683: Pull complete
01:23:05 Digest: sha256:9f1003c480699be56815db0f8146ad2e22efea85129b5b5983d0e0fb52d9ab70
01:23:05 Status: Downloaded newer image for busybox:latest
[Pipeline] echo
01:23:07 Removing all docker containers
[Pipeline] sh
01:23:07 + docker container ls -aq
[Pipeline] echo
01:23:07 Docker containers have been removed
[Pipeline] echo
01:23:07 cleanWorkspace: Removing existing workspace
[Pipeline] deleteDir
[Pipeline] echo
01:23:07 cleanWorkspace: Workspace is clean.
[Pipeline] stage
[Pipeline] { (test python=py27 / docker=19.03.2-rc1 / baseImage=alpine)
[Pipeline] checkout
01:23:08 using credential sf-release-bot.github.ssh
01:23:08 Cloning the remote Git repository
01:23:08 Cloning with configured refspecs honoured and without tags
Cloning repository git@github.com:docker/compose.git
 > git init /home/ubuntu/workspace/compose_PR-6850 # 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/pull/6850/head:refs/remotes/origin/PR-6850
01:23:10 Fetching without tags
01:23:10 Checking out Revision 04ce00a71373d402ca9ab2ea7a9f732eeab4778e (PR-6850)
01:23:10 Commit message: "add --skip-env-file option"
 > git config remote.origin.url git@github.com:docker/compose.git # timeout=10
 > git config --add remote.origin.fetch +refs/pull/6850/head:refs/remotes/origin/PR-6850 # 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/pull/6850/head:refs/remotes/origin/PR-6850
 > git config core.sparsecheckout # timeout=10
 > git checkout -f 04ce00a71373d402ca9ab2ea7a9f732eeab4778e
[Pipeline] sh
01:23:11 + awk -F :  $1 == "Storage Driver" { print $2; exit }
01:23:11 + docker info
01:23:16 WARNING: No swap limit support
01:23:16 WARNING: the aufs storage-driver is deprecated, and will be removed in a future release.
[Pipeline] echo
01:23:16 Using local system's storage driver: 
[Pipeline] sh
01:23:17 + pwd
01:23:17 + docker run -t --rm --privileged --volume=/home/ubuntu/workspace/compose_PR-6850/.git:/code/.git --volume=/var/run/docker.sock:/var/run/docker.sock -e TAG=dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e -e STORAGE_DRIVER= -e DOCKER_VERSIONS=19.03.2-rc1 -e BUILD_NUMBER=jenkins-compose-PR-6850-2 -e PY_TEST_VERSIONS=py27 --entrypoint=script/test/ci dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e --verbose
01:23:17 Unable to find image 'dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e' locally
01:23:17 alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e: Pulling from dockerbuildbot/compose
01:23:17 050382585609: Pulling fs layer
01:23:17 dac2222ca532: Pulling fs layer
01:23:17 29a7fe408caa: Pulling fs layer
01:23:17 6ad337b9b53f: Pulling fs layer
01:23:17 7ad6fc7f0fa9: Pulling fs layer
01:23:17 2099bcf0bd4a: Pulling fs layer
01:23:17 51b9ddb7198d: Pulling fs layer
01:23:17 6c8318350323: Pulling fs layer
01:23:17 9601eb373c5a: Pulling fs layer
01:23:17 259b78ba95b0: Pulling fs layer
01:23:17 4ec236b62c9b: Pulling fs layer
01:23:17 4f10d41363a8: Pulling fs layer
01:23:17 dfa88475ea08: Pulling fs layer
01:23:17 a11c274c0f9b: Pulling fs layer
01:23:17 42d83eff80c9: Pulling fs layer
01:23:17 8ceab1156925: Pulling fs layer
01:23:17 4600801c3d3a: Pulling fs layer
01:23:17 f423c3d5c2bb: Pulling fs layer
01:23:17 34181986d124: Pulling fs layer
01:23:17 00932efc1e1d: Pulling fs layer
01:23:17 a3c986dbc6a4: Pulling fs layer
01:23:17 6ad337b9b53f: Waiting
01:23:17 7ad6fc7f0fa9: Waiting
01:23:17 2099bcf0bd4a: Waiting
01:23:17 51b9ddb7198d: Waiting
01:23:17 6c8318350323: Waiting
01:23:17 9601eb373c5a: Waiting
01:23:17 259b78ba95b0: Waiting
01:23:17 4ec236b62c9b: Waiting
01:23:17 4f10d41363a8: Waiting
01:23:17 dfa88475ea08: Waiting
01:23:17 a11c274c0f9b: Waiting
01:23:17 42d83eff80c9: Waiting
01:23:17 8ceab1156925: Waiting
01:23:17 a3c986dbc6a4: Waiting
01:23:17 4600801c3d3a: Waiting
01:23:17 f423c3d5c2bb: Waiting
01:23:17 00932efc1e1d: Waiting
01:23:17 34181986d124: Waiting
01:23:17 dac2222ca532: Download complete
01:23:17 050382585609: Verifying Checksum
01:23:17 050382585609: Download complete
01:23:17 6ad337b9b53f: Verifying Checksum
01:23:17 6ad337b9b53f: Download complete
01:23:17 7ad6fc7f0fa9: Verifying Checksum
01:23:17 7ad6fc7f0fa9: Download complete
01:23:17 29a7fe408caa: Verifying Checksum
01:23:17 29a7fe408caa: Download complete
01:23:17 51b9ddb7198d: Verifying Checksum
01:23:17 51b9ddb7198d: Download complete
01:23:17 9601eb373c5a: Verifying Checksum
01:23:17 9601eb373c5a: Download complete
Running on ubuntu-1804-overlay2 (i-04f11f6a8d2bf2b7b) in /home/ubuntu/workspace/compose_PR-6850
[Pipeline] {
[Pipeline] withDockerRegistry
$ docker login -u dockerbuildbot -p ******** https://index.docker.io/v1/
WARNING! Using --password via the CLI is insecure. Use --password-stdin.
WARNING! Your password will be stored unencrypted in /home/ubuntu/workspace/compose_PR-6850@tmp/23aac3b0-25ac-4b96-a149-618f665e0c5d/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store

Login Succeeded
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] wrap
01:23:17 050382585609: Pull complete
[Pipeline] {
[Pipeline] echo
01:23:17 cleanWorkspace: Ensuring workspace is owned by ubuntu
[Pipeline] echo
01:23:17 chowning workspace
[Pipeline] sh
01:23:18 259b78ba95b0: Verifying Checksum
01:23:18 259b78ba95b0: Download complete
01:23:18 6c8318350323: Verifying Checksum
01:23:18 6c8318350323: Download complete
01:23:18 4ec236b62c9b: Download complete
01:23:18 4f10d41363a8: Verifying Checksum
01:23:18 4f10d41363a8: Download complete
01:23:18 dac2222ca532: Pull complete
01:23:18 dfa88475ea08: Verifying Checksum
01:23:18 dfa88475ea08: Download complete
01:23:18 + uname -m
[Pipeline] sh
01:23:18 a11c274c0f9b: Verifying Checksum
01:23:18 a11c274c0f9b: Download complete
01:23:18 8ceab1156925: Verifying Checksum
01:23:18 8ceab1156925: Download complete
01:23:18 42d83eff80c9: Verifying Checksum
01:23:18 42d83eff80c9: Download complete
01:23:18 4600801c3d3a: Verifying Checksum
01:23:18 4600801c3d3a: Download complete
01:23:18 + pwd
01:23:18 + id -u
01:23:18 + id -g
01:23:18 + docker run --rm -v /home/ubuntu/workspace/compose_PR-6850:/workspace busybox chown -R 1000:1000 /workspace
01:23:18 2099bcf0bd4a: Verifying Checksum
01:23:18 2099bcf0bd4a: Download complete
01:23:18 f423c3d5c2bb: Verifying Checksum
01:23:18 f423c3d5c2bb: Download complete
01:23:18 00932efc1e1d: Verifying Checksum
01:23:18 00932efc1e1d: Download complete
01:23:19 34181986d124: Verifying Checksum
01:23:19 34181986d124: Download complete
[Pipeline] echo
01:23:19 Removing all docker containers
[Pipeline] sh
01:23:19 a3c986dbc6a4: Verifying Checksum
01:23:19 a3c986dbc6a4: Download complete
01:23:19 + docker container ls -aq
[Pipeline] echo
01:23:19 Docker containers have been removed
[Pipeline] echo
01:23:19 cleanWorkspace: Removing existing workspace
[Pipeline] deleteDir
[Pipeline] echo
01:23:19 cleanWorkspace: Workspace is clean.
[Pipeline] stage
[Pipeline] { (test python=py37 / docker=19.03.2-rc1 / baseImage=alpine)
[Pipeline] checkout
01:23:19 using credential sf-release-bot.github.ssh
01:23:19 Cloning the remote Git repository
01:23:19 Cloning with configured refspecs honoured and without tags
01:23:20 29a7fe408caa: Pull complete
01:23:20 6ad337b9b53f: Pull complete
01:23:20 7ad6fc7f0fa9: Pull complete
Cloning repository git@github.com:docker/compose.git
 > git init /home/ubuntu/workspace/compose_PR-6850 # 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/pull/6850/head:refs/remotes/origin/PR-6850
01:23:21 Fetching without tags
01:23:21 Checking out Revision 04ce00a71373d402ca9ab2ea7a9f732eeab4778e (PR-6850)
01:23:21 Commit message: "add --skip-env-file option"
 > git config remote.origin.url git@github.com:docker/compose.git # timeout=10
 > git config --add remote.origin.fetch +refs/pull/6850/head:refs/remotes/origin/PR-6850 # 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/pull/6850/head:refs/remotes/origin/PR-6850
 > git config core.sparsecheckout # timeout=10
 > git checkout -f 04ce00a71373d402ca9ab2ea7a9f732eeab4778e
[Pipeline] sh
01:23:22 + awk -F :  $1 == "Storage Driver" { print $2; exit }
01:23:22 + docker info
01:23:22 WARNING: No swap limit support
[Pipeline] echo
01:23:22 Using local system's storage driver: 
[Pipeline] sh
01:23:22 + pwd
01:23:22 + docker run -t --rm --privileged --volume=/home/ubuntu/workspace/compose_PR-6850/.git:/code/.git --volume=/var/run/docker.sock:/var/run/docker.sock -e TAG=dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e -e STORAGE_DRIVER= -e DOCKER_VERSIONS=19.03.2-rc1 -e BUILD_NUMBER=jenkins-compose-PR-6850-2 -e PY_TEST_VERSIONS=py37 --entrypoint=script/test/ci dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e --verbose
01:23:22 Unable to find image 'dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e' locally
01:23:22 alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e: Pulling from dockerbuildbot/compose
01:23:22 050382585609: Already exists
01:23:22 dac2222ca532: Already exists
01:23:22 29a7fe408caa: Already exists
01:23:22 6ad337b9b53f: Already exists
01:23:22 7ad6fc7f0fa9: Already exists
01:23:22 2099bcf0bd4a: Pulling fs layer
01:23:22 51b9ddb7198d: Pulling fs layer
01:23:22 6c8318350323: Pulling fs layer
01:23:22 9601eb373c5a: Pulling fs layer
01:23:22 259b78ba95b0: Pulling fs layer
01:23:22 4ec236b62c9b: Pulling fs layer
01:23:22 4f10d41363a8: Pulling fs layer
01:23:22 dfa88475ea08: Pulling fs layer
01:23:22 a11c274c0f9b: Pulling fs layer
01:23:22 42d83eff80c9: Pulling fs layer
01:23:22 8ceab1156925: Pulling fs layer
01:23:22 4600801c3d3a: Pulling fs layer
01:23:22 f423c3d5c2bb: Pulling fs layer
01:23:22 34181986d124: Pulling fs layer
01:23:22 00932efc1e1d: Pulling fs layer
01:23:22 a3c986dbc6a4: Pulling fs layer
01:23:22 9601eb373c5a: Waiting
01:23:22 259b78ba95b0: Waiting
01:23:22 4ec236b62c9b: Waiting
01:23:22 4f10d41363a8: Waiting
01:23:22 dfa88475ea08: Waiting
01:23:22 a11c274c0f9b: Waiting
01:23:22 42d83eff80c9: Waiting
01:23:22 8ceab1156925: Waiting
01:23:22 4600801c3d3a: Waiting
01:23:22 f423c3d5c2bb: Waiting
01:23:22 34181986d124: Waiting
01:23:22 00932efc1e1d: Waiting
01:23:22 a3c986dbc6a4: Waiting
01:23:22 51b9ddb7198d: Verifying Checksum
01:23:22 51b9ddb7198d: Download complete
01:23:22 9601eb373c5a: Verifying Checksum
01:23:22 9601eb373c5a: Download complete
01:23:23 6c8318350323: Verifying Checksum
01:23:23 6c8318350323: Download complete
01:23:23 4ec236b62c9b: Verifying Checksum
01:23:23 4ec236b62c9b: Download complete
01:23:23 259b78ba95b0: Verifying Checksum
01:23:23 259b78ba95b0: Download complete
01:23:23 4f10d41363a8: Verifying Checksum
01:23:23 4f10d41363a8: Download complete
01:23:23 a11c274c0f9b: Verifying Checksum
01:23:23 a11c274c0f9b: Download complete
01:23:23 dfa88475ea08: Verifying Checksum
01:23:23 dfa88475ea08: Download complete
01:23:23 42d83eff80c9: Verifying Checksum
01:23:23 42d83eff80c9: Download complete
01:23:23 4600801c3d3a: Verifying Checksum
01:23:23 4600801c3d3a: Download complete
01:23:23 f423c3d5c2bb: Verifying Checksum
01:23:23 f423c3d5c2bb: Download complete
01:23:23 8ceab1156925: Verifying Checksum
01:23:23 8ceab1156925: Download complete
01:23:23 2099bcf0bd4a: Verifying Checksum
01:23:23 2099bcf0bd4a: Download complete
01:23:23 00932efc1e1d: Verifying Checksum
01:23:23 00932efc1e1d: Download complete
01:23:23 34181986d124: Verifying Checksum
01:23:23 34181986d124: Download complete
01:23:23 2099bcf0bd4a: Pull complete
01:23:23 51b9ddb7198d: Pull complete
01:23:24 a3c986dbc6a4: Verifying Checksum
01:23:24 a3c986dbc6a4: Download complete
01:23:24 6c8318350323: Pull complete
01:23:24 9601eb373c5a: Pull complete
01:23:24 259b78ba95b0: Pull complete
01:23:24 4ec236b62c9b: Pull complete
01:23:24 4f10d41363a8: Pull complete
01:23:25 dfa88475ea08: Pull complete
01:23:25 a11c274c0f9b: Pull complete
01:23:25 42d83eff80c9: Pull complete
01:23:25 8ceab1156925: Pull complete
01:23:25 4600801c3d3a: Pull complete
01:23:25 f423c3d5c2bb: Pull complete
01:23:26 2099bcf0bd4a: Pull complete
01:23:27 51b9ddb7198d: Pull complete
01:23:27 34181986d124: Pull complete
01:23:27 6c8318350323: Pull complete
01:23:27 9601eb373c5a: Pull complete
01:23:27 00932efc1e1d: Pull complete
01:23:28 259b78ba95b0: Pull complete
01:23:28 4ec236b62c9b: Pull complete
01:23:28 4f10d41363a8: Pull complete
01:23:28 dfa88475ea08: Pull complete
01:23:28 a11c274c0f9b: Pull complete
01:23:28 42d83eff80c9: Pull complete
01:23:28 8ceab1156925: Pull complete
01:23:28 4600801c3d3a: Pull complete
01:23:28 f423c3d5c2bb: Pull complete
01:23:28 a3c986dbc6a4: Pull complete
01:23:28 Digest: sha256:8c6049026883a4e1422f4aab41226b903fb69db598a8e3bdff45679df802b11a
01:23:28 Status: Downloaded newer image for dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e
01:23:29 + docker version
01:23:29 Client: Docker Engine - Community
01:23:29  Version:           18.09.7
01:23:29  API version:       1.39
01:23:29  Go version:        go1.10.8
01:23:29  Git commit:        2d0083d
01:23:29  Built:             Thu Jun 27 17:54:15 2019
01:23:29  OS/Arch:           linux/amd64
01:23:29  Experimental:      false
01:23:29 
01:23:29 Server: Docker Engine - Community
01:23:29  Engine:
01:23:29   Version:          19.03.1
01:23:29   API version:      1.40 (minimum version 1.12)
01:23:29   Go version:       go1.12.5
01:23:29   Git commit:       74b1e89e8a
01:23:29   Built:            Thu Jul 25 21:20:09 2019
01:23:29   OS/Arch:          linux/amd64
01:23:29   Experimental:     true
01:23:29  containerd:
01:23:29   Version:          1.2.6
01:23:29   GitCommit:        894b81a4b802e4eb2a91d1ce216b8817763c29fb
01:23:29  runc:
01:23:29   Version:          1.0.0-rc8
01:23:29   GitCommit:        425e105d5a03fabd737a126ad93d62a9eeede87f
01:23:29  docker-init:
01:23:29   Version:          0.18.0
01:23:29   GitCommit:        fec3683
01:23:29 + export DOCKER_VERSIONS=19.03.2-rc1
01:23:29 + DOCKER_VERSIONS=19.03.2-rc1
01:23:29 + STORAGE_DRIVER=overlay
01:23:29 + export DOCKER_DAEMON_ARGS=--storage-driver=overlay
01:23:29 + DOCKER_DAEMON_ARGS=--storage-driver=overlay
01:23:29 ++ hostname
01:23:29 + GIT_VOLUME=--volumes-from=258389fa16e8
01:23:29 + . script/test/all
01:23:29 ++ set -e
01:23:29 ++ echo 'Running lint checks'
01:23:29 Running lint checks
01:23:29 ++ docker run --rm --tty --volumes-from=258389fa16e8 dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e tox -e pre-commit
01:23:31 pre-commit installed: aspy.yaml==1.3.0,cfgv==2.0.1,identify==1.4.6,importlib-metadata==0.19,nodeenv==1.3.3,pre-commit==1.18.1,PyYAML==5.1.2,six==1.12.0,toml==0.10.0,virtualenv==16.7.2,zipp==0.5.2

01:23:31 pre-commit runtests: PYTHONHASHSEED='3925520356'

01:23:31 pre-commit runtests: commands[0] | pre-commit install

01:23:31 pre-commit installed at .git/hooks/pre-commit

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

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

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

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

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

01:23:31 34181986d124: Pull complete
01:23:31 00932efc1e1d: Pull complete
01:23:31 [INFO] Installing environment for git://github.com/pre-commit/pre-commit-hooks.

01:23:31 [INFO] Once installed this environment will be reused.

01:23:31 [INFO] This may take a few minutes...

01:23:32 a3c986dbc6a4: Pull complete
01:23:32 Digest: sha256:8c6049026883a4e1422f4aab41226b903fb69db598a8e3bdff45679df802b11a
01:23:32 Status: Downloaded newer image for dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e
01:23:36 + docker version
01:23:36 Client: Docker Engine - Community
01:23:36  Version:           18.09.7
01:23:36  API version:       1.39
01:23:36  Go version:        go1.10.8
01:23:36  Git commit:        2d0083d
01:23:36  Built:             Thu Jun 27 17:54:15 2019
01:23:36  OS/Arch:           linux/amd64
01:23:36  Experimental:      false
01:23:36 
01:23:36 Server: Docker Engine - Community
01:23:36  Engine:
01:23:36   Version:          19.03.1
01:23:36   API version:      1.40 (minimum version 1.12)
01:23:36   Go version:       go1.12.5
01:23:36   Git commit:       74b1e89
01:23:36   Built:            Thu Jul 25 21:19:41 2019
01:23:36   OS/Arch:          linux/amd64
01:23:36   Experimental:     true
01:23:36  containerd:
01:23:36   Version:          1.2.6
01:23:36   GitCommit:        894b81a4b802e4eb2a91d1ce216b8817763c29fb
01:23:36  runc:
01:23:36   Version:          1.0.0-rc8
01:23:36   GitCommit:        425e105d5a03fabd737a126ad93d62a9eeede87f
01:23:36  docker-init:
01:23:36   Version:          0.18.0
01:23:36   GitCommit:        fec3683
01:23:36 + export DOCKER_VERSIONS=19.03.2-rc1
01:23:36 + DOCKER_VERSIONS=19.03.2-rc1
01:23:36 + STORAGE_DRIVER=overlay
01:23:36 + export DOCKER_DAEMON_ARGS=--storage-driver=overlay
01:23:36 + DOCKER_DAEMON_ARGS=--storage-driver=overlay
01:23:36 ++ hostname
01:23:36 + GIT_VOLUME=--volumes-from=67cbaf1b8ed9
01:23:36 + . script/test/all
01:23:36 ++ set -e
01:23:36 ++ echo 'Running lint checks'
01:23:36 Running lint checks
01:23:36 ++ docker run --rm --tty --volumes-from=67cbaf1b8ed9 dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e tox -e pre-commit
01:23:37 pre-commit installed: aspy.yaml==1.3.0,cfgv==2.0.1,identify==1.4.6,importlib-metadata==0.19,nodeenv==1.3.3,pre-commit==1.18.1,PyYAML==5.1.2,six==1.12.0,toml==0.10.0,virtualenv==16.7.2,zipp==0.5.2

01:23:37 pre-commit runtests: PYTHONHASHSEED='158888109'

01:23:37 pre-commit runtests: commands[0] | pre-commit install

01:23:38 pre-commit installed at .git/hooks/pre-commit

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

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

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

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

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

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

01:23:38 [INFO] Once installed this environment will be reused.

01:23:38 [INFO] This may take a few minutes...

Running on ubuntu-1604-aufs (i-0633df9acb9848218) in /home/ubuntu/workspace/compose_PR-6850
[Pipeline] {
[Pipeline] withDockerRegistry
01:23:49 [INFO] Installing environment for git://github.com/asottile/reorder_python_imports.

01:23:49 [INFO] Once installed this environment will be reused.

01:23:49 [INFO] This may take a few minutes...

$ docker login -u dockerbuildbot -p ******** https://index.docker.io/v1/
WARNING! Using --password via the CLI is insecure. Use --password-stdin.
WARNING! Your password will be stored unencrypted in /home/ubuntu/workspace/compose_PR-6850@tmp/a182b7f6-6636-41d4-9355-85721e0b0635/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store

Login Succeeded
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] echo
01:23:53 cleanWorkspace: Ensuring workspace is owned by ubuntu
[Pipeline] echo
01:23:53 chowning workspace
[Pipeline] sh
01:23:54 + uname -m
[Pipeline] sh
01:23:54 + pwd
01:23:54 + id -u
01:23:54 + id -g
01:23:54 + docker run --rm -v /home/ubuntu/workspace/compose_PR-6850:/workspace busybox chown -R 1000:1000 /workspace
01:23:54 Unable to find image 'busybox:latest' locally
01:23:54 latest: Pulling from library/busybox
01:23:54 ee153a04d683: Pulling fs layer
01:23:54 ee153a04d683: Verifying Checksum
01:23:54 ee153a04d683: Download complete
01:23:55 ee153a04d683: Pull complete
01:23:55 Digest: sha256:9f1003c480699be56815db0f8146ad2e22efea85129b5b5983d0e0fb52d9ab70
01:23:55 Status: Downloaded newer image for busybox:latest
[Pipeline] echo
01:23:56 Removing all docker containers
[Pipeline] sh
01:23:56 [INFO] Installing environment for git://github.com/asottile/reorder_python_imports.

01:23:56 [INFO] Once installed this environment will be reused.

01:23:56 [INFO] This may take a few minutes...

01:23:57 + docker container ls -aq
[Pipeline] echo
01:23:57 Docker containers have been removed
[Pipeline] echo
01:23:57 cleanWorkspace: Removing existing workspace
[Pipeline] deleteDir
[Pipeline] echo
01:23:57 cleanWorkspace: Workspace is clean.
[Pipeline] stage
[Pipeline] { (test python=py27 / docker=18.09.9-rc1 / baseImage=alpine)
[Pipeline] checkout
01:23:58 using credential sf-release-bot.github.ssh
01:23:58 Cloning the remote Git repository
01:23:58 Cloning with configured refspecs honoured and without tags
Cloning repository git@github.com:docker/compose.git
 > git init /home/ubuntu/workspace/compose_PR-6850 # 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/pull/6850/head:refs/remotes/origin/PR-6850
01:24:00 Fetching without tags
 > git config remote.origin.url git@github.com:docker/compose.git # timeout=10
 > git config --add remote.origin.fetch +refs/pull/6850/head:refs/remotes/origin/PR-6850 # 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/pull/6850/head:refs/remotes/origin/PR-6850
01:24:00 Checking out Revision 04ce00a71373d402ca9ab2ea7a9f732eeab4778e (PR-6850)
01:24:00 Commit message: "add --skip-env-file option"
 > git config core.sparsecheckout # timeout=10
 > git checkout -f 04ce00a71373d402ca9ab2ea7a9f732eeab4778e
[Pipeline] sh
01:24:01 Check for added large files..............................................Passed

01:24:01 Check docstring is first.................................................Passed

01:24:01 Check for merge conflicts................................................Passed

01:24:01 Check Yaml...............................................................Passed

01:24:01 Check JSON...............................................................Passed

01:24:01 Debug Statements (Python)................................................Passed

01:24:01 Fix End of Files.........................................................Passed

01:24:01 + docker info
01:24:01 + awk -F :  $1 == "Storage Driver" { print $2; exit }
01:24:06 WARNING: No swap limit support
01:24:06 WARNING: the aufs storage-driver is deprecated, and will be removed in a future release.
[Pipeline] echo
01:24:06 Using local system's storage driver: 
[Pipeline] sh
01:24:06 + pwd
01:24:06 + docker run -t --rm --privileged --volume=/home/ubuntu/workspace/compose_PR-6850/.git:/code/.git --volume=/var/run/docker.sock:/var/run/docker.sock -e TAG=dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e -e STORAGE_DRIVER= -e DOCKER_VERSIONS=18.09.9-rc1 -e BUILD_NUMBER=jenkins-compose-PR-6850-2 -e PY_TEST_VERSIONS=py27 --entrypoint=script/test/ci dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e --verbose
01:24:06 Unable to find image 'dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e' locally
01:24:06 alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e: Pulling from dockerbuildbot/compose
01:24:06 050382585609: Pulling fs layer
01:24:06 dac2222ca532: Pulling fs layer
01:24:06 29a7fe408caa: Pulling fs layer
01:24:06 6ad337b9b53f: Pulling fs layer
01:24:06 7ad6fc7f0fa9: Pulling fs layer
01:24:06 2099bcf0bd4a: Pulling fs layer
01:24:06 51b9ddb7198d: Pulling fs layer
01:24:06 6c8318350323: Pulling fs layer
01:24:06 9601eb373c5a: Pulling fs layer
01:24:06 259b78ba95b0: Pulling fs layer
01:24:06 4ec236b62c9b: Pulling fs layer
01:24:06 4f10d41363a8: Pulling fs layer
01:24:06 dfa88475ea08: Pulling fs layer
01:24:06 a11c274c0f9b: Pulling fs layer
01:24:06 42d83eff80c9: Pulling fs layer
01:24:06 8ceab1156925: Pulling fs layer
01:24:06 4600801c3d3a: Pulling fs layer
01:24:06 f423c3d5c2bb: Pulling fs layer
01:24:06 34181986d124: Pulling fs layer
01:24:06 00932efc1e1d: Pulling fs layer
01:24:06 a3c986dbc6a4: Pulling fs layer
01:24:06 6ad337b9b53f: Waiting
01:24:06 dfa88475ea08: Waiting
01:24:06 a11c274c0f9b: Waiting
01:24:06 42d83eff80c9: Waiting
01:24:06 8ceab1156925: Waiting
01:24:06 4600801c3d3a: Waiting
01:24:06 f423c3d5c2bb: Waiting
01:24:06 34181986d124: Waiting
01:24:06 00932efc1e1d: Waiting
01:24:06 a3c986dbc6a4: Waiting
01:24:06 7ad6fc7f0fa9: Waiting
01:24:06 2099bcf0bd4a: Waiting
01:24:06 51b9ddb7198d: Waiting
01:24:06 6c8318350323: Waiting
01:24:06 9601eb373c5a: Waiting
01:24:06 259b78ba95b0: Waiting
01:24:06 4ec236b62c9b: Waiting
01:24:06 4f10d41363a8: Waiting
01:24:06 050382585609: Verifying Checksum
01:24:06 050382585609: Download complete
01:24:06 dac2222ca532: Verifying Checksum
01:24:06 dac2222ca532: Download complete
01:24:06 6ad337b9b53f: Verifying Checksum
01:24:06 6ad337b9b53f: Download complete
01:24:07 7ad6fc7f0fa9: Verifying Checksum
01:24:07 7ad6fc7f0fa9: Download complete
01:24:07 29a7fe408caa: Verifying Checksum
01:24:07 29a7fe408caa: Download complete
01:24:07 51b9ddb7198d: Verifying Checksum
01:24:07 51b9ddb7198d: Download complete
01:24:07 9601eb373c5a: Verifying Checksum
01:24:07 9601eb373c5a: Download complete
01:24:07 050382585609: Pull complete
01:24:07 259b78ba95b0: Verifying Checksum
01:24:07 259b78ba95b0: Download complete
01:24:07 6c8318350323: Verifying Checksum
01:24:07 6c8318350323: Download complete
01:24:07 4f10d41363a8: Verifying Checksum
01:24:07 4f10d41363a8: Download complete
01:24:07 4ec236b62c9b: Verifying Checksum
01:24:07 4ec236b62c9b: Download complete
01:24:07 dac2222ca532: Pull complete
01:24:07 dfa88475ea08: Verifying Checksum
01:24:07 dfa88475ea08: Download complete
01:24:07 a11c274c0f9b: Verifying Checksum
01:24:07 a11c274c0f9b: Download complete
01:24:07 8ceab1156925: Verifying Checksum
01:24:07 8ceab1156925: Download complete
01:24:07 4600801c3d3a: Verifying Checksum
01:24:07 4600801c3d3a: Download complete
01:24:07 42d83eff80c9: Verifying Checksum
01:24:07 42d83eff80c9: Download complete
01:24:07 f423c3d5c2bb: Verifying Checksum
01:24:07 f423c3d5c2bb: Download complete
01:24:08 00932efc1e1d: Verifying Checksum
01:24:08 00932efc1e1d: Download complete
01:24:08 2099bcf0bd4a: Verifying Checksum
01:24:08 2099bcf0bd4a: Download complete
01:24:08 Flake8...................................................................Passed

01:24:08 Tests should end in _test.py.............................................Passed

01:24:08 Fix requirements.txt.....................................................Passed

01:24:08 Trim Trailing Whitespace.................................................Passed

01:24:08 Check for added large files..............................................Passed

01:24:08 Check docstring is first.................................................Passed

01:24:08 Check for merge conflicts................................................Passed

01:24:08 Check Yaml...............................................................Passed

01:24:08 Check JSON...............................................................Passed

01:24:08 Debug Statements (Python)................................................Passed

01:24:08 34181986d124: Verifying Checksum
01:24:08 34181986d124: Download complete
01:24:08 a3c986dbc6a4: Verifying Checksum
01:24:08 a3c986dbc6a4: Download complete
01:24:09 Reorder python imports...................................................Passed

01:24:09 ___________________________________ summary ____________________________________

01:24:09   pre-commit: commands succeeded

01:24:09   congratulations :)

01:24:09 Fix End of Files.........................................................Passed

01:24:09 29a7fe408caa: Pull complete
01:24:09 6ad337b9b53f: Pull complete
01:24:09 ++ get_versions='docker run --rm
01:24:09     --entrypoint=/code/.tox/py27/bin/python
01:24:09     dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e
01:24:09     /code/script/test/versions.py docker/docker-ce,moby/moby'
01:24:09 ++ '[' 19.03.2-rc1 == '' ']'
01:24:09 ++ '[' 19.03.2-rc1 == all ']'
01:24:09 ++ BUILD_NUMBER=jenkins-compose-PR-6850-2
01:24:09 ++ PY_TEST_VERSIONS=py27
01:24:09 ++ for version in $DOCKER_VERSIONS
01:24:09 ++ echo 'Running tests against Docker 19.03.2-rc1'
01:24:09 Running tests against Docker 19.03.2-rc1
01:24:09 ++ daemon_container=compose-dind-19.03.2-rc1-jenkins-compose-PR-6850-2
01:24:09 ++ trap on_exit EXIT
01:24:09 ++ repo=dockerswarm/dind
01:24:09 ++ docker run -d --name compose-dind-19.03.2-rc1-jenkins-compose-PR-6850-2 --privileged --volume=/var/lib/docker dockerswarm/dind:19.03.2-rc1 dockerd -H tcp://0.0.0.0:2375 --storage-driver=overlay
01:24:09 ++ tail -n 10
01:24:10 7ad6fc7f0fa9: Pull complete
01:24:13 2099bcf0bd4a: Pull complete
01:24:13 51b9ddb7198d: Pull complete
01:24:13 6c8318350323: Pull complete
01:24:13 9601eb373c5a: Pull complete
01:24:13 259b78ba95b0: Pull complete
01:24:14 4ec236b62c9b: Pull complete
01:24:14 4f10d41363a8: Pull complete
01:24:14 dfa88475ea08: Pull complete
01:24:14 a11c274c0f9b: Pull complete
01:24:14 42d83eff80c9: Pull complete
01:24:14 8ceab1156925: Pull complete
01:24:14 4600801c3d3a: Pull complete
01:24:14 f423c3d5c2bb: Pull complete
01:24:16 b0b8081c21b9: Verifying Checksum
01:24:16 b0b8081c21b9: Download complete
01:24:16 b0b8081c21b9: Pull complete
01:24:16 f0363a51a0f4: Pull complete
01:24:16 14457cbcc43a: Pull complete
01:24:16 baae4e02d0f0: Pull complete
01:24:16 fbc676048046: Pull complete
01:24:16 Digest: sha256:640e8123ebb07f686320b3ba801edd1bde9015aa39913588ba34173a02bf2435
01:24:16 Status: Downloaded newer image for dockerswarm/dind:19.03.2-rc1
01:24:16 a13a8770e3632eec3f053d69f0d48f61188058ed3b1464b2152450df1ef87238
01:24:16 ++ docker run --rm --tty --link=compose-dind-19.03.2-rc1-jenkins-compose-PR-6850-2:docker --env=DOCKER_HOST=tcp://docker:2375 --env=DOCKER_VERSION=19.03.2-rc1 --entrypoint=tox dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e -e py27 -- --verbose
01:24:16 34181986d124: Pull complete
01:24:16 00932efc1e1d: Pull complete
01:24:17 py27 develop-inst-nodeps: /code

01:24:17 Flake8...................................................................Passed

01:24:17 Tests should end in _test.py.............................................Passed

01:24:17 Fix requirements.txt.....................................................Passed

01:24:17 Trim Trailing Whitespace.................................................Passed

01:24:18 Reorder python imports...................................................Passed

01:24:18 ___________________________________ summary ____________________________________

01:24:18   pre-commit: commands succeeded

01:24:18   congratulations :)

01:24:18 a3c986dbc6a4: Pull complete
01:24:18 Digest: sha256:8c6049026883a4e1422f4aab41226b903fb69db598a8e3bdff45679df802b11a
01:24:18 Status: Downloaded newer image for dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e
01:24:18 ++ get_versions='docker run --rm
01:24:18     --entrypoint=/code/.tox/py27/bin/python
01:24:18     dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e
01:24:18     /code/script/test/versions.py docker/docker-ce,moby/moby'
01:24:18 ++ '[' 19.03.2-rc1 == '' ']'
01:24:18 ++ '[' 19.03.2-rc1 == all ']'
01:24:18 ++ BUILD_NUMBER=jenkins-compose-PR-6850-2
01:24:18 ++ PY_TEST_VERSIONS=py37
01:24:18 ++ for version in $DOCKER_VERSIONS
01:24:18 ++ echo 'Running tests against Docker 19.03.2-rc1'
01:24:18 Running tests against Docker 19.03.2-rc1
01:24:18 ++ daemon_container=compose-dind-19.03.2-rc1-jenkins-compose-PR-6850-2
01:24:18 ++ trap on_exit EXIT
01:24:18 ++ repo=dockerswarm/dind
01:24:18 ++ docker run -d --name compose-dind-19.03.2-rc1-jenkins-compose-PR-6850-2 --privileged --volume=/var/lib/docker dockerswarm/dind:19.03.2-rc1 dockerd -H tcp://0.0.0.0:2375 --storage-driver=overlay
01:24:18 ++ tail -n 10
01:24:20 + docker version
01:24:20 Client: Docker Engine - Community
01:24:20  Version:           18.09.7
01:24:20  API version:       1.39
01:24:20  Go version:        go1.10.8
01:24:20  Git commit:        2d0083d
01:24:20  Built:             Thu Jun 27 17:54:15 2019
01:24:20  OS/Arch:           linux/amd64
01:24:20  Experimental:      false
01:24:20 
01:24:20 Server: Docker Engine - Community
01:24:20  Engine:
01:24:20   Version:          19.03.1
01:24:20   API version:      1.40 (minimum version 1.12)
01:24:20   Go version:       go1.12.5
01:24:20   Git commit:       74b1e89e8a
01:24:20   Built:            Thu Jul 25 21:20:09 2019
01:24:20   OS/Arch:          linux/amd64
01:24:20   Experimental:     true
01:24:20  containerd:
01:24:20   Version:          1.2.6
01:24:20   GitCommit:        894b81a4b802e4eb2a91d1ce216b8817763c29fb
01:24:20  runc:
01:24:20   Version:          1.0.0-rc8
01:24:20   GitCommit:        425e105d5a03fabd737a126ad93d62a9eeede87f
01:24:20  docker-init:
01:24:20   Version:          0.18.0
01:24:20   GitCommit:        fec3683
01:24:20 + export DOCKER_VERSIONS=18.09.9-rc1
01:24:20 + DOCKER_VERSIONS=18.09.9-rc1
01:24:20 + STORAGE_DRIVER=overlay
01:24:20 + export DOCKER_DAEMON_ARGS=--storage-driver=overlay
01:24:20 + DOCKER_DAEMON_ARGS=--storage-driver=overlay
01:24:20 ++ hostname
01:24:20 + GIT_VOLUME=--volumes-from=50fab7fd7cf4
01:24:20 + . script/test/all
01:24:20 ++ set -e
01:24:20 ++ echo 'Running lint checks'
01:24:20 Running lint checks
01:24:20 ++ docker run --rm --tty --volumes-from=50fab7fd7cf4 dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e tox -e pre-commit
01:24:22 pre-commit installed: aspy.yaml==1.3.0,cfgv==2.0.1,identify==1.4.6,importlib-metadata==0.19,nodeenv==1.3.3,pre-commit==1.18.1,PyYAML==5.1.2,six==1.12.0,toml==0.10.0,virtualenv==16.7.2,zipp==0.5.2

01:24:22 pre-commit runtests: PYTHONHASHSEED='178010905'

01:24:22 pre-commit runtests: commands[0] | pre-commit install

01:24:22 pre-commit installed at .git/hooks/pre-commit

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

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

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

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

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

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

01:24:23 [INFO] Once installed this environment will be reused.

01:24:23 [INFO] This may take a few minutes...

01:24:23 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,asn1crypto==0.24.0,atomicwrites==1.3.0,attrs==19.1.0,backports.ssl-match-hostname==3.5.0.1,bcrypt==3.1.7,cached-property==1.3.0,certifi==2017.4.17,cffi==1.12.3,chardet==3.0.4,configparser==3.8.1,coverage==4.4.2,cryptography==2.7,ddt==1.2.0,docker==4.0.1,# Editable install with no version control (docker-compose==1.25.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==2.6.0,mccabe==0.6.1,mock==3.0.5,more-itertools==5.0.0,paramiko==2.4.2,pluggy==0.6.0,py==1.8.0,pyasn1==0.4.6,pycodestyle==2.3.1,pycparser==2.19,pyflakes==1.6.0,PyNaCl==1.3.0,PySocks==1.6.7,pytest==3.6.3,pytest-cov==2.5.1,PyYAML==4.2b1,requests==2.22.0,six==1.10.0,texttable==1.6.2,urllib3==1.25.3,websocket-client==0.32.0

01:24:23 py27 runtests: PYTHONHASHSEED='3560581313'

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

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

01:24:23 ============================= test session starts ==============================

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

01:24:23 cachedir: .pytest_cache

01:24:23 rootdir: /code, inifile: tox.ini

01:24:23 plugins: cov-2.5.1

01:24:27 
collecting 0 items                                                             
collecting 196 items                                                           
collecting 196 items                                                           
collecting 196 items                                                           
collecting 196 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 399 items                                                           
collecting 403 items                                                           
collecting 403 items                                                           
collecting 403 items                                                           
collecting 403 items                                                           
collecting 406 items                                                           
collecting 415 items                                                           
collecting 426 items                                                           
collecting 434 items                                                           
collecting 434 items                                                           
collecting 434 items                                                           
collecting 434 items                                                           
collecting 445 items                                                           
collecting 445 items                                                           
collecting 462 items                                                           
collecting 475 items                                                           
collecting 475 items                                                           
collecting 493 items                                                           
collecting 494 items                                                           
collecting 494 items                                                           
collecting 501 items                                                           
collecting 501 items                                                           
collecting 506 items                                                           
collecting 509 items                                                           
collecting 518 items                                                           
collecting 518 items                                                           
collecting 545 items                                                           
collecting 545 items                                                           
collecting 619 items                                                           
collecting 620 items                                                           
collecting 623 items                                                           
collecting 627 items                                                           
collecting 628 items                                                           
collecting 638 items                                                           
collecting 641 items                                                           
collecting 644 items                                                           
collecting 644 items                                                           
collecting 649 items                                                           
collecting 649 items                                                           
collecting 662 items                                                           
collecting 665 items                                                           
collecting 665 items                                                           
collecting 667 items                                                           
collecting 667 items                                                           
collecting 669 items                                                           
collecting 669 items                                                           
collecting 670 items                                                           
collecting 670 items                                                           
collecting 671 items                                                           
collecting 671 items                                                           
collecting 671 items                                                           
collecting 673 items                                                           
collecting 673 items                                                           
collecting 673 items                                                           
collecting 681 items                                                           
collecting 681 items                                                           
collecting 681 items                                                           
collecting 685 items                                                           
collecting 701 items                                                           
collecting 704 items                                                           
collecting 704 items                                                           
collecting 704 items                                                           
collecting 712 items                                                           
collecting 712 items                                                           
collecting 712 items                                                           
collecting 718 items                                                           
collecting 718 items                                                           
collecting 720 items                                                           
collecting 720 items                                                           
collecting 723 items                                                           
collecting 723 items                                                           
collecting 726 items                                                           
collecting 726 items                                                           
collecting 730 items                                                           
collecting 730 items                                                           
collecting 733 items                                                           
collecting 738 items                                                           
collecting 738 items                                                           
collecting 741 items                                                           
collecting 741 items                                                           
collecting 745 items                                                           
collecting 745 items                                                           
collecting 752 items                                                           
collecting 752 items                                                           
collecting 752 items                                                           
collecting 756 items                                                           
collecting 760 items                                                           
collecting 760 items                                                           
collecting 764 items                                                           
collecting 764 items                                                           
collecting 908 items                                                           
collecting 916 items                                                           
collecting 924 items                                                           
collecting 927 items                                                           
collecting 937 items                                                           
collecting 948 items                                                           
collecting 954 items                                                           
collecting 960 items                                                           
collecting 963 items                                                           
collecting 968 items                                                           
collecting 976 items                                                           
collecting 980 items                                                           
collecting 986 items                                                           
collecting 989 items                                                           
collecting 992 items                                                           
collecting 1004 items                                                          
collecting 1034 items                                                          
collecting 1037 items                                                          
collecting 1040 items                                                          
collecting 1047 items                                                          
collecting 1051 items                                                          
collecting 1053 items                                                          
collecting 1068 items                                                          
collecting 1068 items                                                          
collecting 1073 items                                                          
collecting 1073 items                                                          
collecting 1094 items                                                          
collecting 1106 items                                                          
collecting 1106 items                                                          
collecting 1106 items                                                          
collecting 1115 items                                                          
collecting 1115 items                                                          
collecting 1127 items                                                          
collecting 1127 items                                                          
collecting 1136 items                                                          
collecting 1136 items                                                          
collecting 1138 items                                                          
collected 1138 items                                                           

01:24:27 

01:24:28 baae4e02d0f0: Verifying Checksum
01:24:28 baae4e02d0f0: Download complete
01:24:28 b0b8081c21b9: Pull complete
01:24:28 f0363a51a0f4: Pull complete
01:24:28 14457cbcc43a: Pull complete
01:24:28 baae4e02d0f0: Pull complete
01:24:28 fbc676048046: Pull complete
01:24:28 Digest: sha256:640e8123ebb07f686320b3ba801edd1bde9015aa39913588ba34173a02bf2435
01:24:28 Status: Downloaded newer image for dockerswarm/dind:19.03.2-rc1
01:24:28 8b21696911fc3c6578d1ac0dc3be0315f05decd7054e609e891846815aca9b66
01:24:28 ++ docker run --rm --tty --link=compose-dind-19.03.2-rc1-jenkins-compose-PR-6850-2:docker --env=DOCKER_HOST=tcp://docker:2375 --env=DOCKER_VERSION=19.03.2-rc1 --entrypoint=tox dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e -e py37 -- --verbose
01:24:28 py37 develop-inst-nodeps: /code

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

01:24:34 py37 installed: altgraph==0.16.1,asn1crypto==0.24.0,atomicwrites==1.3.0,attrs==19.1.0,bcrypt==3.1.7,cached-property==1.3.0,certifi==2017.4.17,cffi==1.12.3,chardet==3.0.4,coverage==4.4.2,cryptography==2.7,ddt==1.2.0,docker==4.0.1,# Editable install with no version control (docker-compose==1.25.0.dev0),-e /code,docker-pycreds==0.4.0,dockerpty==0.4.1,docopt==0.6.2,flake8==3.5.0,future==0.17.1,idna==2.5,ipaddress==1.0.18,jsonschema==2.6.0,macholib==1.11,mccabe==0.6.1,mock==3.0.5,more-itertools==7.2.0,paramiko==2.4.2,pefile==2019.4.18,pluggy==0.6.0,py==1.8.0,pyasn1==0.4.6,pycodestyle==2.3.1,pycparser==2.19,pyflakes==1.6.0,PyInstaller==3.4,PyNaCl==1.3.0,PySocks==1.6.7,pytest==3.6.3,pytest-cov==2.5.1,PyYAML==4.2b1,requests==2.22.0,six==1.10.0,texttable==1.6.2,urllib3==1.25.3,websocket-client==0.32.0

01:24:34 py37 runtests: PYTHONHASHSEED='1082667948'

01:24:34 py37 runtests: commands[0] | mkdir -p .coverage-binfiles

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

01:24:34 ============================= test session starts ==============================

01:24:34 platform linux -- Python 3.7.4, pytest-3.6.3, py-1.8.0, pluggy-0.6.0 -- /code/.tox/py37/bin/python3.7

01:24:34 cachedir: .pytest_cache

01:24:34 rootdir: /code, inifile: tox.ini

01:24:34 plugins: cov-2.5.1

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

01:24:37 
collecting 0 items                                                             
collecting 196 items                                                           
collecting 196 items                                                           
collecting 196 items                                                           
collecting 196 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 399 items                                                           
collecting 403 items                                                           
collecting 403 items                                                           
collecting 403 items                                                           
collecting 403 items                                                           
collecting 406 items                                                           
collecting 415 items                                                           
collecting 426 items                                                           
collecting 434 items                                                           
collecting 434 items                                                           
collecting 434 items                                                           
collecting 434 items                                                           
collecting 445 items                                                           
collecting 445 items                                                           
collecting 462 items                                                           
collecting 475 items                                                           
collecting 475 items                                                           
collecting 493 items                                                           
collecting 494 items                                                           
collecting 494 items                                                           
collecting 501 items                                                           
collecting 501 items                                                           
collecting 506 items                                                           
collecting 509 items                                                           
collecting 518 items                                                           
collecting 518 items                                                           
collecting 545 items                                                           
collecting 545 items                                                           
collecting 619 items                                                           
collecting 620 items                                                           
collecting 623 items                                                           
collecting 627 items                                                           
collecting 628 items                                                           
collecting 638 items                                                           
collecting 641 items                                                           
collecting 644 items                                                           
collecting 644 items                                                           
collecting 649 items                                                           
collecting 649 items                                                           
collecting 662 items                                                           
collecting 665 items                                                           
collecting 665 items                                                           
collecting 667 items                                                           
collecting 667 items                                                           
collecting 669 items                                                           
collecting 669 items                                                           
collecting 670 items                                                           
collecting 670 items                                                           
collecting 671 items                                                           
collecting 671 items                                                           
collecting 671 items                                                           
collecting 673 items                                                           
collecting 673 items                                                           
collecting 673 items                                                           
collecting 681 items                                                           
collecting 681 items                                                           
collecting 681 items                                                           
collecting 685 items                                                           
collecting 701 items                                                           
collecting 704 items                                                           
collecting 704 items                                                           
collecting 704 items                                                           
collecting 712 items                                                           
collecting 712 items                                                           
collecting 712 items                                                           
collecting 718 items                                                           
collecting 718 items                                                           
collecting 720 items                                                           
collecting 720 items                                                           
collecting 723 items                                                           
collecting 723 items                                                           
collecting 726 items                                                           
collecting 726 items                                                           
collecting 730 items                                                           
collecting 730 items                                                           
collecting 733 items                                                           
collecting 738 items                                                           
collecting 738 items                                                           
collecting 741 items                                                           
collecting 741 items                                                           
collecting 745 items                                                           
collecting 745 items                                                           
collecting 752 items                                                           
collecting 752 items                                                           
collecting 752 items                                                           
collecting 756 items                                                           
collecting 760 items                                                           
collecting 760 items                                                           
collecting 764 items                                                           
collecting 764 items                                                           
collecting 908 items                                                           
collecting 916 items                                                           
collecting 924 items                                                           
collecting 927 items                                                           
collecting 937 items                                                           
collecting 948 items                                                           
collecting 954 items                                                           
collecting 960 items                                                           
collecting 963 items                                                           
collecting 968 items                                                           
collecting 976 items                                                           
collecting 980 items                                                           
collecting 986 items                                                           
collecting 989 items                                                           
collecting 992 items                                                           
collecting 1004 items                                                          
collecting 1034 items                                                          
collecting 1037 items                                                          
collecting 1040 items                                                          
collecting 1047 items                                                          
collecting 1051 items                                                          
collecting 1053 items                                                          
collecting 1068 items                                                          
collecting 1068 items                                                          
collecting 1073 items                                                          
collecting 1073 items                                                          
collecting 1094 items                                                          
collecting 1106 items                                                          
collecting 1106 items                                                          
collecting 1106 items                                                          
collecting 1115 items                                                          
collecting 1115 items                                                          
collecting 1127 items                                                          
collecting 1127 items                                                          
collecting 1136 items                                                          
collecting 1136 items                                                          
collecting 1138 items                                                          
collected 1138 items                                                           

01:24:37 

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

01:24:41 [INFO] Once installed this environment will be reused.

01:24:41 [INFO] This may take a few minutes...

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

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

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

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

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

01:24:53 Check for added large files..............................................Passed

01:24:54 Check docstring is first.................................................Passed

01:24:54 Check for merge conflicts................................................Passed

01:24:54 Check Yaml...............................................................Passed

01:24:54 Check JSON...............................................................Passed

01:24:54 Debug Statements (Python)................................................Passed

01:24:54 Fix End of Files.........................................................Passed

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

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

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

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

Running on ubuntu-1604-aufs (i-0dbbdaf065ba164f2) in /home/ubuntu/workspace/compose_PR-6850
[Pipeline] {
[Pipeline] withDockerRegistry
$ docker login -u dockerbuildbot -p ******** https://index.docker.io/v1/
01:24:59 tests/acceptance/cli_test.py::CLITestCase::test_build_override_dir_invalid_path PASSED [  0%]

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

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

01:25:02 Flake8...................................................................Passed

01:25:02 Tests should end in _test.py.............................................Passed

01:25:02 Fix requirements.txt.....................................................Passed

01:25:02 Trim Trailing Whitespace.................................................Passed

01:25:02 Reorder python imports...................................................Passed

01:25:02 ___________________________________ summary ____________________________________

01:25:02   pre-commit: commands succeeded

01:25:02   congratulations :)

WARNING! Using --password via the CLI is insecure. Use --password-stdin.
WARNING! Your password will be stored unencrypted in /home/ubuntu/workspace/compose_PR-6850@tmp/40a1f02e-d29e-4eae-91dc-50626ebe18b5/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store

Login Succeeded
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] echo
01:25:03 cleanWorkspace: Ensuring workspace is owned by ubuntu
[Pipeline] echo
01:25:03 chowning workspace
[Pipeline] sh
01:25:03 ++ get_versions='docker run --rm
01:25:03     --entrypoint=/code/.tox/py27/bin/python
01:25:03     dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e
01:25:03     /code/script/test/versions.py docker/docker-ce,moby/moby'
01:25:03 ++ '[' 18.09.9-rc1 == '' ']'
01:25:03 ++ '[' 18.09.9-rc1 == all ']'
01:25:03 ++ BUILD_NUMBER=jenkins-compose-PR-6850-2
01:25:03 ++ PY_TEST_VERSIONS=py27
01:25:03 ++ for version in $DOCKER_VERSIONS
01:25:03 ++ echo 'Running tests against Docker 18.09.9-rc1'
01:25:03 Running tests against Docker 18.09.9-rc1
01:25:03 ++ daemon_container=compose-dind-18.09.9-rc1-jenkins-compose-PR-6850-2
01:25:03 ++ trap on_exit EXIT
01:25:03 ++ repo=dockerswarm/dind
01:25:03 ++ ++ tail docker -n run -d 10--name 
01:25:03 compose-dind-18.09.9-rc1-jenkins-compose-PR-6850-2 --privileged --volume=/var/lib/docker dockerswarm/dind:18.09.9-rc1 dockerd -H tcp://0.0.0.0:2375 --storage-driver=overlay
01:25:03 + uname -m
[Pipeline] sh
01:25:04 + pwd
01:25:04 + id -u
01:25:04 + id -g
01:25:04 + docker run --rm -v /home/ubuntu/workspace/compose_PR-6850:/workspace busybox chown -R 1000:1000 /workspace
01:25:04 Unable to find image 'busybox:latest' locally
01:25:04 latest: Pulling from library/busybox
01:25:04 ee153a04d683: Pulling fs layer
01:25:04 ee153a04d683: Verifying Checksum
01:25:04 ee153a04d683: Download complete
01:25:04 ee153a04d683: Pull complete
01:25:04 Digest: sha256:9f1003c480699be56815db0f8146ad2e22efea85129b5b5983d0e0fb52d9ab70
01:25:04 Status: Downloaded newer image for busybox:latest
01:25:04 tests/acceptance/cli_test.py::CLITestCase::test_build_plain PASSED       [  0%]

[Pipeline] echo
01:25:07 Removing all docker containers
[Pipeline] sh
01:25:07 + docker container ls -aq
[Pipeline] echo
01:25:07 Docker containers have been removed
[Pipeline] echo
01:25:07 cleanWorkspace: Removing existing workspace
[Pipeline] deleteDir
[Pipeline] echo
01:25:07 cleanWorkspace: Workspace is clean.
[Pipeline] stage
[Pipeline] { (test python=py37 / docker=18.09.9-rc1 / baseImage=alpine)
[Pipeline] checkout
01:25:07 tests/acceptance/cli_test.py::CLITestCase::test_build_no_cache_pull PASSED [  0%]

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

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

01:25:09 using credential sf-release-bot.github.ssh
01:25:09 Cloning the remote Git repository
01:25:09 Cloning with configured refspecs honoured and without tags
01:25:09 tests/acceptance/cli_test.py::CLITestCase::test_build_override_dir_invalid_path PASSED [  0%]

01:25:10 b0b8081c21b9: Pull complete
01:25:10 7591cec14231: Verifying Checksum
01:25:10 7591cec14231: Download complete
01:25:10 b7cf13d7afa6: Pull complete
01:25:10 b5aa1770fbfe: Pull complete
01:25:10 7591cec14231: Pull complete
01:25:10 337759c3f8bf: Pull complete
01:25:10 Digest: sha256:d1b34ee995071956f6c17fa12f07c807b9768265c5238b7e1e848f1eb9c65a83
01:25:10 Status: Downloaded newer image for dockerswarm/dind:18.09.9-rc1
01:25:10 d7ca9c538d7de0d84fb6cf025f2dcb1e69e70d5a192788eb7311098353104a8f
01:25:10 ++ docker run --rm --tty --link=compose-dind-18.09.9-rc1-jenkins-compose-PR-6850-2:docker --env=DOCKER_HOST=tcp://docker:2375 --env=DOCKER_VERSION=18.09.9-rc1 --entrypoint=tox dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e -e py27 -- --verbose
01:25:10 tests/acceptance/cli_test.py::CLITestCase::test_build_rm XPASS           [  1%]

Cloning repository git@github.com:docker/compose.git
 > git init /home/ubuntu/workspace/compose_PR-6850 # 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/pull/6850/head:refs/remotes/origin/PR-6850
01:25:11 py27 develop-inst-nodeps: /code

01:25:12 Fetching without tags
 > git config remote.origin.url git@github.com:docker/compose.git # timeout=10
 > git config --add remote.origin.fetch +refs/pull/6850/head:refs/remotes/origin/PR-6850 # 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/pull/6850/head:refs/remotes/origin/PR-6850
01:25:12 Checking out Revision 04ce00a71373d402ca9ab2ea7a9f732eeab4778e (PR-6850)
01:25:12 tests/acceptance/cli_test.py::CLITestCase::test_build_shm_size_build_option PASSED [  1%]

01:25:12 Commit message: "add --skip-env-file option"
01:25:13 tests/acceptance/cli_test.py::CLITestCase::test_build_parallel PASSED    [  0%]

 > git config core.sparsecheckout # timeout=10
 > git checkout -f 04ce00a71373d402ca9ab2ea7a9f732eeab4778e
[Pipeline] sh
01:25:13 + awk -F :  $1 == "Storage Driver" { print $2; exit }
01:25:13 + docker info
01:25:16 tests/acceptance/cli_test.py::CLITestCase::test_build_plain PASSED       [  0%]

01:25:16 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,asn1crypto==0.24.0,atomicwrites==1.3.0,attrs==19.1.0,backports.ssl-match-hostname==3.5.0.1,bcrypt==3.1.7,cached-property==1.3.0,certifi==2017.4.17,cffi==1.12.3,chardet==3.0.4,configparser==3.8.1,coverage==4.4.2,cryptography==2.7,ddt==1.2.0,docker==4.0.1,# Editable install with no version control (docker-compose==1.25.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==2.6.0,mccabe==0.6.1,mock==3.0.5,more-itertools==5.0.0,paramiko==2.4.2,pluggy==0.6.0,py==1.8.0,pyasn1==0.4.6,pycodestyle==2.3.1,pycparser==2.19,pyflakes==1.6.0,PyNaCl==1.3.0,PySocks==1.6.7,pytest==3.6.3,pytest-cov==2.5.1,PyYAML==4.2b1,requests==2.22.0,six==1.10.0,texttable==1.6.2,urllib3==1.25.3,websocket-client==0.32.0

01:25:16 py27 runtests: PYTHONHASHSEED='1706272480'

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

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

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

01:25:16 ============================= test session starts ==============================

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

01:25:16 cachedir: .pytest_cache

01:25:16 rootdir: /code, inifile: tox.ini

01:25:16 plugins: cov-2.5.1

01:25:17 WARNING: No swap limit support
01:25:17 WARNING: the aufs storage-driver is deprecated, and will be removed in a future release.
[Pipeline] echo
01:25:17 Using local system's storage driver: 
[Pipeline] sh
01:25:18 + pwd
01:25:18 + docker run -t --rm --privileged --volume=/home/ubuntu/workspace/compose_PR-6850/.git:/code/.git --volume=/var/run/docker.sock:/var/run/docker.sock -e TAG=dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e -e STORAGE_DRIVER= -e DOCKER_VERSIONS=18.09.9-rc1 -e BUILD_NUMBER=jenkins-compose-PR-6850-2 -e PY_TEST_VERSIONS=py37 --entrypoint=script/test/ci dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e --verbose
01:25:18 Unable to find image 'dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e' locally
01:25:18 alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e: Pulling from dockerbuildbot/compose
01:25:18 050382585609: Pulling fs layer
01:25:18 dac2222ca532: Pulling fs layer
01:25:18 29a7fe408caa: Pulling fs layer
01:25:18 6ad337b9b53f: Pulling fs layer
01:25:18 7ad6fc7f0fa9: Pulling fs layer
01:25:18 2099bcf0bd4a: Pulling fs layer
01:25:18 51b9ddb7198d: Pulling fs layer
01:25:18 6c8318350323: Pulling fs layer
01:25:18 9601eb373c5a: Pulling fs layer
01:25:18 259b78ba95b0: Pulling fs layer
01:25:18 4ec236b62c9b: Pulling fs layer
01:25:18 4f10d41363a8: Pulling fs layer
01:25:18 dfa88475ea08: Pulling fs layer
01:25:18 a11c274c0f9b: Pulling fs layer
01:25:18 42d83eff80c9: Pulling fs layer
01:25:18 8ceab1156925: Pulling fs layer
01:25:18 4600801c3d3a: Pulling fs layer
01:25:18 f423c3d5c2bb: Pulling fs layer
01:25:18 34181986d124: Pulling fs layer
01:25:18 00932efc1e1d: Pulling fs layer
01:25:18 a3c986dbc6a4: Pulling fs layer
01:25:18 6ad337b9b53f: Waiting
01:25:18 7ad6fc7f0fa9: Waiting
01:25:18 2099bcf0bd4a: Waiting
01:25:18 51b9ddb7198d: Waiting
01:25:18 6c8318350323: Waiting
01:25:18 9601eb373c5a: Waiting
01:25:18 259b78ba95b0: Waiting
01:25:18 4ec236b62c9b: Waiting
01:25:18 4f10d41363a8: Waiting
01:25:18 dfa88475ea08: Waiting
01:25:18 a11c274c0f9b: Waiting
01:25:18 42d83eff80c9: Waiting
01:25:18 8ceab1156925: Waiting
01:25:18 4600801c3d3a: Waiting
01:25:18 f423c3d5c2bb: Waiting
01:25:18 34181986d124: Waiting
01:25:18 00932efc1e1d: Waiting
01:25:18 a3c986dbc6a4: Waiting
01:25:18 dac2222ca532: Verifying Checksum
01:25:18 dac2222ca532: Download complete
01:25:18 050382585609: Download complete
01:25:18 6ad337b9b53f: Verifying Checksum
01:25:18 6ad337b9b53f: Download complete
01:25:18 7ad6fc7f0fa9: Verifying Checksum
01:25:18 7ad6fc7f0fa9: Download complete
01:25:18 29a7fe408caa: Verifying Checksum
01:25:18 29a7fe408caa: Download complete
01:25:18 51b9ddb7198d: Verifying Checksum
01:25:18 51b9ddb7198d: Download complete
01:25:18 050382585609: Pull complete
01:25:18 9601eb373c5a: Verifying Checksum
01:25:18 9601eb373c5a: Download complete
01:25:19 tests/acceptance/cli_test.py::CLITestCase::test_build_pull PASSED        [  0%]

01:25:19 6c8318350323: Verifying Checksum
01:25:19 6c8318350323: Download complete
01:25:19 dac2222ca532: Pull complete
01:25:19 259b78ba95b0: Verifying Checksum
01:25:19 259b78ba95b0: Download complete
01:25:19 4ec236b62c9b: Verifying Checksum
01:25:19 4ec236b62c9b: Download complete
01:25:19 4f10d41363a8: Verifying Checksum
01:25:19 4f10d41363a8: Download complete
01:25:19 dfa88475ea08: Verifying Checksum
01:25:19 dfa88475ea08: Download complete
01:25:19 a11c274c0f9b: Verifying Checksum
01:25:19 a11c274c0f9b: Download complete
01:25:19 2099bcf0bd4a: Verifying Checksum
01:25:19 2099bcf0bd4a: Download complete
01:25:19 8ceab1156925: Verifying Checksum
01:25:19 8ceab1156925: Download complete
01:25:19 42d83eff80c9: Verifying Checksum
01:25:19 42d83eff80c9: Download complete
01:25:19 4600801c3d3a: Verifying Checksum
01:25:19 4600801c3d3a: Download complete
01:25:19 f423c3d5c2bb: Verifying Checksum
01:25:19 f423c3d5c2bb: Download complete
01:25:19 00932efc1e1d: Verifying Checksum
01:25:19 00932efc1e1d: Download complete
01:25:20 34181986d124: Verifying Checksum
01:25:20 34181986d124: Download complete
01:25:20 a3c986dbc6a4: Verifying Checksum
01:25:20 a3c986dbc6a4: Download complete
01:25:20 
collecting 0 items                                                             
collecting 196 items                                                           
collecting 196 items                                                           
collecting 196 items                                                           
collecting 196 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 399 items                                                           
collecting 403 items                                                           
collecting 403 items                                                           
collecting 403 items                                                           
collecting 403 items                                                           
collecting 406 items                                                           
collecting 415 items                                                           
collecting 426 items                                                           
collecting 434 items                                                           
collecting 434 items                                                           
collecting 434 items                                                           
collecting 434 items                                                           
collecting 445 items                                                           
collecting 445 items                                                           
collecting 462 items                                                           
collecting 475 items                                                           
collecting 475 items                                                           
collecting 493 items                                                           
collecting 494 items                                                           
collecting 494 items                                                           
collecting 501 items                                                           
collecting 501 items                                                           
collecting 506 items                                                           
collecting 509 items                                                           
collecting 518 items                                                           
collecting 518 items                                                           
collecting 545 items                                                           
collecting 545 items                                                           
collecting 619 items                                                           
collecting 620 items                                                           
collecting 623 items                                                           
collecting 627 items                                                           
collecting 628 items                                                           
collecting 638 items                                                           
collecting 641 items                                                           
collecting 644 items                                                           
collecting 644 items                                                           
collecting 649 items                                                           
collecting 649 items                                                           
collecting 662 items                                                           
collecting 665 items                                                           
collecting 665 items                                                           
collecting 667 items                                                           
collecting 667 items                                                           
collecting 669 items                                                           
collecting 669 items                                                           
collecting 670 items                                                           
collecting 670 items                                                           
collecting 671 items                                                           
collecting 671 items                                                           
collecting 671 items                                                           
collecting 673 items                                                           
collecting 673 items                                                           
collecting 673 items                                                           
collecting 681 items                                                           
collecting 681 items                                                           
collecting 681 items                                                           
collecting 685 items                                                           
collecting 701 items                                                           
collecting 704 items                                                           
collecting 704 items                                                           
collecting 704 items                                                           
collecting 712 items                                                           
collecting 712 items                                                           
collecting 712 items                                                           
collecting 718 items                                                           
collecting 718 items                                                           
collecting 720 items                                                           
collecting 720 items                                                           
collecting 723 items                                                           
collecting 723 items                                                           
collecting 726 items                                                           
collecting 726 items                                                           
collecting 730 items                                                           
collecting 730 items                                                           
collecting 733 items                                                           
collecting 738 items                                                           
collecting 738 items                                                           
collecting 741 items                                                           
collecting 741 items                                                           
collecting 745 items                                                           
collecting 745 items                                                           
collecting 752 items                                                           
collecting 752 items                                                           
collecting 752 items                                                           
collecting 756 items                                                           
collecting 760 items                                                           
collecting 760 items                                                           
collecting 764 items                                                           
collecting 764 items                                                           
collecting 908 items                                                           
collecting 916 items                                                           
collecting 924 items                                                           
collecting 927 items                                                           
collecting 937 items                                                           
collecting 948 items                                                           
collecting 954 items                                                           
collecting 960 items                                                           
collecting 963 items                                                           
collecting 968 items                                                           
collecting 976 items                                                           
collecting 980 items                                                           
collecting 986 items                                                           
collecting 989 items                                                           
collecting 992 items                                                           
collecting 1004 items                                                          
collecting 1034 items                                                          
collecting 1037 items                                                          
collecting 1040 items                                                          
collecting 1047 items                                                          
collecting 1051 items                                                          
collecting 1053 items                                                          
collecting 1068 items                                                          
collecting 1068 items                                                          
collecting 1073 items                                                          
collecting 1073 items                                                          
collecting 1094 items                                                          
collecting 1106 items                                                          
collecting 1106 items                                                          
collecting 1106 items                                                          
collecting 1115 items                                                          
collecting 1115 items                                                          
collecting 1127 items                                                          
collecting 1127 items                                                          
collecting 1136 items                                                          
collecting 1136 items                                                          
collecting 1138 items                                                          
collected 1138 items                                                           

01:25:20 

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

01:25:21 29a7fe408caa: Pull complete
01:25:21 6ad337b9b53f: Pull complete
01:25:21 tests/acceptance/cli_test.py::CLITestCase::test_build_rm XPASS           [  1%]

01:25:21 7ad6fc7f0fa9: Pull complete
01:25:23 tests/acceptance/cli_test.py::CLITestCase::test_build_shm_size_build_option PASSED [  1%]

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

01:25:24 2099bcf0bd4a: Pull complete
01:25:24 51b9ddb7198d: Pull complete
01:25:25 tests/acceptance/cli_test.py::CLITestCase::test_bundle_with_digests PASSED [  1%]

01:25:25 6c8318350323: Pull complete
01:25:25 9601eb373c5a: Pull complete
01:25:25 259b78ba95b0: Pull complete
01:25:25 4ec236b62c9b: Pull complete
01:25:25 4f10d41363a8: Pull complete
01:25:25 dfa88475ea08: Pull complete
01:25:26 a11c274c0f9b: Pull complete
01:25:26 42d83eff80c9: Pull complete
01:25:26 tests/acceptance/cli_test.py::CLITestCase::test_build_failed PASSED      [  0%]

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

01:25:26 8ceab1156925: Pull complete
01:25:26 4600801c3d3a: Pull complete
01:25:26 f423c3d5c2bb: Pull complete
01:25:26 tests/acceptance/cli_test.py::CLITestCase::test_config_default PASSED    [  1%]

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

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

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

01:25:29 34181986d124: Pull complete
01:25:29 00932efc1e1d: Pull complete
01:25:29 tests/acceptance/cli_test.py::CLITestCase::test_config_external_volume_v2 PASSED [  1%]

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

01:25:30 a3c986dbc6a4: Pull complete
01:25:30 Digest: sha256:8c6049026883a4e1422f4aab41226b903fb69db598a8e3bdff45679df802b11a
01:25:30 Status: Downloaded newer image for dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e
01:25:30 tests/acceptance/cli_test.py::CLITestCase::test_build_failed_forcerm PASSED [  0%]

01:25:30 + docker version
01:25:30 Client: Docker Engine - Community
01:25:30  Version:           18.09.7
01:25:30  API version:       1.39
01:25:30  Go version:        go1.10.8
01:25:30  Git commit:        2d0083d
01:25:30  Built:             Thu Jun 27 17:54:15 2019
01:25:30  OS/Arch:           linux/amd64
01:25:30  Experimental:      false
01:25:30 
01:25:30 Server: Docker Engine - Community
01:25:30  Engine:
01:25:30   Version:          19.03.1
01:25:30   API version:      1.40 (minimum version 1.12)
01:25:30   Go version:       go1.12.5
01:25:30   Git commit:       74b1e89e8a
01:25:30   Built:            Thu Jul 25 21:20:09 2019
01:25:30   OS/Arch:          linux/amd64
01:25:30   Experimental:     true
01:25:30  containerd:
01:25:30   Version:          1.2.6
01:25:30   GitCommit:        894b81a4b802e4eb2a91d1ce216b8817763c29fb
01:25:30  runc:
01:25:30   Version:          1.0.0-rc8
01:25:30   GitCommit:        425e105d5a03fabd737a126ad93d62a9eeede87f
01:25:30  docker-init:
01:25:30   Version:          0.18.0
01:25:30   GitCommit:        fec3683
01:25:30 + export DOCKER_VERSIONS=18.09.9-rc1
01:25:30 + DOCKER_VERSIONS=18.09.9-rc1
01:25:30 + STORAGE_DRIVER=overlay
01:25:30 + export DOCKER_DAEMON_ARGS=--storage-driver=overlay
01:25:30 + DOCKER_DAEMON_ARGS=--storage-driver=overlay
01:25:30 ++ hostname
01:25:30 + GIT_VOLUME=--volumes-from=197130f4f65d
01:25:30 + . script/test/all
01:25:30 ++ set -e
01:25:30 ++ echo 'Running lint checks'
01:25:30 Running lint checks
01:25:30 ++ docker run --rm --tty --volumes-from=197130f4f65d dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e tox -e pre-commit
01:25:31 tests/acceptance/cli_test.py::CLITestCase::test_config_external_volume_v3_4 PASSED [  2%]

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

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

01:25:32 pre-commit installed: aspy.yaml==1.3.0,cfgv==2.0.1,identify==1.4.6,importlib-metadata==0.19,nodeenv==1.3.3,pre-commit==1.18.1,PyYAML==5.1.2,six==1.12.0,toml==0.10.0,virtualenv==16.7.2,zipp==0.5.2

01:25:32 pre-commit runtests: PYTHONHASHSEED='462611802'

01:25:32 pre-commit runtests: commands[0] | pre-commit install

01:25:32 pre-commit installed at .git/hooks/pre-commit

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

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

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

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

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

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

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

01:25:33 [INFO] Once installed this environment will be reused.

01:25:33 [INFO] This may take a few minutes...

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

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

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

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

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

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

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

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

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

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

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

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

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

01:25:39 tests/acceptance/cli_test.py::CLITestCase::test_config_with_dot_env_and_override_dir PASSED [  2%]

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

01:25:49 tests/acceptance/cli_test.py::CLITestCase::test_config_with_dot_env_and_override_dir PASSED [  2%]

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

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

01:25:51 [INFO] Once installed this environment will be reused.

01:25:51 [INFO] This may take a few minutes...

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

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

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

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

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

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

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

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

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

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

01:26:03 Check for added large files..............................................Passed

01:26:03 Check docstring is first.................................................Passed

01:26:03 Check for merge conflicts................................................Passed

01:26:03 Check Yaml...............................................................Passed

01:26:03 Check JSON...............................................................Passed

01:26:03 Debug Statements (Python)................................................Passed

01:26:03 Fix End of Files.........................................................Passed

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

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

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

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

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

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

Running on ubuntu-1604-aufs (i-0d5ccdfc4437526c6) in /home/ubuntu/workspace/compose_PR-6850
[Pipeline] {
[Pipeline] withDockerRegistry
$ docker login -u dockerbuildbot -p ******** https://index.docker.io/v1/
01:26:11 Flake8...................................................................Passed

01:26:11 Tests should end in _test.py.............................................Passed

01:26:11 Fix requirements.txt.....................................................Passed

01:26:11 Trim Trailing Whitespace.................................................Passed

01:26:11 Reorder python imports...................................................Passed

01:26:11 ___________________________________ summary ____________________________________

01:26:11   pre-commit: commands succeeded

01:26:11   congratulations :)

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

01:26:12 ++ get_versions='docker run --rm
01:26:12     --entrypoint=/code/.tox/py27/bin/python
01:26:12     dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e
01:26:12     /code/script/test/versions.py docker/docker-ce,moby/moby'
01:26:12 ++ '[' 18.09.9-rc1 == '' ']'
01:26:12 ++ '[' 18.09.9-rc1 == all ']'
01:26:12 ++ BUILD_NUMBER=jenkins-compose-PR-6850-2
01:26:12 ++ PY_TEST_VERSIONS=py37
01:26:12 ++ for version in $DOCKER_VERSIONS
01:26:12 ++ echo 'Running tests against Docker 18.09.9-rc1'
01:26:12 Running tests against Docker 18.09.9-rc1
01:26:12 ++ daemon_container=compose-dind-18.09.9-rc1-jenkins-compose-PR-6850-2
01:26:12 ++ trap on_exit EXIT
01:26:12 ++ repo=dockerswarm/dind
01:26:12 ++ docker run -d --name compose-dind-18.09.9-rc1-jenkins-compose-PR-6850-2 --privileged --volume=/var/lib/docker dockerswarm/dind:18.09.9-rc1 dockerd -H tcp://0.0.0.0:2375 --storage-driver=overlay
01:26:12 ++ tail -n 10
01:26:12 tests/acceptance/cli_test.py::CLITestCase::test_build_with_buildarg_cli_override PASSED [  1%]

01:26:12 tests/acceptance/cli_test.py::CLITestCase::test_env_file_relative_to_compose_file PASSED [  3%]

WARNING! Using --password via the CLI is insecure. Use --password-stdin.
WARNING! Your password will be stored unencrypted in /home/ubuntu/workspace/compose_PR-6850@tmp/9e63e563-ae23-4a92-857a-8e947439927e/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store

Login Succeeded
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] echo
01:26:14 cleanWorkspace: Ensuring workspace is owned by ubuntu
[Pipeline] echo
01:26:14 chowning workspace
[Pipeline] sh
01:26:14 tests/acceptance/cli_test.py::CLITestCase::test_events_human_readable PASSED [  4%]

01:26:15 + uname -m
[Pipeline] sh
01:26:15 + pwd
01:26:15 + id -u
01:26:15 + id -g
01:26:15 + docker run --rm -v /home/ubuntu/workspace/compose_PR-6850:/workspace busybox chown -R 1000:1000 /workspace
01:26:15 Unable to find image 'busybox:latest' locally
01:26:15 latest: Pulling from library/busybox
01:26:15 ee153a04d683: Pulling fs layer
01:26:15 ee153a04d683: Verifying Checksum
01:26:15 ee153a04d683: Download complete
01:26:16 ee153a04d683: Pull complete
01:26:16 Digest: sha256:9f1003c480699be56815db0f8146ad2e22efea85129b5b5983d0e0fb52d9ab70
01:26:16 Status: Downloaded newer image for busybox:latest
01:26:16 tests/acceptance/cli_test.py::CLITestCase::test_build_with_buildarg_from_compose_file PASSED [  1%]

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

01:26:18 7591cec14231: Verifying Checksum
01:26:18 7591cec14231: Download complete
01:26:18 b0b8081c21b9: Pull complete
01:26:18 b7cf13d7afa6: Pull complete
01:26:18 b5aa1770fbfe: Pull complete
01:26:18 7591cec14231: Pull complete
01:26:18 337759c3f8bf: Pull complete
01:26:18 Digest: sha256:d1b34ee995071956f6c17fa12f07c807b9768265c5238b7e1e848f1eb9c65a83
01:26:18 Status: Downloaded newer image for dockerswarm/dind:18.09.9-rc1
01:26:18 aea9f4f2835e94c8e911a06d224f138e40c316579ffc1239ec20d72a9bb06a4c
01:26:18 ++ docker run --rm --tty --link=compose-dind-18.09.9-rc1-jenkins-compose-PR-6850-2:docker --env=DOCKER_HOST=tcp://docker:2375 --env=DOCKER_VERSION=18.09.9-rc1 --entrypoint=tox dockerbuildbot/compose:alpine-04ce00a71373d402ca9ab2ea7a9f732eeab4778e -e py37 -- --verbose
[Pipeline] echo
01:26:19 Removing all docker containers
[Pipeline] sh
01:26:19 + docker container ls -aq
[Pipeline] echo
01:26:19 Docker containers have been removed
[Pipeline] echo
01:26:19 cleanWorkspace: Removing existing workspace
[Pipeline] deleteDir
[Pipeline] echo
01:26:19 cleanWorkspace: Workspace is clean.
[Pipeline] stage
[Pipeline] { (test python=py27 / docker=19.03.2-rc1 / baseImage=debian)
[Pipeline] checkout
01:26:19 tests/acceptance/cli_test.py::CLITestCase::test_down PASSED              [  3%]

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

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

01:26:19 py37 develop-inst-nodeps: /code

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

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

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

01:26:21 using credential sf-release-bot.github.ssh
01:26:21 Cloning the remote Git repository
01:26:21 Cloning with configured refspecs honoured and without tags
01:26:21 tests/acceptance/cli_test.py::CLITestCase::test_exec_detach_long_form PASSED [  4%]

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

Cloning repository git@github.com:docker/compose.git
 > git init /home/ubuntu/workspace/compose_PR-6850 # 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/pull/6850/head:refs/remotes/origin/PR-6850
01:26:22 tests/acceptance/cli_test.py::CLITestCase::test_config_default PASSED    [  1%]

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

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

01:26:23 Fetching without tags
01:26:24 Checking out Revision 04ce00a71373d402ca9ab2ea7a9f732eeab4778e (PR-6850)
01:26:24 tests/acceptance/cli_test.py::CLITestCase::test_exec_service_with_environment_overridden PASSED [  4%]

01:26:24 tests/acceptance/cli_test.py::CLITestCase::test_env_file_relative_to_compose_file PASSED [  3%]

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

01:26:24 Commit message: "add --skip-env-file option"
 > git config remote.origin.url git@github.com:docker/compose.git # timeout=10
 > git config --add remote.origin.fetch +refs/pull/6850/head:refs/remotes/origin/PR-6850 # 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/pull/6850/head:refs/remotes/origin/PR-6850
 > git config core.sparsecheckout # timeout=10
 > git checkout -f 04ce00a71373d402ca9ab2ea7a9f732eeab4778e
01:26:25 py37 installed: altgraph==0.16.1,asn1crypto==0.24.0,atomicwrites==1.3.0,attrs==19.1.0,bcrypt==3.1.7,cached-property==1.3.0,certifi==2017.4.17,cffi==1.12.3,chardet==3.0.4,coverage==4.4.2,cryptography==2.7,ddt==1.2.0,docker==4.0.1,# Editable install with no version control (docker-compose==1.25.0.dev0),-e /code,docker-pycreds==0.4.0,dockerpty==0.4.1,docopt==0.6.2,flake8==3.5.0,future==0.17.1,idna==2.5,ipaddress==1.0.18,jsonschema==2.6.0,macholib==1.11,mccabe==0.6.1,mock==3.0.5,more-itertools==7.2.0,paramiko==2.4.2,pefile==2019.4.18,pluggy==0.6.0,py==1.8.0,pyasn1==0.4.6,pycodestyle==2.3.1,pycparser==2.19,pyflakes==1.6.0,PyInstaller==3.4,PyNaCl==1.3.0,PySocks==1.6.7,pytest==3.6.3,pytest-cov==2.5.1,PyYAML==4.2b1,requests==2.22.0,six==1.10.0,texttable==1.6.2,urllib3==1.25.3,websocket-client==0.32.0

01:26:25 py37 runtests: PYTHONHASHSEED='4004539470'

01:26:25 py37 runtests: commands[0] | mkdir -p .coverage-binfiles

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

01:26:25 ============================= test session starts ==============================

01:26:25 platform linux -- Python 3.7.4, pytest-3.6.3, py-1.8.0, pluggy-0.6.0 -- /code/.tox/py37/bin/python3.7

01:26:25 cachedir: .pytest_cache

01:26:25 rootdir: /code, inifile: tox.ini

01:26:25 plugins: cov-2.5.1

[Pipeline] sh
01:26:25 tests/acceptance/cli_test.py::CLITestCase::test_config_external_volume_v2 PASSED [  1%]

01:26:25 + awk -F :  $1 == "Storage Driver" { print $2; exit }
01:26:25 + docker info
01:26:26 tests/acceptance/cli_test.py::CLITestCase::test_config_external_volume_v2_x PASSED [  2%]

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

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

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

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

01:26:28 
collecting 0 items                                                             
collecting 196 items                                                           
collecting 196 items                                                           
collecting 196 items                                                           
collecting 196 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 399 items                                                           
collecting 403 items                                                           
collecting 403 items                                                           
collecting 403 items                                                           
collecting 403 items                                                           
collecting 406 items                                                           
collecting 415 items                                                           
collecting 426 items                                                           
collecting 434 items                                                           
collecting 434 items                                                           
collecting 434 items                                                           
collecting 434 items                                                           
collecting 445 items                                                           
collecting 445 items                                                           
collecting 462 items                                                           
collecting 475 items                                                           
collecting 475 items                                                           
collecting 493 items                                                           
collecting 494 items                                                           
collecting 494 items                                                           
collecting 501 items                                                           
collecting 501 items                                                           
collecting 506 items                                                           
collecting 509 items                                                           
collecting 518 items                                                           
collecting 518 items                                                           
collecting 545 items                                                           
collecting 545 items                                                           
collecting 619 items                                                           
collecting 620 items                                                           
collecting 623 items                                                           
collecting 627 items                                                           
collecting 628 items                                                           
collecting 638 items                                                           
collecting 641 items                                                           
collecting 644 items                                                           
collecting 644 items                                                           
collecting 649 items                                                           
collecting 649 items                                                           
collecting 662 items                                                           
collecting 665 items                                                           
collecting 665 items                                                           
collecting 667 items                                                           
collecting 667 items                                                           
collecting 669 items                                                           
collecting 669 items                                                           
collecting 670 items                                                           
collecting 670 items                                                           
collecting 671 items                                                           
collecting 671 items                                                           
collecting 671 items                                                           
collecting 673 items                                                           
collecting 673 items                                                           
collecting 673 items                                                           
collecting 681 items                                                           
collecting 681 items                                                           
collecting 681 items                                                           
collecting 685 items                                                           
collecting 701 items                                                           
collecting 704 items                                                           
collecting 704 items                                                           
collecting 704 items                                                           
collecting 712 items                                                           
collecting 712 items                                                           
collecting 712 items                                                           
collecting 718 items                                                           
collecting 718 items                                                           
collecting 720 items                                                           
collecting 720 items                                                           
collecting 723 items                                                           
collecting 723 items                                                           
collecting 726 items                                                           
collecting 726 items                                                           
collecting 730 items                                                           
collecting 730 items                                                           
collecting 733 items                                                           
collecting 738 items                                                           
collecting 738 items                                                           
collecting 741 items                                                           
collecting 741 items                                                           
collecting 745 items                                                           
collecting 745 items                                                           
collecting 752 items                                                           
collecting 752 items                                                           
collecting 752 items                                                           
collecting 756 items                                                           
collecting 760 items                                                           
collecting 760 items                                                           
collecting 764 items                                                           
collecting 764 items                                                           
collecting 908 items                                                           
collecting 916 items                                                           
collecting 924 items                                                           
collecting 927 items                                                           
collecting 937 items                                                           
collecting 948 items                                                           
collecting 954 items                                                           
collecting 960 items                                                           
collecting 963 items                                                           
collecting 968 items                                                           
collecting 976 items                                                           
collecting 980 items                                                           
collecting 986 items                                                           
collecting 989 items                                                           
collecting 992 items                                                           
collecting 1004 items                                                          
collecting 1034 items                                                          
collecting 1037 items                                                          
collecting 1040 items                                                          
collecting 1047 items                                                          
collecting 1051 items                                                          
collecting 1053 items                                                          
collecting 1068 items                                                          
collecting 1068 items                                                          
collecting 1073 items                                                          
collecting 1073 items                                                          
collecting 1094 items                                                          
collecting 1106 items                                                          
collecting 1106 items                                                          
collecting 1106 items                                                          
collecting 1115 items                                                          
collecting 1115 items                                                          
collecting 1127 items                                                          
collecting 1127 items                                                          
collecting 1136 items                                                          
collecting 1136 items                                                          
collecting 1138 items                                                          
collected 1138 items                                                           

01:26:28 

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

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

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

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

01:26:29 WARNING: No swap limit support
01:26:29 WARNING: the aufs storage-driver is deprecated, and will be removed in a future release.
[Pipeline] echo
01:26:29 Using local system's storage driver: 
[Pipeline] sh
01:26:29 + pwd
01:26:29 + docker run -t --rm --privileged --volume=/home/ubuntu/workspace/compose_PR-6850/.git:/code/.git --volume=/var/run/docker.sock:/var/run/docker.sock -e TAG=dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e -e STORAGE_DRIVER= -e DOCKER_VERSIONS=19.03.2-rc1 -e BUILD_NUMBER=jenkins-compose-PR-6850-2 -e PY_TEST_VERSIONS=py27 --entrypoint=script/test/ci dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e --verbose
01:26:29 Unable to find image 'dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e' locally
01:26:29 debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e: Pulling from dockerbuildbot/compose
01:26:29 0a4690c5d889: Pulling fs layer
01:26:29 9ef510f4d0f7: Pulling fs layer
01:26:29 53fe96932e3f: Pulling fs layer
01:26:29 13d55380052c: Pulling fs layer
01:26:29 3102f4cc793a: Pulling fs layer
01:26:29 d320458ac7a5: Pulling fs layer
01:26:29 9f3ef983a669: Pulling fs layer
01:26:29 7d4fe19f703b: Pulling fs layer
01:26:29 a20184eb9807: Pulling fs layer
01:26:29 151fd087b5a9: Pulling fs layer
01:26:29 1639fd0d0dee: Pulling fs layer
01:26:29 8c3fcfeb31cb: Pulling fs layer
01:26:29 2bed9d31e3c9: Pulling fs layer
01:26:29 f69ce32ceba7: Pulling fs layer
01:26:29 a3bead48c3ea: Pulling fs layer
01:26:29 b40280e945e0: Pulling fs layer
01:26:29 c3ef7a730c92: Pulling fs layer
01:26:29 c65815eb55fa: Pulling fs layer
01:26:29 64f3aacfb141: Pulling fs layer
01:26:29 b6e24a215c19: Pulling fs layer
01:26:29 4d7a60876880: Pulling fs layer
01:26:29 8c3fcfeb31cb: Waiting
01:26:29 2bed9d31e3c9: Waiting
01:26:29 f69ce32ceba7: Waiting
01:26:29 a3bead48c3ea: Waiting
01:26:29 b40280e945e0: Waiting
01:26:29 13d55380052c: Waiting
01:26:29 3102f4cc793a: Waiting
01:26:29 d320458ac7a5: Waiting
01:26:29 9f3ef983a669: Waiting
01:26:29 7d4fe19f703b: Waiting
01:26:29 a20184eb9807: Waiting
01:26:29 151fd087b5a9: Waiting
01:26:29 1639fd0d0dee: Waiting
01:26:29 c3ef7a730c92: Waiting
01:26:29 c65815eb55fa: Waiting
01:26:29 64f3aacfb141: Waiting
01:26:29 b6e24a215c19: Waiting
01:26:29 4d7a60876880: Waiting
01:26:30 9ef510f4d0f7: Verifying Checksum
01:26:30 9ef510f4d0f7: Download complete
01:26:30 tests/acceptance/cli_test.py::CLITestCase::test_config_quiet PASSED      [  2%]

01:26:30 0a4690c5d889: Verifying Checksum
01:26:30 0a4690c5d889: Download complete
01:26:30 53fe96932e3f: Verifying Checksum
01:26:30 53fe96932e3f: Download complete
01:26:30 13d55380052c: Verifying Checksum
01:26:30 13d55380052c: Download complete
01:26:30 9f3ef983a669: Verifying Checksum
01:26:30 9f3ef983a669: Download complete
01:26:30 3102f4cc793a: Verifying Checksum
01:26:30 3102f4cc793a: Download complete
01:26:30 a20184eb9807: Verifying Checksum
01:26:30 a20184eb9807: Download complete
01:26:31 tests/acceptance/cli_test.py::CLITestCase::test_config_quiet_with_error PASSED [  2%]

01:26:31 7d4fe19f703b: Verifying Checksum
01:26:31 7d4fe19f703b: Download complete
01:26:31 151fd087b5a9: Verifying Checksum
01:26:31 151fd087b5a9: Download complete
01:26:31 8c3fcfeb31cb: Verifying Checksum
01:26:31 8c3fcfeb31cb: Download complete
01:26:31 2bed9d31e3c9: Verifying Checksum
01:26:31 2bed9d31e3c9: Download complete
01:26:31 1639fd0d0dee: Verifying Checksum
01:26:31 1639fd0d0dee: Download complete
01:26:31 tests/acceptance/cli_test.py::CLITestCase::test_exec_custom_user PASSED  [  4%]

01:26:31 f69ce32ceba7: Verifying Checksum
01:26:31 f69ce32ceba7: Download complete
01:26:31 a3bead48c3ea: Verifying Checksum
01:26:31 a3bead48c3ea: Download complete
01:26:31 b40280e945e0: Verifying Checksum
01:26:31 b40280e945e0: Download complete
01:26:31 c3ef7a730c92: Verifying Checksum
01:26:31 c3ef7a730c92: Download complete
01:26:31 c65815eb55fa: Verifying Checksum
01:26:31 c65815eb55fa: Download complete
01:26:31 b6e24a215c19: Verifying Checksum
01:26:31 b6e24a215c19: Download complete
01:26:31 tests/acceptance/cli_test.py::CLITestCase::test_config_restart PASSED    [  2%]

01:26:32 64f3aacfb141: Verifying Checksum
01:26:32 64f3aacfb141: Download complete
01:26:32 d320458ac7a5: Verifying Checksum
01:26:32 d320458ac7a5: Download complete
01:26:32 4d7a60876880: Verifying Checksum
01:26:32 4d7a60876880: Download complete
01:26:32 0a4690c5d889: Pull complete
01:26:32 tests/acceptance/cli_test.py::CLITestCase::test_config_v1 PASSED         [  2%]

01:26:32 9ef510f4d0f7: Pull complete
01:26:33 tests/acceptance/cli_test.py::CLITestCase::test_build_failed PASSED      [  0%]

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

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

01:26:34 53fe96932e3f: Pull complete
01:26:34 13d55380052c: Pull complete
01:26:34 3102f4cc793a: Pull complete
01:26:34 tests/acceptance/cli_test.py::CLITestCase::test_config_with_dot_env PASSED [  2%]

01:26:35 tests/acceptance/cli_test.py::CLITestCase::test_config_with_dot_env_and_override_dir PASSED [  2%]

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

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

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

01:26:37 d320458ac7a5: Pull complete
01:26:37 9f3ef983a669: Pull complete
01:26:38 tests/acceptance/cli_test.py::CLITestCase::test_config_with_hash_option PASSED [  3%]

01:26:38 7d4fe19f703b: Pull complete
01:26:38 a20184eb9807: Pull complete
01:26:38 151fd087b5a9: Pull complete
01:26:38 tests/acceptance/cli_test.py::CLITestCase::test_exec_without_tty PASSED  [  4%]

01:26:38 1639fd0d0dee: Pull complete
01:26:38 8c3fcfeb31cb: Pull complete
01:26:39 tests/acceptance/cli_test.py::CLITestCase::test_create PASSED            [  3%]

01:26:39 2bed9d31e3c9: Pull complete
01:26:39 f69ce32ceba7: Pull complete
01:26:39 a3bead48c3ea: Pull complete
01:26:39 b40280e945e0: Pull complete
01:26:39 c3ef7a730c92: Pull complete
01:26:39 c65815eb55fa: Pull complete
01:26:40 tests/acceptance/cli_test.py::CLITestCase::test_create_with_force_recreate PASSED [  3%]

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

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

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

01:26:42 64f3aacfb141: Pull complete
01:26:42 b6e24a215c19: Pull complete
01:26:42 4d7a60876880: Pull complete
01:26:42 Digest: sha256:ec739b4cd5f5766868b7732ee60ae6e6ce65f5f937cb06e3339bc38627a53751
01:26:42 Status: Downloaded newer image for dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e
01:26:43 + docker version
01:26:43 Client: Docker Engine - Community
01:26:43  Version:           18.09.7
01:26:43  API version:       1.39
01:26:43  Go version:        go1.10.8
01:26:43  Git commit:        2d0083d
01:26:43  Built:             Thu Jun 27 17:54:15 2019
01:26:43  OS/Arch:           linux/amd64
01:26:43  Experimental:      false
01:26:43 
01:26:43 Server: Docker Engine - Community
01:26:43  Engine:
01:26:43   Version:          19.03.1
01:26:43   API version:      1.40 (minimum version 1.12)
01:26:43   Go version:       go1.12.5
01:26:43   Git commit:       74b1e89e8a
01:26:43   Built:            Thu Jul 25 21:20:09 2019
01:26:43   OS/Arch:          linux/amd64
01:26:43   Experimental:     true
01:26:43  containerd:
01:26:43   Version:          1.2.6
01:26:43   GitCommit:        894b81a4b802e4eb2a91d1ce216b8817763c29fb
01:26:43  runc:
01:26:43   Version:          1.0.0-rc8
01:26:43   GitCommit:        425e105d5a03fabd737a126ad93d62a9eeede87f
01:26:43  docker-init:
01:26:43   Version:          0.18.0
01:26:43   GitCommit:        fec3683
01:26:43 + export DOCKER_VERSIONS=19.03.2-rc1
01:26:43 + DOCKER_VERSIONS=19.03.2-rc1
01:26:43 + STORAGE_DRIVER=overlay
01:26:43 + export DOCKER_DAEMON_ARGS=--storage-driver=overlay
01:26:43 + DOCKER_DAEMON_ARGS=--storage-driver=overlay
01:26:43 ++ hostname
01:26:43 + GIT_VOLUME=--volumes-from=8e8b3a194a5b
01:26:43 + . script/test/all
01:26:43 ++ set -e
01:26:43 ++ echo 'Running lint checks'
01:26:43 Running lint checks
01:26:43 ++ docker run --rm --tty --volumes-from=8e8b3a194a5b dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e tox -e pre-commit
01:26:43 tests/acceptance/cli_test.py::CLITestCase::test_create_with_no_recreate PASSED [  3%]

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

01:26:45 pre-commit installed: aspy.yaml==1.3.0,cfgv==2.0.1,identify==1.4.6,importlib-metadata==0.19,nodeenv==1.3.3,pre-commit==1.18.1,PyYAML==5.1.2,six==1.12.0,toml==0.10.0,virtualenv==16.7.2,zipp==0.5.2

01:26:45 pre-commit runtests: PYTHONHASHSEED='3320960199'

01:26:45 pre-commit runtests: commands[0] | pre-commit install

01:26:45 pre-commit installed at .git/hooks/pre-commit

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

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

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

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

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

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

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

01:26:45 [INFO] Once installed this environment will be reused.

01:26:45 [INFO] This may take a few minutes...

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

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

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

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

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

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

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

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

Running on ubuntu-1604-aufs (i-0683f2eb7f1ad3369) in /home/ubuntu/workspace/compose_PR-6850
[Pipeline] {
[Pipeline] withDockerRegistry
$ docker login -u dockerbuildbot -p ******** https://index.docker.io/v1/
01:26:59 tests/acceptance/cli_test.py::CLITestCase::test_build_override_dir PASSED [  0%]

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

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

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

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

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

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

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

WARNING! Using --password via the CLI is insecure. Use --password-stdin.
01:27:03 tests/acceptance/cli_test.py::CLITestCase::test_build_parallel PASSED    [  0%]

WARNING! Your password will be stored unencrypted in /home/ubuntu/workspace/compose_PR-6850@tmp/1df7ddde-42ab-44b7-97f2-6cc2ae1a0f6b/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store

Login Succeeded
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] wrap
[Pipeline] {
[Pipeline] echo
01:27:03 cleanWorkspace: Ensuring workspace is owned by ubuntu
[Pipeline] echo
01:27:03 chowning workspace
[Pipeline] sh
01:27:03 [INFO] Installing environment for git://github.com/asottile/reorder_python_imports.

01:27:03 [INFO] Once installed this environment will be reused.

01:27:03 [INFO] This may take a few minutes...

01:27:04 + uname -m
[Pipeline] sh
01:27:04 + pwd
01:27:04 + id -u
01:27:04 + id -g
01:27:04 + docker run --rm -v /home/ubuntu/workspace/compose_PR-6850:/workspace busybox chown -R 1000:1000 /workspace
01:27:04 Unable to find image 'busybox:latest' locally
01:27:04 tests/acceptance/cli_test.py::CLITestCase::test_down_signal PASSED       [  3%]

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

01:27:05 latest: Pulling from library/busybox
01:27:05 ee153a04d683: Pulling fs layer
01:27:05 ee153a04d683: Verifying Checksum
01:27:05 ee153a04d683: Download complete
01:27:05 ee153a04d683: Pull complete
01:27:05 Digest: sha256:9f1003c480699be56815db0f8146ad2e22efea85129b5b5983d0e0fb52d9ab70
01:27:05 Status: Downloaded newer image for busybox:latest
01:27:06 tests/acceptance/cli_test.py::CLITestCase::test_build_plain PASSED       [  0%]

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

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

[Pipeline] echo
01:27:08 Removing all docker containers
[Pipeline] sh
01:27:08 tests/acceptance/cli_test.py::CLITestCase::test_env_file_relative_to_compose_file PASSED [  3%]

01:27:08 + docker container ls -aq
[Pipeline] echo
01:27:08 Docker containers have been removed
[Pipeline] echo
01:27:08 cleanWorkspace: Removing existing workspace
[Pipeline] deleteDir
[Pipeline] echo
01:27:08 cleanWorkspace: Workspace is clean.
[Pipeline] stage
[Pipeline] { (test python=py37 / docker=19.03.2-rc1 / baseImage=debian)
[Pipeline] checkout
01:27:09 tests/acceptance/cli_test.py::CLITestCase::test_forward_exitval PASSED   [  4%]

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

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

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

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

01:27:10 using credential sf-release-bot.github.ssh
01:27:10 Cloning the remote Git repository
01:27:10 Cloning with configured refspecs honoured and without tags
01:27:11 tests/acceptance/cli_test.py::CLITestCase::test_images_use_service_tag PASSED [  5%]

Cloning repository git@github.com:docker/compose.git
 > git init /home/ubuntu/workspace/compose_PR-6850 # 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/pull/6850/head:refs/remotes/origin/PR-6850
01:27:12 tests/acceptance/cli_test.py::CLITestCase::test_build_rm XPASS           [  1%]

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

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

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

01:27:13 Fetching without tags
01:27:13 tests/acceptance/cli_test.py::CLITestCase::test_host_not_reachable_volumes_from_container PASSED [  5%]

01:27:13 Checking out Revision 04ce00a71373d402ca9ab2ea7a9f732eeab4778e (PR-6850)
01:27:13 Check for added large files..............................................Passed

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

01:27:14 Commit message: "add --skip-env-file option"
 > git config remote.origin.url git@github.com:docker/compose.git # timeout=10
 > git config --add remote.origin.fetch +refs/pull/6850/head:refs/remotes/origin/PR-6850 # 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/pull/6850/head:refs/remotes/origin/PR-6850
 > git config core.sparsecheckout # timeout=10
 > git checkout -f 04ce00a71373d402ca9ab2ea7a9f732eeab4778e
01:27:14 Check docstring is first.................................................Passed

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

01:27:14 Check for merge conflicts................................................Passed

01:27:14 Check Yaml...............................................................Passed

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

[Pipeline] sh
01:27:14 Check JSON...............................................................Passed

01:27:15 Debug Statements (Python)................................................Passed

01:27:15 Fix End of Files.........................................................Passed

01:27:15 + awk -F :  $1 == "Storage Driver" { print $2; exit }
01:27:15 + docker info
01:27:15 tests/acceptance/cli_test.py::CLITestCase::test_exec_custom_user PASSED  [  4%]

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

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

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

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

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

01:27:19 WARNING: No swap limit support
01:27:19 WARNING: the aufs storage-driver is deprecated, and will be removed in a future release.
[Pipeline] echo
01:27:19 Using local system's storage driver: 
[Pipeline] sh
01:27:19 + pwd
01:27:19 + docker run -t --rm --privileged --volume=/home/ubuntu/workspace/compose_PR-6850/.git:/code/.git --volume=/var/run/docker.sock:/var/run/docker.sock -e TAG=dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e -e STORAGE_DRIVER= -e DOCKER_VERSIONS=19.03.2-rc1 -e BUILD_NUMBER=jenkins-compose-PR-6850-2 -e PY_TEST_VERSIONS=py37 --entrypoint=script/test/ci dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e --verbose
01:27:19 Unable to find image 'dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e' locally
01:27:19 tests/acceptance/cli_test.py::CLITestCase::test_exec_service_with_environment_overridden PASSED [  4%]

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

01:27:20 tests/acceptance/cli_test.py::CLITestCase::test_logs_default SKIPPED     [  5%]

01:27:20 debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e: Pulling from dockerbuildbot/compose
01:27:20 0a4690c5d889: Pulling fs layer
01:27:20 9ef510f4d0f7: Pulling fs layer
01:27:20 53fe96932e3f: Pulling fs layer
01:27:20 13d55380052c: Pulling fs layer
01:27:20 3102f4cc793a: Pulling fs layer
01:27:20 d320458ac7a5: Pulling fs layer
01:27:20 9f3ef983a669: Pulling fs layer
01:27:20 7d4fe19f703b: Pulling fs layer
01:27:20 a20184eb9807: Pulling fs layer
01:27:20 151fd087b5a9: Pulling fs layer
01:27:20 1639fd0d0dee: Pulling fs layer
01:27:20 8c3fcfeb31cb: Pulling fs layer
01:27:20 2bed9d31e3c9: Pulling fs layer
01:27:20 f69ce32ceba7: Pulling fs layer
01:27:20 a3bead48c3ea: Pulling fs layer
01:27:20 b40280e945e0: Pulling fs layer
01:27:20 c3ef7a730c92: Pulling fs layer
01:27:20 c65815eb55fa: Pulling fs layer
01:27:20 64f3aacfb141: Pulling fs layer
01:27:20 b6e24a215c19: Pulling fs layer
01:27:20 4d7a60876880: Pulling fs layer
01:27:20 13d55380052c: Waiting
01:27:20 3102f4cc793a: Waiting
01:27:20 d320458ac7a5: Waiting
01:27:20 9f3ef983a669: Waiting
01:27:20 7d4fe19f703b: Waiting
01:27:20 a20184eb9807: Waiting
01:27:20 151fd087b5a9: Waiting
01:27:20 1639fd0d0dee: Waiting
01:27:20 8c3fcfeb31cb: Waiting
01:27:20 2bed9d31e3c9: Waiting
01:27:20 f69ce32ceba7: Waiting
01:27:20 a3bead48c3ea: Waiting
01:27:20 b40280e945e0: Waiting
01:27:20 c3ef7a730c92: Waiting
01:27:20 c65815eb55fa: Waiting
01:27:20 64f3aacfb141: Waiting
01:27:20 b6e24a215c19: Waiting
01:27:20 4d7a60876880: Waiting
01:27:20 0a4690c5d889: Verifying Checksum
01:27:20 0a4690c5d889: Download complete
01:27:20 53fe96932e3f: Verifying Checksum
01:27:20 53fe96932e3f: Download complete
01:27:20 9ef510f4d0f7: Verifying Checksum
01:27:20 9ef510f4d0f7: Download complete
01:27:20 13d55380052c: Verifying Checksum
01:27:20 13d55380052c: Download complete
01:27:20 9f3ef983a669: Verifying Checksum
01:27:20 9f3ef983a669: Download complete
01:27:20 3102f4cc793a: Verifying Checksum
01:27:20 3102f4cc793a: Download complete
01:27:20 a20184eb9807: Verifying Checksum
01:27:20 a20184eb9807: Download complete
01:27:20 7d4fe19f703b: Verifying Checksum
01:27:20 7d4fe19f703b: Download complete
01:27:20 151fd087b5a9: Verifying Checksum
01:27:20 151fd087b5a9: Download complete
01:27:20 1639fd0d0dee: Verifying Checksum
01:27:20 1639fd0d0dee: Download complete
01:27:21 8c3fcfeb31cb: Verifying Checksum
01:27:21 8c3fcfeb31cb: Download complete
01:27:21 2bed9d31e3c9: Verifying Checksum
01:27:21 2bed9d31e3c9: Download complete
01:27:21 f69ce32ceba7: Verifying Checksum
01:27:21 f69ce32ceba7: Download complete
01:27:21 a3bead48c3ea: Verifying Checksum
01:27:21 a3bead48c3ea: Download complete
01:27:21 b40280e945e0: Verifying Checksum
01:27:21 b40280e945e0: Download complete
01:27:21 c3ef7a730c92: Verifying Checksum
01:27:21 c3ef7a730c92: Download complete
01:27:21 c65815eb55fa: Verifying Checksum
01:27:21 c65815eb55fa: Download complete
01:27:21 b6e24a215c19: Verifying Checksum
01:27:21 b6e24a215c19: Download complete
01:27:22 64f3aacfb141: Verifying Checksum
01:27:22 64f3aacfb141: Download complete
01:27:22 tests/acceptance/cli_test.py::CLITestCase::test_build_with_buildarg_from_compose_file PASSED [  1%]

01:27:22 d320458ac7a5: Verifying Checksum
01:27:22 d320458ac7a5: Download complete
01:27:22 tests/acceptance/cli_test.py::CLITestCase::test_exec_without_tty PASSED  [  4%]

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

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

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

01:27:22 4d7a60876880: Verifying Checksum
01:27:22 4d7a60876880: Download complete
01:27:22 0a4690c5d889: Pull complete
01:27:22 9ef510f4d0f7: Pull complete
01:27:23 tests/acceptance/cli_test.py::CLITestCase::test_logs_invalid_service_name PASSED [  6%]

01:27:23 Flake8...................................................................Passed

01:27:23 Tests should end in _test.py.............................................Passed

01:27:23 Fix requirements.txt.....................................................Passed

01:27:23 Trim Trailing Whitespace.................................................Passed

01:27:23 Reorder python imports...................................................Passed

01:27:23 ___________________________________ summary ____________________________________

01:27:23   pre-commit: commands succeeded

01:27:23   congratulations :)

01:27:24 ++ get_versions='docker run --rm
01:27:24     --entrypoint=/code/.tox/py27/bin/python
01:27:24     dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e
01:27:24     /code/script/test/versions.py docker/docker-ce,moby/moby'
01:27:24 ++ '[' 19.03.2-rc1 == '' ']'
01:27:24 ++ '[' 19.03.2-rc1 == all ']'
01:27:24 ++ BUILD_NUMBER=jenkins-compose-PR-6850-2
01:27:24 ++ PY_TEST_VERSIONS=py27
01:27:24 ++ for version in $DOCKER_VERSIONS
01:27:24 ++ echo 'Running tests against Docker 19.03.2-rc1'
01:27:24 Running tests against Docker 19.03.2-rc1
01:27:24 ++ daemon_container=compose-dind-19.03.2-rc1-jenkins-compose-PR-6850-2
01:27:24 ++ trap on_exit EXIT
01:27:24 ++ repo=dockerswarm/dind
01:27:24 ++ docker run -d --name compose-dind-19.03.2-rc1-jenkins-compose-PR-6850-2 --privileged --volume=/var/lib/docker dockerswarm/dind:19.03.2-rc1 dockerd -H tcp://0.0.0.0:2375 --storage-driver=overlay
01:27:24 ++ tail -n 10
01:27:24 53fe96932e3f: Pull complete
01:27:24 13d55380052c: Pull complete
01:27:24 3102f4cc793a: Pull complete
01:27:24 tests/acceptance/cli_test.py::CLITestCase::test_images_use_service_tag PASSED [  5%]

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

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

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

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

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

01:27:27 d320458ac7a5: Pull complete
01:27:27 9f3ef983a669: Pull complete
01:27:27 tests/acceptance/cli_test.py::CLITestCase::test_config_compatibility_mode PASSED [  1%]

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

01:27:28 7d4fe19f703b: Pull complete
01:27:28 a20184eb9807: Pull complete
01:27:28 151fd087b5a9: Pull complete
01:27:28 tests/acceptance/cli_test.py::CLITestCase::test_config_default PASSED    [  1%]

01:27:28 1639fd0d0dee: Pull complete
01:27:29 8c3fcfeb31cb: Pull complete
01:27:29 2bed9d31e3c9: Pull complete
01:27:29 f69ce32ceba7: Pull complete
01:27:29 a3bead48c3ea: Pull complete
01:27:29 b40280e945e0: Pull complete
01:27:29 tests/acceptance/cli_test.py::CLITestCase::test_kill_signal_sigstop PASSED [  5%]

01:27:29 c3ef7a730c92: Pull complete
01:27:29 c65815eb55fa: Pull complete
01:27:29 tests/acceptance/cli_test.py::CLITestCase::test_config_external_network PASSED [  1%]

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

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

01:27:30 baae4e02d0f0: Verifying Checksum
01:27:30 baae4e02d0f0: Download complete
01:27:30 b0b8081c21b9: Pull complete
01:27:30 f0363a51a0f4: Pull complete
01:27:30 14457cbcc43a: Pull complete
01:27:30 baae4e02d0f0: Pull complete
01:27:30 fbc676048046: Pull complete
01:27:30 Digest: sha256:640e8123ebb07f686320b3ba801edd1bde9015aa39913588ba34173a02bf2435
01:27:30 Status: Downloaded newer image for dockerswarm/dind:19.03.2-rc1
01:27:30 08fa7bf4c476e8eba7ad398d547aa62e850b2dfdf906c37e6560197aeda47b45
01:27:30 ++ docker run --rm --tty --link=compose-dind-19.03.2-rc1-jenkins-compose-PR-6850-2:docker --env=DOCKER_HOST=tcp://docker:2375 --env=DOCKER_VERSION=19.03.2-rc1 --entrypoint=tox dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e -e py27 -- --verbose
01:27:31 tests/acceptance/cli_test.py::CLITestCase::test_config_external_volume_v2 PASSED [  1%]

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

01:27:32 py27 develop-inst-nodeps: /code

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

01:27:32 64f3aacfb141: Pull complete
01:27:32 b6e24a215c19: Pull complete
01:27:32 tests/acceptance/cli_test.py::CLITestCase::test_config_external_volume_v3_4 PASSED [  2%]

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

01:27:32 tests/acceptance/cli_test.py::CLITestCase::test_logs_default SKIPPED     [  5%]

01:27:33 4d7a60876880: Pull complete
01:27:33 Digest: sha256:ec739b4cd5f5766868b7732ee60ae6e6ce65f5f937cb06e3339bc38627a53751
01:27:33 Status: Downloaded newer image for dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e
01:27:33 tests/acceptance/cli_test.py::CLITestCase::test_config_external_volume_v3_x PASSED [  2%]

01:27:33 + docker version
01:27:33 Client: Docker Engine - Community
01:27:33  Version:           18.09.7
01:27:33  API version:       1.39
01:27:33  Go version:        go1.10.8
01:27:33  Git commit:        2d0083d
01:27:33  Built:             Thu Jun 27 17:54:15 2019
01:27:33  OS/Arch:           linux/amd64
01:27:33  Experimental:      false
01:27:33 
01:27:33 Server: Docker Engine - Community
01:27:33  Engine:
01:27:33   Version:          19.03.1
01:27:33   API version:      1.40 (minimum version 1.12)
01:27:33   Go version:       go1.12.5
01:27:33   Git commit:       74b1e89e8a
01:27:33   Built:            Thu Jul 25 21:20:09 2019
01:27:33   OS/Arch:          linux/amd64
01:27:33   Experimental:     true
01:27:33  containerd:
01:27:33   Version:          1.2.6
01:27:33   GitCommit:        894b81a4b802e4eb2a91d1ce216b8817763c29fb
01:27:33  runc:
01:27:33   Version:          1.0.0-rc8
01:27:33   GitCommit:        425e105d5a03fabd737a126ad93d62a9eeede87f
01:27:33  docker-init:
01:27:33   Version:          0.18.0
01:27:33   GitCommit:        fec3683
01:27:33 + export DOCKER_VERSIONS=19.03.2-rc1
01:27:33 + DOCKER_VERSIONS=19.03.2-rc1
01:27:33 + STORAGE_DRIVER=overlay
01:27:33 + export DOCKER_DAEMON_ARGS=--storage-driver=overlay
01:27:33 + DOCKER_DAEMON_ARGS=--storage-driver=overlay
01:27:33 ++ hostname
01:27:33 + GIT_VOLUME=--volumes-from=2f11ea96e81a
01:27:33 + . script/test/all
01:27:33 ++ set -e
01:27:33 ++ echo 'Running lint checks'
01:27:33 Running lint checks
01:27:33 ++ docker run --rm --tty --volumes-from=2f11ea96e81a dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e tox -e pre-commit
01:27:34 tests/acceptance/cli_test.py::CLITestCase::test_config_list_services PASSED [  2%]

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

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

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

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

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

01:27:35 pre-commit installed: aspy.yaml==1.3.0,cfgv==2.0.1,identify==1.4.6,importlib-metadata==0.19,nodeenv==1.3.3,pre-commit==1.18.1,PyYAML==5.1.2,six==1.12.0,toml==0.10.0,virtualenv==16.7.2,zipp==0.5.2

01:27:35 pre-commit runtests: PYTHONHASHSEED='2432525817'

01:27:35 pre-commit runtests: commands[0] | pre-commit install

01:27:35 pre-commit installed at .git/hooks/pre-commit

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

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

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

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

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

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

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

01:27:36 [INFO] Once installed this environment will be reused.

01:27:36 [INFO] This may take a few minutes...

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

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

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

01:27:37 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,asn1crypto==0.24.0,atomicwrites==1.3.0,attrs==19.1.0,backports.ssl-match-hostname==3.5.0.1,bcrypt==3.1.7,cached-property==1.3.0,certifi==2017.4.17,cffi==1.12.3,chardet==3.0.4,configparser==3.8.1,coverage==4.4.2,cryptography==2.7,ddt==1.2.0,docker==4.0.1,# Editable install with no version control (docker-compose==1.25.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==2.6.0,mccabe==0.6.1,mock==3.0.5,more-itertools==5.0.0,paramiko==2.4.2,pluggy==0.6.0,py==1.8.0,pyasn1==0.4.6,pycodestyle==2.3.1,pycparser==2.19,pyflakes==1.6.0,PyNaCl==1.3.0,PySocks==1.6.7,pytest==3.6.3,pytest-cov==2.5.1,PyYAML==4.2b1,requests==2.22.0,six==1.10.0,texttable==1.6.2,urllib3==1.25.3,websocket-client==0.32.0

01:27:37 py27 runtests: PYTHONHASHSEED='1053088428'

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

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

01:27:37 ============================= test session starts ==============================

01:27:37 platform linux2 -- Python 2.7.13, pytest-3.6.3, py-1.8.0, pluggy-0.6.0 -- /code/.tox/py27/bin/python2.7

01:27:37 cachedir: .pytest_cache

01:27:37 rootdir: /code, inifile: tox.ini

01:27:37 plugins: cov-2.5.1

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

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

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

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

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

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

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

01:27:40 
collecting 0 items                                                             
collecting 196 items                                                           
collecting 196 items                                                           
collecting 196 items                                                           
collecting 196 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 399 items                                                           
collecting 403 items                                                           
collecting 403 items                                                           
collecting 403 items                                                           
collecting 403 items                                                           
collecting 406 items                                                           
collecting 415 items                                                           
collecting 426 items                                                           
collecting 434 items                                                           
collecting 434 items                                                           
collecting 434 items                                                           
collecting 434 items                                                           
collecting 445 items                                                           
collecting 445 items                                                           
collecting 462 items                                                           
collecting 475 items                                                           
collecting 475 items                                                           
collecting 493 items                                                           
collecting 494 items                                                           
collecting 494 items                                                           
collecting 501 items                                                           
collecting 501 items                                                           
collecting 506 items                                                           
collecting 509 items                                                           
collecting 518 items                                                           
collecting 518 items                                                           
collecting 545 items                                                           
collecting 545 items                                                           
collecting 619 items                                                           
collecting 620 items                                                           
collecting 623 items                                                           
collecting 627 items                                                           
collecting 628 items                                                           
collecting 638 items                                                           
collecting 641 items                                                           
collecting 644 items                                                           
collecting 644 items                                                           
collecting 649 items                                                           
collecting 649 items                                                           
collecting 662 items                                                           
collecting 665 items                                                           
collecting 665 items                                                           
collecting 667 items                                                           
collecting 667 items                                                           
collecting 669 items                                                           
collecting 669 items                                                           
collecting 670 items                                                           
collecting 670 items                                                           
collecting 671 items                                                           
collecting 671 items                                                           
collecting 671 items                                                           
collecting 673 items                                                           
collecting 673 items                                                           
collecting 673 items                                                           
collecting 681 items                                                           
collecting 681 items                                                           
collecting 681 items                                                           
collecting 685 items                                                           
collecting 701 items                                                           
collecting 704 items                                                           
collecting 704 items                                                           
collecting 704 items                                                           
collecting 712 items                                                           
collecting 712 items                                                           
collecting 712 items                                                           
collecting 718 items                                                           
collecting 718 items                                                           
collecting 720 items                                                           
collecting 720 items                                                           
collecting 723 items                                                           
collecting 723 items                                                           
collecting 726 items                                                           
collecting 726 items                                                           
collecting 730 items                                                           
collecting 730 items                                                           
collecting 733 items                                                           
collecting 738 items                                                           
collecting 738 items                                                           
collecting 741 items                                                           
collecting 741 items                                                           
collecting 745 items                                                           
collecting 745 items                                                           
collecting 752 items                                                           
collecting 752 items                                                           
collecting 752 items                                                           
collecting 756 items                                                           
collecting 760 items                                                           
collecting 760 items                                                           
collecting 764 items                                                           
collecting 764 items                                                           
collecting 908 items                                                           
collecting 916 items                                                           
collecting 924 items                                                           
collecting 927 items                                                           
collecting 937 items                                                           
collecting 948 items                                                           
collecting 954 items                                                           
collecting 960 items                                                           
collecting 963 items                                                           
collecting 968 items                                                           
collecting 976 items                                                           
collecting 980 items                                                           
collecting 986 items                                                           
collecting 989 items                                                           
collecting 992 items                                                           
collecting 1004 items                                                          
collecting 1034 items                                                          
collecting 1037 items                                                          
collecting 1040 items                                                          
collecting 1047 items                                                          
collecting 1051 items                                                          
collecting 1053 items                                                          
collecting 1068 items                                                          
collecting 1068 items                                                          
collecting 1073 items                                                          
collecting 1073 items                                                          
collecting 1094 items                                                          
collecting 1106 items                                                          
collecting 1106 items                                                          
collecting 1106 items                                                          
collecting 1115 items                                                          
collecting 1115 items                                                          
collecting 1127 items                                                          
collecting 1127 items                                                          
collecting 1136 items                                                          
collecting 1136 items                                                          
collecting 1138 items                                                          
collected 1138 items                                                           

01:27:40 

01:27:40 tests/acceptance/cli_test.py::CLITestCase::test_config_with_dot_env_and_override_dir PASSED [  2%]

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

01:27:54 [INFO] Once installed this environment will be reused.

01:27:54 [INFO] This may take a few minutes...

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

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

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

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

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

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

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

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

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

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

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

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

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

01:28:01 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_build PASSED   [  7%]

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

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

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

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

01:28:03 Check for added large files..............................................Passed

01:28:04 Check docstring is first.................................................Passed

01:28:04 Check for merge conflicts................................................Passed

01:28:04 Check Yaml...............................................................Passed

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

01:28:04 Check JSON...............................................................Passed

01:28:05 Debug Statements (Python)................................................Passed

01:28:05 Fix End of Files.........................................................Passed

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

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

01:28:05 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_no_deps PASSED [  7%]

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

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

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

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

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

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

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

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

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

Running on ubuntu-1604-aufs (i-02965249113a0b65e) in /home/ubuntu/workspace/compose_PR-6850
[Pipeline] {
[Pipeline] withDockerRegistry
01:28:12 tests/acceptance/cli_test.py::CLITestCase::test_down_timeout PASSED      [  3%]

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

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

$ docker login -u dockerbuildbot -p ******** https://index.docker.io/v1/
01:28:13 Flake8...................................................................Passed

01:28:13 Tests should end in _test.py.............................................Passed

01:28:13 Fix requirements.txt.....................................................Passed

01:28:13 Trim Trailing Whitespace.................................................Passed

01:28:13 Reorder python imports...................................................Passed

01:28:13 ___________________________________ summary ____________________________________

01:28:13   pre-commit: commands succeeded

01:28:13   congratulations :)

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

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

01:28:13 tests/acceptance/cli_test.py::CLITestCase::test_env_file_relative_to_compose_file PASSED [  3%]

01:28:13 ++ get_versions='docker run --rm
01:28:13     --entrypoint=/code/.tox/py27/bin/python
01:28:13     dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e
01:28:13     /code/script/test/versions.py docker/docker-ce,moby/moby'
01:28:13 ++ '[' 19.03.2-rc1 == '' ']'
01:28:13 ++ '[' 19.03.2-rc1 == all ']'
01:28:13 ++ BUILD_NUMBER=jenkins-compose-PR-6850-2
01:28:13 ++ PY_TEST_VERSIONS=py37
01:28:13 ++ for version in $DOCKER_VERSIONS
01:28:13 ++ echo 'Running tests against Docker 19.03.2-rc1'
01:28:13 Running tests against Docker 19.03.2-rc1
01:28:13 ++ daemon_container=compose-dind-19.03.2-rc1-jenkins-compose-PR-6850-2
01:28:13 ++ trap on_exit EXIT
01:28:13 ++ repo=dockerswarm/dind
01:28:13 ++ docker run -d --name compose-dind-19.03.2-rc1-jenkins-compose-PR-6850-2 --privileged --volume=/var/lib/docker dockerswarm/dind:19.03.2-rc1 dockerd -H tcp://0.0.0.0:2375 --storage-driver=overlay
01:28:13 ++ tail -n 10
Running on ubuntu-1804-overlay2 (i-027e4a282628fe713) in /home/ubuntu/workspace/compose_PR-6850
01:28:14 tests/acceptance/cli_test.py::CLITestCase::test_quiet_build PASSED       [  8%]

01:28:14 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_build PASSED   [  7%]

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

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

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

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

01:28:15 tests/acceptance/cli_test.py::CLITestCase::test_logs_default SKIPPED     [  5%]

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

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

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

WARNING! Using --password via the CLI is insecure. Use --password-stdin.
WARNING! Your password will be stored unencrypted in /home/ubuntu/workspace/compose_PR-6850@tmp/d5f788ab-f7b2-46a6-84d2-5b07dc0493fe/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store

Login Succeeded
[Pipeline] {
[Pipeline] {
[Pipeline] wrap
[Pipeline] withDockerRegistry
$ docker login -u dockerbuildbot -p ******** https://index.docker.io/v1/
WARNING! Using --password via the CLI is insecure. Use --password-stdin.
WARNING! Your password will be stored unencrypted in /home/ubuntu/workspace/compose_PR-6850@tmp/9f00b2fb-ac78-45b4-aab9-1e9eec7503b3/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store

Login Succeeded
[Pipeline] {
[Pipeline] {
[Pipeline] wrap
[Pipeline] wrap
[Pipeline] {
[Pipeline] {
[Pipeline] wrap
[Pipeline] echo
01:28:16 cleanWorkspace: Ensuring workspace is owned by ubuntu
[Pipeline] echo
01:28:16 chowning workspace
[Pipeline] sh
[Pipeline] {
[Pipeline] echo
01:28:16 cleanWorkspace: Ensuring workspace is owned by ubuntu
[Pipeline] echo
01:28:16 chowning workspace
[Pipeline] sh
01:28:17 + uname -m
01:28:17 + uname -m
[Pipeline] sh
[Pipeline] sh
01:28:17 tests/acceptance/cli_test.py::CLITestCase::test_logs_follow PASSED       [  6%]

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

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

01:28:17 + pwd
01:28:17 + id -u
01:28:17 + id -g
01:28:17 + docker run --rm -v /home/ubuntu/workspace/compose_PR-6850:/workspace busybox chown -R 1000:1000 /workspace
01:28:17 + pwd
01:28:17 + id -u
01:28:17 + id -g
01:28:17 + docker run --rm -v /home/ubuntu/workspace/compose_PR-6850:/workspace busybox chown -R 1000:1000 /workspace
01:28:17 Unable to find image 'busybox:latest' locally
01:28:17 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_include_deps PASSED [  7%]

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

01:28:17 latest: Pulling from library/busybox
01:28:17 ee153a04d683: Pulling fs layer
01:28:17 ee153a04d683: Download complete
01:28:17 tests/acceptance/cli_test.py::CLITestCase::test_events_json PASSED       [  4%]

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

[Pipeline] echo
01:28:18 Removing all docker containers
[Pipeline] sh
01:28:18 ee153a04d683: Pull complete
01:28:18 Digest: sha256:9f1003c480699be56815db0f8146ad2e22efea85129b5b5983d0e0fb52d9ab70
01:28:18 Status: Downloaded newer image for busybox:latest
01:28:18 + docker container ls -aq
[Pipeline] echo
01:28:18 Docker containers have been removed
[Pipeline] echo
01:28:18 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_no_deps PASSED [  7%]

01:28:18 cleanWorkspace: Removing existing workspace
[Pipeline] deleteDir
[Pipeline] echo
01:28:18 cleanWorkspace: Workspace is clean.
[Pipeline] stage
[Pipeline] { (test python=py37 / docker=18.09.9-rc1 / baseImage=debian)
[Pipeline] checkout
01:28:18 using credential sf-release-bot.github.ssh
01:28:18 Cloning the remote Git repository
01:28:18 Cloning with configured refspecs honoured and without tags
01:28:19 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_parallel_failure PASSED [  8%]

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

Cloning repository git@github.com:docker/compose.git
 > git init /home/ubuntu/workspace/compose_PR-6850 # 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/pull/6850/head:refs/remotes/origin/PR-6850
01:28:19 tests/acceptance/cli_test.py::CLITestCase::test_exec_custom_user PASSED  [  4%]

01:28:20 baae4e02d0f0: Verifying Checksum
01:28:20 baae4e02d0f0: Download complete
01:28:20 b0b8081c21b9: Pull complete
01:28:20 f0363a51a0f4: Pull complete
01:28:20 14457cbcc43a: Pull complete
01:28:20 baae4e02d0f0: Pull complete
01:28:20 fbc676048046: Pull complete
01:28:20 Digest: sha256:640e8123ebb07f686320b3ba801edd1bde9015aa39913588ba34173a02bf2435
01:28:20 Status: Downloaded newer image for dockerswarm/dind:19.03.2-rc1
01:28:20 bb4e526c08a75c9ab1bb47a7c2bae90c13dd93c499b6dbc87f4e8e54581c0371
01:28:20 ++ docker run --rm --tty --link=compose-dind-19.03.2-rc1-jenkins-compose-PR-6850-2:docker --env=DOCKER_HOST=tcp://docker:2375 --env=DOCKER_VERSION=19.03.2-rc1 --entrypoint=tox dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e -e py37 -- --verbose
01:28:20 Fetching without tags
01:28:20 tests/acceptance/cli_test.py::CLITestCase::test_rm PASSED                [  8%]

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

01:28:20 Checking out Revision 04ce00a71373d402ca9ab2ea7a9f732eeab4778e (PR-6850)
01:28:20 Commit message: "add --skip-env-file option"
 > git config remote.origin.url git@github.com:docker/compose.git # timeout=10
 > git config --add remote.origin.fetch +refs/pull/6850/head:refs/remotes/origin/PR-6850 # 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/pull/6850/head:refs/remotes/origin/PR-6850
 > git config core.sparsecheckout # timeout=10
 > git checkout -f 04ce00a71373d402ca9ab2ea7a9f732eeab4778e
[Pipeline] echo
01:28:21 Removing all docker containers
[Pipeline] sh
01:28:21 py37 develop-inst-nodeps: /code

[Pipeline] sh
01:28:21 + docker container ls -aq
[Pipeline] echo
01:28:21 Docker containers have been removed
[Pipeline] echo
01:28:21 cleanWorkspace: Removing existing workspace
[Pipeline] deleteDir
[Pipeline] echo
01:28:21 cleanWorkspace: Workspace is clean.
[Pipeline] stage
[Pipeline] { (test python=py27 / docker=18.09.9-rc1 / baseImage=debian)
[Pipeline] checkout
01:28:21 + awk -F :  $1 == "Storage Driver" { print $2; exit }
01:28:21 + docker info
01:28:21 WARNING: No swap limit support
[Pipeline] echo
01:28:21 Using local system's storage driver: 
[Pipeline] sh
01:28:21 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_quiet PASSED   [  8%]

01:28:21 + pwd
01:28:21 + docker run -t --rm --privileged --volume=/home/ubuntu/workspace/compose_PR-6850/.git:/code/.git --volume=/var/run/docker.sock:/var/run/docker.sock -e TAG=dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e -e STORAGE_DRIVER= -e DOCKER_VERSIONS=18.09.9-rc1 -e BUILD_NUMBER=jenkins-compose-PR-6850-2 -e PY_TEST_VERSIONS=py37 --entrypoint=script/test/ci dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e --verbose
01:28:21 Unable to find image 'dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e' locally
01:28:21 debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e: Pulling from dockerbuildbot/compose
01:28:21 0a4690c5d889: Pulling fs layer
01:28:21 9ef510f4d0f7: Pulling fs layer
01:28:21 53fe96932e3f: Pulling fs layer
01:28:21 13d55380052c: Pulling fs layer
01:28:21 3102f4cc793a: Pulling fs layer
01:28:21 d320458ac7a5: Pulling fs layer
01:28:21 9f3ef983a669: Pulling fs layer
01:28:21 7d4fe19f703b: Pulling fs layer
01:28:21 a20184eb9807: Pulling fs layer
01:28:21 151fd087b5a9: Pulling fs layer
01:28:21 1639fd0d0dee: Pulling fs layer
01:28:21 8c3fcfeb31cb: Pulling fs layer
01:28:21 2bed9d31e3c9: Pulling fs layer
01:28:21 f69ce32ceba7: Pulling fs layer
01:28:21 a3bead48c3ea: Pulling fs layer
01:28:21 b40280e945e0: Pulling fs layer
01:28:21 c3ef7a730c92: Pulling fs layer
01:28:21 c65815eb55fa: Pulling fs layer
01:28:21 64f3aacfb141: Pulling fs layer
01:28:21 b6e24a215c19: Pulling fs layer
01:28:21 4d7a60876880: Pulling fs layer
01:28:21 13d55380052c: Waiting
01:28:21 3102f4cc793a: Waiting
01:28:21 d320458ac7a5: Waiting
01:28:21 9f3ef983a669: Waiting
01:28:21 7d4fe19f703b: Waiting
01:28:21 a20184eb9807: Waiting
01:28:21 151fd087b5a9: Waiting
01:28:21 1639fd0d0dee: Waiting
01:28:21 8c3fcfeb31cb: Waiting
01:28:21 2bed9d31e3c9: Waiting
01:28:21 f69ce32ceba7: Waiting
01:28:21 b40280e945e0: Waiting
01:28:21 c3ef7a730c92: Waiting
01:28:21 c65815eb55fa: Waiting
01:28:21 64f3aacfb141: Waiting
01:28:21 b6e24a215c19: Waiting
01:28:21 4d7a60876880: Waiting
01:28:21 a3bead48c3ea: Waiting
01:28:21 9ef510f4d0f7: Verifying Checksum
01:28:21 9ef510f4d0f7: Download complete
01:28:22 tests/acceptance/cli_test.py::CLITestCase::test_build_pull PASSED        [  0%]

01:28:22 0a4690c5d889: Verifying Checksum
01:28:22 0a4690c5d889: Download complete
01:28:22 13d55380052c: Verifying Checksum
01:28:22 13d55380052c: Download complete
01:28:22 53fe96932e3f: Verifying Checksum
01:28:22 53fe96932e3f: Download complete
01:28:22 3102f4cc793a: Verifying Checksum
01:28:22 3102f4cc793a: Download complete
01:28:22 9f3ef983a669: Verifying Checksum
01:28:22 9f3ef983a669: Download complete
01:28:22 tests/acceptance/cli_test.py::CLITestCase::test_rm_all PASSED            [  8%]

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

01:28:22 a20184eb9807: Verifying Checksum
01:28:22 a20184eb9807: Download complete
01:28:22 151fd087b5a9: Verifying Checksum
01:28:22 151fd087b5a9: Download complete
01:28:22 7d4fe19f703b: Verifying Checksum
01:28:22 7d4fe19f703b: Download complete
01:28:22 8c3fcfeb31cb: Verifying Checksum
01:28:22 8c3fcfeb31cb: Download complete
01:28:22 1639fd0d0dee: Verifying Checksum
01:28:22 1639fd0d0dee: Download complete
01:28:22 tests/acceptance/cli_test.py::CLITestCase::test_logs_tail PASSED         [  6%]

01:28:23 2bed9d31e3c9: Verifying Checksum
01:28:23 2bed9d31e3c9: Download complete
01:28:23 f69ce32ceba7: Verifying Checksum
01:28:23 f69ce32ceba7: Download complete
01:28:23 a3bead48c3ea: Verifying Checksum
01:28:23 a3bead48c3ea: Download complete
01:28:23 b40280e945e0: Verifying Checksum
01:28:23 b40280e945e0: Download complete
01:28:23 c3ef7a730c92: Verifying Checksum
01:28:23 c3ef7a730c92: Download complete
01:28:23 using credential sf-release-bot.github.ssh
01:28:23 Cloning the remote Git repository
01:28:23 Cloning with configured refspecs honoured and without tags
01:28:23 c65815eb55fa: Verifying Checksum
01:28:23 c65815eb55fa: Download complete
01:28:23 b6e24a215c19: Verifying Checksum
01:28:23 b6e24a215c19: Download complete
Cloning repository git@github.com:docker/compose.git
 > git init /home/ubuntu/workspace/compose_PR-6850 # timeout=10
01:28:24 64f3aacfb141: Verifying Checksum
01:28:24 64f3aacfb141: Download complete
01:28:24 4d7a60876880: Verifying Checksum
01:28:24 4d7a60876880: Download complete
01:28:24 d320458ac7a5: Verifying Checksum
01:28:24 d320458ac7a5: Download complete
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/pull/6850/head:refs/remotes/origin/PR-6850
01:28:24 0a4690c5d889: Pull complete
01:28:24 tests/acceptance/cli_test.py::CLITestCase::test_build_rm XPASS           [  1%]

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

01:28:24 9ef510f4d0f7: Pull complete
01:28:25 tests/acceptance/cli_test.py::CLITestCase::test_logs_timestamps PASSED   [  6%]

01:28:25 53fe96932e3f: Pull complete
01:28:25 13d55380052c: Pull complete
01:28:26 tests/acceptance/cli_test.py::CLITestCase::test_pause_no_containers PASSED [  6%]

01:28:26 3102f4cc793a: Pull complete
01:28:26 Fetching without tags
01:28:26 py37 installed: altgraph==0.16.1,asn1crypto==0.24.0,atomicwrites==1.3.0,attrs==19.1.0,bcrypt==3.1.7,cached-property==1.3.0,certifi==2017.4.17,cffi==1.12.3,chardet==3.0.4,coverage==4.4.2,cryptography==2.7,ddt==1.2.0,docker==4.0.1,# Editable install with no version control (docker-compose==1.25.0.dev0),-e /code,docker-pycreds==0.4.0,dockerpty==0.4.1,docopt==0.6.2,flake8==3.5.0,future==0.17.1,idna==2.5,ipaddress==1.0.18,jsonschema==2.6.0,macholib==1.11,mccabe==0.6.1,mock==3.0.5,more-itertools==7.2.0,paramiko==2.4.2,pefile==2019.4.18,pluggy==0.6.0,py==1.8.0,pyasn1==0.4.6,pycodestyle==2.3.1,pycparser==2.19,pyflakes==1.6.0,PyInstaller==3.4,PyNaCl==1.3.0,PySocks==1.6.7,pytest==3.6.3,pytest-cov==2.5.1,PyYAML==4.2b1,requests==2.22.0,six==1.10.0,texttable==1.6.2,urllib3==1.25.3,websocket-client==0.32.0

01:28:26 py37 runtests: PYTHONHASHSEED='895381543'

01:28:26 py37 runtests: commands[0] | mkdir -p .coverage-binfiles

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

01:28:26 Checking out Revision 04ce00a71373d402ca9ab2ea7a9f732eeab4778e (PR-6850)
01:28:26 tests/acceptance/cli_test.py::CLITestCase::test_build_shm_size_build_option PASSED [  1%]

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

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

01:28:26 ============================= test session starts ==============================

01:28:26 platform linux -- Python 3.7.4, pytest-3.6.3, py-1.8.0, pluggy-0.6.0 -- /code/.tox/py37/bin/python3.7

01:28:26 cachedir: .pytest_cache

01:28:26 rootdir: /code, inifile: tox.ini

01:28:26 plugins: cov-2.5.1

 > git config remote.origin.url git@github.com:docker/compose.git # timeout=10
 > git config --add remote.origin.fetch +refs/pull/6850/head:refs/remotes/origin/PR-6850 # 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/pull/6850/head:refs/remotes/origin/PR-6850
 > git config core.sparsecheckout # timeout=10
 > git checkout -f 04ce00a71373d402ca9ab2ea7a9f732eeab4778e
01:28:26 Commit message: "add --skip-env-file option"
[Pipeline] sh
01:28:27 tests/acceptance/cli_test.py::CLITestCase::test_rm_stop PASSED           [  8%]

01:28:27 + docker info
01:28:27 + awk -F :  $1 == "Storage Driver" { print $2; exit }
01:28:28 tests/acceptance/cli_test.py::CLITestCase::test_restart PASSED           [  8%]

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

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

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

01:28:29 d320458ac7a5: Pull complete
01:28:29 
collecting 0 items                                                             
collecting 196 items                                                           
collecting 196 items                                                           
collecting 196 items                                                           
collecting 196 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 399 items                                                           
collecting 403 items                                                           
collecting 403 items                                                           
collecting 403 items                                                           
collecting 403 items                                                           
collecting 406 items                                                           
collecting 415 items                                                           
collecting 426 items                                                           
collecting 434 items                                                           
collecting 434 items                                                           
collecting 434 items                                                           
collecting 434 items                                                           
collecting 445 items                                                           
collecting 445 items                                                           
collecting 462 items                                                           
collecting 475 items                                                           
collecting 475 items                                                           
collecting 493 items                                                           
collecting 494 items                                                           
collecting 494 items                                                           
collecting 501 items                                                           
collecting 501 items                                                           
collecting 506 items                                                           
collecting 509 items                                                           
collecting 518 items                                                           
collecting 518 items                                                           
collecting 545 items                                                           
collecting 545 items                                                           
collecting 619 items                                                           
collecting 620 items                                                           
collecting 623 items                                                           
collecting 627 items                                                           
collecting 628 items                                                           
collecting 638 items                                                           
collecting 641 items                                                           
collecting 644 items                                                           
collecting 644 items                                                           
collecting 649 items                                                           
collecting 649 items                                                           
collecting 662 items                                                           
collecting 665 items                                                           
collecting 665 items                                                           
collecting 667 items                                                           
collecting 667 items                                                           
collecting 669 items                                                           
collecting 669 items                                                           
collecting 670 items                                                           
collecting 670 items                                                           
collecting 671 items                                                           
collecting 671 items                                                           
collecting 671 items                                                           
collecting 673 items                                                           
collecting 673 items                                                           
collecting 673 items                                                           
collecting 681 items                                                           
collecting 681 items                                                           
collecting 681 items                                                           
collecting 685 items                                                           
collecting 701 items                                                           
collecting 704 items                                                           
collecting 704 items                                                           
collecting 704 items                                                           
collecting 712 items                                                           
collecting 712 items                                                           
collecting 712 items                                                           
collecting 718 items                                                           
collecting 718 items                                                           
collecting 720 items                                                           
collecting 720 items                                                           
collecting 723 items                                                           
collecting 723 items                                                           
collecting 726 items                                                           
collecting 726 items                                                           
collecting 730 items                                                           
collecting 730 items                                                           
collecting 733 items                                                           
collecting 738 items                                                           
collecting 738 items                                                           
collecting 741 items                                                           
collecting 741 items                                                           
collecting 745 items                                                           
collecting 745 items                                                           
collecting 752 items                                                           
collecting 752 items                                                           
collecting 752 items                                                           
collecting 756 items                                                           
collecting 760 items                                                           
collecting 760 items                                                           
collecting 764 items                                                           
collecting 764 items                                                           
collecting 908 items                                                           
collecting 916 items                                                           
collecting 924 items                                                           
collecting 927 items                                                           
collecting 937 items                                                           
collecting 948 items                                                           
collecting 954 items                                                           
collecting 960 items                                                           
collecting 963 items                                                           
collecting 968 items                                                           
collecting 976 items                                                           
collecting 980 items                                                           
collecting 986 items                                                           
collecting 989 items                                                           
collecting 992 items                                                           
collecting 1004 items                                                          
collecting 1034 items                                                          
collecting 1037 items                                                          
collecting 1040 items                                                          
collecting 1047 items                                                          
collecting 1051 items                                                          
collecting 1053 items                                                          
collecting 1068 items                                                          
collecting 1068 items                                                          
collecting 1073 items                                                          
collecting 1073 items                                                          
collecting 1094 items                                                          
collecting 1106 items                                                          
collecting 1106 items                                                          
collecting 1106 items                                                          
collecting 1115 items                                                          
collecting 1115 items                                                          
collecting 1127 items                                                          
collecting 1127 items                                                          
collecting 1136 items                                                          
collecting 1136 items                                                          
collecting 1138 items                                                          
collected 1138 items                                                           

01:28:29 

01:28:29 9f3ef983a669: Pull complete
01:28:30 7d4fe19f703b: Pull complete
01:28:30 a20184eb9807: Pull complete
01:28:30 151fd087b5a9: Pull complete
01:28:30 1639fd0d0dee: Pull complete
01:28:30 tests/acceptance/cli_test.py::CLITestCase::test_build_with_buildarg_cli_override PASSED [  1%]

01:28:30 8c3fcfeb31cb: Pull complete
01:28:30 2bed9d31e3c9: Pull complete
01:28:30 f69ce32ceba7: Pull complete
01:28:31 tests/acceptance/cli_test.py::CLITestCase::test_restart_stopped_container PASSED [  8%]

01:28:31 a3bead48c3ea: Pull complete
01:28:31 b40280e945e0: Pull complete
01:28:31 c3ef7a730c92: Pull complete
01:28:31 c65815eb55fa: Pull complete
01:28:32 WARNING: No swap limit support
01:28:32 WARNING: the aufs storage-driver is deprecated, and will be removed in a future release.
[Pipeline] echo
01:28:32 Using local system's storage driver: 
[Pipeline] sh
01:28:32 + pwd
01:28:32 + docker run -t --rm --privileged --volume=/home/ubuntu/workspace/compose_PR-6850/.git:/code/.git --volume=/var/run/docker.sock:/var/run/docker.sock -e TAG=dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e -e STORAGE_DRIVER= -e DOCKER_VERSIONS=18.09.9-rc1 -e BUILD_NUMBER=jenkins-compose-PR-6850-2 -e PY_TEST_VERSIONS=py27 --entrypoint=script/test/ci dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e --verbose
01:28:32 Unable to find image 'dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e' locally
01:28:32 debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e: Pulling from dockerbuildbot/compose
01:28:32 0a4690c5d889: Pulling fs layer
01:28:32 9ef510f4d0f7: Pulling fs layer
01:28:32 53fe96932e3f: Pulling fs layer
01:28:32 13d55380052c: Pulling fs layer
01:28:32 3102f4cc793a: Pulling fs layer
01:28:32 d320458ac7a5: Pulling fs layer
01:28:32 9f3ef983a669: Pulling fs layer
01:28:32 7d4fe19f703b: Pulling fs layer
01:28:32 a20184eb9807: Pulling fs layer
01:28:32 151fd087b5a9: Pulling fs layer
01:28:32 1639fd0d0dee: Pulling fs layer
01:28:32 8c3fcfeb31cb: Pulling fs layer
01:28:32 2bed9d31e3c9: Pulling fs layer
01:28:32 f69ce32ceba7: Pulling fs layer
01:28:32 a3bead48c3ea: Pulling fs layer
01:28:32 b40280e945e0: Pulling fs layer
01:28:32 c3ef7a730c92: Pulling fs layer
01:28:32 c65815eb55fa: Pulling fs layer
01:28:32 64f3aacfb141: Pulling fs layer
01:28:32 b6e24a215c19: Pulling fs layer
01:28:32 4d7a60876880: Pulling fs layer
01:28:32 13d55380052c: Waiting
01:28:32 3102f4cc793a: Waiting
01:28:32 d320458ac7a5: Waiting
01:28:32 9f3ef983a669: Waiting
01:28:32 7d4fe19f703b: Waiting
01:28:32 a20184eb9807: Waiting
01:28:32 151fd087b5a9: Waiting
01:28:32 1639fd0d0dee: Waiting
01:28:32 8c3fcfeb31cb: Waiting
01:28:32 2bed9d31e3c9: Waiting
01:28:32 f69ce32ceba7: Waiting
01:28:32 a3bead48c3ea: Waiting
01:28:32 b40280e945e0: Waiting
01:28:32 c3ef7a730c92: Waiting
01:28:32 c65815eb55fa: Waiting
01:28:32 64f3aacfb141: Waiting
01:28:32 b6e24a215c19: Waiting
01:28:32 4d7a60876880: Waiting
01:28:32 9ef510f4d0f7: Verifying Checksum
01:28:32 9ef510f4d0f7: Download complete
01:28:32 tests/acceptance/cli_test.py::CLITestCase::test_run_detached_connects_to_network PASSED [  8%]

01:28:32 0a4690c5d889: Verifying Checksum
01:28:32 0a4690c5d889: Download complete
01:28:32 53fe96932e3f: Verifying Checksum
01:28:32 53fe96932e3f: Download complete
01:28:32 13d55380052c: Verifying Checksum
01:28:32 13d55380052c: Download complete
01:28:32 9f3ef983a669: Verifying Checksum
01:28:32 9f3ef983a669: Download complete
01:28:32 3102f4cc793a: Verifying Checksum
01:28:32 3102f4cc793a: Download complete
01:28:32 a20184eb9807: Verifying Checksum
01:28:32 a20184eb9807: Download complete
01:28:33 7d4fe19f703b: Verifying Checksum
01:28:33 7d4fe19f703b: Download complete
01:28:33 151fd087b5a9: Verifying Checksum
01:28:33 151fd087b5a9: Download complete
01:28:33 1639fd0d0dee: Verifying Checksum
01:28:33 1639fd0d0dee: Download complete
01:28:33 8c3fcfeb31cb: Verifying Checksum
01:28:33 8c3fcfeb31cb: Download complete
01:28:33 2bed9d31e3c9: Verifying Checksum
01:28:33 2bed9d31e3c9: Download complete
01:28:33 tests/acceptance/cli_test.py::CLITestCase::test_rm PASSED                [  8%]

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

01:28:33 f69ce32ceba7: Verifying Checksum
01:28:33 f69ce32ceba7: Download complete
01:28:33 a3bead48c3ea: Verifying Checksum
01:28:33 a3bead48c3ea: Download complete
01:28:33 b40280e945e0: Verifying Checksum
01:28:33 b40280e945e0: Download complete
01:28:33 c3ef7a730c92: Verifying Checksum
01:28:33 c3ef7a730c92: Download complete
01:28:33 tests/acceptance/cli_test.py::CLITestCase::test_build_failed PASSED      [  0%]

01:28:33 c65815eb55fa: Verifying Checksum
01:28:33 c65815eb55fa: Download complete
01:28:33 b6e24a215c19: Verifying Checksum
01:28:33 b6e24a215c19: Download complete
01:28:34 64f3aacfb141: Pull complete
01:28:34 b6e24a215c19: Pull complete
01:28:34 d320458ac7a5: Verifying Checksum
01:28:34 d320458ac7a5: Download complete
01:28:34 4d7a60876880: Pull complete
01:28:34 Digest: sha256:ec739b4cd5f5766868b7732ee60ae6e6ce65f5f937cb06e3339bc38627a53751
01:28:34 Status: Downloaded newer image for dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e
01:28:34 64f3aacfb141: Verifying Checksum
01:28:34 64f3aacfb141: Download complete
01:28:34 4d7a60876880: Verifying Checksum
01:28:34 4d7a60876880: Download complete
01:28:34 tests/acceptance/cli_test.py::CLITestCase::test_build_with_buildarg_from_compose_file PASSED [  1%]

01:28:35 0a4690c5d889: Pull complete
01:28:35 tests/acceptance/cli_test.py::CLITestCase::test_run_does_not_recreate_linked_containers PASSED [  8%]

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

01:28:35 9ef510f4d0f7: Pull complete
01:28:36 53fe96932e3f: Pull complete
01:28:36 tests/acceptance/cli_test.py::CLITestCase::test_run_env_values_from_system PASSED [  9%]

01:28:36 13d55380052c: Pull complete
01:28:37 3102f4cc793a: Pull complete
01:28:37 + docker version
01:28:37 Client: Docker Engine - Community
01:28:37  Version:           18.09.7
01:28:37  API version:       1.39
01:28:37  Go version:        go1.10.8
01:28:37  Git commit:        2d0083d
01:28:37  Built:             Thu Jun 27 17:54:15 2019
01:28:37  OS/Arch:           linux/amd64
01:28:37  Experimental:      false
01:28:37 
01:28:37 Server: Docker Engine - Community
01:28:37  Engine:
01:28:37   Version:          19.03.1
01:28:37   API version:      1.40 (minimum version 1.12)
01:28:37   Go version:       go1.12.5
01:28:37   Git commit:       74b1e89
01:28:37   Built:            Thu Jul 25 21:19:41 2019
01:28:37   OS/Arch:          linux/amd64
01:28:37   Experimental:     true
01:28:37  containerd:
01:28:37   Version:          1.2.6
01:28:37   GitCommit:        894b81a4b802e4eb2a91d1ce216b8817763c29fb
01:28:37  runc:
01:28:37   Version:          1.0.0-rc8
01:28:37   GitCommit:        425e105d5a03fabd737a126ad93d62a9eeede87f
01:28:37  docker-init:
01:28:37   Version:          0.18.0
01:28:37   GitCommit:        fec3683
01:28:37 + export DOCKER_VERSIONS=18.09.9-rc1
01:28:37 + DOCKER_VERSIONS=18.09.9-rc1
01:28:37 + STORAGE_DRIVER=overlay
01:28:37 + export DOCKER_DAEMON_ARGS=--storage-driver=overlay
01:28:37 + DOCKER_DAEMON_ARGS=--storage-driver=overlay
01:28:37 ++ hostname
01:28:37 + GIT_VOLUME=--volumes-from=a0a3c55bd9ab
01:28:37 + . script/test/all
01:28:37 ++ set -e
01:28:37 ++ echo 'Running lint checks'
01:28:37 Running lint checks
01:28:37 ++ docker run --rm --tty --volumes-from=a0a3c55bd9ab dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e tox -e pre-commit
01:28:37 tests/acceptance/cli_test.py::CLITestCase::test_port_with_scale PASSED   [  6%]

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

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

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

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

01:28:38 pre-commit installed: aspy.yaml==1.3.0,cfgv==2.0.1,identify==1.4.6,importlib-metadata==0.19,nodeenv==1.3.3,pre-commit==1.18.1,PyYAML==5.1.2,six==1.12.0,toml==0.10.0,virtualenv==16.7.2,zipp==0.5.2

01:28:38 pre-commit runtests: PYTHONHASHSEED='3438237525'

01:28:38 pre-commit runtests: commands[0] | pre-commit install

01:28:38 pre-commit installed at .git/hooks/pre-commit

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

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

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

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

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

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

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

01:28:39 [INFO] Once installed this environment will be reused.

01:28:39 [INFO] This may take a few minutes...

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

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

01:28:40 d320458ac7a5: Pull complete
01:28:40 9f3ef983a669: Pull complete
01:28:40 tests/acceptance/cli_test.py::CLITestCase::test_ps_all PASSED            [  7%]

01:28:40 7d4fe19f703b: Pull complete
01:28:40 tests/acceptance/cli_test.py::CLITestCase::test_config_default PASSED    [  1%]

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

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

01:28:40 a20184eb9807: Pull complete
01:28:40 tests/acceptance/cli_test.py::CLITestCase::test_run_handles_sigterm PASSED [  9%]

01:28:41 151fd087b5a9: Pull complete
01:28:41 1639fd0d0dee: Pull complete
01:28:41 8c3fcfeb31cb: Pull complete
01:28:41 tests/acceptance/cli_test.py::CLITestCase::test_config_external_network PASSED [  1%]

01:28:41 2bed9d31e3c9: Pull complete
01:28:41 f69ce32ceba7: Pull complete
01:28:41 a3bead48c3ea: Pull complete
01:28:41 b40280e945e0: Pull complete
01:28:41 c3ef7a730c92: Pull complete
01:28:42 c65815eb55fa: Pull complete
01:28:42 tests/acceptance/cli_test.py::CLITestCase::test_config_external_network_v3_5 PASSED [  1%]

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

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

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

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

01:28:44 64f3aacfb141: Pull complete
01:28:44 b6e24a215c19: Pull complete
01:28:45 tests/acceptance/cli_test.py::CLITestCase::test_expanded_port PASSED     [  4%]

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

01:28:45 4d7a60876880: Pull complete
01:28:45 Digest: sha256:ec739b4cd5f5766868b7732ee60ae6e6ce65f5f937cb06e3339bc38627a53751
01:28:45 Status: Downloaded newer image for dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e
01:28:45 tests/acceptance/cli_test.py::CLITestCase::test_config_external_volume_v3_x PASSED [  2%]

01:28:45 + docker version
01:28:45 Client: Docker Engine - Community
01:28:45  Version:           18.09.7
01:28:45  API version:       1.39
01:28:45  Go version:        go1.10.8
01:28:45  Git commit:        2d0083d
01:28:45  Built:             Thu Jun 27 17:54:15 2019
01:28:45  OS/Arch:           linux/amd64
01:28:45  Experimental:      false
01:28:45 
01:28:45 Server: Docker Engine - Community
01:28:45  Engine:
01:28:45   Version:          19.03.1
01:28:45   API version:      1.40 (minimum version 1.12)
01:28:45   Go version:       go1.12.5
01:28:45   Git commit:       74b1e89e8a
01:28:45   Built:            Thu Jul 25 21:20:09 2019
01:28:45   OS/Arch:          linux/amd64
01:28:45   Experimental:     true
01:28:45  containerd:
01:28:45   Version:          1.2.6
01:28:45   GitCommit:        894b81a4b802e4eb2a91d1ce216b8817763c29fb
01:28:45  runc:
01:28:45   Version:          1.0.0-rc8
01:28:45   GitCommit:        425e105d5a03fabd737a126ad93d62a9eeede87f
01:28:45  docker-init:
01:28:45   Version:          0.18.0
01:28:45   GitCommit:        fec3683
01:28:45 + export DOCKER_VERSIONS=18.09.9-rc1
01:28:45 + DOCKER_VERSIONS=18.09.9-rc1
01:28:45 + STORAGE_DRIVER=overlay
01:28:45 + export DOCKER_DAEMON_ARGS=--storage-driver=overlay
01:28:45 + DOCKER_DAEMON_ARGS=--storage-driver=overlay
01:28:45 ++ hostname
01:28:45 + GIT_VOLUME=--volumes-from=29b43302e3e1
01:28:45 + . script/test/all
01:28:45 ++ set -e
01:28:45 ++ echo 'Running lint checks'
01:28:45 Running lint checks
01:28:45 ++ docker run --rm --tty --volumes-from=29b43302e3e1 dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e tox -e pre-commit
01:28:46 tests/acceptance/cli_test.py::CLITestCase::test_build_log_level PASSED   [  0%]

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

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

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

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

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

01:28:47 pre-commit installed: aspy.yaml==1.3.0,cfgv==2.0.1,identify==1.4.6,importlib-metadata==0.19,nodeenv==1.3.3,pre-commit==1.18.1,PyYAML==5.1.2,six==1.12.0,toml==0.10.0,virtualenv==16.7.2,zipp==0.5.2

01:28:47 pre-commit runtests: PYTHONHASHSEED='1609469434'

01:28:47 pre-commit runtests: commands[0] | pre-commit install

01:28:47 pre-commit installed at .git/hooks/pre-commit

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

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

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

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

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

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

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

01:28:48 [INFO] Once installed this environment will be reused.

01:28:48 [INFO] This may take a few minutes...

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

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

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

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

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

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

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

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

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

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

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

01:28:52 tests/acceptance/cli_test.py::CLITestCase::test_config_with_dot_env_and_override_dir PASSED [  2%]

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

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

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

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

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

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

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

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

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

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

01:28:56 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_build PASSED   [  7%]

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

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

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

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

01:28:57 [INFO] Once installed this environment will be reused.

01:28:57 [INFO] This may take a few minutes...

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

01:29:01 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_no_deps PASSED [  7%]

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

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

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

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

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

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

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

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

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

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

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

01:29:06 [INFO] Once installed this environment will be reused.

01:29:06 [INFO] This may take a few minutes...

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

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

01:29:07 Check for added large files..............................................Passed

01:29:07 Check docstring is first.................................................Passed

01:29:07 Check for merge conflicts................................................Passed

01:29:08 Check Yaml...............................................................Passed

01:29:08 Check JSON...............................................................Passed

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

01:29:08 Debug Statements (Python)................................................Passed

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

01:29:08 Fix End of Files.........................................................Passed

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

01:29:16 Check for added large files..............................................Passed

01:29:16 Check docstring is first.................................................Passed

01:29:16 Check for merge conflicts................................................Passed

01:29:17 Flake8...................................................................Passed

01:29:17 Tests should end in _test.py.............................................Passed

01:29:17 Fix requirements.txt.....................................................Passed

01:29:17 Trim Trailing Whitespace.................................................Passed

01:29:17 Check Yaml...............................................................Passed

01:29:17 Check JSON...............................................................Passed

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

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

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

01:29:17 Reorder python imports...................................................Passed

01:29:17 ___________________________________ summary ____________________________________

01:29:17   pre-commit: commands succeeded

01:29:17   congratulations :)

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

01:29:17 Debug Statements (Python)................................................Passed

01:29:17 Fix End of Files.........................................................Passed

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

01:29:18 ++ get_versions='docker run --rm
01:29:18     --entrypoint=/code/.tox/py27/bin/python
01:29:18     dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e
01:29:18     /code/script/test/versions.py docker/docker-ce,moby/moby'
01:29:18 ++ '[' 18.09.9-rc1 == '' ']'
01:29:18 ++ '[' 18.09.9-rc1 == all ']'
01:29:18 ++ BUILD_NUMBER=jenkins-compose-PR-6850-2
01:29:18 ++ PY_TEST_VERSIONS=py37
01:29:18 ++ for version in $DOCKER_VERSIONS
01:29:18 ++ echo 'Running tests against Docker 18.09.9-rc1'
01:29:18 Running tests against Docker 18.09.9-rc1
01:29:18 ++ daemon_container=compose-dind-18.09.9-rc1-jenkins-compose-PR-6850-2
01:29:18 ++ trap on_exit EXIT
01:29:18 ++ repo=dockerswarm/dind
01:29:18 ++ tail -n 10
01:29:18 ++ docker run -d --name compose-dind-18.09.9-rc1-jenkins-compose-PR-6850-2 --privileged --volume=/var/lib/docker dockerswarm/dind:18.09.9-rc1 dockerd -H tcp://0.0.0.0:2375 --storage-driver=overlay
01:29:18 tests/acceptance/cli_test.py::CLITestCase::test_kill_stopped_service PASSED [  5%]

01:29:18 tests/acceptance/cli_test.py::CLITestCase::test_logs_default SKIPPED     [  5%]

01:29:18 4bfaa073501b09492f44d06b881a1e44b2ce95af9ad502a9dde14564dc1c78f8
01:29:18 ++ docker run --rm --tty --link=compose-dind-18.09.9-rc1-jenkins-compose-PR-6850-2:docker --env=DOCKER_HOST=tcp://docker:2375 --env=DOCKER_VERSION=18.09.9-rc1 --entrypoint=tox dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e -e py37 -- --verbose
01:29:18 tests/acceptance/cli_test.py::CLITestCase::test_down PASSED              [  3%]

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

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

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

01:29:20 py37 develop-inst-nodeps: /code

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

01:29:25 py37 installed: altgraph==0.16.1,asn1crypto==0.24.0,atomicwrites==1.3.0,attrs==19.1.0,bcrypt==3.1.7,cached-property==1.3.0,certifi==2017.4.17,cffi==1.12.3,chardet==3.0.4,coverage==4.4.2,cryptography==2.7,ddt==1.2.0,docker==4.0.1,# Editable install with no version control (docker-compose==1.25.0.dev0),-e /code,docker-pycreds==0.4.0,dockerpty==0.4.1,docopt==0.6.2,flake8==3.5.0,future==0.17.1,idna==2.5,ipaddress==1.0.18,jsonschema==2.6.0,macholib==1.11,mccabe==0.6.1,mock==3.0.5,more-itertools==7.2.0,paramiko==2.4.2,pefile==2019.4.18,pluggy==0.6.0,py==1.8.0,pyasn1==0.4.6,pycodestyle==2.3.1,pycparser==2.19,pyflakes==1.6.0,PyInstaller==3.4,PyNaCl==1.3.0,PySocks==1.6.7,pytest==3.6.3,pytest-cov==2.5.1,PyYAML==4.2b1,requests==2.22.0,six==1.10.0,texttable==1.6.2,urllib3==1.25.3,websocket-client==0.32.0

01:29:25 py37 runtests: PYTHONHASHSEED='1168564757'

01:29:25 py37 runtests: commands[0] | mkdir -p .coverage-binfiles

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

01:29:25 ============================= test session starts ==============================

01:29:25 platform linux -- Python 3.7.4, pytest-3.6.3, py-1.8.0, pluggy-0.6.0 -- /code/.tox/py37/bin/python3.7

01:29:25 cachedir: .pytest_cache

01:29:25 rootdir: /code, inifile: tox.ini

01:29:25 plugins: cov-2.5.1

01:29:25 Flake8...................................................................Passed

01:29:25 Tests should end in _test.py.............................................Passed

01:29:25 Fix requirements.txt.....................................................Passed

01:29:25 Trim Trailing Whitespace.................................................Passed

01:29:25 Reorder python imports...................................................Passed

01:29:25 ___________________________________ summary ____________________________________

01:29:25   pre-commit: commands succeeded

01:29:25   congratulations :)

01:29:25 tests/acceptance/cli_test.py::CLITestCase::test_env_file_relative_to_compose_file PASSED [  3%]

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

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

01:29:26 ++ get_versions='docker run --rm
01:29:26     --entrypoint=/code/.tox/py27/bin/python
01:29:26     dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e
01:29:26     /code/script/test/versions.py docker/docker-ce,moby/moby'
01:29:26 ++ '[' 18.09.9-rc1 == '' ']'
01:29:26 ++ '[' 18.09.9-rc1 == all ']'
01:29:26 ++ BUILD_NUMBER=jenkins-compose-PR-6850-2
01:29:26 ++ PY_TEST_VERSIONS=py27
01:29:26 ++ for version in $DOCKER_VERSIONS
01:29:26 ++ echo 'Running tests against Docker 18.09.9-rc1'
01:29:26 Running tests against Docker 18.09.9-rc1
01:29:26 ++ daemon_container=compose-dind-18.09.9-rc1-jenkins-compose-PR-6850-2
01:29:26 ++ trap on_exit EXIT
01:29:26 ++ repo=dockerswarm/dind
01:29:26 ++ docker run -d --name compose-dind-18.09.9-rc1-jenkins-compose-PR-6850-2 --privileged --volume=/var/lib/docker dockerswarm/dind:18.09.9-rc1 dockerd -H tcp://0.0.0.0:2375 --storage-driver=overlay
01:29:26 ++ tail -n 10
01:29:27 tests/acceptance/cli_test.py::CLITestCase::test_config_compatibility_mode PASSED [  1%]

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

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

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

01:29:28 
collecting 0 items                                                             
collecting 196 items                                                           
collecting 196 items                                                           
collecting 196 items                                                           
collecting 196 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 399 items                                                           
collecting 403 items                                                           
collecting 403 items                                                           
collecting 403 items                                                           
collecting 403 items                                                           
collecting 406 items                                                           
collecting 415 items                                                           
collecting 426 items                                                           
collecting 434 items                                                           
collecting 434 items                                                           
collecting 434 items                                                           
collecting 434 items                                                           
collecting 445 items                                                           
collecting 445 items                                                           
collecting 462 items                                                           
collecting 475 items                                                           
collecting 475 items                                                           
collecting 493 items                                                           
collecting 494 items                                                           
collecting 494 items                                                           
collecting 501 items                                                           
collecting 501 items                                                           
collecting 506 items                                                           
collecting 509 items                                                           
collecting 518 items                                                           
collecting 518 items                                                           
collecting 545 items                                                           
collecting 545 items                                                           
collecting 619 items                                                           
collecting 620 items                                                           
collecting 623 items                                                           
collecting 627 items                                                           
collecting 628 items                                                           
collecting 638 items                                                           
collecting 641 items                                                           
collecting 644 items                                                           
collecting 644 items                                                           
collecting 649 items                                                           
collecting 649 items                                                           
collecting 662 items                                                           
collecting 665 items                                                           
collecting 665 items                                                           
collecting 667 items                                                           
collecting 667 items                                                           
collecting 669 items                                                           
collecting 669 items                                                           
collecting 670 items                                                           
collecting 670 items                                                           
collecting 671 items                                                           
collecting 671 items                                                           
collecting 671 items                                                           
collecting 673 items                                                           
collecting 673 items                                                           
collecting 673 items                                                           
collecting 681 items                                                           
collecting 681 items                                                           
collecting 681 items                                                           
collecting 685 items                                                           
collecting 701 items                                                           
collecting 704 items                                                           
collecting 704 items                                                           
collecting 704 items                                                           
collecting 712 items                                                           
collecting 712 items                                                           
collecting 712 items                                                           
collecting 718 items                                                           
collecting 718 items                                                           
collecting 720 items                                                           
collecting 720 items                                                           
collecting 723 items                                                           
collecting 723 items                                                           
collecting 726 items                                                           
collecting 726 items                                                           
collecting 730 items                                                           
collecting 730 items                                                           
collecting 733 items                                                           
collecting 738 items                                                           
collecting 738 items                                                           
collecting 741 items                                                           
collecting 741 items                                                           
collecting 745 items                                                           
collecting 745 items                                                           
collecting 752 items                                                           
collecting 752 items                                                           
collecting 752 items                                                           
collecting 756 items                                                           
collecting 760 items                                                           
collecting 760 items                                                           
collecting 764 items                                                           
collecting 764 items                                                           
collecting 908 items                                                           
collecting 916 items                                                           
collecting 924 items                                                           
collecting 927 items                                                           
collecting 937 items                                                           
collecting 948 items                                                           
collecting 954 items                                                           
collecting 960 items                                                           
collecting 963 items                                                           
collecting 968 items                                                           
collecting 976 items                                                           
collecting 980 items                                                           
collecting 986 items                                                           
collecting 989 items                                                           
collecting 992 items                                                           
collecting 1004 items                                                          
collecting 1034 items                                                          
collecting 1037 items                                                          
collecting 1040 items                                                          
collecting 1047 items                                                          
collecting 1051 items                                                          
collecting 1053 items                                                          
collecting 1068 items                                                          
collecting 1068 items                                                          
collecting 1073 items                                                          
collecting 1073 items                                                          
collecting 1094 items                                                          
collecting 1106 items                                                          
collecting 1106 items                                                          
collecting 1106 items                                                          
collecting 1115 items                                                          
collecting 1115 items                                                          
collecting 1127 items                                                          
collecting 1127 items                                                          
collecting 1136 items                                                          
collecting 1136 items                                                          
collecting 1138 items                                                          
collected 1138 items                                                           

01:29:28 

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

01:29:32 7591cec14231: Verifying Checksum
01:29:32 7591cec14231: Download complete
01:29:32 b0b8081c21b9: Pull complete
01:29:32 b7cf13d7afa6: Pull complete
01:29:32 b5aa1770fbfe: Pull complete
01:29:32 7591cec14231: Pull complete
01:29:32 337759c3f8bf: Pull complete
01:29:32 Digest: sha256:d1b34ee995071956f6c17fa12f07c807b9768265c5238b7e1e848f1eb9c65a83
01:29:32 Status: Downloaded newer image for dockerswarm/dind:18.09.9-rc1
01:29:32 e0df9e6398ff394f34b2ed70cdec9226d8a6da9d281cad6d9ea5487f84992a60
01:29:32 ++ docker run --rm --tty --link=compose-dind-18.09.9-rc1-jenkins-compose-PR-6850-2:docker --env=DOCKER_HOST=tcp://docker:2375 --env=DOCKER_VERSION=18.09.9-rc1 --entrypoint=tox dockerbuildbot/compose:debian-04ce00a71373d402ca9ab2ea7a9f732eeab4778e -e py27 -- --verbose
01:29:33 tests/acceptance/cli_test.py::CLITestCase::test_config_list_services PASSED [  2%]

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

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

01:29:33 py27 develop-inst-nodeps: /code

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

01:29:39 tests/acceptance/cli_test.py::CLITestCase::test_config_with_dot_env_and_override_dir PASSED [  2%]

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

01:29:39 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,asn1crypto==0.24.0,atomicwrites==1.3.0,attrs==19.1.0,backports.ssl-match-hostname==3.5.0.1,bcrypt==3.1.7,cached-property==1.3.0,certifi==2017.4.17,cffi==1.12.3,chardet==3.0.4,configparser==3.8.1,coverage==4.4.2,cryptography==2.7,ddt==1.2.0,docker==4.0.1,# Editable install with no version control (docker-compose==1.25.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==2.6.0,mccabe==0.6.1,mock==3.0.5,more-itertools==5.0.0,paramiko==2.4.2,pluggy==0.6.0,py==1.8.0,pyasn1==0.4.6,pycodestyle==2.3.1,pycparser==2.19,pyflakes==1.6.0,PyNaCl==1.3.0,PySocks==1.6.7,pytest==3.6.3,pytest-cov==2.5.1,PyYAML==4.2b1,requests==2.22.0,six==1.10.0,texttable==1.6.2,urllib3==1.25.3,websocket-client==0.32.0

01:29:39 py27 runtests: PYTHONHASHSEED='2513274966'

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

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

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

01:29:39 ============================= test session starts ==============================

01:29:39 platform linux2 -- Python 2.7.13, pytest-3.6.3, py-1.8.0, pluggy-0.6.0 -- /code/.tox/py27/bin/python2.7

01:29:39 cachedir: .pytest_cache

01:29:39 rootdir: /code, inifile: tox.ini

01:29:39 plugins: cov-2.5.1

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

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

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

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

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

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

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

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

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

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

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

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

01:29:42 
collecting 0 items                                                             
collecting 196 items                                                           
collecting 196 items                                                           
collecting 196 items                                                           
collecting 196 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 399 items                                                           
collecting 403 items                                                           
collecting 403 items                                                           
collecting 403 items                                                           
collecting 403 items                                                           
collecting 406 items                                                           
collecting 415 items                                                           
collecting 426 items                                                           
collecting 434 items                                                           
collecting 434 items                                                           
collecting 434 items                                                           
collecting 434 items                                                           
collecting 445 items                                                           
collecting 445 items                                                           
collecting 462 items                                                           
collecting 475 items                                                           
collecting 475 items                                                           
collecting 493 items                                                           
collecting 494 items                                                           
collecting 494 items                                                           
collecting 501 items                                                           
collecting 501 items                                                           
collecting 506 items                                                           
collecting 509 items                                                           
collecting 518 items                                                           
collecting 518 items                                                           
collecting 545 items                                                           
collecting 545 items                                                           
collecting 619 items                                                           
collecting 620 items                                                           
collecting 623 items                                                           
collecting 627 items                                                           
collecting 628 items                                                           
collecting 638 items                                                           
collecting 641 items                                                           
collecting 644 items                                                           
collecting 644 items                                                           
collecting 649 items                                                           
collecting 649 items                                                           
collecting 662 items                                                           
collecting 665 items                                                           
collecting 665 items                                                           
collecting 667 items                                                           
collecting 667 items                                                           
collecting 669 items                                                           
collecting 669 items                                                           
collecting 670 items                                                           
collecting 670 items                                                           
collecting 671 items                                                           
collecting 671 items                                                           
collecting 671 items                                                           
collecting 673 items                                                           
collecting 673 items                                                           
collecting 673 items                                                           
collecting 681 items                                                           
collecting 681 items                                                           
collecting 681 items                                                           
collecting 685 items                                                           
collecting 701 items                                                           
collecting 704 items                                                           
collecting 704 items                                                           
collecting 704 items                                                           
collecting 712 items                                                           
collecting 712 items                                                           
collecting 712 items                                                           
collecting 718 items                                                           
collecting 718 items                                                           
collecting 720 items                                                           
collecting 720 items                                                           
collecting 723 items                                                           
collecting 723 items                                                           
collecting 726 items                                                           
collecting 726 items                                                           
collecting 730 items                                                           
collecting 730 items                                                           
collecting 733 items                                                           
collecting 738 items                                                           
collecting 738 items                                                           
collecting 741 items                                                           
collecting 741 items                                                           
collecting 745 items                                                           
collecting 745 items                                                           
collecting 752 items                                                           
collecting 752 items                                                           
collecting 752 items                                                           
collecting 756 items                                                           
collecting 760 items                                                           
collecting 760 items                                                           
collecting 764 items                                                           
collecting 764 items                                                           
collecting 908 items                                                           
collecting 916 items                                                           
collecting 924 items                                                           
collecting 927 items                                                           
collecting 937 items                                                           
collecting 948 items                                                           
collecting 954 items                                                           
collecting 960 items                                                           
collecting 963 items                                                           
collecting 968 items                                                           
collecting 976 items                                                           
collecting 980 items                                                           
collecting 986 items                                                           
collecting 989 items                                                           
collecting 992 items                                                           
collecting 1004 items                                                          
collecting 1034 items                                                          
collecting 1037 items                                                          
collecting 1040 items                                                          
collecting 1047 items                                                          
collecting 1051 items                                                          
collecting 1053 items                                                          
collecting 1068 items                                                          
collecting 1068 items                                                          
collecting 1073 items                                                          
collecting 1073 items                                                          
collecting 1094 items                                                          
collecting 1106 items                                                          
collecting 1106 items                                                          
collecting 1106 items                                                          
collecting 1115 items                                                          
collecting 1115 items                                                          
collecting 1127 items                                                          
collecting 1127 items                                                          
collecting 1136 items                                                          
collecting 1136 items                                                          
collecting 1138 items                                                          
collected 1138 items                                                           

01:29:42 

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

01:29:57 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_build PASSED   [  7%]

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

01:30:02 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_no_deps PASSED [  7%]

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

01:30:10 tests/acceptance/cli_test.py::CLITestCase::test_env_file_relative_to_compose_file PASSED [  3%]

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

01:30:31 tests/acceptance/cli_test.py::CLITestCase::test_logs_default SKIPPED     [  5%]

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

01:30:36 tests/acceptance/cli_test.py::CLITestCase::test_top_services_not_running PASSED [ 13%]

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

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

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

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

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

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

01:30:39 tests/acceptance/cli_test.py::CLITestCase::test_config_with_dot_env_and_override_dir PASSED [  2%]

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

01:30:54 tests/acceptance/cli_test.py::CLITestCase::test_config_with_dot_env_and_override_dir PASSED [  2%]

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

01:31:04 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_to_zero PASSED  [ 15%]

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

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

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

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

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

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

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

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

01:31:07 tests/acceptance/cli_test.py::CLITestCase::test_top_services_not_running PASSED [ 13%]

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

01:31:13 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_build PASSED   [  7%]

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

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

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

01:31:13 tests/acceptance/cli_test.py::CLITestCase::test_logs_default SKIPPED     [  5%]

01:31:14 tests/acceptance/cli_test.py::CLITestCase::test_env_file_relative_to_compose_file PASSED [  3%]

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

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

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

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

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

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

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

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

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

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

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

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

01:31:16 tests/acceptance/cli_test.py::CLITestCase::test_logs_invalid_service_name PASSED [  6%]

01:31:16 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_links PASSED [ 10%]

01:31:16 tests/acceptance/cli_test.py::CLITestCase::test_up_detached PASSED       [ 13%]

01:31:17 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_include_deps PASSED [  7%]

01:31:18 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_no_deps PASSED [  7%]

01:31:18 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_map_ports PASSED [ 10%]

01:31:18 tests/acceptance/cli_test.py::CLITestCase::test_events_json PASSED       [  4%]

01:31:18 tests/acceptance/cli_test.py::CLITestCase::test_up_detached_long_form PASSED [ 13%]

01:31:19 tests/acceptance/cli_test.py::CLITestCase::test_logs_on_stopped_containers_exits PASSED [  6%]

01:31:19 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_parallel_failure PASSED [  8%]

01:31:20 tests/acceptance/cli_test.py::CLITestCase::test_exec_custom_user PASSED  [  4%]

01:31:20 tests/acceptance/cli_test.py::CLITestCase::test_down PASSED              [  3%]

01:31:21 tests/acceptance/cli_test.py::CLITestCase::test_logs_tail PASSED         [  6%]

01:31:21 tests/acceptance/cli_test.py::CLITestCase::test_up_external_networks PASSED [ 13%]

01:31:21 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_quiet PASSED   [  8%]

01:31:21 tests/acceptance/cli_test.py::CLITestCase::test_down_invalid_rmi_flag PASSED [  3%]

01:31:22 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_scaled_dependencies PASSED [ 11%]

01:31:22 tests/acceptance/cli_test.py::CLITestCase::test_exec_detach_long_form PASSED [  4%]

01:31:23 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_reset PASSED    [ 14%]

01:31:23 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_abort_on_container_exit PASSED [ 13%]

01:31:23 tests/acceptance/cli_test.py::CLITestCase::test_logs_timestamps PASSED   [  6%]

01:31:23 tests/acceptance/cli_test.py::CLITestCase::test_down_signal PASSED       [  3%]

01:31:24 tests/acceptance/cli_test.py::CLITestCase::test_pause_no_containers PASSED [  6%]

01:31:24 tests/acceptance/cli_test.py::CLITestCase::test_up_with_healthcheck PASSED [ 15%]

01:31:25 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_abort_on_container_exit_code PASSED [ 13%]

01:31:25 tests/acceptance/cli_test.py::CLITestCase::test_up_with_ignore_remove_orphans PASSED [ 15%]

01:31:25 tests/acceptance/cli_test.py::CLITestCase::test_exec_service_with_environment_overridden PASSED [  4%]

01:31:25 tests/acceptance/cli_test.py::CLITestCase::test_quiet_build PASSED       [  8%]

01:31:26 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_scale_down PASSED [ 14%]

01:31:26 tests/acceptance/cli_test.py::CLITestCase::test_down_timeout PASSED      [  3%]

01:31:26 tests/acceptance/cli_test.py::CLITestCase::test_restart PASSED           [  8%]

01:31:26 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_force_shutdown PASSED [ 13%]

01:31:26 tests/acceptance/cli_test.py::CLITestCase::test_up_with_links_v1 PASSED  [ 15%]

01:31:27 tests/acceptance/cli_test.py::CLITestCase::test_pause_unpause PASSED     [  6%]

01:31:27 tests/acceptance/cli_test.py::CLITestCase::test_env_file_relative_to_compose_file PASSED [  3%]

01:31:27 tests/acceptance/cli_test.py::CLITestCase::test_restart_no_containers PASSED [  8%]

01:31:27 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_unset_entrypoint PASSED [ 11%]

01:31:27 tests/acceptance/cli_test.py::CLITestCase::test_exec_without_tty PASSED  [  4%]

01:31:28 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_sigint PASSED [ 13%]

01:31:29 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_use_aliases PASSED [ 11%]

01:31:29 tests/acceptance/cli_test.py::CLITestCase::test_up_with_multiple_files PASSED [ 15%]

01:31:29 tests/acceptance/cli_test.py::CLITestCase::test_events_human_readable PASSED [  4%]

01:31:29 tests/acceptance/cli_test.py::CLITestCase::test_restart_stopped_container PASSED [  8%]

01:31:29 tests/acceptance/cli_test.py::CLITestCase::test_exec_workdir PASSED      [  4%]

01:31:30 tests/acceptance/cli_test.py::CLITestCase::test_up_with_net_is_invalid PASSED [ 16%]

01:31:30 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_user_overridden PASSED [ 11%]

01:31:30 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_sigterm PASSED [ 14%]

01:31:30 tests/acceptance/cli_test.py::CLITestCase::test_port PASSED              [  6%]

01:31:31 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_user_overridden_short_form PASSED [ 11%]

01:31:31 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_scale_up PASSED [ 14%]

01:31:31 tests/acceptance/cli_test.py::CLITestCase::test_up_with_net_v1 <- tests/integration/testcases.py PASSED [ 16%]

01:31:32 tests/acceptance/cli_test.py::CLITestCase::test_events_json PASSED       [  4%]

01:31:32 tests/acceptance/cli_test.py::CLITestCase::test_rm PASSED                [  8%]

01:31:32 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_workdir_overridden PASSED [ 11%]

01:31:32 tests/acceptance/cli_test.py::CLITestCase::test_up_logging PASSED        [ 14%]

01:31:33 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_aliases PASSED [ 16%]

01:31:33 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_workdir_overridden_short_form PASSED [ 11%]

01:31:33 tests/acceptance/cli_test.py::CLITestCase::test_up_logging_legacy PASSED [ 14%]

01:31:34 tests/acceptance/cli_test.py::CLITestCase::test_exec_custom_user PASSED  [  4%]

01:31:34 tests/acceptance/cli_test.py::CLITestCase::test_rm_all PASSED            [  8%]

01:31:34 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_to_zero PASSED  [ 15%]

01:31:34 tests/acceptance/cli_test.py::CLITestCase::test_up_missing_network PASSED [ 14%]

01:31:35 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_internal PASSED [ 16%]

01:31:35 tests/acceptance/cli_test.py::CLITestCase::test_run_service_without_links PASSED [ 11%]

01:31:36 tests/acceptance/cli_test.py::CLITestCase::test_port_with_scale PASSED   [  6%]

01:31:36 tests/acceptance/cli_test.py::CLITestCase::test_ps PASSED                [  7%]

01:31:36 tests/acceptance/cli_test.py::CLITestCase::test_exec_detach_long_form PASSED [  4%]

01:31:36 tests/acceptance/cli_test.py::CLITestCase::test_run_service_without_map_ports PASSED [ 11%]

01:31:36 tests/acceptance/cli_test.py::CLITestCase::test_up_no_ansi PASSED        [ 14%]

01:31:37 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_labels PASSED [ 16%]

01:31:37 tests/acceptance/cli_test.py::CLITestCase::test_up_with_default_network_config PASSED [ 15%]

01:31:37 tests/acceptance/cli_test.py::CLITestCase::test_run_unicode_env_values_from_system PASSED [ 11%]

01:31:37 tests/acceptance/cli_test.py::CLITestCase::test_up_no_services PASSED    [ 14%]

01:31:37 tests/acceptance/cli_test.py::CLITestCase::test_ps_all PASSED            [  7%]

01:31:38 tests/acceptance/cli_test.py::CLITestCase::test_exec_service_with_environment_overridden PASSED [  4%]

01:31:38 tests/acceptance/cli_test.py::CLITestCase::test_run_with_custom_name PASSED [ 11%]

01:31:39 tests/acceptance/cli_test.py::CLITestCase::test_rm_stop PASSED           [  8%]

01:31:39 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_mode <- tests/integration/testcases.py PASSED [ 16%]

01:31:39 tests/acceptance/cli_test.py::CLITestCase::test_ps_alternate_composefile PASSED [  7%]

01:31:39 tests/acceptance/cli_test.py::CLITestCase::test_up_with_default_override_file PASSED [ 15%]

01:31:39 tests/acceptance/cli_test.py::CLITestCase::test_up_with_duplicate_override_yaml_files PASSED [ 15%]

01:31:40 tests/acceptance/cli_test.py::CLITestCase::test_run_with_expose_ports PASSED [ 12%]

01:31:40 tests/acceptance/cli_test.py::CLITestCase::test_up_no_start PASSED       [ 14%]

01:31:41 tests/acceptance/cli_test.py::CLITestCase::test_exec_without_tty PASSED  [  4%]

01:31:41 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_static_addresses PASSED [ 16%]

01:31:41 tests/acceptance/cli_test.py::CLITestCase::test_run_with_no_deps PASSED  [ 12%]

01:31:42 tests/acceptance/cli_test.py::CLITestCase::test_exit_code_from_signal_stop PASSED [  4%]

01:31:42 tests/acceptance/cli_test.py::CLITestCase::test_ps_default_composefile PASSED [  7%]

01:31:42 tests/acceptance/cli_test.py::CLITestCase::test_up_with_extends PASSED   [ 15%]

01:31:42 tests/acceptance/cli_test.py::CLITestCase::test_up_no_start_remove_orphans PASSED [ 14%]

01:31:43 tests/acceptance/cli_test.py::CLITestCase::test_exec_workdir PASSED      [  4%]

01:31:44 tests/acceptance/cli_test.py::CLITestCase::test_ps_services_filter_option PASSED [  7%]

01:31:44 tests/acceptance/cli_test.py::CLITestCase::test_run_detached_connects_to_network PASSED [  8%]

01:31:44 tests/acceptance/cli_test.py::CLITestCase::test_up_with_networks PASSED  [ 16%]

01:31:45 tests/acceptance/cli_test.py::CLITestCase::test_up_with_external_default_network PASSED [ 15%]

01:31:45 tests/acceptance/cli_test.py::CLITestCase::test_run_without_command PASSED [ 12%]

01:31:45 tests/acceptance/cli_test.py::CLITestCase::test_up_with_no_deps PASSED   [ 16%]

01:31:46 tests/acceptance/cli_test.py::CLITestCase::test_expanded_port PASSED     [  4%]

01:31:47 tests/acceptance/cli_test.py::CLITestCase::test_run_does_not_recreate_linked_containers PASSED [  8%]

01:31:48 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_reset PASSED    [ 14%]

01:31:48 tests/acceptance/cli_test.py::CLITestCase::test_run_env_values_from_system PASSED [  9%]

01:31:48 tests/acceptance/cli_test.py::CLITestCase::test_up_with_force_recreate PASSED [ 15%]

01:31:49 tests/acceptance/cli_test.py::CLITestCase::test_up_with_no_recreate PASSED [ 16%]

01:31:49 tests/acceptance/cli_test.py::CLITestCase::test_up_with_force_recreate_and_no_recreate PASSED [ 15%]

01:31:49 tests/acceptance/cli_test.py::CLITestCase::test_run_handles_sighup PASSED [  9%]

01:31:50 tests/acceptance/cli_test.py::CLITestCase::test_up_with_override_yaml PASSED [ 16%]

01:31:50 tests/acceptance/cli_test.py::CLITestCase::test_ps_services_filter_status PASSED [  7%]

01:31:50 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_scale_down PASSED [ 14%]

01:31:50 tests/acceptance/cli_test.py::CLITestCase::test_pull PASSED              [  7%]

01:31:51 tests/acceptance/cli_test.py::CLITestCase::test_run_handles_sigint PASSED [  9%]

01:31:51 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_build PASSED   [  7%]

01:31:52 tests/acceptance/cli_test.py::CLITestCase::test_scale PASSED             [ 12%]

01:31:52 tests/acceptance/cli_test.py::CLITestCase::test_scale_v2_2 PASSED        [ 12%]

01:31:52 tests/acceptance/cli_test.py::CLITestCase::test_run_handles_sigterm PASSED [  9%]

01:31:53 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_digest PASSED  [  7%]

01:31:53 tests/acceptance/cli_test.py::CLITestCase::test_up_with_pid_mode <- tests/integration/testcases.py PASSED [ 17%]

01:31:54 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_ignore_pull_failures PASSED [  7%]

01:31:54 tests/acceptance/cli_test.py::CLITestCase::test_shorthand_host_opt PASSED [ 12%]

01:31:54 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_scale_up PASSED [ 14%]

01:31:55 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_include_deps PASSED [  7%]

01:31:55 tests/acceptance/cli_test.py::CLITestCase::test_exit_code_from_signal_stop PASSED [  4%]

01:31:55 tests/acceptance/cli_test.py::CLITestCase::test_up_with_timeout PASSED   [ 17%]

01:31:55 tests/acceptance/cli_test.py::CLITestCase::test_shorthand_host_opt_interactive PASSED [ 12%]

01:31:56 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_no_deps PASSED [  7%]

01:31:56 tests/acceptance/cli_test.py::CLITestCase::test_start_no_containers PASSED [ 12%]

01:31:56 tests/acceptance/cli_test.py::CLITestCase::test_up_with_volume_labels PASSED [ 17%]

01:31:56 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_parallel_failure PASSED [  8%]

01:31:57 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_to_zero PASSED  [ 15%]

01:31:58 tests/acceptance/cli_test.py::CLITestCase::test_forward_exitval PASSED   [  4%]

01:31:58 tests/acceptance/cli_test.py::CLITestCase::test_help PASSED              [  4%]

01:31:58 tests/acceptance/cli_test.py::CLITestCase::test_stop PASSED              [ 12%]

01:31:58 tests/acceptance/cli_test.py::CLITestCase::test_help_nonexistent PASSED  [  5%]

01:31:59 tests/acceptance/cli_test.py::CLITestCase::test_run_interactive_connects_to_network PASSED [  9%]

01:31:59 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_quiet PASSED   [  8%]

01:31:59 tests/integration/environment_test.py::EnvironmentOverrideFileTest::test_env_file_override PASSED [ 17%]

01:31:59 tests/acceptance/cli_test.py::CLITestCase::test_up_with_default_network_config PASSED [ 15%]

01:31:59 tests/acceptance/cli_test.py::CLITestCase::test_expanded_port PASSED     [  4%]

01:31:59 tests/acceptance/cli_test.py::CLITestCase::test_up_with_healthcheck PASSED [ 15%]

01:31:59 tests/acceptance/cli_test.py::CLITestCase::test_up_with_ignore_remove_orphans PASSED [ 15%]

01:31:59 tests/acceptance/cli_test.py::CLITestCase::test_run_label_flag PASSED    [  9%]

01:32:00 tests/acceptance/cli_test.py::CLITestCase::test_home_and_env_var_in_volume_path PASSED [  5%]

01:32:00 tests/acceptance/cli_test.py::CLITestCase::test_up_with_links_v1 PASSED  [ 15%]

01:32:01 tests/acceptance/cli_test.py::CLITestCase::test_host_not_reachable PASSED [  5%]

01:32:01 tests/acceptance/cli_test.py::CLITestCase::test_up_with_default_override_file PASSED [ 15%]

01:32:01 tests/acceptance/cli_test.py::CLITestCase::test_up_with_duplicate_override_yaml_files PASSED [ 15%]

01:32:01 tests/acceptance/cli_test.py::CLITestCase::test_stop_signal PASSED       [ 12%]

01:32:02 tests/acceptance/cli_test.py::CLITestCase::test_host_not_reachable_volumes_from_container PASSED [  5%]

01:32:02 tests/integration/environment_test.py::EnvironmentSkipFileTest::test_env_file_skip PASSED [ 17%]

01:32:02 tests/acceptance/cli_test.py::CLITestCase::test_run_one_off_with_multiple_volumes PASSED [  9%]

01:32:03 tests/acceptance/cli_test.py::CLITestCase::test_images PASSED            [  5%]

01:32:03 tests/integration/network_test.py::NetworkTest::test_network_default_labels PASSED [ 17%]

01:32:03 tests/integration/network_test.py::NetworkTest::test_network_external_default_ensure PASSED [ 17%]

01:32:03 tests/integration/network_test.py::NetworkTest::test_network_external_overlay_ensure PASSED [ 17%]

01:32:03 tests/acceptance/cli_test.py::CLITestCase::test_quiet_build PASSED       [  8%]

01:32:03 tests/acceptance/cli_test.py::CLITestCase::test_up_with_extends PASSED   [ 15%]

01:32:03 tests/acceptance/cli_test.py::CLITestCase::test_top_processes_running PASSED [ 12%]

01:32:03 tests/integration/project_test.py::ProjectTest::test_containers PASSED   [ 17%]

01:32:04 tests/acceptance/cli_test.py::CLITestCase::test_up_with_multiple_files PASSED [ 15%]

01:32:04 tests/acceptance/cli_test.py::CLITestCase::test_top_services_not_running PASSED [ 13%]

01:32:04 tests/acceptance/cli_test.py::CLITestCase::test_run_one_off_with_volume PASSED [  9%]

01:32:04 tests/integration/project_test.py::ProjectTest::test_containers_stopped PASSED [ 17%]

01:32:05 tests/acceptance/cli_test.py::CLITestCase::test_up_with_net_is_invalid PASSED [ 16%]

01:32:05 tests/acceptance/cli_test.py::CLITestCase::test_restart PASSED           [  8%]

01:32:05 tests/integration/project_test.py::ProjectTest::test_containers_with_extra_service PASSED [ 17%]

01:32:05 tests/acceptance/cli_test.py::CLITestCase::test_images_default_composefile PASSED [  5%]

01:32:05 tests/acceptance/cli_test.py::CLITestCase::test_restart_no_containers PASSED [  8%]

01:32:06 tests/acceptance/cli_test.py::CLITestCase::test_run_one_off_with_volume_merge PASSED [  9%]

01:32:06 tests/integration/project_test.py::ProjectTest::test_containers_with_service_names PASSED [ 18%]

01:32:06 tests/integration/project_test.py::ProjectTest::test_create PASSED       [ 18%]

01:32:06 tests/integration/project_test.py::ProjectTest::test_create_strategy_always PASSED [ 18%]

01:32:06 tests/acceptance/cli_test.py::CLITestCase::test_up_with_external_default_network PASSED [ 15%]

01:32:06 tests/acceptance/cli_test.py::CLITestCase::test_top_services_running PASSED [ 13%]

01:32:06 tests/integration/project_test.py::ProjectTest::test_create_strategy_never PASSED [ 18%]

01:32:06 tests/acceptance/cli_test.py::CLITestCase::test_images_tagless_image PASSED [  5%]

01:32:07 tests/acceptance/cli_test.py::CLITestCase::test_up_with_net_v1 PASSED    [ 16%]

01:32:07 tests/integration/project_test.py::ProjectTest::test_create_twice PASSED [ 18%]

01:32:07 tests/integration/project_test.py::ProjectTest::test_create_with_links PASSED [ 18%]

01:32:07 tests/integration/project_test.py::ProjectTest::test_initialize_volumes PASSED [ 18%]

01:32:07 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_external_volumes <- tests/integration/testcases.py PASSED [ 18%]

01:32:07 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_inexistent_external_volume PASSED [ 18%]

01:32:07 tests/acceptance/cli_test.py::CLITestCase::test_restart_stopped_container PASSED [  8%]

01:32:07 tests/acceptance/cli_test.py::CLITestCase::test_unpause_no_containers PASSED [ 13%]

01:32:08 tests/acceptance/cli_test.py::CLITestCase::test_run_rm PASSED            [  9%]

01:32:08 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_aliases PASSED [ 16%]

01:32:09 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint PASSED [  9%]

01:32:09 tests/acceptance/cli_test.py::CLITestCase::test_up_with_force_recreate PASSED [ 15%]

01:32:10 tests/acceptance/cli_test.py::CLITestCase::test_rm PASSED                [  8%]

01:32:10 tests/acceptance/cli_test.py::CLITestCase::test_up PASSED                [ 13%]

01:32:10 tests/acceptance/cli_test.py::CLITestCase::test_up_with_force_recreate_and_no_recreate PASSED [ 15%]

01:32:10 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_internal PASSED [ 16%]

01:32:10 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint_and_command_overridden PASSED [ 10%]

01:32:11 tests/acceptance/cli_test.py::CLITestCase::test_rm_all PASSED            [  8%]

01:32:11 tests/acceptance/cli_test.py::CLITestCase::test_up_attached PASSED       [ 13%]

01:32:11 tests/acceptance/cli_test.py::CLITestCase::test_forward_exitval PASSED   [  4%]

01:32:11 tests/acceptance/cli_test.py::CLITestCase::test_help PASSED              [  4%]

01:32:12 tests/acceptance/cli_test.py::CLITestCase::test_help_nonexistent PASSED  [  5%]

01:32:12 tests/acceptance/cli_test.py::CLITestCase::test_images_use_service_tag PASSED [  5%]

01:32:12 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint_and_empty_string_command PASSED [ 10%]

01:32:12 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_labels PASSED [ 16%]

01:32:13 tests/acceptance/cli_test.py::CLITestCase::test_home_and_env_var_in_volume_path PASSED [  5%]

01:32:13 tests/acceptance/cli_test.py::CLITestCase::test_up_detached PASSED       [ 13%]

01:32:14 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint_overridden PASSED [ 10%]

01:32:14 tests/acceptance/cli_test.py::CLITestCase::test_host_not_reachable PASSED [  5%]

01:32:14 tests/acceptance/cli_test.py::CLITestCase::test_kill PASSED              [  5%]

01:32:14 tests/acceptance/cli_test.py::CLITestCase::test_up_detached_long_form PASSED [ 13%]

01:32:15 tests/acceptance/cli_test.py::CLITestCase::test_host_not_reachable_volumes_from_container PASSED [  5%]

01:32:15 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_mode PASSED [ 16%]

01:32:15 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dependencies PASSED [ 10%]

01:32:16 tests/acceptance/cli_test.py::CLITestCase::test_images PASSED            [  5%]

01:32:16 tests/acceptance/cli_test.py::CLITestCase::test_kill_signal_sigstop PASSED [  5%]

01:32:16 tests/acceptance/cli_test.py::CLITestCase::test_rm_stop PASSED           [  8%]

01:32:17 tests/acceptance/cli_test.py::CLITestCase::test_up_external_networks PASSED [ 13%]

01:32:17 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_static_addresses PASSED [ 16%]

01:32:18 tests/acceptance/cli_test.py::CLITestCase::test_up_with_healthcheck PASSED [ 15%]

01:32:18 tests/acceptance/cli_test.py::CLITestCase::test_up_with_ignore_remove_orphans PASSED [ 15%]

01:32:18 tests/acceptance/cli_test.py::CLITestCase::test_images_default_composefile PASSED [  5%]

01:32:19 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_abort_on_container_exit PASSED [ 13%]

01:32:19 tests/acceptance/cli_test.py::CLITestCase::test_kill_stopped_service PASSED [  5%]

01:32:19 tests/acceptance/cli_test.py::CLITestCase::test_logs_default SKIPPED     [  5%]

01:32:20 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dockerfile_entrypoint PASSED [ 10%]

01:32:20 tests/acceptance/cli_test.py::CLITestCase::test_images_tagless_image PASSED [  5%]

01:32:20 tests/acceptance/cli_test.py::CLITestCase::test_up_with_links_v1 PASSED  [ 15%]

01:32:20 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_abort_on_container_exit_code PASSED [ 13%]

01:32:21 tests/acceptance/cli_test.py::CLITestCase::test_up_with_networks PASSED  [ 16%]

01:32:21 tests/acceptance/cli_test.py::CLITestCase::test_run_detached_connects_to_network PASSED [  8%]

01:32:22 tests/acceptance/cli_test.py::CLITestCase::test_logs_follow PASSED       [  6%]

01:32:22 tests/acceptance/cli_test.py::CLITestCase::test_logs_follow_logs_from_new_containers SKIPPED [  6%]

01:32:22 tests/acceptance/cli_test.py::CLITestCase::test_logs_follow_logs_from_restarted_containers SKIPPED [  6%]

01:32:22 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_force_shutdown PASSED [ 13%]

01:32:22 tests/acceptance/cli_test.py::CLITestCase::test_up_with_multiple_files PASSED [ 15%]

01:32:22 tests/acceptance/cli_test.py::CLITestCase::test_up_with_no_deps PASSED   [ 16%]

01:32:22 tests/acceptance/cli_test.py::CLITestCase::test_logs_invalid_service_name PASSED [  6%]

01:32:23 tests/acceptance/cli_test.py::CLITestCase::test_up_with_net_is_invalid PASSED [ 16%]

01:32:23 tests/acceptance/cli_test.py::CLITestCase::test_run_does_not_recreate_linked_containers PASSED [  8%]

01:32:24 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dockerfile_entrypoint_and_command_overridden PASSED [ 10%]

01:32:24 tests/acceptance/cli_test.py::CLITestCase::test_images_use_service_tag PASSED [  5%]

01:32:24 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_sigint PASSED [ 13%]

01:32:25 tests/acceptance/cli_test.py::CLITestCase::test_run_env_values_from_system PASSED [  9%]

01:32:25 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_invalid_volume_driver PASSED [ 18%]

01:32:25 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_blank_driver PASSED [ 18%]

01:32:25 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_driver <- tests/integration/testcases.py PASSED [ 18%]

01:32:25 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_driver_opts <- tests/integration/testcases.py PASSED [ 19%]

01:32:25 tests/integration/project_test.py::ProjectTest::test_net_from_container_v1 <- tests/integration/testcases.py PASSED [ 19%]

01:32:25 tests/integration/project_test.py::ProjectTest::test_net_from_service_v1 <- tests/integration/testcases.py PASSED [ 19%]

01:32:25 tests/integration/project_test.py::ProjectTest::test_network_mode_from_container <- tests/integration/testcases.py PASSED [ 19%]

01:32:25 tests/acceptance/cli_test.py::CLITestCase::test_up_with_no_recreate PASSED [ 16%]

01:32:25 tests/acceptance/cli_test.py::CLITestCase::test_up_with_net_v1 <- tests/integration/testcases.py PASSED [ 16%]

01:32:26 tests/acceptance/cli_test.py::CLITestCase::test_logs_on_stopped_containers_exits PASSED [  6%]

01:32:26 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_sigterm PASSED [ 14%]

01:32:26 tests/integration/project_test.py::ProjectTest::test_network_mode_from_service <- tests/integration/testcases.py PASSED [ 19%]

01:32:26 tests/integration/project_test.py::ProjectTest::test_parallel_pull_with_no_image PASSED [ 19%]

01:32:26 tests/acceptance/cli_test.py::CLITestCase::test_run_handles_sighup PASSED [  9%]

01:32:26 tests/integration/project_test.py::ProjectTest::test_project_up PASSED   [ 19%]

01:32:26 tests/acceptance/cli_test.py::CLITestCase::test_kill PASSED              [  5%]

01:32:27 tests/acceptance/cli_test.py::CLITestCase::test_up_with_override_yaml PASSED [ 16%]

01:32:27 tests/acceptance/cli_test.py::CLITestCase::test_run_handles_sigint PASSED [  9%]

01:32:27 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_aliases PASSED [ 16%]

01:32:27 tests/acceptance/cli_test.py::CLITestCase::test_up_logging PASSED        [ 14%]

01:32:28 tests/acceptance/cli_test.py::CLITestCase::test_logs_tail PASSED         [  6%]

01:32:28 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dockerfile_entrypoint_overridden PASSED [ 10%]

01:32:28 tests/acceptance/cli_test.py::CLITestCase::test_run_handles_sigterm PASSED [  9%]

01:32:28 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_internal PASSED [ 16%]

01:32:29 tests/acceptance/cli_test.py::CLITestCase::test_kill_signal_sigstop PASSED [  5%]

01:32:29 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_environment_overridden PASSED [ 10%]

01:32:29 tests/acceptance/cli_test.py::CLITestCase::test_up_logging_legacy PASSED [ 14%]

01:32:30 tests/acceptance/cli_test.py::CLITestCase::test_up_missing_network PASSED [ 14%]

01:32:30 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_labels PASSED [ 16%]

01:32:30 tests/acceptance/cli_test.py::CLITestCase::test_logs_timestamps PASSED   [  6%]

01:32:30 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_explicitly_mapped_ip_ports PASSED [ 10%]

01:32:31 tests/integration/project_test.py::ProjectTest::test_project_up_config_scale PASSED [ 19%]

01:32:31 tests/acceptance/cli_test.py::CLITestCase::test_pause_no_containers PASSED [  6%]

01:32:31 tests/acceptance/cli_test.py::CLITestCase::test_up_with_pid_mode PASSED  [ 17%]

01:32:31 tests/acceptance/cli_test.py::CLITestCase::test_up_no_ansi PASSED        [ 14%]

01:32:32 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_explicitly_mapped_ports PASSED [ 10%]

01:32:32 tests/acceptance/cli_test.py::CLITestCase::test_up_no_services PASSED    [ 14%]

01:32:32 tests/acceptance/cli_test.py::CLITestCase::test_kill_stopped_service PASSED [  5%]

01:32:32 tests/acceptance/cli_test.py::CLITestCase::test_logs_default SKIPPED     [  5%]

01:32:33 tests/acceptance/cli_test.py::CLITestCase::test_up_with_timeout PASSED   [ 17%]

01:32:33 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_mode <- tests/integration/testcases.py PASSED [ 16%]

01:32:33 tests/integration/project_test.py::ProjectTest::test_project_up_healthy_dependency PASSED [ 19%]

01:32:34 tests/acceptance/cli_test.py::CLITestCase::test_run_interactive_connects_to_network PASSED [  9%]

01:32:34 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_links PASSED [ 10%]

01:32:34 tests/integration/project_test.py::ProjectTest::test_project_up_ignore_orphans PASSED [ 19%]

01:32:34 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_static_addresses PASSED [ 16%]

01:32:34 tests/acceptance/cli_test.py::CLITestCase::test_pause_unpause PASSED     [  6%]

01:32:35 tests/integration/project_test.py::ProjectTest::test_project_up_implicit_volume_driver PASSED [ 19%]

01:32:35 tests/acceptance/cli_test.py::CLITestCase::test_logs_follow PASSED       [  6%]

01:32:35 tests/acceptance/cli_test.py::CLITestCase::test_logs_follow_logs_from_new_containers SKIPPED [  6%]

01:32:35 tests/acceptance/cli_test.py::CLITestCase::test_logs_follow_logs_from_restarted_containers SKIPPED [  6%]

01:32:35 tests/acceptance/cli_test.py::CLITestCase::test_up_with_volume_labels PASSED [ 17%]

01:32:35 tests/acceptance/cli_test.py::CLITestCase::test_run_label_flag PASSED    [  9%]

01:32:35 tests/acceptance/cli_test.py::CLITestCase::test_logs_invalid_service_name PASSED [  6%]

01:32:35 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_map_ports PASSED [ 10%]

01:32:35 tests/acceptance/cli_test.py::CLITestCase::test_up_no_start PASSED       [ 14%]

01:32:36 tests/integration/project_test.py::ProjectTest::test_project_up_logging_with_multiple_files PASSED [ 20%]

01:32:37 tests/acceptance/cli_test.py::CLITestCase::test_up_no_start_remove_orphans PASSED [ 14%]

01:32:37 tests/integration/project_test.py::ProjectTest::test_project_up_name_starts_with_illegal_char <- tests/integration/testcases.py PASSED [ 20%]

01:32:37 tests/acceptance/cli_test.py::CLITestCase::test_up_with_networks PASSED  [ 16%]

01:32:37 tests/integration/environment_test.py::EnvironmentOverrideFileTest::test_env_file_override PASSED [ 17%]

01:32:38 tests/integration/project_test.py::ProjectTest::test_project_up_named_volumes_in_binds PASSED [ 20%]

01:32:38 tests/acceptance/cli_test.py::CLITestCase::test_port PASSED              [  6%]

01:32:38 tests/acceptance/cli_test.py::CLITestCase::test_logs_on_stopped_containers_exits PASSED [  6%]

01:32:38 tests/acceptance/cli_test.py::CLITestCase::test_run_one_off_with_multiple_volumes PASSED [  9%]

01:32:39 tests/acceptance/cli_test.py::CLITestCase::test_up_with_no_deps PASSED   [ 16%]

01:32:39 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_scaled_dependencies PASSED [ 11%]

01:32:39 tests/integration/project_test.py::ProjectTest::test_project_up_networks PASSED [ 20%]

01:32:40 tests/acceptance/cli_test.py::CLITestCase::test_run_one_off_with_volume PASSED [  9%]

01:32:40 tests/integration/project_test.py::ProjectTest::test_project_up_no_healthcheck_dependency PASSED [ 20%]

01:32:40 tests/acceptance/cli_test.py::CLITestCase::test_logs_tail PASSED         [  6%]

01:32:41 tests/acceptance/cli_test.py::CLITestCase::test_up_with_no_recreate PASSED [ 16%]

01:32:41 tests/integration/project_test.py::ProjectTest::test_project_up_orphans PASSED [ 20%]

01:32:41 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_reset PASSED    [ 14%]

01:32:41 tests/acceptance/cli_test.py::CLITestCase::test_run_one_off_with_volume_merge PASSED [  9%]

01:32:41 tests/integration/environment_test.py::EnvironmentSkipFileTest::test_env_file_skip PASSED [ 17%]

01:32:41 tests/integration/network_test.py::NetworkTest::test_network_default_labels PASSED [ 17%]

01:32:41 tests/integration/network_test.py::NetworkTest::test_network_external_default_ensure PASSED [ 17%]

01:32:41 tests/integration/network_test.py::NetworkTest::test_network_external_overlay_ensure PASSED [ 17%]

01:32:42 tests/integration/project_test.py::ProjectTest::test_project_up_port_mappings_with_multiple_files PASSED [ 20%]

01:32:42 tests/acceptance/cli_test.py::CLITestCase::test_port_with_scale PASSED   [  6%]

01:32:43 tests/acceptance/cli_test.py::CLITestCase::test_logs_timestamps PASSED   [  6%]

01:32:43 tests/integration/project_test.py::ProjectTest::test_containers PASSED   [ 17%]

01:32:43 tests/acceptance/cli_test.py::CLITestCase::test_run_rm PASSED            [  9%]

01:32:43 tests/acceptance/cli_test.py::CLITestCase::test_ps PASSED                [  7%]

01:32:43 tests/integration/project_test.py::ProjectTest::test_project_up_recreate_with_tmpfs_volume PASSED [ 20%]

01:32:43 tests/acceptance/cli_test.py::CLITestCase::test_up_with_override_yaml PASSED [ 16%]

01:32:43 tests/acceptance/cli_test.py::CLITestCase::test_pause_no_containers PASSED [  6%]

01:32:44 tests/integration/project_test.py::ProjectTest::test_containers_stopped PASSED [ 17%]

01:32:44 tests/integration/project_test.py::ProjectTest::test_project_up_seccomp_profile PASSED [ 20%]

01:32:44 tests/integration/project_test.py::ProjectTest::test_containers_with_extra_service PASSED [ 17%]

01:32:44 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint PASSED [  9%]

01:32:45 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_unset_entrypoint PASSED [ 11%]

01:32:45 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_scale_down PASSED [ 14%]

01:32:45 tests/acceptance/cli_test.py::CLITestCase::test_ps_all PASSED            [  7%]

01:32:45 tests/integration/project_test.py::ProjectTest::test_containers_with_service_names PASSED [ 18%]

01:32:45 tests/integration/project_test.py::ProjectTest::test_create PASSED       [ 18%]

01:32:46 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint_and_command_overridden PASSED [ 10%]

01:32:46 tests/integration/project_test.py::ProjectTest::test_create_strategy_always PASSED [ 18%]

01:32:46 tests/integration/project_test.py::ProjectTest::test_create_strategy_never PASSED [ 18%]

01:32:46 tests/integration/project_test.py::ProjectTest::test_project_up_starts_depends PASSED [ 20%]

01:32:46 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_use_aliases PASSED [ 11%]

01:32:46 tests/integration/project_test.py::ProjectTest::test_create_twice PASSED [ 18%]

01:32:46 tests/integration/project_test.py::ProjectTest::test_create_with_links PASSED [ 18%]

01:32:46 tests/integration/project_test.py::ProjectTest::test_initialize_volumes PASSED [ 18%]

01:32:46 tests/acceptance/cli_test.py::CLITestCase::test_up_with_pid_mode <- tests/integration/testcases.py PASSED [ 17%]

01:32:46 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_external_volumes PASSED [ 18%]

01:32:46 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_inexistent_external_volume PASSED [ 18%]

01:32:46 tests/acceptance/cli_test.py::CLITestCase::test_pause_unpause PASSED     [  6%]

01:32:47 tests/acceptance/cli_test.py::CLITestCase::test_ps_alternate_composefile PASSED [  7%]

01:32:47 tests/integration/project_test.py::ProjectTest::test_project_up_starts_links PASSED [ 20%]

01:32:47 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_user_overridden PASSED [ 11%]

01:32:47 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint_and_empty_string_command PASSED [ 10%]

01:32:48 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_user_overridden_short_form PASSED [ 11%]

01:32:48 tests/integration/project_test.py::ProjectTest::test_project_up_starts_uncreated_services PASSED [ 21%]

01:32:48 tests/acceptance/cli_test.py::CLITestCase::test_up_with_timeout PASSED   [ 17%]

01:32:48 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint_overridden PASSED [ 10%]

01:32:49 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_scale_up PASSED [ 14%]

01:32:49 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_workdir_overridden PASSED [ 11%]

01:32:49 tests/acceptance/cli_test.py::CLITestCase::test_ps_default_composefile PASSED [  7%]

01:32:50 tests/acceptance/cli_test.py::CLITestCase::test_up_with_volume_labels PASSED [ 17%]

01:32:50 tests/integration/project_test.py::ProjectTest::test_project_up_unhealthy_dependency PASSED [ 21%]

01:32:51 tests/integration/project_test.py::ProjectTest::test_project_up_volumes PASSED [ 21%]

01:32:51 tests/acceptance/cli_test.py::CLITestCase::test_port PASSED              [  6%]

01:32:51 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dependencies PASSED [ 10%]

01:32:51 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_workdir_overridden_short_form PASSED [ 11%]

01:32:51 tests/acceptance/cli_test.py::CLITestCase::test_ps_services_filter_option PASSED [  7%]

01:32:51 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_to_zero PASSED  [ 15%]

01:32:52 tests/integration/environment_test.py::EnvironmentOverrideFileTest::test_env_file_override PASSED [ 17%]

01:32:52 tests/acceptance/cli_test.py::CLITestCase::test_run_service_without_links PASSED [ 11%]

01:32:53 tests/integration/project_test.py::ProjectTest::test_project_up_with_added_secrets PASSED [ 21%]

01:32:53 tests/acceptance/cli_test.py::CLITestCase::test_up_with_default_network_config PASSED [ 15%]

01:32:53 tests/integration/project_test.py::ProjectTest::test_project_up_with_network_internal PASSED [ 21%]

01:32:54 tests/integration/project_test.py::ProjectTest::test_project_up_with_network_label PASSED [ 21%]

01:32:54 tests/acceptance/cli_test.py::CLITestCase::test_run_service_without_map_ports PASSED [ 11%]

01:32:55 tests/integration/project_test.py::ProjectTest::test_project_up_with_no_deps PASSED [ 21%]

01:32:55 tests/acceptance/cli_test.py::CLITestCase::test_up_with_default_override_file PASSED [ 15%]

01:32:55 tests/acceptance/cli_test.py::CLITestCase::test_up_with_duplicate_override_yaml_files PASSED [ 15%]

01:32:55 tests/acceptance/cli_test.py::CLITestCase::test_port_with_scale PASSED   [  6%]

01:32:55 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dockerfile_entrypoint PASSED [ 10%]

01:32:55 tests/acceptance/cli_test.py::CLITestCase::test_run_unicode_env_values_from_system PASSED [ 11%]

01:32:55 tests/integration/environment_test.py::EnvironmentSkipFileTest::test_env_file_skip PASSED [ 17%]

01:32:55 tests/integration/project_test.py::ProjectTest::test_project_up_with_no_recreate_running PASSED [ 21%]

01:32:56 tests/integration/network_test.py::NetworkTest::test_network_default_labels PASSED [ 17%]

01:32:56 tests/integration/network_test.py::NetworkTest::test_network_external_default_ensure PASSED [ 17%]

01:32:56 tests/integration/network_test.py::NetworkTest::test_network_external_overlay_ensure PASSED [ 17%]

01:32:56 tests/acceptance/cli_test.py::CLITestCase::test_ps PASSED                [  7%]

01:32:56 tests/integration/project_test.py::ProjectTest::test_containers PASSED   [ 17%]

01:32:57 tests/acceptance/cli_test.py::CLITestCase::test_up_with_extends PASSED   [ 15%]

01:32:57 tests/acceptance/cli_test.py::CLITestCase::test_run_with_custom_name PASSED [ 11%]

01:32:57 tests/integration/project_test.py::ProjectTest::test_project_up_with_no_recreate_stopped PASSED [ 21%]

01:32:57 tests/integration/project_test.py::ProjectTest::test_containers_stopped PASSED [ 17%]

01:32:58 tests/acceptance/cli_test.py::CLITestCase::test_ps_services_filter_status PASSED [  7%]

01:32:58 tests/acceptance/cli_test.py::CLITestCase::test_ps_all PASSED            [  7%]

01:32:58 tests/integration/project_test.py::ProjectTest::test_containers_with_extra_service PASSED [ 17%]

01:32:58 tests/acceptance/cli_test.py::CLITestCase::test_run_with_expose_ports PASSED [ 12%]

01:32:58 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dockerfile_entrypoint_and_command_overridden PASSED [ 10%]

01:32:58 tests/integration/project_test.py::ProjectTest::test_project_up_with_secrets PASSED [ 21%]

01:32:59 tests/acceptance/cli_test.py::CLITestCase::test_pull PASSED              [  7%]

01:32:59 tests/integration/project_test.py::ProjectTest::test_containers_with_service_names PASSED [ 18%]

01:32:59 tests/integration/project_test.py::ProjectTest::test_create PASSED       [ 18%]

01:32:59 tests/integration/project_test.py::ProjectTest::test_project_up_with_volume_labels PASSED [ 21%]

01:32:59 tests/acceptance/cli_test.py::CLITestCase::test_up_with_external_default_network PASSED [ 15%]

01:32:59 tests/integration/project_test.py::ProjectTest::test_create_strategy_always PASSED [ 18%]

01:32:59 tests/integration/project_test.py::ProjectTest::test_create_strategy_never PASSED [ 18%]

01:32:59 tests/acceptance/cli_test.py::CLITestCase::test_run_with_no_deps PASSED  [ 12%]

01:32:59 tests/integration/project_test.py::ProjectTest::test_create_twice PASSED [ 18%]

01:33:00 tests/acceptance/cli_test.py::CLITestCase::test_ps_alternate_composefile PASSED [  7%]

01:33:00 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_build PASSED   [  7%]

01:33:00 tests/integration/project_test.py::ProjectTest::test_create_with_links PASSED [ 18%]

01:33:00 tests/integration/project_test.py::ProjectTest::test_initialize_volumes PASSED [ 18%]

01:33:00 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_external_volumes <- tests/integration/testcases.py PASSED [ 18%]

01:33:00 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_inexistent_external_volume PASSED [ 18%]

01:33:00 tests/integration/project_test.py::ProjectTest::test_project_up_without_all_services PASSED [ 21%]

01:33:01 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_digest PASSED  [  7%]

01:33:01 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_invalid_volume_driver PASSED [ 18%]

01:33:01 tests/integration/project_test.py::ProjectTest::test_recreate_preserves_mounts PASSED [ 22%]

01:33:02 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_blank_driver PASSED [ 18%]

01:33:02 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_driver PASSED [ 18%]

01:33:02 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_driver_opts PASSED [ 19%]

01:33:02 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_ignore_pull_failures PASSED [  7%]

01:33:02 tests/acceptance/cli_test.py::CLITestCase::test_ps_default_composefile PASSED [  7%]

01:33:02 tests/acceptance/cli_test.py::CLITestCase::test_up_with_force_recreate PASSED [ 15%]

01:33:02 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dockerfile_entrypoint_overridden PASSED [ 10%]

01:33:02 tests/integration/project_test.py::ProjectTest::test_net_from_container_v1 PASSED [ 19%]

01:33:03 tests/integration/project_test.py::ProjectTest::test_recreate_preserves_volumes PASSED [ 22%]

01:33:03 tests/acceptance/cli_test.py::CLITestCase::test_up_with_force_recreate_and_no_recreate PASSED [ 15%]

01:33:03 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_include_deps PASSED [  7%]

01:33:04 tests/acceptance/cli_test.py::CLITestCase::test_run_without_command PASSED [ 12%]

01:33:04 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_environment_overridden PASSED [ 10%]

01:33:04 tests/integration/project_test.py::ProjectTest::test_net_from_service_v1 PASSED [ 19%]

01:33:04 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_no_deps PASSED [  7%]

01:33:05 tests/integration/project_test.py::ProjectTest::test_start_pause_unpause_stop_kill_remove PASSED [ 22%]

01:33:05 tests/acceptance/cli_test.py::CLITestCase::test_ps_services_filter_option PASSED [  7%]

01:33:05 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_explicitly_mapped_ip_ports PASSED [ 10%]

01:33:05 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_parallel_failure PASSED [  8%]

01:33:05 tests/integration/project_test.py::ProjectTest::test_network_mode_from_container PASSED [ 19%]

01:33:06 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_explicitly_mapped_ports PASSED [ 10%]

01:33:07 tests/integration/project_test.py::ProjectTest::test_network_mode_from_service PASSED [ 19%]

01:33:07 tests/integration/project_test.py::ProjectTest::test_parallel_pull_with_no_image PASSED [ 19%]

01:33:07 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_quiet PASSED   [  8%]

01:33:07 tests/integration/project_test.py::ProjectTest::test_project_up PASSED   [ 19%]

01:33:08 tests/integration/project_test.py::ProjectTest::test_unscale_after_restart PASSED [ 22%]

01:33:08 tests/integration/project_test.py::ProjectTest::test_up_with_custom_name_resources PASSED [ 22%]

01:33:08 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_links PASSED [ 10%]

01:33:09 tests/integration/project_test.py::ProjectTest::test_up_with_enable_ipv6 PASSED [ 22%]

01:33:09 tests/integration/project_test.py::ProjectTest::test_up_with_invalid_isolation PASSED [ 22%]

01:33:09 tests/integration/project_test.py::ProjectTest::test_up_with_invalid_runtime PASSED [ 22%]

01:33:10 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_map_ports PASSED [ 10%]

01:33:10 tests/integration/project_test.py::ProjectTest::test_up_with_ipam_config PASSED [ 22%]

01:33:10 tests/acceptance/cli_test.py::CLITestCase::test_scale PASSED             [ 12%]

01:33:10 tests/integration/project_test.py::ProjectTest::test_up_with_ipam_options PASSED [ 22%]

01:33:11 tests/acceptance/cli_test.py::CLITestCase::test_scale_v2_2 PASSED        [ 12%]

01:33:11 tests/integration/project_test.py::ProjectTest::test_up_with_isolation PASSED [ 22%]

01:33:11 tests/acceptance/cli_test.py::CLITestCase::test_ps_services_filter_status PASSED [  7%]

01:33:11 tests/acceptance/cli_test.py::CLITestCase::test_up_with_healthcheck PASSED [ 15%]

01:33:11 tests/acceptance/cli_test.py::CLITestCase::test_up_with_ignore_remove_orphans PASSED [ 15%]

01:33:12 tests/acceptance/cli_test.py::CLITestCase::test_pull PASSED              [  7%]

01:33:12 tests/integration/project_test.py::ProjectTest::test_up_with_network_link_local_ips PASSED [ 23%]

01:33:12 tests/acceptance/cli_test.py::CLITestCase::test_quiet_build PASSED       [  8%]

01:33:13 tests/acceptance/cli_test.py::CLITestCase::test_shorthand_host_opt PASSED [ 12%]

01:33:13 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_build PASSED   [  7%]

01:33:13 tests/acceptance/cli_test.py::CLITestCase::test_up_with_links_v1 PASSED  [ 15%]

01:33:14 tests/acceptance/cli_test.py::CLITestCase::test_restart PASSED           [  8%]

01:33:14 tests/integration/project_test.py::ProjectTest::test_project_up_config_scale PASSED [ 19%]

01:33:14 tests/acceptance/cli_test.py::CLITestCase::test_shorthand_host_opt_interactive PASSED [ 12%]

01:33:14 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_scaled_dependencies PASSED [ 11%]

01:33:14 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_digest PASSED  [  7%]

01:33:14 tests/acceptance/cli_test.py::CLITestCase::test_restart_no_containers PASSED [  8%]

01:33:14 tests/acceptance/cli_test.py::CLITestCase::test_start_no_containers PASSED [ 12%]

01:33:14 tests/integration/project_test.py::ProjectTest::test_up_with_network_priorities PASSED [ 23%]

01:33:15 tests/acceptance/cli_test.py::CLITestCase::test_up_with_multiple_files PASSED [ 15%]

01:33:15 tests/integration/project_test.py::ProjectTest::test_up_with_network_static_addresses PASSED [ 23%]

01:33:15 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_ignore_pull_failures PASSED [  7%]

01:33:16 tests/integration/project_test.py::ProjectTest::test_up_with_network_static_addresses_missing_subnet PASSED [ 23%]

01:33:16 tests/integration/project_test.py::ProjectTest::test_up_with_nvidia_runtime <- tests/integration/testcases.py SKIPPED [ 23%]

01:33:16 tests/acceptance/cli_test.py::CLITestCase::test_up_with_net_is_invalid PASSED [ 16%]

01:33:16 tests/acceptance/cli_test.py::CLITestCase::test_restart_stopped_container PASSED [  8%]

01:33:16 tests/integration/project_test.py::ProjectTest::test_up_with_runtime <- tests/integration/testcases.py PASSED [ 23%]

01:33:16 tests/integration/project_test.py::ProjectTest::test_volumes_from_container PASSED [ 23%]

01:33:16 tests/integration/project_test.py::ProjectTest::test_volumes_from_service PASSED [ 23%]

01:33:16 tests/integration/project_test.py::ProjectTest::test_project_up_healthy_dependency PASSED [ 19%]

01:33:16 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_include_deps PASSED [  7%]

01:33:17 tests/acceptance/cli_test.py::CLITestCase::test_stop PASSED              [ 12%]

01:33:17 tests/integration/project_test.py::ProjectTest::test_project_up_ignore_orphans PASSED [ 19%]

01:33:17 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_no_deps PASSED [  7%]

01:33:18 tests/integration/resilience_test.py::ResilienceTest::test_create_failure PASSED [ 23%]

01:33:18 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_invalid_volume_driver PASSED [ 18%]

01:33:18 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_blank_driver PASSED [ 18%]

01:33:18 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_driver <- tests/integration/testcases.py PASSED [ 18%]

01:33:18 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_driver_opts <- tests/integration/testcases.py PASSED [ 19%]

01:33:18 tests/integration/project_test.py::ProjectTest::test_net_from_container_v1 <- tests/integration/testcases.py PASSED [ 19%]

01:33:18 tests/integration/project_test.py::ProjectTest::test_net_from_service_v1 <- tests/integration/testcases.py PASSED [ 19%]

01:33:18 tests/integration/project_test.py::ProjectTest::test_network_mode_from_container <- tests/integration/testcases.py PASSED [ 19%]

01:33:18 tests/acceptance/cli_test.py::CLITestCase::test_up_with_net_v1 PASSED    [ 16%]

01:33:18 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_parallel_failure PASSED [  8%]

01:33:19 tests/integration/project_test.py::ProjectTest::test_project_up_implicit_volume_driver PASSED [ 19%]

01:33:19 tests/integration/project_test.py::ProjectTest::test_network_mode_from_service <- tests/integration/testcases.py PASSED [ 19%]

01:33:19 tests/integration/project_test.py::ProjectTest::test_parallel_pull_with_no_image PASSED [ 19%]

01:33:19 tests/acceptance/cli_test.py::CLITestCase::test_rm PASSED                [  8%]

01:33:19 tests/integration/resilience_test.py::ResilienceTest::test_start_failure PASSED [ 23%]

01:33:19 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_aliases PASSED [ 16%]

01:33:19 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_unset_entrypoint PASSED [ 11%]

01:33:19 tests/integration/project_test.py::ProjectTest::test_project_up PASSED   [ 19%]

01:33:20 tests/acceptance/cli_test.py::CLITestCase::test_stop_signal PASSED       [ 12%]

01:33:20 tests/integration/resilience_test.py::ResilienceTest::test_successful_recreate PASSED [ 23%]

01:33:20 tests/integration/service_test.py::ServiceTest::test_build PASSED        [ 23%]

01:33:20 tests/integration/service_test.py::ServiceTest::test_build_non_ascii_filename PASSED [ 24%]

01:33:20 tests/integration/project_test.py::ProjectTest::test_project_up_logging_with_multiple_files PASSED [ 20%]

01:33:20 tests/acceptance/cli_test.py::CLITestCase::test_pull_with_quiet PASSED   [  8%]

01:33:20 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_use_aliases PASSED [ 11%]

01:33:21 tests/acceptance/cli_test.py::CLITestCase::test_rm_all PASSED            [  8%]

01:33:21 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_internal PASSED [ 16%]

01:33:21 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_user_overridden PASSED [ 11%]

01:33:22 tests/integration/service_test.py::ServiceTest::test_build_with_build_args PASSED [ 24%]

01:33:22 tests/acceptance/cli_test.py::CLITestCase::test_top_processes_running PASSED [ 12%]

01:33:22 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_labels PASSED [ 16%]

01:33:22 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_user_overridden_short_form PASSED [ 11%]

01:33:23 tests/integration/project_test.py::ProjectTest::test_project_up_name_starts_with_illegal_char PASSED [ 20%]

01:33:23 tests/acceptance/cli_test.py::CLITestCase::test_top_services_not_running PASSED [ 13%]

01:33:23 tests/integration/project_test.py::ProjectTest::test_project_up_config_scale PASSED [ 19%]

01:33:24 tests/integration/project_test.py::ProjectTest::test_project_up_named_volumes_in_binds PASSED [ 20%]

01:33:24 tests/integration/service_test.py::ServiceTest::test_build_with_build_args_override PASSED [ 24%]

01:33:24 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_workdir_overridden PASSED [ 11%]

01:33:25 tests/integration/service_test.py::ServiceTest::test_build_with_build_labels PASSED [ 24%]

01:33:25 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_mode PASSED [ 16%]

01:33:25 tests/integration/service_test.py::ServiceTest::test_build_with_cachefrom PASSED [ 24%]

01:33:25 tests/integration/project_test.py::ProjectTest::test_project_up_networks PASSED [ 20%]

01:33:25 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_workdir_overridden_short_form PASSED [ 11%]

01:33:26 tests/acceptance/cli_test.py::CLITestCase::test_quiet_build PASSED       [  8%]

01:33:26 tests/acceptance/cli_test.py::CLITestCase::test_top_services_running PASSED [ 13%]

01:33:26 tests/acceptance/cli_test.py::CLITestCase::test_rm_stop PASSED           [  8%]

01:33:26 tests/integration/project_test.py::ProjectTest::test_project_up_healthy_dependency PASSED [ 19%]

01:33:26 tests/acceptance/cli_test.py::CLITestCase::test_run_service_without_links PASSED [ 11%]

01:33:26 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_static_addresses PASSED [ 16%]

01:33:26 tests/integration/project_test.py::ProjectTest::test_project_up_no_healthcheck_dependency PASSED [ 20%]

01:33:26 tests/acceptance/cli_test.py::CLITestCase::test_restart PASSED           [  8%]

01:33:26 tests/integration/project_test.py::ProjectTest::test_project_up_ignore_orphans PASSED [ 19%]

01:33:26 tests/acceptance/cli_test.py::CLITestCase::test_unpause_no_containers PASSED [ 13%]

01:33:27 tests/integration/service_test.py::ServiceTest::test_build_with_extra_hosts PASSED [ 24%]

01:33:27 tests/acceptance/cli_test.py::CLITestCase::test_restart_no_containers PASSED [  8%]

01:33:27 tests/integration/project_test.py::ProjectTest::test_project_up_implicit_volume_driver PASSED [ 19%]

01:33:28 tests/acceptance/cli_test.py::CLITestCase::test_run_service_without_map_ports PASSED [ 11%]

01:33:28 tests/integration/project_test.py::ProjectTest::test_project_up_orphans PASSED [ 20%]

01:33:28 tests/integration/service_test.py::ServiceTest::test_build_with_git_url PASSED [ 24%]

01:33:28 tests/integration/project_test.py::ProjectTest::test_project_up_logging_with_multiple_files PASSED [ 20%]

01:33:29 tests/integration/project_test.py::ProjectTest::test_project_up_port_mappings_with_multiple_files PASSED [ 20%]

01:33:29 tests/acceptance/cli_test.py::CLITestCase::test_run_unicode_env_values_from_system PASSED [ 11%]

01:33:29 tests/acceptance/cli_test.py::CLITestCase::test_up PASSED                [ 13%]

01:33:29 tests/acceptance/cli_test.py::CLITestCase::test_restart_stopped_container PASSED [  8%]

01:33:29 tests/acceptance/cli_test.py::CLITestCase::test_up_with_networks PASSED  [ 16%]

01:33:30 tests/integration/service_test.py::ServiceTest::test_build_with_gzip PASSED [ 24%]

01:33:30 tests/integration/project_test.py::ProjectTest::test_project_up_name_starts_with_illegal_char <- tests/integration/testcases.py PASSED [ 20%]

01:33:30 tests/acceptance/cli_test.py::CLITestCase::test_run_with_custom_name PASSED [ 11%]

01:33:30 tests/acceptance/cli_test.py::CLITestCase::test_up_with_no_deps PASSED   [ 16%]

01:33:30 tests/integration/project_test.py::ProjectTest::test_project_up_recreate_with_tmpfs_volume PASSED [ 20%]

01:33:31 tests/integration/project_test.py::ProjectTest::test_project_up_named_volumes_in_binds PASSED [ 20%]

01:33:31 tests/acceptance/cli_test.py::CLITestCase::test_up_attached PASSED       [ 13%]

01:33:31 tests/integration/service_test.py::ServiceTest::test_build_with_illegal_leading_chars PASSED [ 24%]

01:33:31 tests/integration/service_test.py::ServiceTest::test_build_with_image_name PASSED [ 24%]

01:33:31 tests/integration/service_test.py::ServiceTest::test_build_with_isolation PASSED [ 24%]

01:33:31 tests/integration/project_test.py::ProjectTest::test_project_up_networks PASSED [ 20%]

01:33:32 tests/acceptance/cli_test.py::CLITestCase::test_run_with_expose_ports PASSED [ 12%]

01:33:32 tests/acceptance/cli_test.py::CLITestCase::test_rm PASSED                [  8%]

01:33:32 tests/integration/project_test.py::ProjectTest::test_project_up_seccomp_profile PASSED [ 20%]

01:33:32 tests/integration/service_test.py::ServiceTest::test_build_with_network <- tests/integration/testcases.py PASSED [ 25%]

01:33:32 tests/acceptance/cli_test.py::CLITestCase::test_up_detached PASSED       [ 13%]

01:33:32 tests/acceptance/cli_test.py::CLITestCase::test_run_detached_connects_to_network PASSED [  8%]

01:33:32 tests/integration/project_test.py::ProjectTest::test_project_up_no_healthcheck_dependency PASSED [ 20%]

01:33:33 tests/acceptance/cli_test.py::CLITestCase::test_up_with_no_recreate PASSED [ 16%]

01:33:33 tests/acceptance/cli_test.py::CLITestCase::test_run_with_no_deps PASSED  [ 12%]

01:33:33 tests/integration/project_test.py::ProjectTest::test_project_up_orphans PASSED [ 20%]

01:33:34 tests/acceptance/cli_test.py::CLITestCase::test_rm_all PASSED            [  8%]

01:33:34 tests/integration/service_test.py::ServiceTest::test_build_with_target <- tests/integration/testcases.py PASSED [ 25%]

01:33:34 tests/integration/service_test.py::ServiceTest::test_cap_add_list PASSED [ 25%]

01:33:34 tests/acceptance/cli_test.py::CLITestCase::test_up_detached_long_form PASSED [ 13%]

01:33:34 tests/acceptance/cli_test.py::CLITestCase::test_run_does_not_recreate_linked_containers PASSED [  8%]

01:33:34 tests/integration/project_test.py::ProjectTest::test_project_up_port_mappings_with_multiple_files PASSED [ 20%]

01:33:34 tests/integration/project_test.py::ProjectTest::test_project_up_starts_depends PASSED [ 20%]

01:33:35 tests/integration/service_test.py::ServiceTest::test_cap_drop_list PASSED [ 25%]

01:33:35 tests/acceptance/cli_test.py::CLITestCase::test_up_with_override_yaml PASSED [ 16%]

01:33:36 tests/acceptance/cli_test.py::CLITestCase::test_run_env_values_from_system PASSED [  9%]

01:33:36 tests/integration/project_test.py::ProjectTest::test_project_up_recreate_with_tmpfs_volume PASSED [ 20%]

01:33:36 tests/integration/project_test.py::ProjectTest::test_project_up_starts_links PASSED [ 20%]

01:33:36 tests/integration/project_test.py::ProjectTest::test_project_up_seccomp_profile PASSED [ 20%]

01:33:37 tests/integration/service_test.py::ServiceTest::test_containers PASSED   [ 25%]

01:33:37 tests/integration/service_test.py::ServiceTest::test_containers_one_off PASSED [ 25%]

01:33:37 tests/integration/service_test.py::ServiceTest::test_create_container_with_blkio_config PASSED [ 25%]

01:33:37 tests/integration/project_test.py::ProjectTest::test_project_up_starts_uncreated_services PASSED [ 21%]

01:33:37 tests/acceptance/cli_test.py::CLITestCase::test_up_external_networks PASSED [ 13%]

01:33:37 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_count PASSED [ 25%]

01:33:37 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_percent SKIPPED [ 25%]

01:33:37 tests/acceptance/cli_test.py::CLITestCase::test_run_handles_sighup PASSED [  9%]

01:33:37 tests/acceptance/cli_test.py::CLITestCase::test_run_without_command PASSED [ 12%]

01:33:37 tests/acceptance/cli_test.py::CLITestCase::test_up_with_pid_mode PASSED  [ 17%]

01:33:37 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_quota PASSED [ 25%]

01:33:38 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_rt xfail [ 25%]

01:33:38 tests/integration/project_test.py::ProjectTest::test_project_up_starts_depends PASSED [ 20%]

01:33:38 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_set PASSED [ 26%]

01:33:38 tests/acceptance/cli_test.py::CLITestCase::test_run_handles_sigint PASSED [  9%]

01:33:39 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_abort_on_container_exit PASSED [ 13%]

01:33:39 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_shares PASSED [ 26%]

01:33:39 tests/acceptance/cli_test.py::CLITestCase::test_rm_stop PASSED           [  8%]

01:33:39 tests/integration/project_test.py::ProjectTest::test_project_up_starts_links PASSED [ 20%]

01:33:39 tests/integration/project_test.py::ProjectTest::test_project_up_unhealthy_dependency PASSED [ 21%]

01:33:39 tests/acceptance/cli_test.py::CLITestCase::test_up_with_timeout PASSED   [ 17%]

01:33:39 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpus PASSED [ 26%]

01:33:39 tests/integration/service_test.py::ServiceTest::test_create_container_with_device_cgroup_rules PASSED [ 26%]

01:33:40 tests/integration/service_test.py::ServiceTest::test_create_container_with_extra_hosts_dicts PASSED [ 26%]

01:33:40 tests/integration/project_test.py::ProjectTest::test_project_up_starts_uncreated_services PASSED [ 21%]

01:33:40 tests/integration/project_test.py::ProjectTest::test_project_up_volumes PASSED [ 21%]

01:33:40 tests/acceptance/cli_test.py::CLITestCase::test_run_handles_sigterm PASSED [  9%]

01:33:40 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_abort_on_container_exit_code PASSED [ 13%]

01:33:41 tests/integration/service_test.py::ServiceTest::test_create_container_with_extra_hosts_list PASSED [ 26%]

01:33:41 tests/integration/service_test.py::ServiceTest::test_create_container_with_healthcheck_config PASSED [ 26%]

01:33:41 tests/acceptance/cli_test.py::CLITestCase::test_up_with_volume_labels PASSED [ 17%]

01:33:41 tests/integration/service_test.py::ServiceTest::test_create_container_with_host_mount PASSED [ 26%]

01:33:42 tests/integration/service_test.py::ServiceTest::test_create_container_with_init_bool PASSED [ 26%]

01:33:42 tests/integration/project_test.py::ProjectTest::test_project_up_unhealthy_dependency PASSED [ 21%]

01:33:42 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_force_shutdown PASSED [ 13%]

01:33:43 tests/integration/service_test.py::ServiceTest::test_create_container_with_init_path XPASS [ 26%]

01:33:43 tests/integration/project_test.py::ProjectTest::test_project_up_with_added_secrets PASSED [ 21%]

01:33:43 tests/integration/project_test.py::ProjectTest::test_project_up_volumes PASSED [ 21%]

01:33:43 tests/integration/service_test.py::ServiceTest::test_create_container_with_legacy_mount PASSED [ 26%]

01:33:43 tests/integration/environment_test.py::EnvironmentOverrideFileTest::test_env_file_override PASSED [ 17%]

01:33:44 tests/integration/service_test.py::ServiceTest::test_create_container_with_legacy_tmpfs_mount PASSED [ 26%]

01:33:44 tests/acceptance/cli_test.py::CLITestCase::test_scale PASSED             [ 12%]

01:33:44 tests/acceptance/cli_test.py::CLITestCase::test_scale_v2_2 PASSED        [ 12%]

01:33:44 tests/integration/project_test.py::ProjectTest::test_project_up_with_network_internal PASSED [ 21%]

01:33:44 tests/acceptance/cli_test.py::CLITestCase::test_run_detached_connects_to_network PASSED [  8%]

01:33:44 tests/integration/service_test.py::ServiceTest::test_create_container_with_mac_address PASSED [ 27%]

01:33:44 tests/integration/service_test.py::ServiceTest::test_create_container_with_one_off PASSED [ 27%]

01:33:44 tests/integration/service_test.py::ServiceTest::test_create_container_with_one_off_when_existing_container_is_running PASSED [ 27%]

01:33:44 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_sigint PASSED [ 13%]

01:33:45 tests/integration/service_test.py::ServiceTest::test_create_container_with_oom_kill_disable PASSED [ 27%]

01:33:45 tests/integration/project_test.py::ProjectTest::test_project_up_with_added_secrets PASSED [ 21%]

01:33:45 tests/integration/project_test.py::ProjectTest::test_project_up_with_network_label PASSED [ 21%]

01:33:45 tests/integration/service_test.py::ServiceTest::test_create_container_with_pids_limit XPASS [ 27%]

01:33:45 tests/integration/project_test.py::ProjectTest::test_project_up_with_network_internal PASSED [ 21%]

01:33:45 tests/integration/service_test.py::ServiceTest::test_create_container_with_read_only_root_fs PASSED [ 27%]

01:33:46 tests/integration/project_test.py::ProjectTest::test_project_up_with_no_deps PASSED [ 21%]

01:33:46 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_sigterm PASSED [ 14%]

01:33:46 tests/acceptance/cli_test.py::CLITestCase::test_shorthand_host_opt PASSED [ 12%]

01:33:46 tests/integration/service_test.py::ServiceTest::test_create_container_with_security_opt PASSED [ 27%]

01:33:46 tests/integration/project_test.py::ProjectTest::test_project_up_with_network_label PASSED [ 21%]

01:33:46 tests/integration/environment_test.py::EnvironmentSkipFileTest::test_env_file_skip PASSED [ 17%]

01:33:46 tests/integration/network_test.py::NetworkTest::test_network_default_labels PASSED [ 17%]

01:33:46 tests/integration/network_test.py::NetworkTest::test_network_external_default_ensure PASSED [ 17%]

01:33:46 tests/integration/network_test.py::NetworkTest::test_network_external_overlay_ensure PASSED [ 17%]

01:33:46 tests/integration/service_test.py::ServiceTest::test_create_container_with_shm_size PASSED [ 27%]

01:33:47 tests/integration/project_test.py::ProjectTest::test_project_up_with_no_deps PASSED [ 21%]

01:33:47 tests/acceptance/cli_test.py::CLITestCase::test_run_does_not_recreate_linked_containers PASSED [  8%]

01:33:47 tests/integration/project_test.py::ProjectTest::test_project_up_with_no_recreate_running PASSED [ 21%]

01:33:47 tests/integration/project_test.py::ProjectTest::test_containers PASSED   [ 17%]

01:33:47 tests/acceptance/cli_test.py::CLITestCase::test_shorthand_host_opt_interactive PASSED [ 12%]

01:33:47 tests/integration/service_test.py::ServiceTest::test_create_container_with_specified_volume PASSED [ 27%]

01:33:47 tests/integration/service_test.py::ServiceTest::test_create_container_with_storage_opt xfail [ 27%]

01:33:48 tests/acceptance/cli_test.py::CLITestCase::test_up_logging PASSED        [ 14%]

01:33:48 tests/acceptance/cli_test.py::CLITestCase::test_start_no_containers PASSED [ 12%]

01:33:48 tests/acceptance/cli_test.py::CLITestCase::test_run_env_values_from_system PASSED [  9%]

01:33:48 tests/integration/service_test.py::ServiceTest::test_create_container_with_tmpfs_mount PASSED [ 27%]

01:33:48 tests/integration/project_test.py::ProjectTest::test_containers_stopped PASSED [ 17%]

01:33:48 tests/integration/project_test.py::ProjectTest::test_project_up_with_no_recreate_running PASSED [ 21%]

01:33:48 tests/integration/service_test.py::ServiceTest::test_create_container_with_tmpfs_mount_tmpfs_size PASSED [ 28%]

01:33:48 tests/integration/project_test.py::ProjectTest::test_containers_with_extra_service PASSED [ 17%]

01:33:48 tests/acceptance/cli_test.py::CLITestCase::test_run_interactive_connects_to_network PASSED [  9%]

01:33:48 tests/acceptance/cli_test.py::CLITestCase::test_run_label_flag PASSED    [  9%]

01:33:49 tests/integration/service_test.py::ServiceTest::test_create_container_with_unspecified_volume PASSED [ 28%]

01:33:49 tests/integration/project_test.py::ProjectTest::test_project_up_with_no_recreate_stopped PASSED [ 21%]

01:33:49 tests/integration/project_test.py::ProjectTest::test_containers_with_service_names PASSED [ 18%]

01:33:49 tests/integration/project_test.py::ProjectTest::test_create PASSED       [ 18%]

01:33:49 tests/acceptance/cli_test.py::CLITestCase::test_run_handles_sighup PASSED [  9%]

01:33:49 tests/integration/service_test.py::ServiceTest::test_create_container_with_volume_driver PASSED [ 28%]

01:33:49 tests/integration/project_test.py::ProjectTest::test_project_up_with_no_recreate_stopped PASSED [ 21%]

01:33:49 tests/integration/project_test.py::ProjectTest::test_create_strategy_always PASSED [ 18%]

01:33:49 tests/integration/project_test.py::ProjectTest::test_create_strategy_never PASSED [ 18%]

01:33:49 tests/acceptance/cli_test.py::CLITestCase::test_up_logging_legacy PASSED [ 14%]

01:33:50 tests/integration/project_test.py::ProjectTest::test_create_twice PASSED [ 18%]

01:33:50 tests/integration/service_test.py::ServiceTest::test_create_container_with_volume_mount PASSED [ 28%]

01:33:50 tests/integration/project_test.py::ProjectTest::test_create_with_links PASSED [ 18%]

01:33:50 tests/integration/project_test.py::ProjectTest::test_initialize_volumes PASSED [ 18%]

01:33:50 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_external_volumes PASSED [ 18%]

01:33:50 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_inexistent_external_volume PASSED [ 18%]

01:33:50 tests/acceptance/cli_test.py::CLITestCase::test_stop PASSED              [ 12%]

01:33:50 tests/integration/project_test.py::ProjectTest::test_project_up_with_secrets PASSED [ 21%]

01:33:50 tests/integration/project_test.py::ProjectTest::test_project_up_with_secrets PASSED [ 21%]

01:33:50 tests/acceptance/cli_test.py::CLITestCase::test_up_missing_network PASSED [ 14%]

01:33:50 tests/integration/service_test.py::ServiceTest::test_create_container_with_volumes_from PASSED [ 28%]

01:33:50 tests/acceptance/cli_test.py::CLITestCase::test_run_handles_sigint PASSED [  9%]

01:33:51 tests/integration/service_test.py::ServiceTest::test_create_with_image_id PASSED [ 28%]

01:33:51 tests/integration/project_test.py::ProjectTest::test_project_up_with_volume_labels PASSED [ 21%]

01:33:51 tests/integration/project_test.py::ProjectTest::test_project_up_with_volume_labels PASSED [ 21%]

01:33:51 tests/integration/service_test.py::ServiceTest::test_custom_container_name PASSED [ 28%]

01:33:52 tests/acceptance/cli_test.py::CLITestCase::test_run_one_off_with_multiple_volumes PASSED [  9%]

01:33:52 tests/integration/service_test.py::ServiceTest::test_devices PASSED      [ 28%]

01:33:52 tests/acceptance/cli_test.py::CLITestCase::test_run_handles_sigterm PASSED [  9%]

01:33:52 tests/integration/project_test.py::ProjectTest::test_project_up_without_all_services PASSED [ 21%]

01:33:52 tests/acceptance/cli_test.py::CLITestCase::test_up_no_ansi PASSED        [ 14%]

01:33:52 tests/integration/service_test.py::ServiceTest::test_dns_list PASSED     [ 28%]

01:33:52 tests/integration/project_test.py::ProjectTest::test_project_up_without_all_services PASSED [ 21%]

01:33:53 tests/acceptance/cli_test.py::CLITestCase::test_stop_signal PASSED       [ 12%]

01:33:53 tests/integration/service_test.py::ServiceTest::test_dns_no_value PASSED [ 28%]

01:33:53 tests/acceptance/cli_test.py::CLITestCase::test_up_no_services PASSED    [ 14%]

01:33:53 tests/integration/service_test.py::ServiceTest::test_dns_opt_value PASSED [ 28%]

01:33:54 tests/acceptance/cli_test.py::CLITestCase::test_run_one_off_with_volume PASSED [  9%]

01:33:54 tests/integration/project_test.py::ProjectTest::test_recreate_preserves_mounts PASSED [ 22%]

01:33:54 tests/integration/service_test.py::ServiceTest::test_dns_search PASSED   [ 28%]

01:33:54 tests/integration/service_test.py::ServiceTest::test_duplicate_containers PASSED [ 29%]

01:33:54 tests/integration/project_test.py::ProjectTest::test_recreate_preserves_mounts PASSED [ 22%]

01:33:54 tests/acceptance/cli_test.py::CLITestCase::test_top_processes_running PASSED [ 12%]

01:33:55 tests/integration/project_test.py::ProjectTest::test_recreate_preserves_volumes PASSED [ 22%]

01:33:55 tests/acceptance/cli_test.py::CLITestCase::test_top_services_not_running PASSED [ 13%]

01:33:56 tests/integration/service_test.py::ServiceTest::test_duplicate_volume_trailing_slash PASSED [ 29%]

01:33:56 tests/acceptance/cli_test.py::CLITestCase::test_run_one_off_with_volume_merge PASSED [  9%]

01:33:56 tests/integration/service_test.py::ServiceTest::test_empty_labels PASSED [ 29%]

01:33:56 tests/integration/project_test.py::ProjectTest::test_recreate_preserves_volumes PASSED [ 22%]

01:33:56 tests/acceptance/cli_test.py::CLITestCase::test_up_no_start PASSED       [ 14%]

01:33:57 tests/integration/service_test.py::ServiceTest::test_env_from_file_combined_with_env PASSED [ 29%]

01:33:57 tests/integration/project_test.py::ProjectTest::test_start_pause_unpause_stop_kill_remove PASSED [ 22%]

01:33:57 tests/acceptance/cli_test.py::CLITestCase::test_run_rm PASSED            [  9%]

01:33:58 tests/acceptance/cli_test.py::CLITestCase::test_top_services_running PASSED [ 13%]

01:33:58 tests/integration/project_test.py::ProjectTest::test_start_pause_unpause_stop_kill_remove PASSED [ 22%]

01:33:58 tests/acceptance/cli_test.py::CLITestCase::test_up_no_start_remove_orphans PASSED [ 14%]

01:33:58 tests/acceptance/cli_test.py::CLITestCase::test_run_interactive_connects_to_network PASSED [  9%]

01:33:58 tests/acceptance/cli_test.py::CLITestCase::test_unpause_no_containers PASSED [ 13%]

01:33:59 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_anonymous_volume_recreate_then_renew PASSED [ 29%]

01:33:59 tests/acceptance/cli_test.py::CLITestCase::test_run_label_flag PASSED    [  9%]

01:33:59 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint PASSED [  9%]

01:34:00 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_anonymous_volume_renew PASSED [ 29%]

01:34:00 tests/integration/project_test.py::ProjectTest::test_unscale_after_restart PASSED [ 22%]

01:34:00 tests/integration/project_test.py::ProjectTest::test_up_with_custom_name_resources PASSED [ 22%]

01:34:01 tests/acceptance/cli_test.py::CLITestCase::test_up PASSED                [ 13%]

01:34:01 tests/integration/project_test.py::ProjectTest::test_up_with_enable_ipv6 PASSED [ 22%]

01:34:01 tests/integration/project_test.py::ProjectTest::test_up_with_invalid_isolation PASSED [ 22%]

01:34:01 tests/integration/project_test.py::ProjectTest::test_up_with_invalid_runtime PASSED [ 22%]

01:34:01 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint_and_command_overridden PASSED [ 10%]

01:34:01 tests/integration/project_test.py::ProjectTest::test_unscale_after_restart PASSED [ 22%]

01:34:02 tests/integration/project_test.py::ProjectTest::test_up_with_ipam_config PASSED [ 22%]

01:34:02 tests/acceptance/cli_test.py::CLITestCase::test_run_one_off_with_multiple_volumes PASSED [  9%]

01:34:02 tests/acceptance/cli_test.py::CLITestCase::test_up_attached PASSED       [ 13%]

01:34:02 tests/integration/project_test.py::ProjectTest::test_up_with_custom_name_resources PASSED [ 22%]

01:34:03 tests/integration/project_test.py::ProjectTest::test_up_with_ipam_options PASSED [ 22%]

01:34:03 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint_and_empty_string_command PASSED [ 10%]

01:34:03 tests/integration/project_test.py::ProjectTest::test_up_with_isolation PASSED [ 22%]

01:34:03 tests/integration/project_test.py::ProjectTest::test_up_with_enable_ipv6 PASSED [ 22%]

01:34:04 tests/integration/project_test.py::ProjectTest::test_up_with_invalid_isolation PASSED [ 22%]

01:34:04 tests/integration/project_test.py::ProjectTest::test_up_with_invalid_runtime PASSED [ 22%]

01:34:04 tests/acceptance/cli_test.py::CLITestCase::test_run_one_off_with_volume PASSED [  9%]

01:34:04 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_reset PASSED    [ 14%]

01:34:04 tests/integration/project_test.py::ProjectTest::test_up_with_network_link_local_ips PASSED [ 23%]

01:34:04 tests/acceptance/cli_test.py::CLITestCase::test_up_detached PASSED       [ 13%]

01:34:05 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint_overridden PASSED [ 10%]

01:34:05 tests/integration/project_test.py::ProjectTest::test_up_with_ipam_config PASSED [ 22%]

01:34:05 tests/acceptance/cli_test.py::CLITestCase::test_run_one_off_with_volume_merge PASSED [  9%]

01:34:06 tests/integration/project_test.py::ProjectTest::test_up_with_ipam_options PASSED [ 22%]

01:34:06 tests/acceptance/cli_test.py::CLITestCase::test_up_detached_long_form PASSED [ 13%]

01:34:06 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_image_with_volume_is_removed PASSED [ 29%]

01:34:06 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_scale_down PASSED [ 14%]

01:34:06 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate PASSED [ 29%]

01:34:07 tests/integration/project_test.py::ProjectTest::test_up_with_isolation PASSED [ 22%]

01:34:07 tests/integration/project_test.py::ProjectTest::test_up_with_network_priorities PASSED [ 23%]

01:34:07 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_change_mount_target PASSED [ 29%]

01:34:07 tests/acceptance/cli_test.py::CLITestCase::test_run_rm PASSED            [  9%]

01:34:08 tests/integration/project_test.py::ProjectTest::test_up_with_network_static_addresses PASSED [ 23%]

01:34:08 tests/integration/project_test.py::ProjectTest::test_up_with_network_static_addresses_missing_subnet PASSED [ 23%]

01:34:08 tests/integration/project_test.py::ProjectTest::test_up_with_nvidia_runtime <- tests/integration/testcases.py SKIPPED [ 23%]

01:34:08 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_invalid_volume_driver PASSED [ 18%]

01:34:08 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_blank_driver PASSED [ 18%]

01:34:08 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_driver PASSED [ 18%]

01:34:08 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_driver_opts PASSED [ 19%]

01:34:08 tests/integration/project_test.py::ProjectTest::test_net_from_container_v1 PASSED [ 19%]

01:34:08 tests/integration/project_test.py::ProjectTest::test_net_from_service_v1 PASSED [ 19%]

01:34:08 tests/integration/project_test.py::ProjectTest::test_network_mode_from_container PASSED [ 19%]

01:34:08 tests/acceptance/cli_test.py::CLITestCase::test_up_external_networks PASSED [ 13%]

01:34:08 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dependencies PASSED [ 10%]

01:34:08 tests/integration/project_test.py::ProjectTest::test_up_with_network_link_local_ips PASSED [ 23%]

01:34:08 tests/integration/project_test.py::ProjectTest::test_network_mode_from_service PASSED [ 19%]

01:34:08 tests/integration/project_test.py::ProjectTest::test_parallel_pull_with_no_image PASSED [ 19%]

01:34:09 tests/integration/project_test.py::ProjectTest::test_up_with_runtime <- tests/integration/testcases.py PASSED [ 23%]

01:34:09 tests/integration/project_test.py::ProjectTest::test_volumes_from_container PASSED [ 23%]

01:34:09 tests/integration/project_test.py::ProjectTest::test_volumes_from_service PASSED [ 23%]

01:34:09 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint PASSED [  9%]

01:34:09 tests/integration/project_test.py::ProjectTest::test_project_up PASSED   [ 19%]

01:34:09 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_twice PASSED [ 29%]

01:34:10 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_abort_on_container_exit PASSED [ 13%]

01:34:10 tests/integration/resilience_test.py::ResilienceTest::test_create_failure PASSED [ 23%]

01:34:10 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint_and_command_overridden PASSED [ 10%]

01:34:10 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_scale_up PASSED [ 14%]

01:34:11 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_twice_with_mount PASSED [ 29%]

01:34:11 tests/integration/resilience_test.py::ResilienceTest::test_start_failure PASSED [ 23%]

01:34:11 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_containers_are_stopped PASSED [ 30%]

01:34:11 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint_and_empty_string_command PASSED [ 10%]

01:34:12 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_abort_on_container_exit_code PASSED [ 13%]

01:34:12 tests/integration/resilience_test.py::ResilienceTest::test_successful_recreate PASSED [ 23%]

01:34:12 tests/integration/service_test.py::ServiceTest::test_build PASSED        [ 23%]

01:34:12 tests/integration/service_test.py::ServiceTest::test_build_non_ascii_filename PASSED [ 24%]

01:34:12 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dockerfile_entrypoint PASSED [ 10%]

01:34:12 tests/integration/project_test.py::ProjectTest::test_up_with_network_priorities PASSED [ 23%]

01:34:13 tests/integration/project_test.py::ProjectTest::test_project_up_config_scale PASSED [ 19%]

01:34:13 tests/integration/project_test.py::ProjectTest::test_up_with_network_static_addresses PASSED [ 23%]

01:34:13 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_compose_file_entrypoint_overridden PASSED [ 10%]

01:34:14 tests/integration/project_test.py::ProjectTest::test_up_with_network_static_addresses_missing_subnet PASSED [ 23%]

01:34:14 tests/integration/project_test.py::ProjectTest::test_up_with_nvidia_runtime SKIPPED [ 23%]

01:34:14 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_to_zero PASSED  [ 15%]

01:34:14 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_force_shutdown PASSED [ 13%]

01:34:14 tests/integration/service_test.py::ServiceTest::test_build_with_build_args PASSED [ 24%]

01:34:15 tests/integration/project_test.py::ProjectTest::test_up_with_runtime PASSED [ 23%]

01:34:15 tests/integration/project_test.py::ProjectTest::test_volumes_from_container PASSED [ 23%]

01:34:15 tests/integration/project_test.py::ProjectTest::test_volumes_from_service PASSED [ 23%]

01:34:15 tests/integration/project_test.py::ProjectTest::test_project_up_healthy_dependency PASSED [ 19%]

01:34:15 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dependencies PASSED [ 10%]

01:34:15 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_host_volume_is_removed PASSED [ 30%]

01:34:15 tests/acceptance/cli_test.py::CLITestCase::test_up_with_default_network_config PASSED [ 15%]

01:34:16 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_sigint PASSED [ 13%]

01:34:16 tests/integration/service_test.py::ServiceTest::test_build_with_build_args_override PASSED [ 24%]

01:34:16 tests/integration/project_test.py::ProjectTest::test_project_up_ignore_orphans PASSED [ 19%]

01:34:16 tests/integration/resilience_test.py::ResilienceTest::test_create_failure PASSED [ 23%]

01:34:16 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dockerfile_entrypoint_and_command_overridden PASSED [ 10%]

01:34:17 tests/integration/service_test.py::ServiceTest::test_build_with_build_labels PASSED [ 24%]

01:34:17 tests/integration/service_test.py::ServiceTest::test_build_with_cachefrom PASSED [ 24%]

01:34:17 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_sigterm PASSED [ 14%]

01:34:17 tests/integration/project_test.py::ProjectTest::test_project_up_implicit_volume_driver PASSED [ 19%]

01:34:17 tests/acceptance/cli_test.py::CLITestCase::test_up_with_default_override_file PASSED [ 15%]

01:34:17 tests/acceptance/cli_test.py::CLITestCase::test_up_with_duplicate_override_yaml_files PASSED [ 15%]

01:34:17 tests/integration/resilience_test.py::ResilienceTest::test_start_failure PASSED [ 23%]

01:34:18 tests/integration/project_test.py::ProjectTest::test_project_up_logging_with_multiple_files PASSED [ 20%]

01:34:19 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_image_volume_masks_config PASSED [ 30%]

01:34:19 tests/integration/service_test.py::ServiceTest::test_build_with_extra_hosts PASSED [ 24%]

01:34:19 tests/acceptance/cli_test.py::CLITestCase::test_up_logging PASSED        [ 14%]

01:34:19 tests/integration/resilience_test.py::ResilienceTest::test_successful_recreate PASSED [ 23%]

01:34:19 tests/integration/service_test.py::ServiceTest::test_build PASSED        [ 23%]

01:34:19 tests/integration/service_test.py::ServiceTest::test_build_non_ascii_filename PASSED [ 24%]

01:34:19 tests/integration/project_test.py::ProjectTest::test_project_up_name_starts_with_illegal_char PASSED [ 20%]

01:34:19 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dockerfile_entrypoint PASSED [ 10%]

01:34:20 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dockerfile_entrypoint_overridden PASSED [ 10%]

01:34:20 tests/integration/project_test.py::ProjectTest::test_project_up_named_volumes_in_binds PASSED [ 20%]

01:34:20 tests/acceptance/cli_test.py::CLITestCase::test_up_with_extends PASSED   [ 15%]

01:34:20 tests/integration/service_test.py::ServiceTest::test_build_with_git_url PASSED [ 24%]

01:34:20 tests/acceptance/cli_test.py::CLITestCase::test_up_logging_legacy PASSED [ 14%]

01:34:21 tests/integration/service_test.py::ServiceTest::test_build_with_build_args PASSED [ 24%]

01:34:21 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_environment_overridden PASSED [ 10%]

01:34:21 tests/acceptance/cli_test.py::CLITestCase::test_up_missing_network PASSED [ 14%]

01:34:21 tests/integration/project_test.py::ProjectTest::test_project_up_networks PASSED [ 20%]

01:34:22 tests/integration/project_test.py::ProjectTest::test_project_up_no_healthcheck_dependency PASSED [ 20%]

01:34:22 tests/integration/service_test.py::ServiceTest::test_build_with_gzip PASSED [ 24%]

01:34:22 tests/acceptance/cli_test.py::CLITestCase::test_up_with_external_default_network PASSED [ 15%]

01:34:23 tests/integration/service_test.py::ServiceTest::test_build_with_build_args_override PASSED [ 24%]

01:34:23 tests/integration/project_test.py::ProjectTest::test_project_up_orphans PASSED [ 20%]

01:34:23 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_with_image_declared_volume PASSED [ 30%]

01:34:23 tests/integration/service_test.py::ServiceTest::test_build_with_illegal_leading_chars PASSED [ 24%]

01:34:23 tests/integration/service_test.py::ServiceTest::test_build_with_image_name PASSED [ 24%]

01:34:23 tests/integration/service_test.py::ServiceTest::test_build_with_isolation PASSED [ 24%]

01:34:23 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_explicitly_mapped_ip_ports PASSED [ 10%]

01:34:23 tests/acceptance/cli_test.py::CLITestCase::test_up_no_ansi PASSED        [ 14%]

01:34:24 tests/acceptance/cli_test.py::CLITestCase::test_up_no_services PASSED    [ 14%]

01:34:24 tests/integration/service_test.py::ServiceTest::test_build_with_build_labels PASSED [ 24%]

01:34:24 tests/integration/project_test.py::ProjectTest::test_project_up_port_mappings_with_multiple_files PASSED [ 20%]

01:34:24 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dockerfile_entrypoint_and_command_overridden PASSED [ 10%]

01:34:24 tests/integration/service_test.py::ServiceTest::test_build_with_cachefrom PASSED [ 24%]

01:34:24 tests/integration/service_test.py::ServiceTest::test_build_with_network <- tests/integration/testcases.py PASSED [ 25%]

01:34:24 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_explicitly_mapped_ports PASSED [ 10%]

01:34:25 tests/integration/project_test.py::ProjectTest::test_project_up_recreate_with_tmpfs_volume PASSED [ 20%]

01:34:25 tests/integration/project_test.py::ProjectTest::test_project_up_seccomp_profile PASSED [ 20%]

01:34:26 tests/acceptance/cli_test.py::CLITestCase::test_up_with_force_recreate PASSED [ 15%]

01:34:26 tests/integration/service_test.py::ServiceTest::test_build_with_extra_hosts PASSED [ 24%]

01:34:26 tests/integration/service_test.py::ServiceTest::test_build_with_target <- tests/integration/testcases.py PASSED [ 25%]

01:34:26 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_links PASSED [ 10%]

01:34:26 tests/acceptance/cli_test.py::CLITestCase::test_up_with_force_recreate_and_no_recreate PASSED [ 15%]

01:34:26 tests/integration/service_test.py::ServiceTest::test_cap_add_list PASSED [ 25%]

01:34:27 tests/integration/service_test.py::ServiceTest::test_cap_drop_list PASSED [ 25%]

01:34:27 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_with_image_declared_volume_renew PASSED [ 30%]

01:34:27 tests/integration/service_test.py::ServiceTest::test_build_with_git_url PASSED [ 24%]

01:34:27 tests/integration/project_test.py::ProjectTest::test_project_up_starts_depends PASSED [ 20%]

01:34:28 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_map_ports PASSED [ 10%]

01:34:28 tests/acceptance/cli_test.py::CLITestCase::test_up_no_start PASSED       [ 14%]

01:34:28 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_dockerfile_entrypoint_overridden PASSED [ 10%]

01:34:28 tests/integration/project_test.py::ProjectTest::test_project_up_starts_links PASSED [ 20%]

01:34:29 tests/integration/service_test.py::ServiceTest::test_containers PASSED   [ 25%]

01:34:29 tests/integration/service_test.py::ServiceTest::test_containers_one_off PASSED [ 25%]

01:34:29 tests/integration/service_test.py::ServiceTest::test_create_container_with_blkio_config PASSED [ 25%]

01:34:29 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_environment_overridden PASSED [ 10%]

01:34:29 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_count PASSED [ 25%]

01:34:29 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_percent SKIPPED [ 25%]

01:34:29 tests/integration/service_test.py::ServiceTest::test_build_with_gzip PASSED [ 24%]

01:34:29 tests/acceptance/cli_test.py::CLITestCase::test_up_no_start_remove_orphans PASSED [ 14%]

01:34:29 tests/integration/project_test.py::ProjectTest::test_project_up_starts_uncreated_services PASSED [ 21%]

01:34:29 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_quota PASSED [ 25%]

01:34:30 tests/integration/service_test.py::ServiceTest::test_build_with_illegal_leading_chars PASSED [ 24%]

01:34:30 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_rt xfail [ 25%]

01:34:30 tests/integration/service_test.py::ServiceTest::test_build_with_image_name PASSED [ 24%]

01:34:30 tests/integration/service_test.py::ServiceTest::test_build_with_isolation PASSED [ 24%]

01:34:30 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_explicitly_mapped_ip_ports PASSED [ 10%]

01:34:30 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_set PASSED [ 26%]

01:34:30 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_without_start PASSED [ 30%]

01:34:30 tests/integration/service_test.py::ServiceTest::test_expose_does_not_publish_ports PASSED [ 30%]

01:34:31 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_shares PASSED [ 26%]

01:34:31 tests/integration/project_test.py::ProjectTest::test_project_up_unhealthy_dependency PASSED [ 21%]

01:34:31 tests/integration/service_test.py::ServiceTest::test_group_add_value PASSED [ 30%]

01:34:31 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpus PASSED [ 26%]

01:34:31 tests/integration/service_test.py::ServiceTest::test_create_container_with_device_cgroup_rules PASSED [ 26%]

01:34:31 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_explicitly_mapped_ports PASSED [ 10%]

01:34:32 tests/integration/service_test.py::ServiceTest::test_labels PASSED       [ 30%]

01:34:32 tests/integration/service_test.py::ServiceTest::test_create_container_with_extra_hosts_dicts PASSED [ 26%]

01:34:32 tests/integration/project_test.py::ProjectTest::test_project_up_volumes PASSED [ 21%]

01:34:32 tests/integration/service_test.py::ServiceTest::test_log_drive_empty_default_jsonfile PASSED [ 30%]

01:34:32 tests/integration/service_test.py::ServiceTest::test_log_drive_invalid SKIPPED [ 30%]

01:34:32 tests/integration/service_test.py::ServiceTest::test_build_with_network PASSED [ 25%]

01:34:32 tests/integration/service_test.py::ServiceTest::test_create_container_with_extra_hosts_list PASSED [ 26%]

01:34:32 tests/integration/service_test.py::ServiceTest::test_create_container_with_healthcheck_config PASSED [ 26%]

01:34:33 tests/integration/service_test.py::ServiceTest::test_log_drive_none PASSED [ 31%]

01:34:33 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_scaled_dependencies PASSED [ 11%]

01:34:33 tests/integration/service_test.py::ServiceTest::test_mem_reservation PASSED [ 31%]

01:34:33 tests/integration/project_test.py::ProjectTest::test_project_up_with_added_secrets PASSED [ 21%]

01:34:33 tests/integration/service_test.py::ServiceTest::test_create_container_with_host_mount PASSED [ 26%]

01:34:33 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_links PASSED [ 10%]

01:34:34 tests/integration/service_test.py::ServiceTest::test_mem_swappiness PASSED [ 31%]

01:34:34 tests/integration/service_test.py::ServiceTest::test_create_container_with_init_bool PASSED [ 26%]

01:34:34 tests/integration/service_test.py::ServiceTest::test_build_with_target PASSED [ 25%]

01:34:34 tests/integration/project_test.py::ProjectTest::test_project_up_with_network_internal PASSED [ 21%]

01:34:34 tests/integration/service_test.py::ServiceTest::test_network_mode_bridged PASSED [ 31%]

01:34:34 tests/integration/service_test.py::ServiceTest::test_create_container_with_init_path XPASS [ 26%]

01:34:34 tests/integration/service_test.py::ServiceTest::test_cap_add_list PASSED [ 25%]

01:34:34 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_reset PASSED    [ 14%]

01:34:34 tests/integration/project_test.py::ProjectTest::test_project_up_with_network_label PASSED [ 21%]

01:34:34 tests/acceptance/cli_test.py::CLITestCase::test_up_with_healthcheck PASSED [ 15%]

01:34:34 tests/acceptance/cli_test.py::CLITestCase::test_up_with_ignore_remove_orphans PASSED [ 15%]

01:34:35 tests/integration/service_test.py::ServiceTest::test_network_mode_host PASSED [ 31%]

01:34:35 tests/integration/service_test.py::ServiceTest::test_create_container_with_legacy_mount PASSED [ 26%]

01:34:35 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_map_ports PASSED [ 10%]

01:34:35 tests/integration/service_test.py::ServiceTest::test_network_mode_none PASSED [ 31%]

01:34:35 tests/integration/service_test.py::ServiceTest::test_cap_drop_list PASSED [ 25%]

01:34:35 tests/integration/service_test.py::ServiceTest::test_create_container_with_legacy_tmpfs_mount PASSED [ 26%]

01:34:35 tests/integration/service_test.py::ServiceTest::test_oom_score_adj_value PASSED [ 31%]

01:34:35 tests/integration/project_test.py::ProjectTest::test_project_up_with_no_deps PASSED [ 21%]

01:34:36 tests/integration/service_test.py::ServiceTest::test_create_container_with_mac_address PASSED [ 27%]

01:34:36 tests/integration/service_test.py::ServiceTest::test_create_container_with_one_off PASSED [ 27%]

01:34:36 tests/integration/service_test.py::ServiceTest::test_create_container_with_one_off_when_existing_container_is_running PASSED [ 27%]

01:34:36 tests/integration/service_test.py::ServiceTest::test_pid_mode_host PASSED [ 31%]

01:34:36 tests/integration/service_test.py::ServiceTest::test_create_container_with_oom_kill_disable PASSED [ 27%]

01:34:36 tests/acceptance/cli_test.py::CLITestCase::test_up_with_links_v1 PASSED  [ 15%]

01:34:36 tests/integration/project_test.py::ProjectTest::test_project_up_with_no_recreate_running PASSED [ 21%]

01:34:37 tests/integration/service_test.py::ServiceTest::test_pid_mode_none_defined PASSED [ 31%]

01:34:37 tests/integration/service_test.py::ServiceTest::test_create_container_with_pids_limit XPASS [ 27%]

01:34:37 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_scale_down PASSED [ 14%]

01:34:37 tests/integration/service_test.py::ServiceTest::test_create_container_with_read_only_root_fs PASSED [ 27%]

01:34:37 tests/integration/service_test.py::ServiceTest::test_containers PASSED   [ 25%]

01:34:37 tests/integration/service_test.py::ServiceTest::test_containers_one_off PASSED [ 25%]

01:34:37 tests/integration/service_test.py::ServiceTest::test_create_container_with_blkio_config PASSED [ 25%]

01:34:37 tests/integration/service_test.py::ServiceTest::test_port_with_explicit_interface PASSED [ 31%]

01:34:37 tests/integration/service_test.py::ServiceTest::test_create_container_with_security_opt PASSED [ 27%]

01:34:38 tests/integration/service_test.py::ServiceTest::test_project_is_added_to_container_name PASSED [ 31%]

01:34:38 tests/integration/project_test.py::ProjectTest::test_project_up_with_no_recreate_stopped PASSED [ 21%]

01:34:38 tests/integration/service_test.py::ServiceTest::test_create_container_with_shm_size PASSED [ 27%]

01:34:38 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_count PASSED [ 25%]

01:34:38 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_percent SKIPPED [ 25%]

01:34:39 tests/integration/service_test.py::ServiceTest::test_create_container_with_specified_volume PASSED [ 27%]

01:34:39 tests/integration/service_test.py::ServiceTest::test_create_container_with_storage_opt xfail [ 27%]

01:34:39 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_quota PASSED [ 25%]

01:34:39 tests/integration/service_test.py::ServiceTest::test_recreate_preserves_volume_with_trailing_slash PASSED [ 31%]

01:34:39 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_rt xfail [ 25%]

01:34:39 tests/acceptance/cli_test.py::CLITestCase::test_up_with_multiple_files PASSED [ 15%]

01:34:39 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_scaled_dependencies PASSED [ 11%]

01:34:39 tests/integration/service_test.py::ServiceTest::test_create_container_with_tmpfs_mount PASSED [ 27%]

01:34:39 tests/integration/project_test.py::ProjectTest::test_project_up_with_secrets PASSED [ 21%]

01:34:39 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_unset_entrypoint PASSED [ 11%]

01:34:39 tests/integration/project_test.py::ProjectTest::test_project_up_with_volume_labels PASSED [ 21%]

01:34:39 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_set PASSED [ 26%]

01:34:39 tests/acceptance/cli_test.py::CLITestCase::test_up_with_net_is_invalid PASSED [ 16%]

01:34:40 tests/integration/service_test.py::ServiceTest::test_create_container_with_tmpfs_mount_tmpfs_size PASSED [ 28%]

01:34:40 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_shares PASSED [ 26%]

01:34:40 tests/integration/service_test.py::ServiceTest::test_create_container_with_unspecified_volume PASSED [ 28%]

01:34:40 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_use_aliases PASSED [ 11%]

01:34:41 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpus PASSED [ 26%]

01:34:41 tests/integration/project_test.py::ProjectTest::test_project_up_without_all_services PASSED [ 21%]

01:34:41 tests/integration/service_test.py::ServiceTest::test_create_container_with_volume_driver PASSED [ 28%]

01:34:41 tests/integration/service_test.py::ServiceTest::test_create_container_with_device_cgroup_rules PASSED [ 26%]

01:34:41 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_scale_up PASSED [ 14%]

01:34:41 tests/integration/service_test.py::ServiceTest::test_create_container_with_volume_mount PASSED [ 28%]

01:34:41 tests/acceptance/cli_test.py::CLITestCase::test_up_with_net_v1 <- tests/integration/testcases.py PASSED [ 16%]

01:34:41 tests/integration/service_test.py::ServiceTest::test_create_container_with_extra_hosts_dicts PASSED [ 26%]

01:34:42 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_user_overridden PASSED [ 11%]

01:34:42 tests/integration/service_test.py::ServiceTest::test_create_container_with_volumes_from PASSED [ 28%]

01:34:42 tests/integration/service_test.py::ServiceTest::test_create_container_with_extra_hosts_list PASSED [ 26%]

01:34:42 tests/integration/project_test.py::ProjectTest::test_recreate_preserves_mounts PASSED [ 22%]

01:34:42 tests/integration/service_test.py::ServiceTest::test_create_with_image_id PASSED [ 28%]

01:34:42 tests/integration/service_test.py::ServiceTest::test_create_container_with_healthcheck_config PASSED [ 26%]

01:34:43 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_user_overridden_short_form PASSED [ 11%]

01:34:43 tests/integration/service_test.py::ServiceTest::test_custom_container_name PASSED [ 28%]

01:34:43 tests/integration/service_test.py::ServiceTest::test_recreate_volume_to_mount PASSED [ 32%]

01:34:43 tests/integration/service_test.py::ServiceTest::test_create_container_with_host_mount PASSED [ 26%]

01:34:43 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_aliases PASSED [ 16%]

01:34:43 tests/integration/service_test.py::ServiceTest::test_devices PASSED      [ 28%]

01:34:43 tests/integration/service_test.py::ServiceTest::test_resolve_env PASSED  [ 32%]

01:34:43 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_to_zero PASSED  [ 15%]

01:34:43 tests/integration/project_test.py::ProjectTest::test_recreate_preserves_volumes PASSED [ 22%]

01:34:44 tests/integration/service_test.py::ServiceTest::test_dns_list PASSED     [ 28%]

01:34:44 tests/integration/service_test.py::ServiceTest::test_restart_always_value PASSED [ 32%]

01:34:44 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_workdir_overridden PASSED [ 11%]

01:34:44 tests/integration/service_test.py::ServiceTest::test_create_container_with_init_bool PASSED [ 26%]

01:34:44 tests/integration/service_test.py::ServiceTest::test_dns_no_value PASSED [ 28%]

01:34:44 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_unset_entrypoint PASSED [ 11%]

01:34:44 tests/integration/service_test.py::ServiceTest::test_restart_on_failure_value PASSED [ 32%]

01:34:45 tests/integration/service_test.py::ServiceTest::test_create_container_with_init_path XPASS [ 26%]

01:34:45 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_internal PASSED [ 16%]

01:34:45 tests/integration/service_test.py::ServiceTest::test_dns_opt_value PASSED [ 28%]

01:34:45 tests/acceptance/cli_test.py::CLITestCase::test_up_with_default_network_config PASSED [ 15%]

01:34:45 tests/integration/project_test.py::ProjectTest::test_start_pause_unpause_stop_kill_remove PASSED [ 22%]

01:34:45 tests/integration/service_test.py::ServiceTest::test_create_container_with_legacy_mount PASSED [ 26%]

01:34:45 tests/integration/service_test.py::ServiceTest::test_dns_search PASSED   [ 28%]

01:34:45 tests/integration/service_test.py::ServiceTest::test_duplicate_containers PASSED [ 29%]

01:34:45 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_workdir_overridden_short_form PASSED [ 11%]

01:34:46 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_use_aliases PASSED [ 11%]

01:34:46 tests/integration/service_test.py::ServiceTest::test_create_container_with_legacy_tmpfs_mount PASSED [ 26%]

01:34:46 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_labels PASSED [ 16%]

01:34:46 tests/integration/service_test.py::ServiceTest::test_scale PASSED        [ 32%]

01:34:46 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_user_overridden PASSED [ 11%]

01:34:47 tests/integration/service_test.py::ServiceTest::test_duplicate_volume_trailing_slash PASSED [ 29%]

01:34:47 tests/acceptance/cli_test.py::CLITestCase::test_run_service_without_links PASSED [ 11%]

01:34:47 tests/integration/service_test.py::ServiceTest::test_create_container_with_mac_address PASSED [ 27%]

01:34:47 tests/integration/service_test.py::ServiceTest::test_create_container_with_one_off PASSED [ 27%]

01:34:47 tests/integration/service_test.py::ServiceTest::test_create_container_with_one_off_when_existing_container_is_running PASSED [ 27%]

01:34:47 tests/integration/service_test.py::ServiceTest::test_create_container_with_oom_kill_disable PASSED [ 27%]

01:34:47 tests/integration/service_test.py::ServiceTest::test_scale_sets_ports PASSED [ 32%]

01:34:47 tests/acceptance/cli_test.py::CLITestCase::test_up_with_default_override_file PASSED [ 15%]

01:34:47 tests/acceptance/cli_test.py::CLITestCase::test_up_with_duplicate_override_yaml_files PASSED [ 15%]

01:34:47 tests/integration/service_test.py::ServiceTest::test_empty_labels PASSED [ 29%]

01:34:47 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_user_overridden_short_form PASSED [ 11%]

01:34:48 tests/integration/service_test.py::ServiceTest::test_create_container_with_pids_limit XPASS [ 27%]

01:34:48 tests/integration/service_test.py::ServiceTest::test_scale_with_api_error PASSED [ 32%]

01:34:48 tests/integration/service_test.py::ServiceTest::test_env_from_file_combined_with_env PASSED [ 29%]

01:34:48 tests/integration/service_test.py::ServiceTest::test_scale_with_custom_container_name_outputs_warning PASSED [ 32%]

01:34:48 tests/acceptance/cli_test.py::CLITestCase::test_run_service_without_map_ports PASSED [ 11%]

01:34:48 tests/integration/project_test.py::ProjectTest::test_unscale_after_restart PASSED [ 22%]

01:34:48 tests/integration/project_test.py::ProjectTest::test_up_with_custom_name_resources PASSED [ 22%]

01:34:48 tests/integration/service_test.py::ServiceTest::test_create_container_with_read_only_root_fs PASSED [ 27%]

01:34:48 tests/integration/service_test.py::ServiceTest::test_scale_with_desired_number_already_achieved PASSED [ 32%]

01:34:49 tests/acceptance/cli_test.py::CLITestCase::test_up_with_extends PASSED   [ 15%]

01:34:49 tests/integration/service_test.py::ServiceTest::test_create_container_with_security_opt PASSED [ 27%]

01:34:49 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_workdir_overridden PASSED [ 11%]

01:34:49 tests/integration/project_test.py::ProjectTest::test_up_with_enable_ipv6 PASSED [ 22%]

01:34:49 tests/integration/project_test.py::ProjectTest::test_up_with_invalid_isolation PASSED [ 22%]

01:34:49 tests/integration/project_test.py::ProjectTest::test_up_with_invalid_runtime PASSED [ 22%]

01:34:49 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_mode <- tests/integration/testcases.py PASSED [ 16%]

01:34:49 tests/integration/service_test.py::ServiceTest::test_create_container_with_shm_size PASSED [ 27%]

01:34:49 tests/integration/service_test.py::ServiceTest::test_scale_with_immediate_exit PASSED [ 32%]

01:34:50 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_anonymous_volume_recreate_then_renew PASSED [ 29%]

01:34:50 tests/acceptance/cli_test.py::CLITestCase::test_run_unicode_env_values_from_system PASSED [ 11%]

01:34:50 tests/integration/project_test.py::ProjectTest::test_up_with_ipam_config PASSED [ 22%]

01:34:50 tests/acceptance/cli_test.py::CLITestCase::test_run_service_with_workdir_overridden_short_form PASSED [ 11%]

01:34:50 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_anonymous_volume_renew PASSED [ 29%]

01:34:50 tests/integration/service_test.py::ServiceTest::test_create_container_with_specified_volume PASSED [ 27%]

01:34:50 tests/integration/service_test.py::ServiceTest::test_create_container_with_storage_opt xfail [ 27%]

01:34:50 tests/integration/service_test.py::ServiceTest::test_scale_with_stopped_containers PASSED [ 32%]

01:34:51 tests/integration/project_test.py::ProjectTest::test_up_with_ipam_options PASSED [ 22%]

01:34:51 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_static_addresses PASSED [ 16%]

01:34:51 tests/integration/service_test.py::ServiceTest::test_create_container_with_tmpfs_mount PASSED [ 27%]

01:34:51 tests/integration/project_test.py::ProjectTest::test_up_with_isolation PASSED [ 22%]

01:34:51 tests/acceptance/cli_test.py::CLITestCase::test_up_with_external_default_network PASSED [ 15%]

01:34:51 tests/acceptance/cli_test.py::CLITestCase::test_run_with_custom_name PASSED [ 11%]

01:34:51 tests/acceptance/cli_test.py::CLITestCase::test_run_service_without_links PASSED [ 11%]

01:34:52 tests/integration/project_test.py::ProjectTest::test_up_with_network_link_local_ips PASSED [ 23%]

01:34:52 tests/integration/service_test.py::ServiceTest::test_create_container_with_tmpfs_mount_tmpfs_size PASSED [ 28%]

01:34:52 tests/integration/service_test.py::ServiceTest::test_scale_with_stopped_containers_and_needing_creation PASSED [ 33%]

01:34:52 tests/integration/service_test.py::ServiceTest::test_scale_with_unexpected_exception PASSED [ 33%]

01:34:52 tests/integration/service_test.py::ServiceTest::test_create_container_with_unspecified_volume PASSED [ 28%]

01:34:53 tests/integration/service_test.py::ServiceTest::test_split_env PASSED    [ 33%]

01:34:53 tests/acceptance/cli_test.py::CLITestCase::test_run_with_expose_ports PASSED [ 12%]

01:34:53 tests/acceptance/cli_test.py::CLITestCase::test_run_service_without_map_ports PASSED [ 11%]

01:34:53 tests/integration/service_test.py::ServiceTest::test_create_container_with_volume_driver PASSED [ 28%]

01:34:53 tests/integration/service_test.py::ServiceTest::test_start_container_becomes_privileged PASSED [ 33%]

01:34:53 tests/integration/service_test.py::ServiceTest::test_create_container_with_volume_mount PASSED [ 28%]

01:34:54 tests/acceptance/cli_test.py::CLITestCase::test_up_with_networks PASSED  [ 16%]

01:34:54 tests/acceptance/cli_test.py::CLITestCase::test_run_unicode_env_values_from_system PASSED [ 11%]

01:34:54 tests/acceptance/cli_test.py::CLITestCase::test_run_with_no_deps PASSED  [ 12%]

01:34:54 tests/integration/service_test.py::ServiceTest::test_create_container_with_volumes_from PASSED [ 28%]

01:34:54 tests/integration/service_test.py::ServiceTest::test_create_with_image_id PASSED [ 28%]

01:34:54 tests/acceptance/cli_test.py::CLITestCase::test_up_with_force_recreate PASSED [ 15%]

01:34:55 tests/integration/project_test.py::ProjectTest::test_up_with_network_priorities PASSED [ 23%]

01:34:55 tests/acceptance/cli_test.py::CLITestCase::test_up_with_force_recreate_and_no_recreate PASSED [ 15%]

01:34:55 tests/integration/service_test.py::ServiceTest::test_start_container_builds_images PASSED [ 33%]

01:34:55 tests/integration/project_test.py::ProjectTest::test_up_with_network_static_addresses PASSED [ 23%]

01:34:55 tests/acceptance/cli_test.py::CLITestCase::test_up_with_no_deps PASSED   [ 16%]

01:34:55 tests/integration/service_test.py::ServiceTest::test_custom_container_name PASSED [ 28%]

01:34:55 tests/integration/project_test.py::ProjectTest::test_up_with_network_static_addresses_missing_subnet PASSED [ 23%]

01:34:55 tests/integration/project_test.py::ProjectTest::test_up_with_nvidia_runtime SKIPPED [ 23%]

01:34:56 tests/acceptance/cli_test.py::CLITestCase::test_run_with_custom_name PASSED [ 11%]

01:34:56 tests/integration/service_test.py::ServiceTest::test_start_container_creates_fixed_external_ports PASSED [ 33%]

01:34:56 tests/integration/service_test.py::ServiceTest::test_devices PASSED      [ 28%]

01:34:56 tests/integration/project_test.py::ProjectTest::test_up_with_runtime PASSED [ 23%]

01:34:56 tests/integration/project_test.py::ProjectTest::test_volumes_from_container PASSED [ 23%]

01:34:56 tests/integration/project_test.py::ProjectTest::test_volumes_from_service PASSED [ 23%]

01:34:56 tests/integration/service_test.py::ServiceTest::test_start_container_creates_fixed_external_ports_when_it_is_different_to_internal_port PASSED [ 33%]

01:34:56 tests/integration/service_test.py::ServiceTest::test_dns_list PASSED     [ 28%]

01:34:57 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_image_with_volume_is_removed PASSED [ 29%]

01:34:57 tests/acceptance/cli_test.py::CLITestCase::test_run_with_expose_ports PASSED [ 12%]

01:34:57 tests/integration/service_test.py::ServiceTest::test_dns_no_value PASSED [ 28%]

01:34:57 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate PASSED [ 29%]

01:34:57 tests/integration/resilience_test.py::ResilienceTest::test_create_failure PASSED [ 23%]

01:34:58 tests/acceptance/cli_test.py::CLITestCase::test_up_with_no_recreate PASSED [ 16%]

01:34:58 tests/integration/service_test.py::ServiceTest::test_dns_opt_value PASSED [ 28%]

01:34:58 tests/integration/service_test.py::ServiceTest::test_start_container_creates_links <- tests/integration/testcases.py PASSED [ 33%]

01:34:58 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_change_mount_target PASSED [ 29%]

01:34:58 tests/integration/resilience_test.py::ResilienceTest::test_start_failure PASSED [ 23%]

01:34:58 tests/acceptance/cli_test.py::CLITestCase::test_run_with_no_deps PASSED  [ 12%]

01:34:58 tests/acceptance/cli_test.py::CLITestCase::test_run_without_command PASSED [ 12%]

01:34:59 tests/integration/service_test.py::ServiceTest::test_dns_search PASSED   [ 28%]

01:34:59 tests/integration/service_test.py::ServiceTest::test_duplicate_containers PASSED [ 29%]

01:34:59 tests/integration/resilience_test.py::ResilienceTest::test_successful_recreate PASSED [ 23%]

01:34:59 tests/integration/service_test.py::ServiceTest::test_build PASSED        [ 23%]

01:34:59 tests/integration/service_test.py::ServiceTest::test_build_non_ascii_filename PASSED [ 24%]

01:34:59 tests/integration/service_test.py::ServiceTest::test_start_container_creates_links_with_names <- tests/integration/testcases.py PASSED [ 33%]

01:35:00 tests/acceptance/cli_test.py::CLITestCase::test_up_with_override_yaml PASSED [ 16%]

01:35:00 tests/integration/service_test.py::ServiceTest::test_start_container_creates_port_with_explicit_protocol PASSED [ 33%]

01:35:00 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_twice PASSED [ 29%]

01:35:01 tests/integration/service_test.py::ServiceTest::test_start_container_creates_ports PASSED [ 33%]

01:35:01 tests/integration/service_test.py::ServiceTest::test_build_with_build_args PASSED [ 24%]

01:35:01 tests/integration/service_test.py::ServiceTest::test_duplicate_volume_trailing_slash PASSED [ 29%]

01:35:01 tests/integration/service_test.py::ServiceTest::test_start_container_inherits_options_from_constructor PASSED [ 34%]

01:35:01 tests/integration/service_test.py::ServiceTest::test_start_container_passes_through_options PASSED [ 34%]

01:35:01 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_twice_with_mount PASSED [ 29%]

01:35:02 tests/integration/service_test.py::ServiceTest::test_empty_labels PASSED [ 29%]

01:35:02 tests/integration/service_test.py::ServiceTest::test_start_container_stays_unprivileged PASSED [ 34%]

01:35:02 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_containers_are_stopped PASSED [ 30%]

01:35:02 tests/integration/service_test.py::ServiceTest::test_env_from_file_combined_with_env PASSED [ 29%]

01:35:03 tests/acceptance/cli_test.py::CLITestCase::test_run_without_command PASSED [ 12%]

01:35:03 tests/acceptance/cli_test.py::CLITestCase::test_up_with_pid_mode <- tests/integration/testcases.py PASSED [ 17%]

01:35:03 tests/acceptance/cli_test.py::CLITestCase::test_up_with_healthcheck PASSED [ 15%]

01:35:03 tests/integration/service_test.py::ServiceTest::test_build_with_build_args_override PASSED [ 24%]

01:35:04 tests/acceptance/cli_test.py::CLITestCase::test_up_with_ignore_remove_orphans PASSED [ 15%]

01:35:04 tests/integration/service_test.py::ServiceTest::test_build_with_build_labels PASSED [ 24%]

01:35:04 tests/integration/service_test.py::ServiceTest::test_build_with_cachefrom PASSED [ 24%]

01:35:04 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_anonymous_volume_recreate_then_renew PASSED [ 29%]

01:35:04 tests/acceptance/cli_test.py::CLITestCase::test_up_with_timeout PASSED   [ 17%]

01:35:04 tests/integration/service_test.py::ServiceTest::test_start_container_uses_tagged_image_if_it_exists PASSED [ 34%]

01:35:05 tests/acceptance/cli_test.py::CLITestCase::test_scale PASSED             [ 12%]

01:35:05 tests/acceptance/cli_test.py::CLITestCase::test_up_with_links_v1 PASSED  [ 15%]

01:35:06 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_anonymous_volume_renew PASSED [ 29%]

01:35:06 tests/acceptance/cli_test.py::CLITestCase::test_scale_v2_2 PASSED        [ 12%]

01:35:06 tests/integration/service_test.py::ServiceTest::test_build_with_extra_hosts PASSED [ 24%]

01:35:06 tests/acceptance/cli_test.py::CLITestCase::test_up_with_volume_labels PASSED [ 17%]

01:35:06 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_host_volume_is_removed PASSED [ 30%]

01:35:06 tests/integration/service_test.py::ServiceTest::test_start_container_with_external_links <- tests/integration/testcases.py PASSED [ 34%]

01:35:07 tests/integration/service_test.py::ServiceTest::test_build_with_git_url PASSED [ 24%]

01:35:07 tests/acceptance/cli_test.py::CLITestCase::test_shorthand_host_opt PASSED [ 12%]

01:35:08 tests/integration/service_test.py::ServiceTest::test_start_normal_container_does_not_create_links_to_its_own_service <- tests/integration/testcases.py PASSED [ 34%]

01:35:08 tests/acceptance/cli_test.py::CLITestCase::test_up_with_multiple_files PASSED [ 15%]

01:35:09 tests/acceptance/cli_test.py::CLITestCase::test_up_with_net_is_invalid PASSED [ 16%]

01:35:09 tests/integration/environment_test.py::EnvironmentOverrideFileTest::test_env_file_override PASSED [ 17%]

01:35:09 tests/acceptance/cli_test.py::CLITestCase::test_shorthand_host_opt_interactive PASSED [ 12%]

01:35:09 tests/integration/service_test.py::ServiceTest::test_build_with_gzip PASSED [ 24%]

01:35:09 tests/acceptance/cli_test.py::CLITestCase::test_scale PASSED             [ 12%]

01:35:09 tests/acceptance/cli_test.py::CLITestCase::test_scale_v2_2 PASSED        [ 12%]

01:35:09 tests/acceptance/cli_test.py::CLITestCase::test_start_no_containers PASSED [ 12%]

01:35:10 tests/integration/service_test.py::ServiceTest::test_start_one_off_container_creates_links_to_its_own_service <- tests/integration/testcases.py PASSED [ 34%]

01:35:10 tests/integration/service_test.py::ServiceTest::test_build_with_illegal_leading_chars PASSED [ 24%]

01:35:10 tests/integration/service_test.py::ServiceTest::test_build_with_image_name PASSED [ 24%]

01:35:10 tests/integration/service_test.py::ServiceTest::test_build_with_isolation PASSED [ 24%]

01:35:10 tests/integration/service_test.py::ServiceTest::test_stop_signal PASSED  [ 34%]

01:35:10 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_image_volume_masks_config PASSED [ 30%]

01:35:10 tests/acceptance/cli_test.py::CLITestCase::test_up_with_net_v1 PASSED    [ 16%]

01:35:10 tests/integration/service_test.py::ServiceTest::test_tmpfs PASSED        [ 34%]

01:35:11 tests/integration/service_test.py::ServiceTest::test_userns_mode_host PASSED [ 34%]

01:35:11 tests/integration/service_test.py::ServiceTest::test_build_with_network PASSED [ 25%]

01:35:11 tests/acceptance/cli_test.py::CLITestCase::test_shorthand_host_opt PASSED [ 12%]

01:35:12 tests/integration/service_test.py::ServiceTest::test_userns_mode_none_defined PASSED [ 34%]

01:35:12 tests/integration/service_test.py::ServiceTest::test_with_high_enough_api_version_we_get_default_network_mode PASSED [ 34%]

01:35:12 tests/integration/service_test.py::ServiceTest::test_working_dir_param PASSED [ 35%]

01:35:12 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_aliases PASSED [ 16%]

01:35:12 tests/acceptance/cli_test.py::CLITestCase::test_stop PASSED              [ 12%]

01:35:12 tests/integration/environment_test.py::EnvironmentSkipFileTest::test_env_file_skip PASSED [ 17%]

01:35:12 tests/integration/network_test.py::NetworkTest::test_network_default_labels PASSED [ 17%]

01:35:12 tests/integration/network_test.py::NetworkTest::test_network_external_default_ensure PASSED [ 17%]

01:35:12 tests/integration/network_test.py::NetworkTest::test_network_external_overlay_ensure PASSED [ 17%]

01:35:12 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_image_with_volume_is_removed PASSED [ 29%]

01:35:13 tests/acceptance/cli_test.py::CLITestCase::test_shorthand_host_opt_interactive PASSED [ 12%]

01:35:13 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate PASSED [ 29%]

01:35:13 tests/integration/project_test.py::ProjectTest::test_containers PASSED   [ 17%]

01:35:13 tests/integration/service_test.py::ConfigHashTest::test_config_hash_sticks_around PASSED [ 35%]

01:35:13 tests/integration/service_test.py::ServiceTest::test_build_with_target PASSED [ 25%]

01:35:13 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_internal PASSED [ 16%]

01:35:13 tests/acceptance/cli_test.py::CLITestCase::test_start_no_containers PASSED [ 12%]

01:35:13 tests/integration/service_test.py::ConfigHashTest::test_config_hash_with_custom_labels PASSED [ 35%]

01:35:13 tests/integration/service_test.py::ConfigHashTest::test_no_config_hash_when_one_off PASSED [ 35%]

01:35:13 tests/integration/service_test.py::ServiceTest::test_cap_add_list PASSED [ 25%]

01:35:13 tests/integration/service_test.py::ConfigHashTest::test_no_config_hash_when_overriding_options PASSED [ 35%]

01:35:14 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_with_image_declared_volume PASSED [ 30%]

01:35:14 tests/integration/service_test.py::ServiceTest::test_cap_drop_list PASSED [ 25%]

01:35:14 tests/integration/project_test.py::ProjectTest::test_containers_stopped PASSED [ 17%]

01:35:14 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_change_mount_target PASSED [ 29%]

01:35:14 tests/integration/project_test.py::ProjectTest::test_containers_with_extra_service PASSED [ 17%]

01:35:14 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_labels PASSED [ 16%]

01:35:15 tests/acceptance/cli_test.py::CLITestCase::test_stop_signal PASSED       [ 12%]

01:35:15 tests/integration/service_test.py::ServiceTest::test_containers PASSED   [ 25%]

01:35:15 tests/integration/service_test.py::ServiceTest::test_containers_one_off PASSED [ 25%]

01:35:15 tests/integration/service_test.py::ServiceTest::test_create_container_with_blkio_config PASSED [ 25%]

01:35:15 tests/integration/state_test.py::BasicProjectTest::test_all_change PASSED [ 35%]

01:35:15 tests/integration/project_test.py::ProjectTest::test_containers_with_service_names PASSED [ 18%]

01:35:15 tests/integration/project_test.py::ProjectTest::test_create PASSED       [ 18%]

01:35:15 tests/integration/project_test.py::ProjectTest::test_create_strategy_always PASSED [ 18%]

01:35:16 tests/acceptance/cli_test.py::CLITestCase::test_stop PASSED              [ 12%]

01:35:16 tests/integration/project_test.py::ProjectTest::test_create_strategy_never PASSED [ 18%]

01:35:16 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_count PASSED [ 25%]

01:35:16 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_percent SKIPPED [ 25%]

01:35:16 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_twice PASSED [ 29%]

01:35:16 tests/integration/project_test.py::ProjectTest::test_create_twice PASSED [ 18%]

01:35:16 tests/integration/project_test.py::ProjectTest::test_create_with_links PASSED [ 18%]

01:35:16 tests/integration/project_test.py::ProjectTest::test_initialize_volumes PASSED [ 18%]

01:35:16 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_external_volumes <- tests/integration/testcases.py PASSED [ 18%]

01:35:16 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_inexistent_external_volume PASSED [ 18%]

01:35:16 tests/integration/state_test.py::BasicProjectTest::test_no_change PASSED [ 35%]

01:35:16 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_quota PASSED [ 25%]

01:35:17 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_rt xfail [ 25%]

01:35:17 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_mode PASSED [ 16%]

01:35:17 tests/acceptance/cli_test.py::CLITestCase::test_top_processes_running PASSED [ 12%]

01:35:17 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_set PASSED [ 26%]

01:35:18 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_shares PASSED [ 26%]

01:35:18 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_twice_with_mount PASSED [ 29%]

01:35:18 tests/integration/state_test.py::BasicProjectTest::test_partial_change PASSED [ 35%]

01:35:18 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_with_image_declared_volume_renew PASSED [ 30%]

01:35:18 tests/acceptance/cli_test.py::CLITestCase::test_top_services_not_running PASSED [ 13%]

01:35:18 tests/acceptance/cli_test.py::CLITestCase::test_stop_signal PASSED       [ 12%]

01:35:18 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpus PASSED [ 26%]

01:35:18 tests/integration/service_test.py::ServiceTest::test_create_container_with_device_cgroup_rules PASSED [ 26%]

01:35:18 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_containers_are_stopped PASSED [ 30%]

01:35:18 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_static_addresses PASSED [ 16%]

01:35:19 tests/integration/service_test.py::ServiceTest::test_create_container_with_extra_hosts_dicts PASSED [ 26%]

01:35:19 tests/integration/service_test.py::ServiceTest::test_create_container_with_extra_hosts_list PASSED [ 26%]

01:35:19 tests/integration/service_test.py::ServiceTest::test_create_container_with_healthcheck_config PASSED [ 26%]

01:35:20 tests/integration/service_test.py::ServiceTest::test_create_container_with_host_mount PASSED [ 26%]

01:35:21 tests/acceptance/cli_test.py::CLITestCase::test_top_services_running PASSED [ 13%]

01:35:21 tests/integration/service_test.py::ServiceTest::test_create_container_with_init_bool PASSED [ 26%]

01:35:21 tests/integration/service_test.py::ServiceTest::test_create_container_with_init_path XPASS [ 26%]

01:35:21 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_leaf PASSED [ 35%]

01:35:21 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_without_start PASSED [ 30%]

01:35:21 tests/integration/service_test.py::ServiceTest::test_expose_does_not_publish_ports PASSED [ 30%]

01:35:21 tests/acceptance/cli_test.py::CLITestCase::test_unpause_no_containers PASSED [ 13%]

01:35:22 tests/acceptance/cli_test.py::CLITestCase::test_top_processes_running PASSED [ 12%]

01:35:22 tests/integration/service_test.py::ServiceTest::test_create_container_with_legacy_mount PASSED [ 26%]

01:35:22 tests/acceptance/cli_test.py::CLITestCase::test_up_with_networks PASSED  [ 16%]

01:35:22 tests/acceptance/cli_test.py::CLITestCase::test_top_services_not_running PASSED [ 13%]

01:35:22 tests/integration/service_test.py::ServiceTest::test_group_add_value PASSED [ 30%]

01:35:22 tests/integration/service_test.py::ServiceTest::test_create_container_with_legacy_tmpfs_mount PASSED [ 26%]

01:35:22 tests/integration/service_test.py::ServiceTest::test_labels PASSED       [ 30%]

01:35:23 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_host_volume_is_removed PASSED [ 30%]

01:35:23 tests/integration/service_test.py::ServiceTest::test_create_container_with_mac_address PASSED [ 27%]

01:35:23 tests/integration/service_test.py::ServiceTest::test_create_container_with_one_off PASSED [ 27%]

01:35:23 tests/integration/service_test.py::ServiceTest::test_create_container_with_one_off_when_existing_container_is_running PASSED [ 27%]

01:35:23 tests/integration/service_test.py::ServiceTest::test_create_container_with_oom_kill_disable PASSED [ 27%]

01:35:23 tests/integration/service_test.py::ServiceTest::test_log_drive_empty_default_jsonfile PASSED [ 30%]

01:35:23 tests/integration/service_test.py::ServiceTest::test_log_drive_invalid SKIPPED [ 30%]

01:35:23 tests/acceptance/cli_test.py::CLITestCase::test_up_with_no_deps PASSED   [ 16%]

01:35:23 tests/integration/service_test.py::ServiceTest::test_create_container_with_pids_limit XPASS [ 27%]

01:35:24 tests/integration/service_test.py::ServiceTest::test_log_drive_none PASSED [ 31%]

01:35:24 tests/integration/service_test.py::ServiceTest::test_mem_reservation PASSED [ 31%]

01:35:24 tests/integration/service_test.py::ServiceTest::test_create_container_with_read_only_root_fs PASSED [ 27%]

01:35:24 tests/integration/service_test.py::ServiceTest::test_mem_swappiness PASSED [ 31%]

01:35:24 tests/acceptance/cli_test.py::CLITestCase::test_top_services_running PASSED [ 13%]

01:35:24 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_middle PASSED [ 35%]

01:35:24 tests/integration/service_test.py::ServiceTest::test_create_container_with_security_opt PASSED [ 27%]

01:35:25 tests/acceptance/cli_test.py::CLITestCase::test_up PASSED                [ 13%]

01:35:25 tests/integration/service_test.py::ServiceTest::test_network_mode_bridged PASSED [ 31%]

01:35:25 tests/integration/service_test.py::ServiceTest::test_create_container_with_shm_size PASSED [ 27%]

01:35:25 tests/integration/service_test.py::ServiceTest::test_network_mode_host PASSED [ 31%]

01:35:25 tests/acceptance/cli_test.py::CLITestCase::test_unpause_no_containers PASSED [ 13%]

01:35:26 tests/acceptance/cli_test.py::CLITestCase::test_up_with_no_recreate PASSED [ 16%]

01:35:26 tests/integration/service_test.py::ServiceTest::test_create_container_with_specified_volume PASSED [ 27%]

01:35:26 tests/integration/service_test.py::ServiceTest::test_create_container_with_storage_opt xfail [ 27%]

01:35:26 tests/integration/service_test.py::ServiceTest::test_network_mode_none PASSED [ 31%]

01:35:26 tests/acceptance/cli_test.py::CLITestCase::test_up_attached PASSED       [ 13%]

01:35:26 tests/integration/service_test.py::ServiceTest::test_create_container_with_tmpfs_mount PASSED [ 27%]

01:35:26 tests/integration/service_test.py::ServiceTest::test_oom_score_adj_value PASSED [ 31%]

01:35:27 tests/integration/service_test.py::ServiceTest::test_pid_mode_host PASSED [ 31%]

01:35:27 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_image_volume_masks_config PASSED [ 30%]

01:35:27 tests/integration/service_test.py::ServiceTest::test_create_container_with_tmpfs_mount_tmpfs_size PASSED [ 28%]

01:35:27 tests/acceptance/cli_test.py::CLITestCase::test_up_with_override_yaml PASSED [ 16%]

01:35:27 tests/integration/service_test.py::ServiceTest::test_pid_mode_none_defined PASSED [ 31%]

01:35:27 tests/integration/service_test.py::ServiceTest::test_create_container_with_unspecified_volume PASSED [ 28%]

01:35:28 tests/integration/service_test.py::ServiceTest::test_create_container_with_volume_driver PASSED [ 28%]

01:35:28 tests/integration/service_test.py::ServiceTest::test_port_with_explicit_interface PASSED [ 31%]

01:35:28 tests/acceptance/cli_test.py::CLITestCase::test_up PASSED                [ 13%]

01:35:28 tests/acceptance/cli_test.py::CLITestCase::test_up_detached PASSED       [ 13%]

01:35:28 tests/integration/service_test.py::ServiceTest::test_create_container_with_volume_mount PASSED [ 28%]

01:35:28 tests/integration/service_test.py::ServiceTest::test_project_is_added_to_container_name PASSED [ 31%]

01:35:29 tests/integration/service_test.py::ServiceTest::test_create_container_with_volumes_from PASSED [ 28%]

01:35:29 tests/integration/service_test.py::ServiceTest::test_create_with_image_id PASSED [ 28%]

01:35:29 tests/integration/service_test.py::ServiceTest::test_recreate_preserves_volume_with_trailing_slash PASSED [ 31%]

01:35:29 tests/acceptance/cli_test.py::CLITestCase::test_up_detached_long_form PASSED [ 13%]

01:35:30 tests/integration/service_test.py::ServiceTest::test_custom_container_name PASSED [ 28%]

01:35:30 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_middle_always_recreate_deps PASSED [ 35%]

01:35:30 tests/acceptance/cli_test.py::CLITestCase::test_up_attached PASSED       [ 13%]

01:35:30 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_with_image_declared_volume PASSED [ 30%]

01:35:30 tests/integration/service_test.py::ServiceTest::test_devices PASSED      [ 28%]

01:35:30 tests/acceptance/cli_test.py::CLITestCase::test_up_with_pid_mode PASSED  [ 17%]

01:35:31 tests/integration/service_test.py::ServiceTest::test_dns_list PASSED     [ 28%]

01:35:31 tests/acceptance/cli_test.py::CLITestCase::test_up_detached PASSED       [ 13%]

01:35:31 tests/integration/service_test.py::ServiceTest::test_dns_no_value PASSED [ 28%]

01:35:31 tests/integration/service_test.py::ServiceTest::test_dns_opt_value PASSED [ 28%]

01:35:32 tests/acceptance/cli_test.py::CLITestCase::test_up_with_timeout PASSED   [ 17%]

01:35:32 tests/integration/service_test.py::ServiceTest::test_dns_search PASSED   [ 28%]

01:35:32 tests/integration/service_test.py::ServiceTest::test_duplicate_containers PASSED [ 29%]

01:35:33 tests/integration/service_test.py::ServiceTest::test_recreate_volume_to_mount PASSED [ 32%]

01:35:33 tests/acceptance/cli_test.py::CLITestCase::test_up_external_networks PASSED [ 13%]

01:35:33 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root PASSED [ 36%]

01:35:33 tests/acceptance/cli_test.py::CLITestCase::test_up_with_volume_labels PASSED [ 17%]

01:35:33 tests/integration/service_test.py::ServiceTest::test_resolve_env PASSED  [ 32%]

01:35:33 tests/acceptance/cli_test.py::CLITestCase::test_up_detached_long_form PASSED [ 13%]

01:35:34 tests/integration/service_test.py::ServiceTest::test_duplicate_volume_trailing_slash PASSED [ 29%]

01:35:34 tests/integration/service_test.py::ServiceTest::test_restart_always_value PASSED [ 32%]

01:35:34 tests/integration/service_test.py::ServiceTest::test_restart_on_failure_value PASSED [ 32%]

01:35:34 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_with_image_declared_volume_renew PASSED [ 30%]

01:35:34 tests/integration/service_test.py::ServiceTest::test_empty_labels PASSED [ 29%]

01:35:34 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_invalid_volume_driver PASSED [ 18%]

01:35:34 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_blank_driver PASSED [ 18%]

01:35:34 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_driver <- tests/integration/testcases.py PASSED [ 18%]

01:35:34 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_driver_opts <- tests/integration/testcases.py PASSED [ 19%]

01:35:34 tests/integration/project_test.py::ProjectTest::test_net_from_container_v1 <- tests/integration/testcases.py PASSED [ 19%]

01:35:34 tests/integration/project_test.py::ProjectTest::test_net_from_service_v1 <- tests/integration/testcases.py PASSED [ 19%]

01:35:34 tests/integration/project_test.py::ProjectTest::test_network_mode_from_container <- tests/integration/testcases.py PASSED [ 19%]

01:35:35 tests/integration/service_test.py::ServiceTest::test_env_from_file_combined_with_env PASSED [ 29%]

01:35:35 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_abort_on_container_exit PASSED [ 13%]

01:35:35 tests/integration/environment_test.py::EnvironmentOverrideFileTest::test_env_file_override PASSED [ 17%]

01:35:36 tests/integration/project_test.py::ProjectTest::test_network_mode_from_service <- tests/integration/testcases.py PASSED [ 19%]

01:35:36 tests/integration/project_test.py::ProjectTest::test_parallel_pull_with_no_image PASSED [ 19%]

01:35:36 tests/acceptance/cli_test.py::CLITestCase::test_up_external_networks PASSED [ 13%]

01:35:36 tests/integration/service_test.py::ServiceTest::test_scale PASSED        [ 32%]

01:35:36 tests/integration/project_test.py::ProjectTest::test_project_up PASSED   [ 19%]

01:35:36 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_anonymous_volume_recreate_then_renew PASSED [ 29%]

01:35:36 tests/integration/service_test.py::ServiceTest::test_scale_sets_ports PASSED [ 32%]

01:35:36 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_abort_on_container_exit_code PASSED [ 13%]

01:35:37 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_without_start PASSED [ 30%]

01:35:37 tests/integration/service_test.py::ServiceTest::test_scale_with_api_error PASSED [ 32%]

01:35:37 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_anonymous_volume_renew PASSED [ 29%]

01:35:38 tests/integration/service_test.py::ServiceTest::test_scale_with_custom_container_name_outputs_warning PASSED [ 32%]

01:35:38 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_abort_on_container_exit PASSED [ 13%]

01:35:38 tests/integration/service_test.py::ServiceTest::test_expose_does_not_publish_ports PASSED [ 30%]

01:35:38 tests/integration/service_test.py::ServiceTest::test_scale_with_desired_number_already_achieved PASSED [ 32%]

01:35:38 tests/integration/environment_test.py::EnvironmentSkipFileTest::test_env_file_skip PASSED [ 17%]

01:35:38 tests/integration/network_test.py::NetworkTest::test_network_default_labels PASSED [ 17%]

01:35:38 tests/integration/network_test.py::NetworkTest::test_network_external_default_ensure PASSED [ 17%]

01:35:38 tests/integration/network_test.py::NetworkTest::test_network_external_overlay_ensure PASSED [ 17%]

01:35:38 tests/integration/service_test.py::ServiceTest::test_group_add_value PASSED [ 30%]

01:35:38 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_force_shutdown PASSED [ 13%]

01:35:39 tests/integration/service_test.py::ServiceTest::test_labels PASSED       [ 30%]

01:35:39 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_abort_on_container_exit_code PASSED [ 13%]

01:35:39 tests/integration/service_test.py::ServiceTest::test_scale_with_immediate_exit PASSED [ 32%]

01:35:39 tests/integration/service_test.py::ServiceTest::test_log_drive_empty_default_jsonfile PASSED [ 30%]

01:35:39 tests/integration/service_test.py::ServiceTest::test_log_drive_invalid SKIPPED [ 30%]

01:35:40 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root_always_recreate_deps PASSED [ 36%]

01:35:40 tests/integration/project_test.py::ProjectTest::test_containers PASSED   [ 17%]

01:35:40 tests/integration/service_test.py::ServiceTest::test_log_drive_none PASSED [ 31%]

01:35:40 tests/integration/service_test.py::ServiceTest::test_scale_with_stopped_containers PASSED [ 32%]

01:35:40 tests/integration/project_test.py::ProjectTest::test_project_up_config_scale PASSED [ 19%]

01:35:40 tests/integration/project_test.py::ProjectTest::test_containers_stopped PASSED [ 17%]

01:35:40 tests/integration/project_test.py::ProjectTest::test_containers_with_extra_service PASSED [ 17%]

01:35:41 tests/integration/service_test.py::ServiceTest::test_mem_reservation PASSED [ 31%]

01:35:41 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_sigint PASSED [ 13%]

01:35:41 tests/integration/service_test.py::ServiceTest::test_mem_swappiness PASSED [ 31%]

01:35:41 tests/integration/service_test.py::ServiceTest::test_scale_with_stopped_containers_and_needing_creation PASSED [ 33%]

01:35:41 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root_no_recreate PASSED [ 36%]

01:35:41 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_force_shutdown PASSED [ 13%]

01:35:42 tests/integration/service_test.py::ServiceTest::test_scale_with_unexpected_exception PASSED [ 33%]

01:35:42 tests/integration/project_test.py::ProjectTest::test_containers_with_service_names PASSED [ 18%]

01:35:42 tests/integration/project_test.py::ProjectTest::test_create PASSED       [ 18%]

01:35:42 tests/integration/project_test.py::ProjectTest::test_create_strategy_always PASSED [ 18%]

01:35:42 tests/integration/project_test.py::ProjectTest::test_create_strategy_never PASSED [ 18%]

01:35:42 tests/integration/service_test.py::ServiceTest::test_network_mode_bridged PASSED [ 31%]

01:35:42 tests/integration/project_test.py::ProjectTest::test_create_twice PASSED [ 18%]

01:35:42 tests/integration/service_test.py::ServiceTest::test_split_env PASSED    [ 33%]

01:35:42 tests/integration/service_test.py::ServiceTest::test_network_mode_host PASSED [ 31%]

01:35:42 tests/integration/project_test.py::ProjectTest::test_create_with_links PASSED [ 18%]

01:35:42 tests/integration/project_test.py::ProjectTest::test_initialize_volumes PASSED [ 18%]

01:35:42 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_external_volumes PASSED [ 18%]

01:35:42 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_inexistent_external_volume PASSED [ 18%]

01:35:43 tests/integration/project_test.py::ProjectTest::test_project_up_healthy_dependency PASSED [ 19%]

01:35:43 tests/integration/service_test.py::ServiceTest::test_start_container_becomes_privileged PASSED [ 33%]

01:35:43 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_sigterm PASSED [ 14%]

01:35:43 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_sigint PASSED [ 13%]

01:35:43 tests/integration/service_test.py::ServiceTest::test_network_mode_none PASSED [ 31%]

01:35:43 tests/integration/service_test.py::ServiceTest::test_oom_score_adj_value PASSED [ 31%]

01:35:44 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_image_with_volume_is_removed PASSED [ 29%]

01:35:44 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate PASSED [ 29%]

01:35:44 tests/integration/service_test.py::ServiceTest::test_pid_mode_host PASSED [ 31%]

01:35:44 tests/integration/project_test.py::ProjectTest::test_project_up_ignore_orphans PASSED [ 19%]

01:35:45 tests/integration/project_test.py::ProjectTest::test_project_up_implicit_volume_driver PASSED [ 19%]

01:35:45 tests/acceptance/cli_test.py::CLITestCase::test_up_logging PASSED        [ 14%]

01:35:45 tests/acceptance/cli_test.py::CLITestCase::test_up_handles_sigterm PASSED [ 14%]

01:35:45 tests/integration/service_test.py::ServiceTest::test_pid_mode_none_defined PASSED [ 31%]

01:35:45 tests/integration/state_test.py::ProjectWithDependenciesTest::test_service_recreated_when_dependency_created PASSED [ 36%]

01:35:45 tests/integration/service_test.py::ServiceTest::test_start_container_builds_images PASSED [ 33%]

01:35:45 tests/integration/service_test.py::ServiceTest::test_port_with_explicit_interface PASSED [ 31%]

01:35:46 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_change_mount_target PASSED [ 29%]

01:35:46 tests/integration/service_test.py::ServiceTest::test_start_container_creates_fixed_external_ports PASSED [ 33%]

01:35:46 tests/integration/project_test.py::ProjectTest::test_project_up_logging_with_multiple_files PASSED [ 20%]

01:35:46 tests/integration/service_test.py::ServiceTest::test_project_is_added_to_container_name PASSED [ 31%]

01:35:46 tests/integration/service_test.py::ServiceTest::test_start_container_creates_fixed_external_ports_when_it_is_different_to_internal_port PASSED [ 33%]

01:35:47 tests/acceptance/cli_test.py::CLITestCase::test_up_logging_legacy PASSED [ 14%]

01:35:47 tests/acceptance/cli_test.py::CLITestCase::test_up_logging PASSED        [ 14%]

01:35:47 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_twice PASSED [ 29%]

01:35:47 tests/integration/project_test.py::ProjectTest::test_project_up_name_starts_with_illegal_char <- tests/integration/testcases.py PASSED [ 20%]

01:35:48 tests/acceptance/cli_test.py::CLITestCase::test_up_missing_network PASSED [ 14%]

01:35:48 tests/integration/service_test.py::ServiceTest::test_recreate_preserves_volume_with_trailing_slash PASSED [ 31%]

01:35:48 tests/integration/service_test.py::ServiceTest::test_start_container_creates_links <- tests/integration/testcases.py PASSED [ 33%]

01:35:48 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_twice_with_mount PASSED [ 29%]

01:35:48 tests/integration/project_test.py::ProjectTest::test_project_up_named_volumes_in_binds PASSED [ 20%]

01:35:49 tests/acceptance/cli_test.py::CLITestCase::test_up_logging_legacy PASSED [ 14%]

01:35:49 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_containers_are_stopped PASSED [ 30%]

01:35:49 tests/acceptance/cli_test.py::CLITestCase::test_up_missing_network PASSED [ 14%]

01:35:49 tests/integration/service_test.py::ServiceTest::test_start_container_creates_links_with_names <- tests/integration/testcases.py PASSED [ 33%]

01:35:49 tests/integration/project_test.py::ProjectTest::test_project_up_networks PASSED [ 20%]

01:35:50 tests/integration/service_test.py::ServiceTest::test_start_container_creates_port_with_explicit_protocol PASSED [ 33%]

01:35:50 tests/acceptance/cli_test.py::CLITestCase::test_up_no_ansi PASSED        [ 14%]

01:35:50 tests/integration/project_test.py::ProjectTest::test_project_up_no_healthcheck_dependency PASSED [ 20%]

01:35:50 tests/integration/service_test.py::ServiceTest::test_start_container_creates_ports PASSED [ 33%]

01:35:50 tests/acceptance/cli_test.py::CLITestCase::test_up_no_services PASSED    [ 14%]

01:35:51 tests/integration/service_test.py::ServiceTest::test_start_container_inherits_options_from_constructor PASSED [ 34%]

01:35:51 tests/integration/service_test.py::ServiceTest::test_recreate_volume_to_mount PASSED [ 32%]

01:35:51 tests/acceptance/cli_test.py::CLITestCase::test_up_no_ansi PASSED        [ 14%]

01:35:51 tests/integration/service_test.py::ServiceTest::test_start_container_passes_through_options PASSED [ 34%]

01:35:51 tests/integration/state_test.py::ProjectWithDependenciesTest::test_service_removed_while_down PASSED [ 36%]

01:35:51 tests/integration/service_test.py::ServiceTest::test_resolve_env PASSED  [ 32%]

01:35:52 tests/integration/project_test.py::ProjectTest::test_project_up_orphans PASSED [ 20%]

01:35:52 tests/integration/service_test.py::ServiceTest::test_start_container_stays_unprivileged PASSED [ 34%]

01:35:52 tests/acceptance/cli_test.py::CLITestCase::test_up_no_services PASSED    [ 14%]

01:35:52 tests/integration/project_test.py::ProjectTest::test_project_up_port_mappings_with_multiple_files PASSED [ 20%]

01:35:52 tests/integration/state_test.py::ProjectWithDependenciesTest::test_up PASSED [ 36%]

01:35:52 tests/integration/service_test.py::ServiceTest::test_restart_always_value PASSED [ 32%]

01:35:53 tests/integration/service_test.py::ServiceTest::test_restart_on_failure_value PASSED [ 32%]

01:35:53 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_host_volume_is_removed PASSED [ 30%]

01:35:53 tests/integration/project_test.py::ProjectTest::test_project_up_recreate_with_tmpfs_volume PASSED [ 20%]

01:35:54 tests/integration/project_test.py::ProjectTest::test_project_up_seccomp_profile PASSED [ 20%]

01:35:54 tests/integration/service_test.py::ServiceTest::test_start_container_uses_tagged_image_if_it_exists PASSED [ 34%]

01:35:54 tests/acceptance/cli_test.py::CLITestCase::test_up_no_start PASSED       [ 14%]

01:35:55 tests/integration/service_test.py::ServiceTest::test_scale PASSED        [ 32%]

01:35:55 tests/acceptance/cli_test.py::CLITestCase::test_up_no_start PASSED       [ 14%]

01:35:56 tests/integration/service_test.py::ServiceTest::test_scale_sets_ports PASSED [ 32%]

01:35:56 tests/integration/project_test.py::ProjectTest::test_project_up_starts_depends PASSED [ 20%]

01:35:56 tests/integration/service_test.py::ServiceTest::test_start_container_with_external_links <- tests/integration/testcases.py PASSED [ 34%]

01:35:56 tests/integration/service_test.py::ServiceTest::test_scale_with_api_error PASSED [ 32%]

01:35:56 tests/acceptance/cli_test.py::CLITestCase::test_up_no_start_remove_orphans PASSED [ 14%]

01:35:57 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_leaf PASSED [ 36%]

01:35:57 tests/acceptance/cli_test.py::CLITestCase::test_up_no_start_remove_orphans PASSED [ 14%]

01:35:57 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_image_volume_masks_config PASSED [ 30%]

01:35:57 tests/integration/project_test.py::ProjectTest::test_project_up_starts_links PASSED [ 20%]

01:35:57 tests/integration/service_test.py::ServiceTest::test_scale_with_custom_container_name_outputs_warning PASSED [ 32%]

01:35:58 tests/integration/service_test.py::ServiceTest::test_scale_with_desired_number_already_achieved PASSED [ 32%]

01:35:58 tests/integration/service_test.py::ServiceTest::test_start_normal_container_does_not_create_links_to_its_own_service <- tests/integration/testcases.py PASSED [ 34%]

01:35:59 tests/integration/project_test.py::ProjectTest::test_project_up_starts_uncreated_services PASSED [ 21%]

01:35:59 tests/integration/service_test.py::ServiceTest::test_scale_with_immediate_exit PASSED [ 32%]

01:35:59 tests/integration/service_test.py::ServiceTest::test_start_one_off_container_creates_links_to_its_own_service <- tests/integration/testcases.py PASSED [ 34%]

01:36:00 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_middle PASSED [ 36%]

01:36:00 tests/integration/service_test.py::ServiceTest::test_stop_signal PASSED  [ 34%]

01:36:00 tests/integration/service_test.py::ServiceTest::test_tmpfs PASSED        [ 34%]

01:36:00 tests/integration/service_test.py::ServiceTest::test_scale_with_stopped_containers PASSED [ 32%]

01:36:00 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_invalid_volume_driver PASSED [ 18%]

01:36:00 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_blank_driver PASSED [ 18%]

01:36:00 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_driver PASSED [ 18%]

01:36:00 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_driver_opts PASSED [ 19%]

01:36:00 tests/integration/project_test.py::ProjectTest::test_net_from_container_v1 PASSED [ 19%]

01:36:00 tests/integration/project_test.py::ProjectTest::test_net_from_service_v1 PASSED [ 19%]

01:36:00 tests/integration/project_test.py::ProjectTest::test_network_mode_from_container PASSED [ 19%]

01:36:01 tests/integration/project_test.py::ProjectTest::test_project_up_unhealthy_dependency PASSED [ 21%]

01:36:01 tests/integration/service_test.py::ServiceTest::test_userns_mode_host PASSED [ 34%]

01:36:01 tests/integration/project_test.py::ProjectTest::test_project_up_volumes PASSED [ 21%]

01:36:01 tests/integration/service_test.py::ServiceTest::test_userns_mode_none_defined PASSED [ 34%]

01:36:01 tests/integration/service_test.py::ServiceTest::test_with_high_enough_api_version_we_get_default_network_mode PASSED [ 34%]

01:36:01 tests/integration/service_test.py::ServiceTest::test_working_dir_param PASSED [ 35%]

01:36:01 tests/integration/project_test.py::ProjectTest::test_network_mode_from_service PASSED [ 19%]

01:36:01 tests/integration/project_test.py::ProjectTest::test_parallel_pull_with_no_image PASSED [ 19%]

01:36:01 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_with_image_declared_volume PASSED [ 30%]

01:36:02 tests/integration/service_test.py::ServiceTest::test_scale_with_stopped_containers_and_needing_creation PASSED [ 33%]

01:36:02 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_reset PASSED    [ 14%]

01:36:02 tests/integration/project_test.py::ProjectTest::test_project_up PASSED   [ 19%]

01:36:02 tests/integration/service_test.py::ServiceTest::test_scale_with_unexpected_exception PASSED [ 33%]

01:36:02 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_reset PASSED    [ 14%]

01:36:03 tests/integration/service_test.py::ConfigHashTest::test_config_hash_sticks_around PASSED [ 35%]

01:36:03 tests/integration/service_test.py::ServiceTest::test_split_env PASSED    [ 33%]

01:36:03 tests/integration/service_test.py::ConfigHashTest::test_config_hash_with_custom_labels PASSED [ 35%]

01:36:03 tests/integration/project_test.py::ProjectTest::test_project_up_with_added_secrets PASSED [ 21%]

01:36:03 tests/integration/service_test.py::ConfigHashTest::test_no_config_hash_when_one_off PASSED [ 35%]

01:36:03 tests/integration/service_test.py::ConfigHashTest::test_no_config_hash_when_overriding_options PASSED [ 35%]

01:36:03 tests/integration/service_test.py::ServiceTest::test_start_container_becomes_privileged PASSED [ 33%]

01:36:04 tests/integration/project_test.py::ProjectTest::test_project_up_with_network_internal PASSED [ 21%]

01:36:04 tests/integration/project_test.py::ProjectTest::test_project_up_with_network_label PASSED [ 21%]

01:36:05 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_with_image_declared_volume_renew PASSED [ 30%]

01:36:05 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_scale_down PASSED [ 14%]

01:36:05 tests/integration/state_test.py::BasicProjectTest::test_all_change PASSED [ 35%]

01:36:05 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_middle_always_recreate_deps PASSED [ 36%]

01:36:05 tests/integration/project_test.py::ProjectTest::test_project_up_with_no_deps PASSED [ 21%]

01:36:06 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_scale_down PASSED [ 14%]

01:36:06 tests/integration/service_test.py::ServiceTest::test_start_container_builds_images PASSED [ 33%]

01:36:06 tests/integration/state_test.py::BasicProjectTest::test_no_change PASSED [ 35%]

01:36:06 tests/integration/service_test.py::ServiceTest::test_start_container_creates_fixed_external_ports PASSED [ 33%]

01:36:06 tests/integration/project_test.py::ProjectTest::test_project_up_config_scale PASSED [ 19%]

01:36:06 tests/integration/project_test.py::ProjectTest::test_project_up_with_no_recreate_running PASSED [ 21%]

01:36:07 tests/integration/service_test.py::ServiceTest::test_start_container_creates_fixed_external_ports_when_it_is_different_to_internal_port PASSED [ 33%]

01:36:07 tests/integration/state_test.py::BasicProjectTest::test_partial_change PASSED [ 35%]

01:36:08 tests/integration/project_test.py::ProjectTest::test_project_up_healthy_dependency PASSED [ 19%]

01:36:08 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_without_start PASSED [ 30%]

01:36:08 tests/integration/project_test.py::ProjectTest::test_project_up_with_no_recreate_stopped PASSED [ 21%]

01:36:08 tests/integration/service_test.py::ServiceTest::test_start_container_creates_links PASSED [ 33%]

01:36:08 tests/integration/service_test.py::ServiceTest::test_expose_does_not_publish_ports PASSED [ 30%]

01:36:09 tests/integration/service_test.py::ServiceTest::test_group_add_value PASSED [ 30%]

01:36:09 tests/integration/project_test.py::ProjectTest::test_project_up_ignore_orphans PASSED [ 19%]

01:36:09 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_scale_up PASSED [ 14%]

01:36:09 tests/integration/project_test.py::ProjectTest::test_project_up_with_secrets PASSED [ 21%]

01:36:09 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root PASSED [ 36%]

01:36:09 tests/integration/service_test.py::ServiceTest::test_labels PASSED       [ 30%]

01:36:10 tests/integration/project_test.py::ProjectTest::test_project_up_implicit_volume_driver PASSED [ 19%]

01:36:10 tests/integration/service_test.py::ServiceTest::test_log_drive_empty_default_jsonfile PASSED [ 30%]

01:36:10 tests/integration/service_test.py::ServiceTest::test_log_drive_invalid SKIPPED [ 30%]

01:36:10 tests/integration/project_test.py::ProjectTest::test_project_up_with_volume_labels PASSED [ 21%]

01:36:10 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_scale_up PASSED [ 14%]

01:36:10 tests/integration/service_test.py::ServiceTest::test_start_container_creates_links_with_names PASSED [ 33%]

01:36:10 tests/integration/service_test.py::ServiceTest::test_log_drive_none PASSED [ 31%]

01:36:11 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_leaf PASSED [ 35%]

01:36:11 tests/integration/service_test.py::ServiceTest::test_mem_reservation PASSED [ 31%]

01:36:11 tests/integration/project_test.py::ProjectTest::test_project_up_logging_with_multiple_files PASSED [ 20%]

01:36:11 tests/integration/service_test.py::ServiceTest::test_start_container_creates_port_with_explicit_protocol PASSED [ 33%]

01:36:11 tests/integration/service_test.py::ServiceTest::test_mem_swappiness PASSED [ 31%]

01:36:12 tests/integration/project_test.py::ProjectTest::test_project_up_without_all_services PASSED [ 21%]

01:36:12 tests/integration/service_test.py::ServiceTest::test_start_container_creates_ports PASSED [ 33%]

01:36:12 tests/integration/service_test.py::ServiceTest::test_network_mode_bridged PASSED [ 31%]

01:36:12 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_to_zero PASSED  [ 15%]

01:36:12 tests/integration/service_test.py::ServiceTest::test_network_mode_host PASSED [ 31%]

01:36:12 tests/integration/service_test.py::ServiceTest::test_start_container_inherits_options_from_constructor PASSED [ 34%]

01:36:12 tests/integration/project_test.py::ProjectTest::test_project_up_name_starts_with_illegal_char PASSED [ 20%]

01:36:12 tests/integration/service_test.py::ServiceTest::test_network_mode_none PASSED [ 31%]

01:36:13 tests/integration/service_test.py::ServiceTest::test_start_container_passes_through_options PASSED [ 34%]

01:36:13 tests/integration/project_test.py::ProjectTest::test_project_up_named_volumes_in_binds PASSED [ 20%]

01:36:13 tests/integration/project_test.py::ProjectTest::test_recreate_preserves_mounts PASSED [ 22%]

01:36:13 tests/integration/service_test.py::ServiceTest::test_oom_score_adj_value PASSED [ 31%]

01:36:13 tests/acceptance/cli_test.py::CLITestCase::test_up_scale_to_zero PASSED  [ 15%]

01:36:14 tests/integration/service_test.py::ServiceTest::test_pid_mode_host PASSED [ 31%]

01:36:14 tests/integration/service_test.py::ServiceTest::test_start_container_stays_unprivileged PASSED [ 34%]

01:36:14 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_middle PASSED [ 35%]

01:36:14 tests/acceptance/cli_test.py::CLITestCase::test_up_with_default_network_config PASSED [ 15%]

01:36:14 tests/integration/project_test.py::ProjectTest::test_project_up_networks PASSED [ 20%]

01:36:14 tests/integration/service_test.py::ServiceTest::test_pid_mode_none_defined PASSED [ 31%]

01:36:15 tests/integration/project_test.py::ProjectTest::test_project_up_no_healthcheck_dependency PASSED [ 20%]

01:36:15 tests/integration/service_test.py::ServiceTest::test_port_with_explicit_interface PASSED [ 31%]

01:36:15 tests/integration/project_test.py::ProjectTest::test_recreate_preserves_volumes PASSED [ 22%]

01:36:15 tests/integration/service_test.py::ServiceTest::test_project_is_added_to_container_name PASSED [ 31%]

01:36:16 tests/integration/project_test.py::ProjectTest::test_project_up_orphans PASSED [ 20%]

01:36:16 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root_always_recreate_deps PASSED [ 36%]

01:36:16 tests/acceptance/cli_test.py::CLITestCase::test_up_with_default_network_config PASSED [ 15%]

01:36:16 tests/integration/service_test.py::ServiceTest::test_start_container_uses_tagged_image_if_it_exists PASSED [ 34%]

01:36:16 tests/integration/service_test.py::ServiceTest::test_recreate_preserves_volume_with_trailing_slash PASSED [ 31%]

01:36:17 tests/acceptance/cli_test.py::CLITestCase::test_up_with_default_override_file PASSED [ 15%]

01:36:17 tests/acceptance/cli_test.py::CLITestCase::test_up_with_duplicate_override_yaml_files PASSED [ 15%]

01:36:17 tests/integration/project_test.py::ProjectTest::test_project_up_port_mappings_with_multiple_files PASSED [ 20%]

01:36:17 tests/integration/project_test.py::ProjectTest::test_start_pause_unpause_stop_kill_remove PASSED [ 22%]

01:36:18 tests/integration/project_test.py::ProjectTest::test_project_up_recreate_with_tmpfs_volume PASSED [ 20%]

01:36:18 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root_no_recreate PASSED [ 36%]

01:36:18 tests/integration/project_test.py::ProjectTest::test_project_up_seccomp_profile PASSED [ 20%]

01:36:18 tests/acceptance/cli_test.py::CLITestCase::test_up_with_extends PASSED   [ 15%]

01:36:18 tests/acceptance/cli_test.py::CLITestCase::test_up_with_default_override_file PASSED [ 15%]

01:36:18 tests/acceptance/cli_test.py::CLITestCase::test_up_with_duplicate_override_yaml_files PASSED [ 15%]

01:36:19 tests/integration/service_test.py::ServiceTest::test_start_container_with_external_links PASSED [ 34%]

01:36:19 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_middle_always_recreate_deps PASSED [ 35%]

01:36:20 tests/integration/service_test.py::ServiceTest::test_recreate_volume_to_mount PASSED [ 32%]

01:36:20 tests/integration/project_test.py::ProjectTest::test_unscale_after_restart PASSED [ 22%]

01:36:20 tests/integration/service_test.py::ServiceTest::test_resolve_env PASSED  [ 32%]

01:36:20 tests/integration/project_test.py::ProjectTest::test_up_with_custom_name_resources PASSED [ 22%]

01:36:20 tests/integration/project_test.py::ProjectTest::test_project_up_starts_depends PASSED [ 20%]

01:36:20 tests/acceptance/cli_test.py::CLITestCase::test_up_with_extends PASSED   [ 15%]

01:36:20 tests/integration/service_test.py::ServiceTest::test_restart_always_value PASSED [ 32%]

01:36:21 tests/integration/service_test.py::ServiceTest::test_start_normal_container_does_not_create_links_to_its_own_service PASSED [ 34%]

01:36:21 tests/acceptance/cli_test.py::CLITestCase::test_up_with_external_default_network PASSED [ 15%]

01:36:21 tests/integration/service_test.py::ServiceTest::test_restart_on_failure_value PASSED [ 32%]

01:36:21 tests/integration/project_test.py::ProjectTest::test_up_with_enable_ipv6 PASSED [ 22%]

01:36:21 tests/integration/project_test.py::ProjectTest::test_up_with_invalid_isolation PASSED [ 22%]

01:36:21 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_dependency_added PASSED [ 37%]

01:36:21 tests/integration/project_test.py::ProjectTest::test_project_up_starts_links PASSED [ 20%]

01:36:21 tests/integration/project_test.py::ProjectTest::test_up_with_invalid_runtime PASSED [ 22%]

01:36:22 tests/integration/project_test.py::ProjectTest::test_up_with_ipam_config PASSED [ 22%]

01:36:22 tests/integration/project_test.py::ProjectTest::test_project_up_starts_uncreated_services PASSED [ 21%]

01:36:22 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root PASSED [ 36%]

01:36:22 tests/integration/service_test.py::ServiceTest::test_scale PASSED        [ 32%]

01:36:23 tests/integration/service_test.py::ServiceTest::test_start_one_off_container_creates_links_to_its_own_service PASSED [ 34%]

01:36:23 tests/integration/project_test.py::ProjectTest::test_up_with_ipam_options PASSED [ 22%]

01:36:23 tests/integration/service_test.py::ServiceTest::test_stop_signal PASSED  [ 34%]

01:36:23 tests/integration/service_test.py::ServiceTest::test_scale_sets_ports PASSED [ 32%]

01:36:23 tests/integration/project_test.py::ProjectTest::test_up_with_isolation PASSED [ 22%]

01:36:24 tests/acceptance/cli_test.py::CLITestCase::test_up_with_external_default_network PASSED [ 15%]

01:36:24 tests/integration/service_test.py::ServiceTest::test_scale_with_api_error PASSED [ 32%]

01:36:24 tests/integration/project_test.py::ProjectTest::test_up_with_network_link_local_ips PASSED [ 23%]

01:36:24 tests/integration/service_test.py::ServiceTest::test_tmpfs PASSED        [ 34%]

01:36:24 tests/integration/project_test.py::ProjectTest::test_project_up_unhealthy_dependency PASSED [ 21%]

01:36:24 tests/acceptance/cli_test.py::CLITestCase::test_up_with_force_recreate PASSED [ 15%]

01:36:24 tests/integration/service_test.py::ServiceTest::test_scale_with_custom_container_name_outputs_warning PASSED [ 32%]

01:36:25 tests/integration/project_test.py::ProjectTest::test_project_up_volumes PASSED [ 21%]

01:36:25 tests/integration/service_test.py::ServiceTest::test_userns_mode_host PASSED [ 34%]

01:36:25 tests/acceptance/cli_test.py::CLITestCase::test_up_with_force_recreate_and_no_recreate PASSED [ 15%]

01:36:25 tests/integration/service_test.py::ServiceTest::test_scale_with_desired_number_already_achieved PASSED [ 32%]

01:36:25 tests/integration/service_test.py::ServiceTest::test_userns_mode_none_defined PASSED [ 34%]

01:36:25 tests/integration/service_test.py::ServiceTest::test_with_high_enough_api_version_we_get_default_network_mode PASSED [ 34%]

01:36:25 tests/integration/service_test.py::ServiceTest::test_working_dir_param PASSED [ 35%]

01:36:26 tests/integration/service_test.py::ServiceTest::test_scale_with_immediate_exit PASSED [ 32%]

01:36:26 tests/integration/service_test.py::ServiceTest::test_scale_with_stopped_containers PASSED [ 32%]

01:36:27 tests/integration/project_test.py::ProjectTest::test_project_up_with_added_secrets PASSED [ 21%]

01:36:27 tests/integration/project_test.py::ProjectTest::test_project_up_with_network_internal PASSED [ 21%]

01:36:27 tests/integration/service_test.py::ConfigHashTest::test_config_hash_sticks_around PASSED [ 35%]

01:36:27 tests/acceptance/cli_test.py::CLITestCase::test_up_with_force_recreate PASSED [ 15%]

01:36:27 tests/integration/project_test.py::ProjectTest::test_up_with_network_priorities PASSED [ 23%]

01:36:27 tests/integration/service_test.py::ConfigHashTest::test_config_hash_with_custom_labels PASSED [ 35%]

01:36:27 tests/integration/service_test.py::ConfigHashTest::test_no_config_hash_when_one_off PASSED [ 35%]

01:36:27 tests/integration/service_test.py::ConfigHashTest::test_no_config_hash_when_overriding_options PASSED [ 35%]

01:36:27 tests/integration/service_test.py::ServiceTest::test_scale_with_stopped_containers_and_needing_creation PASSED [ 33%]

01:36:28 tests/acceptance/cli_test.py::CLITestCase::test_up_with_force_recreate_and_no_recreate PASSED [ 15%]

01:36:28 tests/integration/project_test.py::ProjectTest::test_project_up_with_network_label PASSED [ 21%]

01:36:28 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_dependency_removed PASSED [ 37%]

01:36:28 tests/integration/service_test.py::ServiceTest::test_scale_with_unexpected_exception PASSED [ 33%]

01:36:28 tests/integration/project_test.py::ProjectTest::test_up_with_network_static_addresses PASSED [ 23%]

01:36:28 tests/integration/project_test.py::ProjectTest::test_up_with_network_static_addresses_missing_subnet PASSED [ 23%]

01:36:28 tests/integration/project_test.py::ProjectTest::test_up_with_nvidia_runtime <- tests/integration/testcases.py SKIPPED [ 23%]

01:36:28 tests/integration/project_test.py::ProjectTest::test_project_up_with_no_deps PASSED [ 21%]

01:36:29 tests/integration/service_test.py::ServiceTest::test_split_env PASSED    [ 33%]

01:36:29 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root_always_recreate_deps PASSED [ 36%]

01:36:29 tests/integration/service_test.py::ServiceTest::test_start_container_becomes_privileged PASSED [ 33%]

01:36:29 tests/integration/project_test.py::ProjectTest::test_up_with_runtime <- tests/integration/testcases.py PASSED [ 23%]

01:36:29 tests/integration/project_test.py::ProjectTest::test_volumes_from_container PASSED [ 23%]

01:36:29 tests/integration/project_test.py::ProjectTest::test_volumes_from_service PASSED [ 23%]

01:36:30 tests/integration/project_test.py::ProjectTest::test_project_up_with_no_recreate_running PASSED [ 21%]

01:36:30 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root_no_recreate PASSED [ 36%]

01:36:30 tests/integration/state_test.py::BasicProjectTest::test_all_change PASSED [ 35%]

01:36:31 tests/integration/resilience_test.py::ResilienceTest::test_create_failure PASSED [ 23%]

01:36:31 tests/integration/state_test.py::BasicProjectTest::test_no_change PASSED [ 35%]

01:36:31 tests/integration/project_test.py::ProjectTest::test_project_up_with_no_recreate_stopped PASSED [ 21%]

01:36:31 tests/integration/resilience_test.py::ResilienceTest::test_start_failure PASSED [ 23%]

01:36:32 tests/integration/service_test.py::ServiceTest::test_start_container_builds_images PASSED [ 33%]

01:36:32 tests/integration/service_test.py::ServiceTest::test_start_container_creates_fixed_external_ports PASSED [ 33%]

01:36:32 tests/integration/project_test.py::ProjectTest::test_project_up_with_secrets PASSED [ 21%]

01:36:32 tests/integration/service_test.py::ServiceTest::test_start_container_creates_fixed_external_ports_when_it_is_different_to_internal_port PASSED [ 33%]

01:36:33 tests/integration/project_test.py::ProjectTest::test_project_up_with_volume_labels PASSED [ 21%]

01:36:33 tests/integration/state_test.py::BasicProjectTest::test_partial_change PASSED [ 35%]

01:36:33 tests/integration/resilience_test.py::ResilienceTest::test_successful_recreate PASSED [ 23%]

01:36:33 tests/integration/service_test.py::ServiceTest::test_build PASSED        [ 23%]

01:36:33 tests/acceptance/cli_test.py::CLITestCase::test_up_with_healthcheck PASSED [ 15%]

01:36:33 tests/acceptance/cli_test.py::CLITestCase::test_up_with_ignore_remove_orphans PASSED [ 15%]

01:36:33 tests/integration/state_test.py::ProjectWithDependenciesTest::test_service_recreated_when_dependency_created PASSED [ 36%]

01:36:33 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_service_removed_while_down PASSED [ 37%]

01:36:33 tests/integration/service_test.py::ServiceTest::test_build_non_ascii_filename PASSED [ 24%]

01:36:33 tests/integration/project_test.py::ProjectTest::test_project_up_without_all_services PASSED [ 21%]

01:36:34 tests/integration/service_test.py::ServiceTest::test_start_container_creates_links PASSED [ 33%]

01:36:35 tests/integration/project_test.py::ProjectTest::test_recreate_preserves_mounts PASSED [ 22%]

01:36:35 tests/integration/service_test.py::ServiceTest::test_build_with_build_args PASSED [ 24%]

01:36:35 tests/acceptance/cli_test.py::CLITestCase::test_up_with_links_v1 PASSED  [ 15%]

01:36:35 tests/integration/service_test.py::ServiceTest::test_start_container_creates_links_with_names PASSED [ 33%]

01:36:36 tests/acceptance/cli_test.py::CLITestCase::test_up_with_healthcheck PASSED [ 15%]

01:36:36 tests/integration/service_test.py::ServiceTest::test_start_container_creates_port_with_explicit_protocol PASSED [ 33%]

01:36:36 tests/integration/service_test.py::ServiceTest::test_start_container_creates_ports PASSED [ 33%]

01:36:37 tests/acceptance/cli_test.py::CLITestCase::test_up_with_ignore_remove_orphans PASSED [ 15%]

01:36:37 tests/integration/project_test.py::ProjectTest::test_recreate_preserves_volumes PASSED [ 22%]

01:36:37 tests/integration/service_test.py::ServiceTest::test_start_container_inherits_options_from_constructor PASSED [ 34%]

01:36:37 tests/integration/service_test.py::ServiceTest::test_build_with_build_args_override PASSED [ 24%]

01:36:37 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_leaf PASSED [ 35%]

01:36:37 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_service_removed_while_up PASSED [ 37%]

01:36:37 tests/integration/service_test.py::ServiceTest::test_start_container_passes_through_options PASSED [ 34%]

01:36:38 tests/acceptance/cli_test.py::CLITestCase::test_up_with_multiple_files PASSED [ 15%]

01:36:38 tests/integration/service_test.py::ServiceTest::test_start_container_stays_unprivileged PASSED [ 34%]

01:36:38 tests/integration/service_test.py::ServiceTest::test_build_with_build_labels PASSED [ 24%]

01:36:38 tests/integration/service_test.py::ServiceTest::test_build_with_cachefrom PASSED [ 24%]

01:36:38 tests/integration/project_test.py::ProjectTest::test_start_pause_unpause_stop_kill_remove PASSED [ 22%]

01:36:38 tests/acceptance/cli_test.py::CLITestCase::test_up_with_links_v1 PASSED  [ 15%]

01:36:39 tests/acceptance/cli_test.py::CLITestCase::test_up_with_net_is_invalid PASSED [ 16%]

01:36:39 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_up PASSED [ 37%]

01:36:40 tests/integration/state_test.py::ProjectWithDependenciesTest::test_service_removed_while_down PASSED [ 36%]

01:36:40 tests/integration/service_test.py::ServiceTest::test_build_with_extra_hosts PASSED [ 24%]

01:36:40 tests/acceptance/cli_test.py::CLITestCase::test_up_with_net_v1 <- tests/integration/testcases.py PASSED [ 16%]

01:36:40 tests/integration/state_test.py::ServiceStateTest::test_image_changed_to_build PASSED [ 37%]

01:36:40 tests/integration/state_test.py::ServiceStateTest::test_trigger_create PASSED [ 37%]

01:36:40 tests/integration/service_test.py::ServiceTest::test_start_container_uses_tagged_image_if_it_exists PASSED [ 34%]

01:36:40 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_middle PASSED [ 35%]

01:36:41 tests/integration/state_test.py::ProjectWithDependenciesTest::test_up PASSED [ 36%]

01:36:41 tests/integration/service_test.py::ServiceTest::test_build_with_git_url PASSED [ 24%]

01:36:41 tests/integration/state_test.py::ServiceStateTest::test_trigger_noop PASSED [ 37%]

01:36:41 tests/integration/project_test.py::ProjectTest::test_unscale_after_restart PASSED [ 22%]

01:36:41 tests/integration/project_test.py::ProjectTest::test_up_with_custom_name_resources PASSED [ 22%]

01:36:42 tests/acceptance/cli_test.py::CLITestCase::test_up_with_multiple_files PASSED [ 15%]

01:36:42 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_aliases PASSED [ 16%]

01:36:42 tests/integration/service_test.py::ServiceTest::test_start_container_with_external_links PASSED [ 34%]

01:36:42 tests/acceptance/cli_test.py::CLITestCase::test_up_with_net_is_invalid PASSED [ 16%]

01:36:42 tests/integration/project_test.py::ProjectTest::test_up_with_enable_ipv6 PASSED [ 22%]

01:36:42 tests/integration/project_test.py::ProjectTest::test_up_with_invalid_isolation PASSED [ 22%]

01:36:43 tests/integration/project_test.py::ProjectTest::test_up_with_invalid_runtime PASSED [ 22%]

01:36:43 tests/integration/project_test.py::ProjectTest::test_up_with_ipam_config PASSED [ 22%]

01:36:43 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_internal PASSED [ 16%]

01:36:43 tests/integration/service_test.py::ServiceTest::test_build_with_gzip PASSED [ 24%]

01:36:43 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_build <- tests/integration/testcases.py PASSED [ 37%]

01:36:43 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_config_change PASSED [ 37%]

01:36:44 tests/integration/service_test.py::ServiceTest::test_start_normal_container_does_not_create_links_to_its_own_service PASSED [ 34%]

01:36:44 tests/integration/service_test.py::ServiceTest::test_build_with_illegal_leading_chars PASSED [ 24%]

01:36:44 tests/integration/service_test.py::ServiceTest::test_build_with_image_name PASSED [ 24%]

01:36:44 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_image_change PASSED [ 37%]

01:36:44 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_nonexistent_image_tag PASSED [ 38%]

01:36:44 tests/integration/service_test.py::ServiceTest::test_build_with_isolation PASSED [ 24%]

01:36:44 tests/integration/project_test.py::ProjectTest::test_up_with_ipam_options PASSED [ 22%]

01:36:44 tests/acceptance/cli_test.py::CLITestCase::test_up_with_net_v1 PASSED    [ 16%]

01:36:45 tests/integration/project_test.py::ProjectTest::test_up_with_isolation PASSED [ 22%]

01:36:45 tests/integration/state_test.py::ServiceStateTest::test_trigger_start PASSED [ 38%]

01:36:45 tests/integration/volume_test.py::VolumeTest::test_create_volume PASSED  [ 38%]

01:36:45 tests/integration/volume_test.py::VolumeTest::test_create_volume_custom_name PASSED [ 38%]

01:36:45 tests/integration/volume_test.py::VolumeTest::test_exists <- tests/integration/testcases.py PASSED [ 38%]

01:36:45 tests/integration/volume_test.py::VolumeTest::test_exists_external <- tests/integration/testcases.py PASSED [ 38%]

01:36:45 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_leaf PASSED [ 36%]

01:36:45 tests/integration/service_test.py::ServiceTest::test_build_with_network <- tests/integration/testcases.py PASSED [ 25%]

01:36:45 tests/integration/volume_test.py::VolumeTest::test_exists_external_aliased <- tests/integration/testcases.py PASSED [ 38%]

01:36:45 tests/integration/volume_test.py::VolumeTest::test_external_aliased_volume <- tests/integration/testcases.py PASSED [ 38%]

01:36:45 tests/integration/volume_test.py::VolumeTest::test_external_volume <- tests/integration/testcases.py PASSED [ 38%]

01:36:45 tests/integration/volume_test.py::VolumeTest::test_inspect_volume <- tests/integration/testcases.py PASSED [ 38%]

01:36:45 tests/integration/volume_test.py::VolumeTest::test_recreate_existing_volume PASSED [ 38%]

01:36:45 tests/integration/volume_test.py::VolumeTest::test_remove_volume <- tests/integration/testcases.py PASSED [ 39%]

01:36:45 tests/integration/volume_test.py::VolumeTest::test_volume_default_labels <- tests/integration/testcases.py PASSED [ 39%]

01:36:45 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_labels PASSED [ 16%]

01:36:45 tests/integration/project_test.py::ProjectTest::test_up_with_network_link_local_ips PASSED [ 23%]

01:36:45 tests/integration/service_test.py::ServiceTest::test_start_one_off_container_creates_links_to_its_own_service PASSED [ 34%]

01:36:45 tests/unit/bundle_test.py::test_get_image_digest_exists PASSED           [ 39%]

01:36:46 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_middle_always_recreate_deps PASSED [ 35%]

01:36:46 tests/integration/service_test.py::ServiceTest::test_stop_signal PASSED  [ 34%]

01:36:46 tests/unit/bundle_test.py::test_get_image_digest_image_uses_digest PASSED [ 39%]

01:36:46 tests/unit/bundle_test.py::test_get_image_digest_from_repository PASSED  [ 39%]

01:36:46 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_aliases PASSED [ 16%]

01:36:46 tests/integration/service_test.py::ServiceTest::test_tmpfs PASSED        [ 34%]

01:36:47 tests/unit/bundle_test.py::test_get_image_digest_no_image PASSED         [ 39%]

01:36:47 tests/integration/service_test.py::ServiceTest::test_build_with_target <- tests/integration/testcases.py PASSED [ 25%]

01:36:47 tests/integration/service_test.py::ServiceTest::test_userns_mode_host PASSED [ 34%]

01:36:47 tests/unit/bundle_test.py::test_push_image_with_saved_digest PASSED      [ 39%]

01:36:47 tests/integration/service_test.py::ServiceTest::test_userns_mode_none_defined PASSED [ 34%]

01:36:47 tests/integration/service_test.py::ServiceTest::test_with_high_enough_api_version_we_get_default_network_mode PASSED [ 34%]

01:36:47 tests/integration/service_test.py::ServiceTest::test_working_dir_param PASSED [ 35%]

01:36:47 tests/integration/service_test.py::ServiceTest::test_cap_add_list PASSED [ 25%]

01:36:47 tests/unit/bundle_test.py::test_push_image PASSED                        [ 39%]

01:36:47 tests/unit/bundle_test.py::test_to_bundle PASSED                         [ 39%]

01:36:47 tests/unit/bundle_test.py::test_convert_service_to_bundle PASSED         [ 39%]

01:36:47 tests/unit/bundle_test.py::test_set_command_and_args_none PASSED         [ 39%]

01:36:47 tests/unit/bundle_test.py::test_set_command_and_args_from_command PASSED [ 39%]

01:36:47 tests/unit/bundle_test.py::test_set_command_and_args_from_entrypoint PASSED [ 40%]

01:36:47 tests/unit/bundle_test.py::test_set_command_and_args_from_both PASSED    [ 40%]

01:36:47 tests/unit/bundle_test.py::test_make_service_networks_default PASSED     [ 40%]

01:36:47 tests/unit/bundle_test.py::test_make_service_networks PASSED             [ 40%]

01:36:47 tests/unit/bundle_test.py::test_make_port_specs PASSED                   [ 40%]

01:36:47 tests/unit/bundle_test.py::test_make_port_spec_with_protocol PASSED      [ 40%]

01:36:47 tests/unit/bundle_test.py::test_make_port_spec_default_protocol PASSED   [ 40%]

01:36:47 tests/unit/cli_test.py::CLITestCase::test_command_help PASSED            [ 40%]

01:36:47 tests/unit/cli_test.py::CLITestCase::test_command_help_nonexistent PASSED [ 40%]

01:36:47 tests/unit/cli_test.py::CLITestCase::test_command_manual_and_service_ports_together PASSED [ 40%]

01:36:47 tests/unit/cli_test.py::CLITestCase::test_default_project_name PASSED    [ 40%]

01:36:47 tests/unit/cli_test.py::CLITestCase::test_get_project PASSED             [ 41%]

01:36:47 tests/unit/cli_test.py::CLITestCase::test_project_name_from_environment_new_var PASSED [ 41%]

01:36:47 tests/unit/cli_test.py::CLITestCase::test_project_name_with_empty_environment_var PASSED [ 41%]

01:36:47 tests/unit/cli_test.py::CLITestCase::test_project_name_with_environment_file PASSED [ 41%]

01:36:47 tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_base_dir PASSED [ 41%]

01:36:47 tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_project_name PASSED [ 41%]

01:36:47 tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_uppercase_base_dir PASSED [ 41%]

01:36:48 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_mode <- tests/integration/testcases.py PASSED [ 16%]

01:36:48 tests/unit/cli_test.py::CLITestCase::test_run_interactive_passes_logs_false PASSED [ 41%]

01:36:48 tests/unit/cli_test.py::CLITestCase::test_run_service_with_restart_always PASSED [ 41%]

01:36:48 tests/unit/container_test.py::ContainerTest::test_environment PASSED     [ 41%]

01:36:48 tests/unit/container_test.py::ContainerTest::test_from_ps PASSED         [ 41%]

01:36:48 tests/unit/container_test.py::ContainerTest::test_from_ps_prefixed PASSED [ 42%]

01:36:48 tests/unit/container_test.py::ContainerTest::test_get PASSED             [ 42%]

01:36:48 tests/unit/container_test.py::ContainerTest::test_get_local_port PASSED  [ 42%]

01:36:48 tests/unit/container_test.py::ContainerTest::test_has_api_logs PASSED    [ 42%]

01:36:48 tests/unit/container_test.py::ContainerTest::test_human_readable_ports_none PASSED [ 42%]

01:36:48 tests/unit/container_test.py::ContainerTest::test_human_readable_ports_public_and_private PASSED [ 42%]

01:36:48 tests/unit/container_test.py::ContainerTest::test_human_readable_states_healthy PASSED [ 42%]

01:36:48 tests/unit/container_test.py::ContainerTest::test_human_readable_states_no_health PASSED [ 42%]

01:36:48 tests/unit/container_test.py::ContainerTest::test_human_readable_states_starting PASSED [ 42%]

01:36:48 tests/integration/service_test.py::ServiceTest::test_cap_drop_list PASSED [ 25%]

01:36:48 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_internal PASSED [ 16%]

01:36:48 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_middle PASSED [ 36%]

01:36:48 tests/unit/container_test.py::ContainerTest::test_inspect_if_not_inspected PASSED [ 42%]

01:36:48 tests/unit/container_test.py::ContainerTest::test_name PASSED            [ 42%]

01:36:48 tests/unit/container_test.py::ContainerTest::test_name_without_project PASSED [ 42%]

01:36:48 tests/unit/container_test.py::ContainerTest::test_name_without_project_custom_container_name PASSED [ 43%]

01:36:48 tests/unit/container_test.py::ContainerTest::test_name_without_project_one_off PASSED [ 43%]

01:36:48 tests/unit/container_test.py::ContainerTest::test_number PASSED          [ 43%]

01:36:48 tests/unit/container_test.py::ContainerTest::test_short_id PASSED        [ 43%]

01:36:48 tests/unit/container_test.py::GetContainerNameTestCase::test_get_container_name PASSED [ 43%]

01:36:48 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_driver_mismatch PASSED [ 43%]

01:36:48 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_null_remote PASSED [ 43%]

01:36:48 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_null_remote_ipam_options PASSED [ 43%]

01:36:48 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_options_mismatch PASSED [ 43%]

01:36:48 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_success PASSED [ 43%]

01:36:48 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_whitelist PASSED [ 43%]

01:36:48 tests/unit/network_test.py::NetworkTest::test_check_remote_network_labels_mismatch PASSED [ 44%]

01:36:48 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute PASSED  [ 44%]

01:36:48 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_deps PASSED [ 44%]

01:36:48 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_global_limit PASSED [ 44%]

01:36:48 tests/integration/service_test.py::ConfigHashTest::test_config_hash_sticks_around PASSED [ 35%]

01:36:48 tests/integration/project_test.py::ProjectTest::test_up_with_network_priorities PASSED [ 23%]

01:36:48 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_limit PASSED [ 44%]

01:36:48 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_upstream_errors PASSED [ 44%]

01:36:48 tests/unit/parallel_test.py::test_parallel_execute_alignment PASSED      [ 44%]

01:36:48 tests/unit/parallel_test.py::test_parallel_execute_ansi PASSED           [ 44%]

01:36:48 tests/unit/parallel_test.py::test_parallel_execute_noansi PASSED         [ 44%]

01:36:48 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_get_digest_from_pull PASSED [ 44%]

01:36:48 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_get_digest_from_push PASSED [ 44%]

01:36:48 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_mismatched_encoding_stream_write PASSED [ 44%]

01:36:48 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output PASSED [ 45%]

01:36:48 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_div_zero PASSED [ 45%]

01:36:48 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_no_progress_event_no_tty PASSED [ 45%]

01:36:48 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_null_total PASSED [ 45%]

01:36:48 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_progress_event_no_tty PASSED [ 45%]

01:36:48 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_progress_event_tty PASSED [ 45%]

01:36:49 tests/integration/project_test.py::ProjectTest::test_up_with_network_static_addresses PASSED [ 23%]

01:36:49 tests/unit/project_test.py::ProjectTest::test_avoid_multiple_push PASSED [ 45%]

01:36:49 tests/integration/service_test.py::ConfigHashTest::test_config_hash_with_custom_labels PASSED [ 35%]

01:36:49 tests/integration/service_test.py::ConfigHashTest::test_no_config_hash_when_one_off PASSED [ 35%]

01:36:49 tests/integration/service_test.py::ConfigHashTest::test_no_config_hash_when_overriding_options PASSED [ 35%]

01:36:49 tests/integration/project_test.py::ProjectTest::test_up_with_network_static_addresses_missing_subnet PASSED [ 23%]

01:36:49 tests/integration/project_test.py::ProjectTest::test_up_with_nvidia_runtime SKIPPED [ 23%]

01:36:49 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_static_addresses PASSED [ 16%]

01:36:49 tests/unit/project_test.py::ProjectTest::test_build_container_operation_with_timeout_func_does_not_mutate_options_with_timeout PASSED [ 45%]

01:36:49 tests/unit/project_test.py::ProjectTest::test_container_without_name PASSED [ 45%]

01:36:49 tests/unit/project_test.py::ProjectTest::test_down_with_no_resources PASSED [ 45%]

01:36:49 tests/integration/project_test.py::ProjectTest::test_up_with_runtime PASSED [ 23%]

01:36:49 tests/integration/project_test.py::ProjectTest::test_volumes_from_container PASSED [ 23%]

01:36:49 tests/integration/project_test.py::ProjectTest::test_volumes_from_service PASSED [ 23%]

01:36:50 tests/integration/service_test.py::ServiceTest::test_containers PASSED   [ 25%]

01:36:50 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root PASSED [ 36%]

01:36:50 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_labels PASSED [ 16%]

01:36:50 tests/unit/project_test.py::ProjectTest::test_error_parallel_pull PASSED [ 45%]

01:36:50 tests/integration/service_test.py::ServiceTest::test_containers_one_off PASSED [ 25%]

01:36:50 tests/integration/service_test.py::ServiceTest::test_create_container_with_blkio_config PASSED [ 25%]

01:36:50 tests/unit/project_test.py::ProjectTest::test_events PASSED              [ 46%]

01:36:51 tests/unit/project_test.py::ProjectTest::test_events_legacy PASSED       [ 46%]

01:36:51 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_count PASSED [ 25%]

01:36:51 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_percent SKIPPED [ 25%]

01:36:51 tests/integration/state_test.py::BasicProjectTest::test_all_change PASSED [ 35%]

01:36:51 tests/unit/project_test.py::ProjectTest::test_from_config_v1 PASSED      [ 46%]

01:36:51 tests/integration/resilience_test.py::ResilienceTest::test_create_failure PASSED [ 23%]

01:36:51 tests/unit/project_test.py::ProjectTest::test_from_config_v2 PASSED      [ 46%]

01:36:51 tests/integration/state_test.py::BasicProjectTest::test_no_change PASSED [ 35%]

01:36:51 tests/unit/project_test.py::ProjectTest::test_get_service PASSED         [ 46%]

01:36:52 tests/unit/project_test.py::ProjectTest::test_get_services_removes_duplicates_following_links PASSED [ 46%]

01:36:52 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_quota PASSED [ 25%]

01:36:52 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_rt xfail [ 25%]

01:36:52 tests/integration/resilience_test.py::ResilienceTest::test_start_failure PASSED [ 23%]

01:36:52 tests/unit/project_test.py::ProjectTest::test_get_services_returns_all_services_without_args PASSED [ 46%]

01:36:52 tests/unit/project_test.py::ProjectTest::test_get_services_returns_listed_services_with_args PASSED [ 46%]

01:36:52 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_set PASSED [ 26%]

01:36:52 tests/acceptance/cli_test.py::CLITestCase::test_up_with_networks PASSED  [ 16%]

01:36:52 tests/unit/project_test.py::ProjectTest::test_get_services_with_include_links PASSED [ 46%]

01:36:52 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_mode PASSED [ 16%]

01:36:53 tests/integration/resilience_test.py::ResilienceTest::test_successful_recreate PASSED [ 23%]

01:36:53 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_shares PASSED [ 26%]

01:36:53 tests/unit/project_test.py::ProjectTest::test_net_unset PASSED           [ 46%]

01:36:53 tests/integration/service_test.py::ServiceTest::test_build PASSED        [ 23%]

01:36:53 tests/integration/service_test.py::ServiceTest::test_build_non_ascii_filename PASSED [ 24%]

01:36:53 tests/integration/state_test.py::BasicProjectTest::test_partial_change PASSED [ 35%]

01:36:53 tests/unit/project_test.py::ProjectTest::test_no_such_service_unicode PASSED [ 46%]

01:36:53 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_middle_always_recreate_deps PASSED [ 36%]

01:36:53 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpus PASSED [ 26%]

01:36:53 tests/integration/service_test.py::ServiceTest::test_create_container_with_device_cgroup_rules PASSED [ 26%]

01:36:53 tests/unit/project_test.py::ProjectTest::test_no_warning_in_normal_mode PASSED [ 47%]

01:36:54 tests/acceptance/cli_test.py::CLITestCase::test_up_with_no_deps PASSED   [ 16%]

01:36:54 tests/unit/project_test.py::ProjectTest::test_no_warning_on_stop PASSED  [ 47%]

01:36:54 tests/integration/service_test.py::ServiceTest::test_create_container_with_extra_hosts_dicts PASSED [ 26%]

01:36:54 tests/unit/project_test.py::ProjectTest::test_no_warning_with_no_swarm_info PASSED [ 47%]

01:36:54 tests/unit/project_test.py::ProjectTest::test_project_platform_value PASSED [ 47%]

01:36:54 tests/acceptance/cli_test.py::CLITestCase::test_up_with_network_static_addresses PASSED [ 16%]

01:36:54 tests/integration/service_test.py::ServiceTest::test_create_container_with_extra_hosts_list PASSED [ 26%]

01:36:54 tests/unit/project_test.py::ProjectTest::test_use_net_from_container PASSED [ 47%]

01:36:55 tests/integration/service_test.py::ServiceTest::test_create_container_with_healthcheck_config PASSED [ 26%]

01:36:55 tests/unit/project_test.py::ProjectTest::test_use_net_from_service PASSED [ 47%]

01:36:55 tests/integration/service_test.py::ServiceTest::test_build_with_build_args PASSED [ 24%]

01:36:55 tests/unit/project_test.py::ProjectTest::test_use_volumes_from_container PASSED [ 47%]

01:36:56 tests/unit/project_test.py::ProjectTest::test_use_volumes_from_service_container PASSED [ 47%]

01:36:56 tests/integration/service_test.py::ServiceTest::test_create_container_with_host_mount PASSED [ 26%]

01:36:56 tests/unit/project_test.py::ProjectTest::test_use_volumes_from_service_no_container PASSED [ 47%]

01:36:56 tests/unit/project_test.py::ProjectTest::test_uses_default_network_false PASSED [ 47%]

01:36:56 tests/acceptance/cli_test.py::CLITestCase::test_up_with_no_recreate PASSED [ 16%]

01:36:56 tests/integration/service_test.py::ServiceTest::test_create_container_with_init_bool PASSED [ 26%]

01:36:56 tests/unit/project_test.py::ProjectTest::test_uses_default_network_true PASSED [ 47%]

01:36:56 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_leaf PASSED [ 35%]

01:36:56 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root PASSED [ 36%]

01:36:57 tests/unit/service_test.py::ServiceTest::test_build_does_not_pull PASSED [ 47%]

01:36:57 tests/integration/service_test.py::ServiceTest::test_build_with_build_args_override PASSED [ 24%]

01:36:57 tests/integration/service_test.py::ServiceTest::test_create_container_with_init_path XPASS [ 26%]

01:36:57 tests/unit/service_test.py::ServiceTest::test_build_isolation_from_build_override_service_config PASSED [ 48%]

01:36:57 tests/unit/service_test.py::ServiceTest::test_build_service_with_proxy_config PASSED [ 48%]

01:36:57 tests/integration/service_test.py::ServiceTest::test_create_container_with_legacy_mount PASSED [ 26%]

01:36:57 tests/unit/service_test.py::ServiceTest::test_build_volume_options_duplicate_binds PASSED [ 48%]

01:36:58 tests/integration/service_test.py::ServiceTest::test_build_with_build_labels PASSED [ 24%]

01:36:58 tests/unit/service_test.py::ServiceTest::test_build_with_default_platform PASSED [ 48%]

01:36:58 tests/integration/service_test.py::ServiceTest::test_create_container_with_legacy_tmpfs_mount PASSED [ 26%]

01:36:58 tests/integration/service_test.py::ServiceTest::test_build_with_cachefrom PASSED [ 24%]

01:36:58 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root_always_recreate_deps PASSED [ 36%]

01:36:58 tests/acceptance/cli_test.py::CLITestCase::test_up_with_override_yaml PASSED [ 16%]

01:36:58 tests/unit/service_test.py::ServiceTest::test_build_with_isolation_from_service_config PASSED [ 48%]

01:36:58 tests/unit/service_test.py::ServiceTest::test_build_with_override_build_args PASSED [ 48%]

01:36:58 tests/integration/service_test.py::ServiceTest::test_create_container_with_mac_address PASSED [ 27%]

01:36:58 tests/integration/service_test.py::ServiceTest::test_create_container_with_one_off PASSED [ 27%]

01:36:58 tests/acceptance/cli_test.py::CLITestCase::test_up_with_networks PASSED  [ 16%]

01:36:58 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root_no_recreate PASSED [ 36%]

01:36:59 tests/integration/service_test.py::ServiceTest::test_create_container_with_one_off_when_existing_container_is_running PASSED [ 27%]

01:36:59 tests/integration/service_test.py::ServiceTest::test_create_container_with_oom_kill_disable PASSED [ 27%]

01:36:59 tests/unit/service_test.py::ServiceTest::test_build_with_platform PASSED [ 48%]

01:36:59 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_middle PASSED [ 35%]

01:36:59 tests/unit/service_test.py::ServiceTest::test_cgroup_parent PASSED       [ 48%]

01:36:59 tests/integration/service_test.py::ServiceTest::test_create_container_with_pids_limit XPASS [ 27%]

01:36:59 tests/unit/service_test.py::ServiceTest::test_config_dict PASSED         [ 48%]

01:36:59 tests/acceptance/cli_test.py::CLITestCase::test_up_with_no_deps PASSED   [ 16%]

01:36:59 tests/unit/service_test.py::ServiceTest::test_config_dict_with_network_mode_from_container PASSED [ 48%]

01:37:00 tests/integration/service_test.py::ServiceTest::test_build_with_extra_hosts PASSED [ 24%]

01:37:00 tests/unit/service_test.py::ServiceTest::test_config_hash_matches_label PASSED [ 48%]

01:37:00 tests/integration/service_test.py::ServiceTest::test_create_container_with_read_only_root_fs PASSED [ 27%]

01:37:00 tests/unit/service_test.py::ServiceTest::test_container_without_name PASSED [ 49%]

01:37:00 tests/unit/service_test.py::ServiceTest::test_containers PASSED          [ 49%]

01:37:00 tests/integration/service_test.py::ServiceTest::test_create_container_with_security_opt PASSED [ 27%]

01:37:01 tests/unit/service_test.py::ServiceTest::test_containers_with_containers PASSED [ 49%]

01:37:01 tests/integration/service_test.py::ServiceTest::test_build_with_git_url PASSED [ 24%]

01:37:01 tests/integration/service_test.py::ServiceTest::test_create_container_with_shm_size PASSED [ 27%]

01:37:01 tests/unit/service_test.py::ServiceTest::test_create_container PASSED    [ 49%]

01:37:01 tests/acceptance/cli_test.py::CLITestCase::test_up_with_pid_mode <- tests/integration/testcases.py PASSED [ 17%]

01:37:01 tests/unit/service_test.py::ServiceTest::test_create_when_removed_containers_are_listed PASSED [ 49%]

01:37:01 tests/integration/service_test.py::ServiceTest::test_create_container_with_specified_volume PASSED [ 27%]

01:37:02 tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_force_build PASSED [ 49%]

01:37:02 tests/integration/service_test.py::ServiceTest::test_create_container_with_storage_opt xfail [ 27%]

01:37:02 tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_no_build PASSED [ 49%]

01:37:02 tests/acceptance/cli_test.py::CLITestCase::test_up_with_no_recreate PASSED [ 16%]

01:37:02 tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_no_build_but_needs_build PASSED [ 49%]

01:37:02 tests/integration/service_test.py::ServiceTest::test_create_container_with_tmpfs_mount PASSED [ 27%]

01:37:02 tests/unit/service_test.py::ServiceTest::test_get_container PASSED       [ 49%]

01:37:03 tests/integration/service_test.py::ServiceTest::test_build_with_gzip PASSED [ 24%]

01:37:03 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_does_not_mutate_options PASSED [ 49%]

01:37:03 tests/integration/state_test.py::ProjectWithDependenciesTest::test_service_recreated_when_dependency_created PASSED [ 36%]

01:37:03 tests/integration/service_test.py::ServiceTest::test_create_container_with_tmpfs_mount_tmpfs_size PASSED [ 28%]

01:37:03 tests/acceptance/cli_test.py::CLITestCase::test_up_with_timeout PASSED   [ 17%]

01:37:03 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_no_affinity_without_binds PASSED [ 49%]

01:37:03 tests/integration/service_test.py::ServiceTest::test_create_container_with_unspecified_volume PASSED [ 28%]

01:37:03 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_sets_affinity_with_binds PASSED [ 50%]

01:37:04 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_with_name_option PASSED [ 50%]

01:37:04 tests/acceptance/cli_test.py::CLITestCase::test_up_with_override_yaml PASSED [ 16%]

01:37:04 tests/integration/service_test.py::ServiceTest::test_build_with_illegal_leading_chars PASSED [ 24%]

01:37:04 tests/integration/service_test.py::ServiceTest::test_build_with_image_name PASSED [ 24%]

01:37:04 tests/integration/service_test.py::ServiceTest::test_build_with_isolation PASSED [ 24%]

01:37:04 tests/integration/service_test.py::ServiceTest::test_create_container_with_volume_driver PASSED [ 28%]

01:37:04 tests/unit/service_test.py::ServiceTest::test_get_container_not_found PASSED [ 50%]

01:37:04 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_middle_always_recreate_deps PASSED [ 35%]

01:37:04 tests/unit/service_test.py::ServiceTest::test_get_create_options_with_proxy_config PASSED [ 50%]

01:37:04 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_container PASSED [ 50%]

01:37:05 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root_always_recreate_deps PASSED [ 36%]

01:37:05 tests/integration/service_test.py::ServiceTest::test_create_container_with_volume_mount PASSED [ 28%]

01:37:05 tests/acceptance/cli_test.py::CLITestCase::test_up_with_volume_labels PASSED [ 17%]

01:37:05 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_container_read_only PASSED [ 50%]

01:37:05 tests/integration/service_test.py::ServiceTest::test_build_with_network PASSED [ 25%]

01:37:05 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_container_exists PASSED [ 50%]

01:37:06 tests/integration/service_test.py::ServiceTest::test_create_container_with_volumes_from PASSED [ 28%]

01:37:06 tests/integration/service_test.py::ServiceTest::test_create_with_image_id PASSED [ 28%]

01:37:06 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root_no_recreate PASSED [ 36%]

01:37:06 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_container_exists_with_flags PASSED [ 50%]

01:37:06 tests/integration/service_test.py::ServiceTest::test_custom_container_name PASSED [ 28%]

01:37:06 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_no_container PASSED [ 50%]

01:37:07 tests/unit/service_test.py::ServiceTest::test_image_name_default PASSED  [ 50%]

01:37:07 tests/integration/service_test.py::ServiceTest::test_devices PASSED      [ 28%]

01:37:07 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root PASSED [ 36%]

01:37:07 tests/integration/service_test.py::ServiceTest::test_build_with_target PASSED [ 25%]

01:37:07 tests/unit/service_test.py::ServiceTest::test_image_name_from_config PASSED [ 50%]

01:37:07 tests/integration/service_test.py::ServiceTest::test_cap_add_list PASSED [ 25%]

01:37:07 tests/unit/service_test.py::ServiceTest::test_log_opt PASSED             [ 50%]

01:37:07 tests/integration/environment_test.py::EnvironmentOverrideFileTest::test_env_file_override PASSED [ 17%]

01:37:07 tests/integration/service_test.py::ServiceTest::test_dns_list PASSED     [ 28%]

01:37:07 tests/unit/service_test.py::ServiceTest::test_mem_reservation PASSED     [ 51%]

01:37:08 tests/unit/service_test.py::ServiceTest::test_memory_swap_limit PASSED   [ 51%]

01:37:08 tests/integration/service_test.py::ServiceTest::test_cap_drop_list PASSED [ 25%]

01:37:08 tests/integration/service_test.py::ServiceTest::test_dns_no_value PASSED [ 28%]

01:37:08 tests/unit/service_test.py::ServiceTest::test_no_default_hostname_when_not_using_networking PASSED [ 51%]

01:37:08 tests/acceptance/cli_test.py::CLITestCase::test_up_with_pid_mode PASSED  [ 17%]

01:37:08 tests/integration/service_test.py::ServiceTest::test_dns_opt_value PASSED [ 28%]

01:37:08 tests/unit/service_test.py::ServiceTest::test_only_log_warning_when_host_ports_clash PASSED [ 51%]

01:37:09 tests/unit/service_test.py::ServiceTest::test_parse_proxy_config PASSED  [ 51%]

01:37:09 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_dependency_added PASSED [ 37%]

01:37:09 tests/integration/service_test.py::ServiceTest::test_dns_search PASSED   [ 28%]

01:37:09 tests/acceptance/cli_test.py::CLITestCase::test_up_with_timeout PASSED   [ 17%]

01:37:09 tests/unit/service_test.py::ServiceTest::test_parse_proxy_config_per_host PASSED [ 51%]

01:37:09 tests/integration/service_test.py::ServiceTest::test_duplicate_containers PASSED [ 29%]

01:37:09 tests/integration/state_test.py::ProjectWithDependenciesTest::test_service_removed_while_down PASSED [ 36%]

01:37:09 tests/unit/service_test.py::ServiceTest::test_parse_repository_tag PASSED [ 51%]

01:37:10 tests/unit/service_test.py::ServiceTest::test_pull_image PASSED          [ 51%]

01:37:10 tests/integration/service_test.py::ServiceTest::test_containers PASSED   [ 25%]

01:37:10 tests/integration/service_test.py::ServiceTest::test_containers_one_off PASSED [ 25%]

01:37:10 tests/integration/service_test.py::ServiceTest::test_create_container_with_blkio_config PASSED [ 25%]

01:37:10 tests/unit/service_test.py::ServiceTest::test_pull_image_digest PASSED   [ 51%]

01:37:10 tests/unit/service_test.py::ServiceTest::test_pull_image_no_tag PASSED   [ 51%]

01:37:10 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_count PASSED [ 25%]

01:37:10 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_percent SKIPPED [ 25%]

01:37:10 tests/integration/environment_test.py::EnvironmentSkipFileTest::test_env_file_skip PASSED [ 17%]

01:37:10 tests/integration/network_test.py::NetworkTest::test_network_default_labels PASSED [ 17%]

01:37:10 tests/integration/network_test.py::NetworkTest::test_network_external_default_ensure PASSED [ 17%]

01:37:10 tests/integration/network_test.py::NetworkTest::test_network_external_overlay_ensure PASSED [ 17%]

01:37:11 tests/unit/service_test.py::ServiceTest::test_pull_image_with_default_platform PASSED [ 51%]

01:37:11 tests/integration/state_test.py::ProjectWithDependenciesTest::test_up PASSED [ 36%]

01:37:11 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_quota PASSED [ 25%]

01:37:11 tests/unit/service_test.py::ServiceTest::test_pull_image_with_platform PASSED [ 52%]

01:37:11 tests/acceptance/cli_test.py::CLITestCase::test_up_with_volume_labels PASSED [ 17%]

01:37:11 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_rt xfail [ 25%]

01:37:11 tests/integration/service_test.py::ServiceTest::test_duplicate_volume_trailing_slash PASSED [ 29%]

01:37:11 tests/unit/service_test.py::ServiceTest::test_pull_image_with_platform_unsupported_api PASSED [ 52%]

01:37:11 tests/integration/service_test.py::ServiceTest::test_empty_labels PASSED [ 29%]

01:37:11 tests/unit/service_test.py::ServiceTest::test_recreate_container PASSED  [ 52%]

01:37:11 tests/integration/project_test.py::ProjectTest::test_containers PASSED   [ 17%]

01:37:11 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_set PASSED [ 26%]

01:37:12 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_shares PASSED [ 26%]

01:37:12 tests/integration/service_test.py::ServiceTest::test_env_from_file_combined_with_env PASSED [ 29%]

01:37:12 tests/unit/service_test.py::ServiceTest::test_recreate_container_with_timeout PASSED [ 52%]

01:37:12 tests/unit/service_test.py::ServiceTest::test_remove_image_all_does_remove PASSED [ 52%]

01:37:12 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpus PASSED [ 26%]

01:37:12 tests/integration/service_test.py::ServiceTest::test_create_container_with_device_cgroup_rules PASSED [ 26%]

01:37:12 tests/integration/project_test.py::ProjectTest::test_containers_stopped PASSED [ 17%]

01:37:12 tests/unit/service_test.py::ServiceTest::test_remove_image_local_with_image_name_doesnt_remove PASSED [ 52%]

01:37:13 tests/integration/project_test.py::ProjectTest::test_containers_with_extra_service PASSED [ 17%]

01:37:13 tests/unit/service_test.py::ServiceTest::test_remove_image_local_without_image_name_does_remove PASSED [ 52%]

01:37:13 tests/integration/service_test.py::ServiceTest::test_create_container_with_extra_hosts_dicts PASSED [ 26%]

01:37:13 tests/unit/service_test.py::ServiceTest::test_remove_image_none PASSED   [ 52%]

01:37:13 tests/unit/service_test.py::ServiceTest::test_remove_image_with_error PASSED [ 52%]

01:37:13 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root_always_recreate_deps PASSED [ 36%]

01:37:13 tests/integration/environment_test.py::EnvironmentOverrideFileTest::test_env_file_override PASSED [ 17%]

01:37:13 tests/integration/service_test.py::ServiceTest::test_create_container_with_extra_hosts_list PASSED [ 26%]

01:37:13 tests/integration/service_test.py::ServiceTest::test_create_container_with_healthcheck_config PASSED [ 26%]

01:37:13 tests/unit/service_test.py::ServiceTest::test_remove_non_existing_image PASSED [ 52%]

01:37:13 tests/integration/project_test.py::ProjectTest::test_containers_with_service_names PASSED [ 18%]

01:37:14 tests/unit/service_test.py::ServiceTest::test_self_reference_external_link PASSED [ 52%]

01:37:14 tests/integration/project_test.py::ProjectTest::test_create PASSED       [ 18%]

01:37:14 tests/integration/project_test.py::ProjectTest::test_create_strategy_always PASSED [ 18%]

01:37:14 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_anonymous_volume_recreate_then_renew PASSED [ 29%]

01:37:14 tests/integration/project_test.py::ProjectTest::test_create_strategy_never PASSED [ 18%]

01:37:14 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_dependency_removed PASSED [ 37%]

01:37:14 tests/integration/project_test.py::ProjectTest::test_create_twice PASSED [ 18%]

01:37:14 tests/unit/service_test.py::ServiceTest::test_service_ignore_default_platform_with_unsupported_api PASSED [ 52%]

01:37:14 tests/integration/service_test.py::ServiceTest::test_create_container_with_host_mount PASSED [ 26%]

01:37:15 tests/integration/project_test.py::ProjectTest::test_create_with_links PASSED [ 18%]

01:37:15 tests/integration/project_test.py::ProjectTest::test_initialize_volumes PASSED [ 18%]

01:37:15 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_external_volumes <- tests/integration/testcases.py PASSED [ 18%]

01:37:15 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_inexistent_external_volume PASSED [ 18%]

01:37:15 tests/unit/service_test.py::ServiceTest::test_service_platform_precedence PASSED [ 53%]

01:37:15 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root_no_recreate PASSED [ 36%]

01:37:15 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_anonymous_volume_renew PASSED [ 29%]

01:37:15 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_container_port PASSED [ 53%]

01:37:15 tests/integration/service_test.py::ServiceTest::test_create_container_with_init_bool PASSED [ 26%]

01:37:15 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_container_port_range PASSED [ 53%]

01:37:15 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_and_port PASSED [ 53%]

01:37:15 tests/integration/service_test.py::ServiceTest::test_create_container_with_init_path XPASS [ 26%]

01:37:16 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_and_port_range PASSED [ 53%]

01:37:16 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_leaf PASSED [ 36%]

01:37:16 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_no_port PASSED [ 53%]

01:37:16 tests/integration/service_test.py::ServiceTest::test_create_container_with_legacy_mount PASSED [ 26%]

01:37:16 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_no_port_range PASSED [ 53%]

01:37:16 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_port PASSED [ 53%]

01:37:17 tests/integration/service_test.py::ServiceTest::test_create_container_with_legacy_tmpfs_mount PASSED [ 26%]

01:37:17 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_port_range PASSED [ 53%]

01:37:17 tests/integration/service_test.py::ServiceTest::test_create_container_with_mac_address PASSED [ 27%]

01:37:17 tests/integration/service_test.py::ServiceTest::test_create_container_with_one_off PASSED [ 27%]

01:37:17 tests/integration/service_test.py::ServiceTest::test_create_container_with_one_off_when_existing_container_is_running PASSED [ 27%]

01:37:17 tests/integration/service_test.py::ServiceTest::test_create_container_with_oom_kill_disable PASSED [ 27%]

01:37:17 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_no_ports PASSED [ 53%]

01:37:17 tests/unit/service_test.py::ServiceTest::test_split_domainname_both PASSED [ 53%]

01:37:18 tests/integration/environment_test.py::EnvironmentSkipFileTest::test_env_file_skip PASSED [ 17%]

01:37:18 tests/integration/network_test.py::NetworkTest::test_network_default_labels PASSED [ 17%]

01:37:18 tests/integration/network_test.py::NetworkTest::test_network_external_default_ensure PASSED [ 17%]

01:37:18 tests/integration/network_test.py::NetworkTest::test_network_external_overlay_ensure PASSED [ 17%]

01:37:18 tests/integration/service_test.py::ServiceTest::test_create_container_with_pids_limit XPASS [ 27%]

01:37:18 tests/unit/service_test.py::ServiceTest::test_split_domainname_fqdn PASSED [ 54%]

01:37:18 tests/unit/service_test.py::ServiceTest::test_split_domainname_none PASSED [ 54%]

01:37:18 tests/integration/state_test.py::ProjectWithDependenciesTest::test_service_recreated_when_dependency_created PASSED [ 36%]

01:37:18 tests/unit/service_test.py::ServiceTest::test_split_domainname_weird PASSED [ 54%]

01:37:18 tests/integration/service_test.py::ServiceTest::test_create_container_with_read_only_root_fs PASSED [ 27%]

01:37:18 tests/unit/service_test.py::ServiceTest::test_stop_grace_period PASSED   [ 54%]

01:37:19 tests/unit/service_test.py::ServiceTest::test_volumes_order_is_preserved PASSED [ 54%]

01:37:19 tests/integration/service_test.py::ServiceTest::test_create_container_with_security_opt PASSED [ 27%]

01:37:19 tests/integration/project_test.py::ProjectTest::test_containers PASSED   [ 17%]

01:37:19 tests/unit/service_test.py::TestServiceNetwork::test_connect_container_to_networks_short_aliase_exists PASSED [ 54%]

01:37:19 tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_dict PASSED [ 54%]

01:37:19 tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_integers_and_dicts PASSED [ 54%]

01:37:19 tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_ints PASSED [ 54%]

01:37:19 tests/integration/service_test.py::ServiceTest::test_create_container_with_shm_size PASSED [ 27%]

01:37:20 tests/unit/service_test.py::NetTestCase::test_network_mode PASSED        [ 54%]

01:37:20 tests/unit/service_test.py::NetTestCase::test_network_mode_container PASSED [ 54%]

01:37:20 tests/integration/project_test.py::ProjectTest::test_containers_stopped PASSED [ 17%]

01:37:20 tests/integration/service_test.py::ServiceTest::test_create_container_with_specified_volume PASSED [ 27%]

01:37:20 tests/integration/service_test.py::ServiceTest::test_create_container_with_storage_opt xfail [ 27%]

01:37:20 tests/unit/service_test.py::NetTestCase::test_network_mode_service PASSED [ 55%]

01:37:20 tests/integration/project_test.py::ProjectTest::test_containers_with_extra_service PASSED [ 17%]

01:37:20 tests/unit/service_test.py::NetTestCase::test_network_mode_service_no_containers PASSED [ 55%]

01:37:20 tests/unit/service_test.py::ServicePortsTest::test_formatted_ports PASSED [ 55%]

01:37:20 tests/integration/service_test.py::ServiceTest::test_create_container_with_tmpfs_mount PASSED [ 27%]

01:37:21 tests/unit/service_test.py::ServiceVolumesTest::test_build_volume_binding PASSED [ 55%]

01:37:21 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_service_removed_while_down PASSED [ 37%]

01:37:21 tests/unit/service_test.py::ServiceVolumesTest::test_create_with_special_volume_mode PASSED [ 55%]

01:37:21 tests/integration/service_test.py::ServiceTest::test_create_container_with_tmpfs_mount_tmpfs_size PASSED [ 28%]

01:37:21 tests/unit/service_test.py::ServiceVolumesTest::test_get_container_create_options_with_different_host_path_in_container_json PASSED [ 55%]

01:37:21 tests/integration/project_test.py::ProjectTest::test_containers_with_service_names PASSED [ 18%]

01:37:21 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_image_with_volume_is_removed PASSED [ 29%]

01:37:21 tests/unit/service_test.py::ServiceVolumesTest::test_get_container_data_volumes PASSED [ 55%]

01:37:21 tests/integration/project_test.py::ProjectTest::test_create PASSED       [ 18%]

01:37:22 tests/integration/project_test.py::ProjectTest::test_create_strategy_always PASSED [ 18%]

01:37:22 tests/integration/project_test.py::ProjectTest::test_create_strategy_never PASSED [ 18%]

01:37:22 tests/integration/service_test.py::ServiceTest::test_create_container_with_unspecified_volume PASSED [ 28%]

01:37:22 tests/integration/project_test.py::ProjectTest::test_create_twice PASSED [ 18%]

01:37:22 tests/unit/service_test.py::ServiceVolumesTest::test_merge_volume_bindings PASSED [ 55%]

01:37:22 tests/integration/project_test.py::ProjectTest::test_create_with_links PASSED [ 18%]

01:37:22 tests/integration/project_test.py::ProjectTest::test_initialize_volumes PASSED [ 18%]

01:37:22 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_external_volumes PASSED [ 18%]

01:37:22 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_inexistent_external_volume PASSED [ 18%]

01:37:22 tests/unit/service_test.py::ServiceVolumesTest::test_mount_same_host_path_to_two_volumes PASSED [ 55%]

01:37:22 tests/integration/service_test.py::ServiceTest::test_create_container_with_volume_driver PASSED [ 28%]

01:37:22 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_middle PASSED [ 36%]

01:37:22 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_no_warning_with_container_only_option PASSED [ 55%]

01:37:23 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate PASSED [ 29%]

01:37:23 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_no_warning_with_same_path PASSED [ 55%]

01:37:23 tests/integration/service_test.py::ServiceTest::test_create_container_with_volume_mount PASSED [ 28%]

01:37:23 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_volume_no_warning_when_no_container_volumes PASSED [ 55%]

01:37:23 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_volume_when_masked PASSED [ 56%]

01:37:23 tests/integration/service_test.py::ServiceTest::test_create_container_with_volumes_from PASSED [ 28%]

01:37:24 tests/integration/service_test.py::ServiceTest::test_create_with_image_id PASSED [ 28%]

01:37:24 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_change_mount_target PASSED [ 29%]

01:37:24 tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes PASSED [ 56%]

01:37:24 tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes_abspath PASSED [ 56%]

01:37:24 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_service_removed_while_up PASSED [ 37%]

01:37:24 tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes_no_target PASSED [ 56%]

01:37:24 tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_unix_path PASSED [ 56%]

01:37:24 tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_url_no_prefix PASSED [ 56%]

01:37:24 tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_windows_path PASSED [ 56%]

01:37:24 tests/unit/split_buffer_test.py::SplitBufferTest::test_chunked_line PASSED [ 56%]

01:37:24 tests/unit/split_buffer_test.py::SplitBufferTest::test_multiple_line_chunk PASSED [ 56%]

01:37:24 tests/unit/split_buffer_test.py::SplitBufferTest::test_no_end_separator PASSED [ 56%]

01:37:24 tests/unit/split_buffer_test.py::SplitBufferTest::test_preserves_unicode_sequences_within_lines PASSED [ 56%]

01:37:24 tests/integration/service_test.py::ServiceTest::test_custom_container_name PASSED [ 28%]

01:37:24 tests/unit/split_buffer_test.py::SplitBufferTest::test_single_line_chunks PASSED [ 57%]

01:37:24 tests/unit/timeparse_test.py::test_milli PASSED                          [ 57%]

01:37:24 tests/unit/timeparse_test.py::test_milli_float PASSED                    [ 57%]

01:37:24 tests/unit/timeparse_test.py::test_second_milli PASSED                   [ 57%]

01:37:24 tests/unit/timeparse_test.py::test_second_milli_micro PASSED             [ 57%]

01:37:24 tests/unit/timeparse_test.py::test_second PASSED                         [ 57%]

01:37:24 tests/unit/timeparse_test.py::test_second_as_float PASSED                [ 57%]

01:37:24 tests/unit/timeparse_test.py::test_minute PASSED                         [ 57%]

01:37:24 tests/unit/timeparse_test.py::test_hour_minute PASSED                    [ 57%]

01:37:24 tests/unit/timeparse_test.py::test_minute_as_float PASSED                [ 57%]

01:37:24 tests/unit/timeparse_test.py::test_hour_minute_second PASSED             [ 57%]

01:37:24 tests/unit/timeparse_test.py::test_invalid_with_space PASSED             [ 57%]

01:37:24 tests/unit/timeparse_test.py::test_invalid_with_comma PASSED             [ 58%]

01:37:24 tests/unit/timeparse_test.py::test_invalid_with_empty_string PASSED      [ 58%]

01:37:24 tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_no_object PASSED [ 58%]

01:37:24 tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_with_object PASSED [ 58%]

01:37:24 tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_leading_whitespace PASSED [ 58%]

01:37:24 tests/unit/utils_test.py::TestStreamAsText::test_stream_with_non_utf_unicode_character PASSED [ 58%]

01:37:24 tests/unit/utils_test.py::TestStreamAsText::test_stream_with_utf_character PASSED [ 58%]

01:37:24 tests/unit/utils_test.py::TestJsonStream::test_with_falsy_entries PASSED [ 58%]

01:37:24 tests/unit/utils_test.py::TestJsonStream::test_with_leading_whitespace PASSED [ 58%]

01:37:24 tests/unit/utils_test.py::TestParseBytes::test_parse_bytes PASSED        [ 58%]

01:37:24 tests/unit/utils_test.py::TestMoreItertools::test_unique_everseen PASSED [ 58%]

01:37:25 tests/unit/volume_test.py::TestVolume::test_remove_local_volume PASSED   [ 59%]

01:37:25 tests/integration/state_test.py::ProjectWithDependenciesTest::test_service_removed_while_down PASSED [ 36%]

01:37:25 tests/integration/service_test.py::ServiceTest::test_devices PASSED      [ 28%]

01:37:25 tests/unit/volume_test.py::TestVolume::test_remove_external_volume PASSED [ 59%]

01:37:25 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_path_from_options PASSED [ 59%]

01:37:25 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_single_path_from_env PASSED [ 59%]

01:37:25 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env PASSED [ 59%]

01:37:25 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env_windows SKIPPED [ 59%]

01:37:25 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env_custom_separator PASSED [ 59%]

01:37:25 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_no_path PASSED [ 59%]

01:37:25 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_unicode_path_from_options PASSED [ 59%]

01:37:25 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_unicode_path_from_env PASSED [ 59%]

01:37:25 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_custom_timeout_error PASSED [ 59%]

01:37:25 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_docker_client_no_home PASSED [ 60%]

01:37:25 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_docker_client_with_custom_timeout PASSED [ 60%]

01:37:25 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_user_agent PASSED [ 60%]

01:37:25 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_assert_hostname_explicit_skip PASSED [ 60%]

01:37:25 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_simple_tls PASSED [ 60%]

01:37:25 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_ca_cert PASSED [ 60%]

01:37:25 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_ca_cert_explicit PASSED [ 60%]

01:37:25 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca PASSED [ 60%]

01:37:25 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca_explicit PASSED [ 60%]

01:37:25 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca_quoted_paths PASSED [ 60%]

01:37:25 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_cert PASSED [ 60%]

01:37:25 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_cert_explicit PASSED [ 60%]

01:37:25 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_missing_key PASSED [ 61%]

01:37:25 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_flags_override_environment PASSED [ 61%]

01:37:25 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_mixed_environment_and_flags PASSED [ 61%]

01:37:25 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_simple_with_tls_version PASSED [ 61%]

01:37:25 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_default_cert_path PASSED [ 61%]

01:37:25 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_env_falsy_value PASSED [ 61%]

01:37:25 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_flag_no_override PASSED [ 61%]

01:37:25 tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_default PASSED [ 61%]

01:37:25 tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_upgrade PASSED [ 61%]

01:37:25 tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_unavailable PASSED [ 61%]

01:37:25 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_generic_connection_error PASSED [ 61%]

01:37:25 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_mismatch PASSED [ 62%]

01:37:25 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_mismatch_unicode_explanation PASSED [ 62%]

01:37:25 tests/integration/service_test.py::ServiceTest::test_dns_list PASSED     [ 28%]

01:37:25 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_other PASSED [ 62%]

01:37:25 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_other_unicode_explanation PASSED [ 62%]

01:37:25 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_no_data SKIPPED [ 62%]

01:37:25 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_misc SKIPPED [ 62%]

01:37:25 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_encoding_issue SKIPPED [ 62%]

01:37:25 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_error PASSED [ 62%]

01:37:25 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_info PASSED [ 62%]

01:37:25 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_error PASSED [ 62%]

01:37:25 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_info PASSED [ 62%]

01:37:25 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_warn PASSED [ 63%]

01:37:25 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_warn PASSED [ 63%]

01:37:25 tests/unit/cli/log_printer_test.py::TestLogPresenter::test_monochrome PASSED [ 63%]

01:37:25 tests/unit/cli/log_printer_test.py::TestLogPresenter::test_polychrome PASSED [ 63%]

01:37:25 tests/unit/cli/log_printer_test.py::test_wait_on_exit PASSED             [ 63%]

01:37:25 tests/unit/cli/log_printer_test.py::test_wait_on_exit_raises PASSED      [ 63%]

01:37:25 tests/unit/cli/log_printer_test.py::test_build_no_log_generator PASSED   [ 63%]

01:37:25 tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_no_log_stream PASSED [ 63%]

01:37:25 tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_with_log_stream PASSED [ 63%]

01:37:25 tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_unicode PASSED [ 63%]

01:37:25 tests/unit/cli/log_printer_test.py::TestWatchEvents::test_stop_event PASSED [ 63%]

01:37:25 tests/unit/cli/log_printer_test.py::TestWatchEvents::test_start_event PASSED [ 63%]

01:37:25 tests/unit/cli/log_printer_test.py::TestWatchEvents::test_other_event PASSED [ 64%]

01:37:25 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_an_exception PASSED [ 64%]

01:37:25 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_stop_without_cascade_stop PASSED [ 64%]

01:37:25 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_stop_with_cascade_stop PASSED [ 64%]

01:37:25 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_none_when_timeout_is_hit PASSED [ 64%]

01:37:25 tests/integration/state_test.py::ProjectWithDependenciesTest::test_up PASSED [ 36%]

01:37:25 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_filter_containers_to_service_names PASSED [ 64%]

01:37:25 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_filter_containers_to_service_names_all PASSED [ 64%]

01:37:25 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_twice PASSED [ 29%]

01:37:26 tests/integration/service_test.py::ServiceTest::test_dns_no_value PASSED [ 28%]

01:37:26 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_up PASSED [ 37%]

01:37:26 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_warning_in_swarm_mode PASSED [ 64%]

01:37:26 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_build_one_off_container_options PASSED [ 64%]

01:37:26 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_get_docker_start_call PASSED [ 64%]

01:37:26 tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_tty_verbose PASSED [ 64%]

01:37:26 tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_tty_not_verbose PASSED [ 65%]

01:37:26 tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_not_a_tty PASSED [ 65%]

01:37:26 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_invalid_opts PASSED [ 65%]

01:37:26 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_always PASSED [ 65%]

01:37:26 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_never PASSED [ 65%]

01:37:26 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_changed PASSED [ 65%]

01:37:26 tests/unit/cli/main_test.py::TestCallDocker::test_simple_no_options PASSED [ 65%]

01:37:26 tests/unit/cli/main_test.py::TestCallDocker::test_simple_tls_option PASSED [ 65%]

01:37:26 tests/unit/cli/main_test.py::TestCallDocker::test_advanced_tls_options PASSED [ 65%]

01:37:26 tests/unit/cli/main_test.py::TestCallDocker::test_with_host_option PASSED [ 65%]

01:37:26 tests/unit/cli/main_test.py::TestCallDocker::test_with_http_host PASSED  [ 65%]

01:37:26 tests/unit/cli/main_test.py::TestCallDocker::test_with_host_option_shorthand_equal PASSED [ 65%]

01:37:26 tests/unit/cli/main_test.py::TestCallDocker::test_with_env PASSED        [ 66%]

01:37:26 tests/unit/cli/utils_test.py::UnquotePathTest::test_nested_quotes PASSED [ 66%]

01:37:26 tests/unit/cli/utils_test.py::UnquotePathTest::test_no_quotes PASSED     [ 66%]

01:37:26 tests/unit/cli/utils_test.py::UnquotePathTest::test_simple_quotes PASSED [ 66%]

01:37:26 tests/unit/cli/utils_test.py::UnquotePathTest::test_uneven_quotes PASSED [ 66%]

01:37:26 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_100b PASSED [ 66%]

01:37:26 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_1023b PASSED [ 66%]

01:37:26 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_1kb PASSED [ 66%]

01:37:26 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_units PASSED [ 66%]

01:37:26 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_call PASSED [ 66%]

01:37:26 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return PASSED [ 66%]

01:37:26 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return_no_result PASSED [ 67%]

01:37:26 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return_sequence PASSED [ 67%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_build_args_allow_empty_properties PASSED [ 67%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_build_args_check_zero_preserved PASSED [ 67%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_config_build_configuration PASSED [ 67%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_config_build_configuration_v2 PASSED [ 67%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_config_convertible_label_types PASSED [ 67%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_config_duplicate_cache_from_values_validation_error PASSED [ 67%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_config_duplicate_mount_points PASSED [ 67%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_config_extra_hosts_list_of_dicts_validation_error PASSED [ 67%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_config_extra_hosts_string_raises_validation_error PASSED [ 67%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_config_hint PASSED    [ 68%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error PASSED [ 68%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error_v2 PASSED [ 68%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error_v2_when_no_interpolate PASSED [ 68%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_property_raise_validation_error PASSED [ 68%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_config_invalid_ipam_config PASSED [ 68%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_config_invalid_label_types PASSED [ 68%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_config_invalid_service_name_raise_validation_error PASSED [ 68%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_invalid_keys_validation_error PASSED [ 68%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_required_keys_validation_error PASSED [ 68%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_soft_greater_than_hard_error PASSED [ 68%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_config_valid_environment_dict_key_contains_dashes PASSED [ 68%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_config_valid_ipam_config PASSED [ 69%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_config_valid_service_label_validation PASSED [ 69%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_config_valid_service_names PASSED [ 69%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_depends_on_orders_services PASSED [ 69%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_depends_on_unknown_service_errors PASSED [ 69%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_dns_opt_option PASSED [ 69%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_empty_environment_key_allowed PASSED [ 69%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_external_volume_config PASSED [ 69%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_external_volume_invalid_config PASSED [ 69%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_group_add_option PASSED [ 69%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_build_and_image_specified_v1 PASSED [ 69%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_not_a_dictionary PASSED [ 70%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_not_unique_items PASSED [ 70%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_type_should_be_an_array PASSED [ 70%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_v1 PASSED [ 70%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_v2 PASSED [ 70%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_invalid_list_of_strings_format PASSED [ 70%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_isolation_option PASSED [ 70%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_linked_service_is_undefined PASSED [ 70%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load PASSED           [ 70%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_bind_mount_relative_path PASSED [ 70%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_bind_mount_relative_path_with_tilde PASSED [ 70%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_build_labels_dict PASSED [ 71%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_build_labels_list PASSED [ 71%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_config_custom_resource_names PASSED [ 71%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_config_dockerfile_without_build_raises_error_v1 PASSED [ 71%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_config_invalid_service_names PASSED [ 71%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_config_invalid_service_names_v2 PASSED [ 71%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_config_link_local_ips_network PASSED [ 71%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_config_service_labels PASSED [ 71%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_config_volume_and_network_labels PASSED [ 71%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_configs PASSED   [ 71%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_configs_multi_file PASSED [ 71%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_dockerfile_without_context PASSED [ 71%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_errors_on_uppercase_with_no_image PASSED [ 72%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_invalid_service_definition PASSED [ 72%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_mixed_extends_resolution PASSED [ 72%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_secrets PASSED   [ 72%]

01:37:26 tests/integration/service_test.py::ServiceTest::test_dns_opt_value PASSED [ 28%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_secrets_multi_file PASSED [ 72%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_service_with_name_version PASSED [ 72%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_sorts_in_dependency_order PASSED [ 72%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_when_not_dict PASSED [ 72%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_when_not_dict_v2 PASSED [ 72%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_with_invalid_network_fields PASSED [ 72%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_v2 PASSED        [ 72%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_with_buildargs PASSED [ 73%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_with_empty_build_args PASSED [ 73%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_with_extensions PASSED [ 73%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_with_invalid_field_name PASSED [ 73%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_with_invalid_field_name_v1 PASSED [ 73%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_base PASSED [ 73%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_base_v2 PASSED [ 73%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_override PASSED [ 73%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_override_v2 PASSED [ 73%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_extends_in_override_file PASSED [ 73%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_invalid_override PASSED [ 73%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_mismatched_networks_format PASSED [ 73%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_mismatched_networks_format_inverse_order PASSED [ 74%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v1 PASSED [ 74%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v2 PASSED [ 74%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v3_2 PASSED [ 74%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_yaml_with_bom PASSED [ 74%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_load_yaml_with_yaml_error PASSED [ 74%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_logs_warning_for_boolean_in_environment PASSED [ 74%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_blkio_config PASSED [ 74%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_configs_override PASSED [ 74%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_credential_spec PASSED [ 74%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_depends_on_mixed_syntax PASSED [ 74%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_depends_on_no_override PASSED [ 75%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_deploy PASSED   [ 75%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_deploy_override PASSED [ 75%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_device_cgroup_rules PASSED [ 75%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_different_configs PASSED [ 75%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_different_secrets PASSED [ 75%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_extra_hosts PASSED [ 75%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_config PASSED [ 75%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_override_disables PASSED [ 75%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_override_enables PASSED [ 75%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_isolation PASSED [ 75%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v1 PASSED [ 76%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2 PASSED [ 76%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_base PASSED [ 76%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_base_driver PASSED [ 76%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_drivers PASSED [ 76%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_override PASSED [ 76%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_override_options PASSED [ 76%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_override_driver PASSED [ 76%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_mixed_ports PASSED [ 76%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_pid PASSED      [ 76%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_scale PASSED    [ 76%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_secrets_override PASSED [ 76%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_from_files_with_extends_in_base PASSED [ 77%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_from_files_with_extends_in_override PASSED [ 77%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous PASSED [ 77%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous_2 PASSED [ 77%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous_volumes PASSED [ 77%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_ports_sorting PASSED [ 77%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_merge_storage_opt PASSED [ 77%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_named_volume_config_empty PASSED [ 77%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_named_volume_invalid_type_list PASSED [ 77%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_named_volume_numeric_driver_opt PASSED [ 77%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_networks_invalid_type_list PASSED [ 77%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_normalize_dns_options PASSED [ 78%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_oom_score_adj_option PASSED [ 78%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_runtime_option PASSED [ 78%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_service_volume_invalid_config PASSED [ 78%]

01:37:26 tests/unit/config/config_test.py::ConfigTest::test_swappiness_option PASSED [ 78%]

01:37:27 tests/unit/config/config_test.py::ConfigTest::test_tmpfs_option PASSED   [ 78%]

01:37:27 tests/unit/config/config_test.py::ConfigTest::test_undeclared_volume_v1 PASSED [ 78%]

01:37:27 tests/unit/config/config_test.py::ConfigTest::test_undeclared_volume_v2 PASSED [ 78%]

01:37:27 tests/unit/config/config_test.py::ConfigTest::test_unsupported_version PASSED [ 78%]

01:37:27 tests/unit/config/config_test.py::ConfigTest::test_v1_file_version PASSED [ 78%]

01:37:27 tests/unit/config/config_test.py::ConfigTest::test_v1_file_with_version_is_invalid PASSED [ 78%]

01:37:27 tests/unit/config/config_test.py::ConfigTest::test_valid_config_oneof_string_or_list PASSED [ 78%]

01:37:27 tests/unit/config/config_test.py::ConfigTest::test_valid_config_which_allows_two_type_definitions PASSED [ 79%]

01:37:27 tests/unit/config/config_test.py::ConfigTest::test_valid_versions PASSED [ 79%]

01:37:27 tests/unit/config/config_test.py::ConfigTest::test_validate_extra_hosts_invalid PASSED [ 79%]

01:37:27 tests/unit/config/config_test.py::ConfigTest::test_validate_extra_hosts_invalid_list PASSED [ 79%]

01:37:27 tests/unit/config/config_test.py::ConfigTest::test_version_1_is_invalid PASSED [ 79%]

01:37:27 tests/unit/config/config_test.py::ConfigTest::test_volume_invalid_driver_opt PASSED [ 79%]

01:37:27 tests/unit/config/config_test.py::ConfigTest::test_volume_mode_override PASSED [ 79%]

01:37:27 tests/unit/config/config_test.py::ConfigTest::test_volumes_long_syntax PASSED [ 79%]

01:37:27 tests/unit/config/config_test.py::ConfigTest::test_wrong_version_type PASSED [ 79%]

01:37:27 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_container PASSED [ 79%]

01:37:27 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_container_v1 PASSED [ 79%]

01:37:27 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_plus_networks_is_invalid PASSED [ 80%]

01:37:27 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service PASSED [ 80%]

01:37:27 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service_nonexistent PASSED [ 80%]

01:37:27 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service_v1 PASSED [ 80%]

01:37:27 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_standard PASSED [ 80%]

01:37:27 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_standard_v1 PASSED [ 80%]

01:37:27 tests/unit/config/config_test.py::PortsTest::test_config_invalid_expose_format_validation PASSED [ 80%]

01:37:27 tests/unit/config/config_test.py::PortsTest::test_config_invalid_expose_type_validation PASSED [ 80%]

01:37:27 tests/unit/config/config_test.py::PortsTest::test_config_invalid_ports_format_validation PASSED [ 80%]

01:37:27 tests/unit/config/config_test.py::PortsTest::test_config_invalid_ports_type_validation PASSED [ 80%]

01:37:27 tests/unit/config/config_test.py::PortsTest::test_config_non_unique_expose_validation PASSED [ 80%]

01:37:27 tests/unit/config/config_test.py::PortsTest::test_config_non_unique_ports_validation PASSED [ 81%]

01:37:27 tests/unit/config/config_test.py::PortsTest::test_config_valid_expose_format_validation PASSED [ 81%]

01:37:27 tests/unit/config/config_test.py::PortsTest::test_config_valid_ports_format_validation PASSED [ 81%]

01:37:27 tests/integration/service_test.py::ServiceTest::test_dns_search PASSED   [ 28%]

01:37:27 tests/integration/service_test.py::ServiceTest::test_duplicate_containers PASSED [ 29%]

01:37:27 tests/unit/config/config_test.py::SubnetTest::test_config_invalid_subnet_format_validation PASSED [ 81%]

01:37:27 tests/unit/config/config_test.py::SubnetTest::test_config_invalid_subnet_type_validation PASSED [ 81%]

01:37:27 tests/unit/config/config_test.py::SubnetTest::test_config_valid_subnet_format_validation PASSED [ 81%]

01:37:27 tests/unit/config/config_test.py::InterpolationTest::test_compatibility_mode_load PASSED [ 81%]

01:37:27 tests/unit/config/config_test.py::InterpolationTest::test_compatibility_mode_warnings PASSED [ 81%]

01:37:27 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_file PASSED [ 81%]

01:37:27 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_variable PASSED [ 81%]

01:37:27 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_variable_with_defaults PASSED [ 81%]

01:37:27 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_options_environment_file PASSED [ 81%]

01:37:27 tests/unit/config/config_test.py::InterpolationTest::test_interpolation_configs_section PASSED [ 82%]

01:37:27 tests/unit/config/config_test.py::InterpolationTest::test_interpolation_secrets_section PASSED [ 82%]

01:37:27 tests/unit/config/config_test.py::InterpolationTest::test_invalid_interpolation PASSED [ 82%]

01:37:27 tests/unit/config/config_test.py::InterpolationTest::test_unset_variable_produces_warning PASSED [ 82%]

01:37:27 tests/unit/config/config_test.py::VolumeConfigTest::test_absolute_posix_path_does_not_expand PASSED [ 82%]

01:37:27 tests/unit/config/config_test.py::VolumeConfigTest::test_absolute_windows_path_does_not_expand PASSED [ 82%]

01:37:27 tests/unit/config/config_test.py::VolumeConfigTest::test_home_directory_with_driver_does_not_expand PASSED [ 82%]

01:37:27 tests/unit/config/config_test.py::VolumeConfigTest::test_name_does_not_expand PASSED [ 82%]

01:37:27 tests/unit/config/config_test.py::VolumeConfigTest::test_no_binding PASSED [ 82%]

01:37:27 tests/unit/config/config_test.py::VolumeConfigTest::test_relative_path_does_expand_posix PASSED [ 82%]

01:37:27 tests/unit/config/config_test.py::VolumeConfigTest::test_relative_path_does_expand_windows SKIPPED [ 82%]

01:37:27 tests/unit/config/config_test.py::VolumeConfigTest::test_volume_binding_with_environment_variable PASSED [ 83%]

01:37:27 tests/unit/config/config_test.py::VolumeConfigTest::test_volume_binding_with_home PASSED [ 83%]

01:37:27 tests/unit/config/config_test.py::VolumeConfigTest::test_volume_path_with_non_ascii_directory PASSED [ 83%]

01:37:27 tests/unit/config/config_test.py::VolumeConfigTest::test_volumes_order_is_preserved PASSED [ 83%]

01:37:27 tests/unit/config/config_test.py::MergeVolumesTest::test_add_explicit_path PASSED [ 83%]

01:37:27 tests/unit/config/config_test.py::MergeVolumesTest::test_empty PASSED    [ 83%]

01:37:27 tests/unit/config/config_test.py::MergeVolumesTest::test_no_base PASSED  [ 83%]

01:37:27 tests/unit/config/config_test.py::MergeVolumesTest::test_no_override PASSED [ 83%]

01:37:27 tests/unit/config/config_test.py::MergeVolumesTest::test_override_explicit_path PASSED [ 83%]

01:37:27 tests/unit/config/config_test.py::MergeVolumesTest::test_remove_explicit_path PASSED [ 83%]

01:37:27 tests/unit/config/config_test.py::MergeDevicesTest::test_add_explicit_path PASSED [ 83%]

01:37:27 tests/unit/config/config_test.py::MergeDevicesTest::test_empty PASSED    [ 84%]

01:37:27 tests/unit/config/config_test.py::MergeDevicesTest::test_no_base PASSED  [ 84%]

01:37:27 tests/unit/config/config_test.py::MergeDevicesTest::test_no_override PASSED [ 84%]

01:37:27 tests/unit/config/config_test.py::MergeDevicesTest::test_override_explicit_path PASSED [ 84%]

01:37:27 tests/unit/config/config_test.py::MergeDevicesTest::test_remove_explicit_path PASSED [ 84%]

01:37:27 tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_no_override PASSED [ 84%]

01:37:27 tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_override_with_other PASSED [ 84%]

01:37:27 tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_override_with_same PASSED [ 84%]

01:37:27 tests/unit/config/config_test.py::MergePortsTest::test_add_item PASSED   [ 84%]

01:37:27 tests/unit/config/config_test.py::MergePortsTest::test_duplicate_port_mappings PASSED [ 84%]

01:37:27 tests/unit/config/config_test.py::MergePortsTest::test_empty PASSED      [ 84%]

01:37:27 tests/unit/config/config_test.py::MergePortsTest::test_no_base PASSED    [ 84%]

01:37:27 tests/unit/config/config_test.py::MergePortsTest::test_no_override PASSED [ 85%]

01:37:27 tests/unit/config/config_test.py::MergeNetworksTest::test_add_item PASSED [ 85%]

01:37:27 tests/unit/config/config_test.py::MergeNetworksTest::test_all_properties PASSED [ 85%]

01:37:27 tests/unit/config/config_test.py::MergeNetworksTest::test_empty PASSED   [ 85%]

01:37:27 tests/unit/config/config_test.py::MergeNetworksTest::test_network_has_none_value PASSED [ 85%]

01:37:27 tests/unit/config/config_test.py::MergeNetworksTest::test_no_base PASSED [ 85%]

01:37:27 tests/unit/config/config_test.py::MergeNetworksTest::test_no_network_name_overrides PASSED [ 85%]

01:37:27 tests/unit/config/config_test.py::MergeNetworksTest::test_no_network_overrides PASSED [ 85%]

01:37:27 tests/unit/config/config_test.py::MergeNetworksTest::test_no_override PASSED [ 85%]

01:37:27 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_add_list PASSED [ 85%]

01:37:27 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_add_string PASSED [ 85%]

01:37:27 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_no_base PASSED [ 86%]

01:37:27 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_no_override PASSED [ 86%]

01:37:27 tests/unit/config/config_test.py::MergeLabelsTest::test_add_explicit_value PASSED [ 86%]

01:37:27 tests/unit/config/config_test.py::MergeLabelsTest::test_empty PASSED     [ 86%]

01:37:27 tests/unit/config/config_test.py::MergeLabelsTest::test_no_base PASSED   [ 86%]

01:37:27 tests/unit/config/config_test.py::MergeLabelsTest::test_no_override PASSED [ 86%]

01:37:27 tests/unit/config/config_test.py::MergeLabelsTest::test_override_explicit_value PASSED [ 86%]

01:37:27 tests/unit/config/config_test.py::MergeLabelsTest::test_remove_explicit_value PASSED [ 86%]

01:37:27 tests/unit/config/config_test.py::MergeBuildTest::test_empty_base PASSED [ 86%]

01:37:27 tests/unit/config/config_test.py::MergeBuildTest::test_empty_override PASSED [ 86%]

01:37:27 tests/unit/config/config_test.py::MergeBuildTest::test_full PASSED       [ 86%]

01:37:27 tests/unit/config/config_test.py::MemoryOptionsTest::test_memswap_can_be_a_string PASSED [ 86%]

01:37:27 tests/unit/config/config_test.py::MemoryOptionsTest::test_validation_fails_with_just_memswap_limit PASSED [ 87%]

01:37:27 tests/unit/config/config_test.py::MemoryOptionsTest::test_validation_with_correct_memswap_values PASSED [ 87%]

01:37:27 tests/unit/config/config_test.py::EnvTest::test_environment_overrides_env_file PASSED [ 87%]

01:37:27 tests/unit/config/config_test.py::EnvTest::test_parse_environment_as_dict PASSED [ 87%]

01:37:27 tests/unit/config/config_test.py::EnvTest::test_parse_environment_as_list PASSED [ 87%]

01:37:27 tests/unit/config/config_test.py::EnvTest::test_parse_environment_empty PASSED [ 87%]

01:37:27 tests/unit/config/config_test.py::EnvTest::test_parse_environment_invalid PASSED [ 87%]

01:37:27 tests/unit/config/config_test.py::EnvTest::test_resolve_build_args PASSED [ 87%]

01:37:27 tests/unit/config/config_test.py::EnvTest::test_resolve_environment PASSED [ 87%]

01:37:27 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_from_env_file PASSED [ 87%]

01:37:27 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_from_env_file_with_empty_values PASSED [ 87%]

01:37:27 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_nonexistent_file PASSED [ 88%]

01:37:27 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_with_multiple_env_files PASSED [ 88%]

01:37:27 tests/unit/config/config_test.py::EnvTest::test_resolve_path PASSED      [ 88%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_circular PASSED      [ 88%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_invalid_config PASSED [ 88%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_valid_config PASSED [ 88%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_verbose_and_shorthand_way PASSED [ 88%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_extends PASSED       [ 88%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_extends_file_defaults_to_self PASSED [ 88%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_empty_dictionary PASSED [ 88%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_invalid_key PASSED [ 88%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_missing_service_key PASSED [ 89%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_no_file_key_no_filename_set PASSED [ 89%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_sub_property_key PASSED [ 89%]

01:37:27 tests/integration/state_test.py::ServiceStateTest::test_image_changed_to_build PASSED [ 37%]

01:37:27 tests/integration/state_test.py::ServiceStateTest::test_trigger_create PASSED [ 37%]

01:37:27 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_twice_with_mount PASSED [ 29%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_valid_config PASSED [ 89%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_defined_version_passes PASSED [ 89%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_depends_on PASSED [ 89%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_environment_and_env_files PASSED [ 89%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_healthcheck PASSED [ 89%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_mixed_versions_is_error PASSED [ 89%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_ports PASSED [ 89%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_security_opt PASSED [ 89%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_invalid_links_in_extended_service PASSED [ 89%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_invalid_net_in_extended_service PASSED [ 90%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_invalid_volumes_from_in_extended_service PASSED [ 90%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_load_config_runs_interpolation_in_extended_service PASSED [ 90%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_load_throws_error_when_base_service_does_not_exist PASSED [ 90%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_merging_env_labels_ulimits PASSED [ 90%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_nested PASSED        [ 90%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_parent_build_path_dne PASSED [ 90%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_partial_service_config_in_extends_is_still_valid PASSED [ 90%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_self_referencing_file PASSED [ 90%]

01:37:27 tests/unit/config/config_test.py::ExtendsTest::test_volume_path PASSED   [ 90%]

01:37:27 tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_absolute PASSED [ 90%]

01:37:27 tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_normal PASSED [ 91%]

01:37:27 tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_with_tilde PASSED [ 91%]

01:37:27 tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_root_mount PASSED [ 91%]

01:37:27 tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_windows_path PASSED [ 91%]

01:37:27 tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_windows_path_in_container PASSED [ 91%]

01:37:27 tests/unit/config/config_test.py::BuildPathTest::test_absolute_path PASSED [ 91%]

01:37:27 tests/unit/config/config_test.py::BuildPathTest::test_from_file PASSED   [ 91%]

01:37:27 tests/unit/config/config_test.py::BuildPathTest::test_from_file_override_dir PASSED [ 91%]

01:37:27 tests/unit/config/config_test.py::BuildPathTest::test_invalid_url_in_build_path PASSED [ 91%]

01:37:28 tests/unit/config/config_test.py::BuildPathTest::test_nonexistent_path PASSED [ 91%]

01:37:28 tests/unit/config/config_test.py::BuildPathTest::test_relative_path PASSED [ 91%]

01:37:28 tests/unit/config/config_test.py::BuildPathTest::test_valid_url_in_build_path PASSED [ 92%]

01:37:28 tests/unit/config/config_test.py::HealthcheckTest::test_disable PASSED   [ 92%]

01:37:28 tests/unit/config/config_test.py::HealthcheckTest::test_disable_with_other_config_is_invalid PASSED [ 92%]

01:37:28 tests/unit/config/config_test.py::HealthcheckTest::test_healthcheck PASSED [ 92%]

01:37:28 tests/unit/config/config_test.py::HealthcheckTest::test_healthcheck_with_invalid_test PASSED [ 92%]

01:37:28 tests/unit/config/config_test.py::GetDefaultConfigFilesTestCase::test_get_config_path_default_file_in_basedir PASSED [ 92%]

01:37:28 tests/unit/config/config_test.py::GetDefaultConfigFilesTestCase::test_get_config_path_default_file_in_parent_dir PASSED [ 92%]

01:37:28 tests/unit/config/config_test.py::SerializeTest::test_denormalize_depends_on_v2_1 PASSED [ 92%]

01:37:28 tests/unit/config/config_test.py::SerializeTest::test_denormalize_depends_on_v3 PASSED [ 92%]

01:37:28 tests/unit/config/config_test.py::SerializeTest::test_denormalize_healthcheck PASSED [ 92%]

01:37:28 tests/unit/config/config_test.py::SerializeTest::test_denormalize_image_has_digest PASSED [ 92%]

01:37:28 tests/unit/config/config_test.py::SerializeTest::test_denormalize_image_no_digest PASSED [ 92%]

01:37:28 tests/unit/config/config_test.py::SerializeTest::test_serialize_bool_string PASSED [ 93%]

01:37:28 tests/unit/config/config_test.py::SerializeTest::test_serialize_configs PASSED [ 93%]

01:37:28 tests/unit/config/config_test.py::SerializeTest::test_serialize_escape_dollar_sign PASSED [ 93%]

01:37:28 tests/unit/config/config_test.py::SerializeTest::test_serialize_escape_dont_interpolate PASSED [ 93%]

01:37:28 tests/unit/config/config_test.py::SerializeTest::test_serialize_external_false PASSED [ 93%]

01:37:28 tests/unit/config/config_test.py::SerializeTest::test_serialize_ports PASSED [ 93%]

01:37:28 tests/unit/config/config_test.py::SerializeTest::test_serialize_ports_with_ext_ip PASSED [ 93%]

01:37:28 tests/unit/config/config_test.py::SerializeTest::test_serialize_secrets PASSED [ 93%]

01:37:28 tests/unit/config/config_test.py::SerializeTest::test_serialize_time PASSED [ 93%]

01:37:28 tests/unit/config/config_test.py::SerializeTest::test_serialize_unicode_values PASSED [ 93%]

01:37:28 tests/unit/config/environment_test.py::EnvironmentTest::test_env_vars_from_file_bom PASSED [ 93%]

01:37:28 tests/unit/config/environment_test.py::EnvironmentTest::test_env_vars_from_file_whitespace PASSED [ 94%]

01:37:28 tests/unit/config/environment_test.py::EnvironmentTest::test_get_boolean PASSED [ 94%]

01:37:28 tests/unit/config/environment_test.py::EnvironmentTest::test_get_simple PASSED [ 94%]

01:37:28 tests/unit/config/environment_test.py::EnvironmentTest::test_get_undefined PASSED [ 94%]

01:37:28 tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_services PASSED [ 94%]

01:37:28 tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_volumes PASSED [ 94%]

01:37:28 tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_secrets PASSED [ 94%]

01:37:28 tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_v2 PASSED [ 94%]

01:37:28 tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_v3 PASSED [ 94%]

01:37:28 tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_invalid PASSED [ 94%]

01:37:28 tests/unit/config/interpolation_test.py::test_interpolate_environment_network_convert_types PASSED [ 94%]

01:37:28 tests/unit/config/interpolation_test.py::test_interpolate_environment_external_resource_convert_types PASSED [ 94%]

01:37:28 tests/unit/config/interpolation_test.py::test_interpolate_service_name_uses_dot PASSED [ 95%]

01:37:28 tests/unit/config/interpolation_test.py::test_escaped_interpolation PASSED [ 95%]

01:37:28 tests/unit/config/interpolation_test.py::test_invalid_interpolation PASSED [ 95%]

01:37:28 tests/unit/config/interpolation_test.py::test_interpolate_missing_no_default PASSED [ 95%]

01:37:28 tests/unit/config/interpolation_test.py::test_interpolate_with_value PASSED [ 95%]

01:37:28 tests/unit/config/interpolation_test.py::test_interpolate_missing_with_default PASSED [ 95%]

01:37:28 tests/unit/config/interpolation_test.py::test_interpolate_with_empty_and_default_value PASSED [ 95%]

01:37:28 tests/unit/config/interpolation_test.py::test_interpolate_mandatory_values PASSED [ 95%]

01:37:28 tests/unit/config/interpolation_test.py::test_interpolate_mandatory_no_err_msg PASSED [ 95%]

01:37:28 tests/unit/config/interpolation_test.py::test_interpolate_mixed_separators PASSED [ 95%]

01:37:28 tests/unit/config/interpolation_test.py::test_unbraced_separators PASSED [ 95%]

01:37:28 tests/unit/config/interpolation_test.py::test_interpolate_unicode_values PASSED [ 96%]

01:37:28 tests/unit/config/interpolation_test.py::test_interpolate_no_fallthrough PASSED [ 96%]

01:37:28 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_1 PASSED [ 96%]

01:37:28 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_2 PASSED [ 96%]

01:37:28 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_3 PASSED [ 96%]

01:37:28 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_4 PASSED [ 96%]

01:37:28 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_5 PASSED [ 96%]

01:37:28 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_6 PASSED [ 96%]

01:37:28 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_7 PASSED [ 96%]

01:37:28 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports PASSED [ 96%]

01:37:28 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports_2 PASSED [ 96%]

01:37:28 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports_3 PASSED [ 97%]

01:37:28 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_self_imports PASSED [ 97%]

01:37:28 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_depends_on_self PASSED [ 97%]

01:37:28 tests/unit/config/types_test.py::test_parse_extra_hosts_list PASSED      [ 97%]

01:37:28 tests/unit/config/types_test.py::test_parse_extra_hosts_dict PASSED      [ 97%]

01:37:28 tests/unit/config/types_test.py::TestServicePort::test_parse_dict PASSED [ 97%]

01:37:28 tests/unit/config/types_test.py::TestServicePort::test_parse_simple_target_port PASSED [ 97%]

01:37:28 tests/unit/config/types_test.py::TestServicePort::test_parse_complete_port_definition PASSED [ 97%]

01:37:28 tests/unit/config/types_test.py::TestServicePort::test_parse_ext_ip_no_published_port PASSED [ 97%]

01:37:28 tests/unit/config/types_test.py::TestServicePort::test_repr_published_port_0 PASSED [ 97%]

01:37:28 tests/unit/config/types_test.py::TestServicePort::test_parse_port_range PASSED [ 97%]

01:37:28 tests/unit/config/types_test.py::TestServicePort::test_parse_port_publish_range PASSED [ 97%]

01:37:28 tests/unit/config/types_test.py::TestServicePort::test_parse_invalid_port PASSED [ 98%]

01:37:28 tests/unit/config/types_test.py::TestServicePort::test_parse_invalid_publish_range PASSED [ 98%]

01:37:28 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_only_one_path PASSED [ 98%]

01:37:28 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_internal_and_external PASSED [ 98%]

01:37:28 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_with_mode PASSED [ 98%]

01:37:28 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_too_many_parts PASSED [ 98%]

01:37:28 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_absolute_path_normalized PASSED [ 98%]

01:37:28 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_absolute_path_native PASSED [ 98%]

01:37:28 tests/integration/state_test.py::ServiceStateTest::test_trigger_noop PASSED [ 37%]

01:37:28 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_internal_path_normalized PASSED [ 98%]

01:37:28 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_internal_path_native PASSED [ 98%]

01:37:28 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_just_drives_normalized PASSED [ 98%]

01:37:28 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_just_drives_native PASSED [ 99%]

01:37:28 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_mixed_notations_normalized PASSED [ 99%]

01:37:28 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_mixed_notations_native PASSED [ 99%]

01:37:28 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_from_service PASSED [ 99%]

01:37:28 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_from_container PASSED [ 99%]

01:37:28 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_invalid PASSED [ 99%]

01:37:28 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_service PASSED [ 99%]

01:37:28 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_service_with_mode PASSED [ 99%]

01:37:28 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_container PASSED [ 99%]

01:37:28 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_container_with_mode PASSED [ 99%]

01:37:28 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_invalid_type PASSED [ 99%]

01:37:28 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_containers_are_stopped PASSED [ 30%]

01:37:29 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_leaf PASSED [ 36%]

01:37:29 tests/integration/service_test.py::ServiceTest::test_duplicate_volume_trailing_slash PASSED [ 29%]

01:37:29 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_middle_always_recreate_deps PASSED [ 36%]

01:37:29 tests/integration/service_test.py::ServiceTest::test_empty_labels PASSED [ 29%]

01:37:30 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_build <- tests/integration/testcases.py PASSED [ 37%]

01:37:30 tests/integration/service_test.py::ServiceTest::test_env_from_file_combined_with_env PASSED [ 29%]

01:37:30 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_config_change PASSED [ 37%]

01:37:31 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_image_change PASSED [ 37%]

01:37:31 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_nonexistent_image_tag PASSED [ 38%]

01:37:32 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_anonymous_volume_recreate_then_renew PASSED [ 29%]

01:37:32 tests/integration/state_test.py::ServiceStateTest::test_trigger_start PASSED [ 38%]

01:37:32 tests/integration/volume_test.py::VolumeTest::test_create_volume PASSED  [ 38%]

01:37:32 tests/integration/volume_test.py::VolumeTest::test_create_volume_custom_name PASSED [ 38%]

01:37:32 tests/integration/volume_test.py::VolumeTest::test_exists <- tests/integration/testcases.py PASSED [ 38%]

01:37:32 tests/integration/volume_test.py::VolumeTest::test_exists_external <- tests/integration/testcases.py PASSED [ 38%]

01:37:32 tests/integration/volume_test.py::VolumeTest::test_exists_external_aliased <- tests/integration/testcases.py PASSED [ 38%]

01:37:32 tests/integration/volume_test.py::VolumeTest::test_external_aliased_volume <- tests/integration/testcases.py PASSED [ 38%]

01:37:32 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_middle PASSED [ 36%]

01:37:32 tests/integration/volume_test.py::VolumeTest::test_external_volume <- tests/integration/testcases.py PASSED [ 38%]

01:37:32 tests/integration/volume_test.py::VolumeTest::test_inspect_volume <- tests/integration/testcases.py PASSED [ 38%]

01:37:32 tests/integration/volume_test.py::VolumeTest::test_recreate_existing_volume PASSED [ 38%]

01:37:32 tests/integration/volume_test.py::VolumeTest::test_remove_volume <- tests/integration/testcases.py PASSED [ 39%]

01:37:32 tests/integration/volume_test.py::VolumeTest::test_volume_default_labels <- tests/integration/testcases.py PASSED [ 39%]

01:37:32 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_invalid PASSED [100%]

01:37:32 

01:37:32 ---------- coverage: platform linux2, python 2.7.16-final-0 ----------

01:37:32 Name                              Stmts   Miss Branch BrPart  Cover   Missing

01:37:32 -----------------------------------------------------------------------------

01:37:32 compose/__init__.py                   3      0      0      0   100%

01:37:32 compose/__main__.py                   4      4      0      0     0%   1-6

01:37:32 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

01:37:32 compose/cli/__init__.py               0      0      0      0   100%

01:37:32 compose/cli/colors.py                23      2     10      2    88%   37-38, 36->37, 48->exit

01:37:32 compose/cli/command.py               93     14     26      4    82%   71-81, 88, 125-130, 174, 70->71, 87->88, 124->125, 171->174

01:37:32 compose/cli/docker_client.py         75      5     24      2    93%   24, 98-99, 107, 123, 106->107, 122->123

01:37:32 compose/cli/docopt_command.py        38      4      8      2    87%   13-14, 29, 35, 28->29, 34->35

01:37:32 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

01:37:32 compose/cli/formatter.py             34      2      8      1    93%   17-18, 15->17

01:37:32 compose/cli/log_printer.py          144     14     50      6    89%   76, 103, 110-115, 162-164, 173, 226-229, 233-234, 253, 43->exit, 75->76, 98->103, 171->173, 225->226, 232->233

01:37:32 compose/cli/main.py                 695     90    292     40    84%   83-84, 86-87, 168, 328, 360-362, 445, 505, 509, 514-515, 525-554, 566, 584-586, 657-658, 696-697, 715, 736-737, 749, 772, 790, 837, 1069, 1078, 1104-1113, 1153-1156, 1164-1168, 1170-1175, 1198, 1220-1249, 1256-1257, 1259-1261, 1276, 1282, 1466, 1484, 1500, 1504-1505, 1516, 1521, 1524, 1550, 1569-1571, 1581, 1592, 60->63, 82->83, 85->86, 167->168, 327->328, 359->360, 444->445, 504->505, 508->509, 519->525, 563->566, 583->584, 655->657, 714->715, 735->736, 748->749, 771->772, 827->837, 829->exit, 1068->1069, 1077->1078, 1163->1164, 1169->1170, 1197->1198, 1255->1256, 1258->1259, 1275->1276, 1281->1282, 1465->1466, 1483->1484, 1499->1500, 1515->1516, 1520->1521, 1523->1524, 1542->exit, 1549->1550, 1563->1571, 1565->1569, 1580->1581, 1590->1592

01:37:32 compose/cli/signals.py               23      0      4      2    93%   36->exit, 43->exit

01:37:32 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

01:37:32 compose/cli/verbose_proxy.py         35     12     10      0    69%   36-39, 42-47, 50-60

01:37:32 compose/config/__init__.py           13      0      0      0   100%

01:37:32 compose/config/config.py            826     30    388     18    95%   266, 277, 508, 621-622, 714, 757, 812-830, 952-953, 959, 979, 982, 1335, 1366, 1412, 265->266, 276->277, 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

01:37:32 compose/config/environment.py       100      7     34      4    92%   41, 104-107, 120, 127, 40->41, 103->104, 119->120, 126->127

01:37:32 compose/config/errors.py             25      2      0      0    92%   36-40

01:37:32 compose/config/interpolation.py     148      7     62      4    94%   66, 148, 196, 222, 227-229, 121->exit, 146->148, 195->196, 221->222

01:37:32 compose/config/serialize.py          97      1     50      2    98%   76, 75->76, 82->85

01:37:32 compose/config/sort_services.py      44      1     18      1    97%   57, 56->57

01:37:32 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

01:37:32 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

01:37:32 compose/const.py                     36      0      0      0   100%

01:37:32 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

01:37:32 compose/errors.py                    17      1      0      0    94%   12

01:37:32 compose/network.py                  190     19     92      5    87%   184, 186-200, 206, 224, 226, 183->184, 185->186, 205->206, 223->224, 225->226

01:37:32 compose/parallel.py                 199      2     56      1    99%   187, 326, 325->326

01:37:32 compose/progress_stream.py           79      8     40      9    86%   40, 71, 74, 80, 85, 90-91, 116, 39->40, 42->46, 53->57, 70->71, 73->74, 79->80, 84->85, 89->90, 112->116

01:37:32 compose/project.py                  424     29    170     16    92%   60, 156, 212-213, 254-255, 364-365, 378-381, 434, 485, 489, 615, 621, 624-627, 752-753, 759-762, 777, 782-785, 788, 809, 57->60, 152->156, 331->333, 362->364, 377->378, 433->434, 484->485, 488->489, 614->615, 620->621, 623->624, 671->exit, 755->762, 776->777, 781->782, 787->788

01:37:32 compose/service.py                  854     48    380     24    94%   271-272, 293, 366-369, 417-422, 428-430, 470-471, 485, 488, 506, 573, 618-619, 727, 946-947, 967-968, 1069, 1115, 1176, 1218, 1240-1255, 1295, 1334-1338, 1526, 1530, 1686, 216->exit, 269->271, 292->293, 427->428, 469->470, 484->485, 487->488, 505->506, 563->573, 722->727, 945->946, 966->967, 1068->1069, 1114->1115, 1175->1176, 1217->1218, 1294->1295, 1331->1334, 1525->1526, 1529->1530, 1578->exit, 1586->1585, 1623->1620, 1685->1686

01:37:32 compose/state.py                      0      0      0      0   100%

01:37:32 compose/timeparse.py                 22      0      4      0   100%

01:37:32 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

01:37:32 compose/version.py                    6      0      0      0   100%

01:37:32 compose/volume.py                   126      4     44      4    94%   150, 200, 211-212, 141->150, 199->200, 201->198, 209->211

01:37:32 -----------------------------------------------------------------------------

01:37:32 TOTAL                              5553    433   2224    203    90%

01:37:32 Coverage HTML written to dir coverage-html

01:37:32 

01:37:32 =========================== short test summary info ============================

01:37:32 XFAIL tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_rt

01:37:32   not supported by kernel

01:37:32 XFAIL tests/integration/service_test.py::ServiceTest::test_create_container_with_storage_opt

01:37:32   Not supported on most drivers

01:37:32 SKIP [1] tests/unit/cli/errors_test.py:90: Needs pywin32

01:37:32 SKIP [1] tests/acceptance/cli_test.py:2424: race condition between up and logs

01:37:32 SKIP [1] tests/acceptance/cli_test.py:2403: race condition between up and logs

01:37:32 SKIP [1] tests/unit/cli/errors_test.py:80: Needs pywin32

01:37:32 SKIP [1] tests/unit/cli/errors_test.py:70: Needs pywin32

01:37:32 SKIP [1] tests/integration/service_test.py:148: cpu_percent is not supported for Linux

01:37:32 SKIP [1] tests/acceptance/cli_test.py:2376: race condition between up and logs

01:37:32 SKIP [1] /code/tests/integration/testcases.py:167: This daemon does not support the 'nvidia'' runtime

01:37:32 SKIP [1] tests/integration/service_test.py:1635: Broken on 1.11.0 - 17.03.0

01:37:32 SKIP [1] tests/unit/cli/command_test.py:39: windows separator

01:37:32 SKIP [1] tests/unit/config/config_test.py:3777: windows paths

01:37:32 

01:37:32 ======= 1122 passed, 11 skipped, 2 xfailed, 3 xpassed in 789.06 seconds ========

01:37:32 ___________________________________ summary ____________________________________

01:37:32   py27: commands succeeded

01:37:32   congratulations :)

01:37:32 + on_exit
01:37:32 + [[ 0 != \0 ]]
01:37:32 + docker rm -vf compose-dind-19.03.2-rc1-jenkins-compose-PR-6850-2
01:37:32 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_host_volume_is_removed PASSED [ 30%]

01:37:32 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_anonymous_volume_renew PASSED [ 29%]

01:37:32 tests/unit/bundle_test.py::test_get_image_digest_exists PASSED           [ 39%]

01:37:32 compose-dind-19.03.2-rc1-jenkins-compose-PR-6850-2
01:37:33 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_invalid_volume_driver PASSED [ 18%]

01:37:33 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_blank_driver PASSED [ 18%]

01:37:33 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_driver <- tests/integration/testcases.py PASSED [ 18%]

01:37:33 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_driver_opts <- tests/integration/testcases.py PASSED [ 19%]

01:37:33 tests/integration/project_test.py::ProjectTest::test_net_from_container_v1 <- tests/integration/testcases.py PASSED [ 19%]

01:37:33 tests/integration/project_test.py::ProjectTest::test_net_from_service_v1 <- tests/integration/testcases.py PASSED [ 19%]

01:37:33 tests/integration/project_test.py::ProjectTest::test_network_mode_from_container <- tests/integration/testcases.py PASSED [ 19%]

01:37:33 tests/unit/bundle_test.py::test_get_image_digest_image_uses_digest PASSED [ 39%]

[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // withDockerRegistry
[Pipeline] }
[Pipeline] // node
[Pipeline] }
01:37:33 tests/unit/bundle_test.py::test_get_image_digest_from_repository PASSED  [ 39%]

01:37:34 tests/integration/project_test.py::ProjectTest::test_network_mode_from_service <- tests/integration/testcases.py PASSED [ 19%]

01:37:34 tests/integration/project_test.py::ProjectTest::test_parallel_pull_with_no_image PASSED [ 19%]

01:37:34 tests/unit/bundle_test.py::test_get_image_digest_no_image PASSED         [ 39%]

01:37:34 tests/unit/bundle_test.py::test_push_image_with_saved_digest PASSED      [ 39%]

01:37:34 tests/integration/project_test.py::ProjectTest::test_project_up PASSED   [ 19%]

01:37:34 tests/unit/bundle_test.py::test_push_image PASSED                        [ 39%]

01:37:34 tests/unit/bundle_test.py::test_to_bundle PASSED                         [ 39%]

01:37:34 tests/unit/bundle_test.py::test_convert_service_to_bundle PASSED         [ 39%]

01:37:34 tests/unit/bundle_test.py::test_set_command_and_args_none PASSED         [ 39%]

01:37:34 tests/unit/bundle_test.py::test_set_command_and_args_from_command PASSED [ 39%]

01:37:34 tests/unit/bundle_test.py::test_set_command_and_args_from_entrypoint PASSED [ 40%]

01:37:34 tests/unit/bundle_test.py::test_set_command_and_args_from_both PASSED    [ 40%]

01:37:34 tests/unit/bundle_test.py::test_make_service_networks_default PASSED     [ 40%]

01:37:34 tests/unit/bundle_test.py::test_make_service_networks PASSED             [ 40%]

01:37:34 tests/unit/bundle_test.py::test_make_port_specs PASSED                   [ 40%]

01:37:34 tests/unit/bundle_test.py::test_make_port_spec_with_protocol PASSED      [ 40%]

01:37:34 tests/unit/bundle_test.py::test_make_port_spec_default_protocol PASSED   [ 40%]

01:37:34 tests/unit/cli_test.py::CLITestCase::test_command_help PASSED            [ 40%]

01:37:34 tests/unit/cli_test.py::CLITestCase::test_command_help_nonexistent PASSED [ 40%]

01:37:34 tests/unit/cli_test.py::CLITestCase::test_command_manual_and_service_ports_together PASSED [ 40%]

01:37:34 tests/unit/cli_test.py::CLITestCase::test_default_project_name PASSED    [ 40%]

01:37:34 tests/unit/cli_test.py::CLITestCase::test_get_project PASSED             [ 41%]

01:37:34 tests/unit/cli_test.py::CLITestCase::test_project_name_from_environment_new_var PASSED [ 41%]

01:37:34 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root PASSED [ 36%]

01:37:34 tests/unit/cli_test.py::CLITestCase::test_project_name_with_empty_environment_var PASSED [ 41%]

01:37:34 tests/unit/cli_test.py::CLITestCase::test_project_name_with_environment_file PASSED [ 41%]

01:37:34 tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_base_dir PASSED [ 41%]

01:37:34 tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_project_name PASSED [ 41%]

01:37:34 tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_uppercase_base_dir PASSED [ 41%]

01:37:35 tests/unit/cli_test.py::CLITestCase::test_run_interactive_passes_logs_false PASSED [ 41%]

01:37:35 tests/unit/cli_test.py::CLITestCase::test_run_service_with_restart_always PASSED [ 41%]

01:37:35 tests/unit/container_test.py::ContainerTest::test_environment PASSED     [ 41%]

01:37:35 tests/unit/container_test.py::ContainerTest::test_from_ps PASSED         [ 41%]

01:37:35 tests/unit/container_test.py::ContainerTest::test_from_ps_prefixed PASSED [ 42%]

01:37:35 tests/unit/container_test.py::ContainerTest::test_get PASSED             [ 42%]

01:37:35 tests/unit/container_test.py::ContainerTest::test_get_local_port PASSED  [ 42%]

01:37:35 tests/unit/container_test.py::ContainerTest::test_has_api_logs PASSED    [ 42%]

01:37:35 tests/unit/container_test.py::ContainerTest::test_human_readable_ports_none PASSED [ 42%]

01:37:35 tests/unit/container_test.py::ContainerTest::test_human_readable_ports_public_and_private PASSED [ 42%]

01:37:35 tests/unit/container_test.py::ContainerTest::test_human_readable_states_healthy PASSED [ 42%]

01:37:35 tests/unit/container_test.py::ContainerTest::test_human_readable_states_no_health PASSED [ 42%]

01:37:35 tests/unit/container_test.py::ContainerTest::test_human_readable_states_starting PASSED [ 42%]

01:37:35 tests/unit/container_test.py::ContainerTest::test_inspect_if_not_inspected PASSED [ 42%]

01:37:35 tests/unit/container_test.py::ContainerTest::test_name PASSED            [ 42%]

01:37:35 tests/unit/container_test.py::ContainerTest::test_name_without_project PASSED [ 42%]

01:37:35 tests/unit/container_test.py::ContainerTest::test_name_without_project_custom_container_name PASSED [ 43%]

01:37:35 tests/unit/container_test.py::ContainerTest::test_name_without_project_one_off PASSED [ 43%]

01:37:35 tests/unit/container_test.py::ContainerTest::test_number PASSED          [ 43%]

01:37:35 tests/unit/container_test.py::ContainerTest::test_short_id PASSED        [ 43%]

01:37:35 tests/unit/container_test.py::GetContainerNameTestCase::test_get_container_name PASSED [ 43%]

01:37:35 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_driver_mismatch PASSED [ 43%]

01:37:35 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_null_remote PASSED [ 43%]

01:37:35 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_null_remote_ipam_options PASSED [ 43%]

01:37:35 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_options_mismatch PASSED [ 43%]

01:37:35 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_success PASSED [ 43%]

01:37:35 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_whitelist PASSED [ 43%]

01:37:35 tests/unit/network_test.py::NetworkTest::test_check_remote_network_labels_mismatch PASSED [ 44%]

01:37:35 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute PASSED  [ 44%]

01:37:35 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_deps PASSED [ 44%]

01:37:35 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_global_limit PASSED [ 44%]

01:37:35 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_limit PASSED [ 44%]

01:37:35 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_upstream_errors PASSED [ 44%]

01:37:35 tests/unit/parallel_test.py::test_parallel_execute_alignment PASSED      [ 44%]

01:37:35 tests/unit/parallel_test.py::test_parallel_execute_ansi PASSED           [ 44%]

01:37:35 tests/unit/parallel_test.py::test_parallel_execute_noansi PASSED         [ 44%]

01:37:35 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_get_digest_from_pull PASSED [ 44%]

01:37:35 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_get_digest_from_push PASSED [ 44%]

01:37:35 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_mismatched_encoding_stream_write PASSED [ 44%]

01:37:35 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output PASSED [ 45%]

01:37:35 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_div_zero PASSED [ 45%]

01:37:35 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_no_progress_event_no_tty PASSED [ 45%]

01:37:35 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_null_total PASSED [ 45%]

01:37:35 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_progress_event_no_tty PASSED [ 45%]

01:37:35 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_progress_event_tty PASSED [ 45%]

01:37:36 tests/unit/project_test.py::ProjectTest::test_avoid_multiple_push PASSED [ 45%]

01:37:36 tests/unit/project_test.py::ProjectTest::test_build_container_operation_with_timeout_func_does_not_mutate_options_with_timeout PASSED [ 45%]

01:37:36 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_image_volume_masks_config PASSED [ 30%]

01:37:37 tests/unit/project_test.py::ProjectTest::test_container_without_name PASSED [ 45%]

01:37:37 tests/unit/project_test.py::ProjectTest::test_down_with_no_resources PASSED [ 45%]

01:37:37 tests/unit/project_test.py::ProjectTest::test_error_parallel_pull PASSED [ 45%]

01:37:37 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_middle_always_recreate_deps PASSED [ 36%]

01:37:37 tests/unit/project_test.py::ProjectTest::test_events PASSED              [ 46%]

01:37:38 tests/unit/project_test.py::ProjectTest::test_events_legacy PASSED       [ 46%]

01:37:38 tests/unit/project_test.py::ProjectTest::test_from_config_v1 PASSED      [ 46%]

01:37:38 tests/integration/project_test.py::ProjectTest::test_project_up_config_scale PASSED [ 19%]

01:37:38 tests/unit/project_test.py::ProjectTest::test_from_config_v2 PASSED      [ 46%]

01:37:38 tests/unit/project_test.py::ProjectTest::test_get_service PASSED         [ 46%]

01:37:39 tests/unit/project_test.py::ProjectTest::test_get_services_removes_duplicates_following_links PASSED [ 46%]

01:37:39 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_image_with_volume_is_removed PASSED [ 29%]

01:37:39 tests/unit/project_test.py::ProjectTest::test_get_services_returns_all_services_without_args PASSED [ 46%]

01:37:39 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate PASSED [ 29%]

01:37:39 tests/unit/project_test.py::ProjectTest::test_get_services_returns_listed_services_with_args PASSED [ 46%]

01:37:40 tests/unit/project_test.py::ProjectTest::test_get_services_with_include_links PASSED [ 46%]

01:37:40 tests/unit/project_test.py::ProjectTest::test_net_unset PASSED           [ 46%]

01:37:40 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_invalid_volume_driver PASSED [ 18%]

01:37:40 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_blank_driver PASSED [ 18%]

01:37:40 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_driver PASSED [ 18%]

01:37:40 tests/integration/project_test.py::ProjectTest::test_initialize_volumes_updated_driver_opts PASSED [ 19%]

01:37:40 tests/integration/project_test.py::ProjectTest::test_net_from_container_v1 PASSED [ 19%]

01:37:40 tests/integration/project_test.py::ProjectTest::test_net_from_service_v1 PASSED [ 19%]

01:37:40 tests/unit/project_test.py::ProjectTest::test_no_such_service_unicode PASSED [ 46%]

01:37:40 tests/integration/project_test.py::ProjectTest::test_network_mode_from_container PASSED [ 19%]

01:37:40 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_with_image_declared_volume PASSED [ 30%]

01:37:40 tests/unit/project_test.py::ProjectTest::test_no_warning_in_normal_mode PASSED [ 47%]

01:37:41 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_change_mount_target PASSED [ 29%]

01:37:41 tests/unit/project_test.py::ProjectTest::test_no_warning_on_stop PASSED  [ 47%]

01:37:41 tests/integration/project_test.py::ProjectTest::test_project_up_healthy_dependency PASSED [ 19%]

01:37:41 tests/unit/project_test.py::ProjectTest::test_no_warning_with_no_swarm_info PASSED [ 47%]

01:37:41 tests/unit/project_test.py::ProjectTest::test_project_platform_value PASSED [ 47%]

01:37:41 tests/integration/project_test.py::ProjectTest::test_project_up_ignore_orphans PASSED [ 19%]

01:37:41 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root PASSED [ 36%]

01:37:42 tests/integration/project_test.py::ProjectTest::test_network_mode_from_service PASSED [ 19%]

01:37:42 tests/integration/project_test.py::ProjectTest::test_parallel_pull_with_no_image PASSED [ 19%]

01:37:42 tests/unit/project_test.py::ProjectTest::test_use_net_from_container PASSED [ 47%]

01:37:42 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_twice PASSED [ 29%]

01:37:42 tests/unit/project_test.py::ProjectTest::test_use_net_from_service PASSED [ 47%]

01:37:42 tests/integration/project_test.py::ProjectTest::test_project_up_implicit_volume_driver PASSED [ 19%]

01:37:42 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root_always_recreate_deps PASSED [ 36%]

01:37:42 tests/unit/project_test.py::ProjectTest::test_use_volumes_from_container PASSED [ 47%]

01:37:42 tests/integration/project_test.py::ProjectTest::test_project_up PASSED   [ 19%]

01:37:43 tests/unit/project_test.py::ProjectTest::test_use_volumes_from_service_container PASSED [ 47%]

01:37:43 tests/unit/project_test.py::ProjectTest::test_use_volumes_from_service_no_container PASSED [ 47%]

Terminated
01:37:43 tests/unit/project_test.py::ProjectTest::test_uses_default_network_false PASSED [ 47%]

01:37:43 tests/unit/project_test.py::ProjectTest::test_uses_default_network_true PASSED [ 47%]

01:37:44 tests/integration/project_test.py::ProjectTest::test_project_up_logging_with_multiple_files PASSED [ 20%]

01:37:44 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_with_image_declared_volume_renew PASSED [ 30%]

01:37:44 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_twice_with_mount PASSED [ 29%]

01:37:44 tests/unit/service_test.py::ServiceTest::test_build_does_not_pull PASSED [ 47%]

01:37:44 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_containers_are_stopped PASSED [ 30%]

01:37:44 tests/unit/service_test.py::ServiceTest::test_build_isolation_from_build_override_service_config PASSED [ 48%]

01:37:44 tests/unit/service_test.py::ServiceTest::test_build_service_with_proxy_config PASSED [ 48%]

01:37:45 tests/unit/service_test.py::ServiceTest::test_build_volume_options_duplicate_binds PASSED [ 48%]

01:37:45 tests/unit/service_test.py::ServiceTest::test_build_with_default_platform PASSED [ 48%]

01:37:45 tests/integration/project_test.py::ProjectTest::test_project_up_name_starts_with_illegal_char <- tests/integration/testcases.py PASSED [ 20%]

01:37:45 tests/unit/service_test.py::ServiceTest::test_build_with_isolation_from_service_config PASSED [ 48%]

01:37:45 tests/unit/service_test.py::ServiceTest::test_build_with_override_build_args PASSED [ 48%]

01:37:46 tests/integration/project_test.py::ProjectTest::test_project_up_named_volumes_in_binds PASSED [ 20%]

01:37:46 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root_no_recreate PASSED [ 36%]

01:37:46 tests/unit/service_test.py::ServiceTest::test_build_with_platform PASSED [ 48%]

01:37:46 tests/unit/service_test.py::ServiceTest::test_cgroup_parent PASSED       [ 48%]

01:37:46 tests/unit/service_test.py::ServiceTest::test_config_dict PASSED         [ 48%]

01:37:47 tests/unit/service_test.py::ServiceTest::test_config_dict_with_network_mode_from_container PASSED [ 48%]

01:37:47 tests/unit/service_test.py::ServiceTest::test_config_hash_matches_label PASSED [ 48%]

01:37:47 tests/integration/project_test.py::ProjectTest::test_project_up_networks PASSED [ 20%]

01:37:47 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_without_start PASSED [ 30%]

01:37:47 tests/unit/service_test.py::ServiceTest::test_container_without_name PASSED [ 49%]

01:37:47 tests/unit/service_test.py::ServiceTest::test_containers PASSED          [ 49%]

01:37:48 tests/integration/project_test.py::ProjectTest::test_project_up_no_healthcheck_dependency PASSED [ 20%]

01:37:48 tests/integration/service_test.py::ServiceTest::test_expose_does_not_publish_ports PASSED [ 30%]

01:37:48 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root_always_recreate_deps PASSED [ 36%]

01:37:48 tests/unit/service_test.py::ServiceTest::test_containers_with_containers PASSED [ 49%]

01:37:48 tests/unit/service_test.py::ServiceTest::test_create_container PASSED    [ 49%]

01:37:48 tests/integration/service_test.py::ServiceTest::test_group_add_value PASSED [ 30%]

01:37:48 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_host_volume_is_removed PASSED [ 30%]

01:37:49 tests/unit/service_test.py::ServiceTest::test_create_when_removed_containers_are_listed PASSED [ 49%]

01:37:49 tests/integration/service_test.py::ServiceTest::test_labels PASSED       [ 30%]

01:37:49 tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_force_build PASSED [ 49%]

01:37:49 tests/integration/project_test.py::ProjectTest::test_project_up_orphans PASSED [ 20%]

01:37:49 tests/integration/project_test.py::ProjectTest::test_project_up_config_scale PASSED [ 19%]

01:37:49 tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_no_build PASSED [ 49%]

01:37:49 tests/integration/service_test.py::ServiceTest::test_log_drive_empty_default_jsonfile PASSED [ 30%]

01:37:49 tests/integration/service_test.py::ServiceTest::test_log_drive_invalid SKIPPED [ 30%]

01:37:49 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root_no_recreate PASSED [ 36%]

01:37:49 tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_no_build_but_needs_build PASSED [ 49%]

01:37:49 tests/integration/project_test.py::ProjectTest::test_project_up_port_mappings_with_multiple_files PASSED [ 20%]

01:37:50 tests/unit/service_test.py::ServiceTest::test_get_container PASSED       [ 49%]

01:37:50 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_dependency_added PASSED [ 37%]

01:37:50 tests/integration/service_test.py::ServiceTest::test_log_drive_none PASSED [ 31%]

01:37:50 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_does_not_mutate_options PASSED [ 49%]

01:37:50 tests/integration/service_test.py::ServiceTest::test_mem_reservation PASSED [ 31%]

01:37:50 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_no_affinity_without_binds PASSED [ 49%]

01:37:51 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_sets_affinity_with_binds PASSED [ 50%]

01:37:51 tests/integration/project_test.py::ProjectTest::test_project_up_recreate_with_tmpfs_volume PASSED [ 20%]

01:37:51 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_with_name_option PASSED [ 50%]

01:37:51 tests/integration/service_test.py::ServiceTest::test_mem_swappiness PASSED [ 31%]

01:37:51 tests/unit/service_test.py::ServiceTest::test_get_container_not_found PASSED [ 50%]

01:37:51 tests/integration/project_test.py::ProjectTest::test_project_up_seccomp_profile PASSED [ 20%]

01:37:51 tests/integration/project_test.py::ProjectTest::test_project_up_healthy_dependency PASSED [ 19%]

01:37:51 tests/unit/service_test.py::ServiceTest::test_get_create_options_with_proxy_config PASSED [ 50%]

01:37:51 tests/integration/service_test.py::ServiceTest::test_network_mode_bridged PASSED [ 31%]

01:37:52 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_image_volume_masks_config PASSED [ 30%]

01:37:52 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_container PASSED [ 50%]

01:37:52 tests/integration/service_test.py::ServiceTest::test_network_mode_host PASSED [ 31%]

01:37:52 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_container_read_only PASSED [ 50%]

01:37:52 tests/integration/service_test.py::ServiceTest::test_network_mode_none PASSED [ 31%]

01:37:52 tests/integration/project_test.py::ProjectTest::test_project_up_ignore_orphans PASSED [ 19%]

01:37:53 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_container_exists PASSED [ 50%]

01:37:53 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_dependency_added PASSED [ 37%]

01:37:53 tests/integration/service_test.py::ServiceTest::test_oom_score_adj_value PASSED [ 31%]

01:37:53 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_container_exists_with_flags PASSED [ 50%]

01:37:53 tests/integration/project_test.py::ProjectTest::test_project_up_starts_depends PASSED [ 20%]

01:37:53 tests/integration/service_test.py::ServiceTest::test_pid_mode_host PASSED [ 31%]

01:37:54 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_no_container PASSED [ 50%]

01:37:54 tests/integration/project_test.py::ProjectTest::test_project_up_implicit_volume_driver PASSED [ 19%]

01:37:54 tests/unit/service_test.py::ServiceTest::test_image_name_default PASSED  [ 50%]

01:37:54 tests/integration/service_test.py::ServiceTest::test_pid_mode_none_defined PASSED [ 31%]

01:37:54 tests/unit/service_test.py::ServiceTest::test_image_name_from_config PASSED [ 50%]

01:37:54 tests/unit/service_test.py::ServiceTest::test_log_opt PASSED             [ 50%]

01:37:55 tests/integration/service_test.py::ServiceTest::test_port_with_explicit_interface PASSED [ 31%]

01:37:55 tests/integration/project_test.py::ProjectTest::test_project_up_starts_links PASSED [ 20%]

01:37:55 tests/unit/service_test.py::ServiceTest::test_mem_reservation PASSED     [ 51%]

01:37:55 tests/unit/service_test.py::ServiceTest::test_memory_swap_limit PASSED   [ 51%]

01:37:55 tests/integration/project_test.py::ProjectTest::test_project_up_logging_with_multiple_files PASSED [ 20%]

01:37:55 tests/integration/service_test.py::ServiceTest::test_project_is_added_to_container_name PASSED [ 31%]

01:37:55 tests/unit/service_test.py::ServiceTest::test_no_default_hostname_when_not_using_networking PASSED [ 51%]

01:37:56 tests/integration/project_test.py::ProjectTest::test_project_up_starts_uncreated_services PASSED [ 21%]

01:37:56 tests/unit/service_test.py::ServiceTest::test_only_log_warning_when_host_ports_clash PASSED [ 51%]

01:37:56 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_with_image_declared_volume PASSED [ 30%]

01:37:56 tests/unit/service_test.py::ServiceTest::test_parse_proxy_config PASSED  [ 51%]

01:37:56 tests/unit/service_test.py::ServiceTest::test_parse_proxy_config_per_host PASSED [ 51%]

01:37:56 tests/unit/service_test.py::ServiceTest::test_parse_repository_tag PASSED [ 51%]

01:37:56 tests/integration/service_test.py::ServiceTest::test_recreate_preserves_volume_with_trailing_slash PASSED [ 31%]

01:37:57 tests/unit/service_test.py::ServiceTest::test_pull_image PASSED          [ 51%]

01:37:57 tests/integration/project_test.py::ProjectTest::test_project_up_name_starts_with_illegal_char PASSED [ 20%]

01:37:57 tests/unit/service_test.py::ServiceTest::test_pull_image_digest PASSED   [ 51%]

01:37:57 tests/unit/service_test.py::ServiceTest::test_pull_image_no_tag PASSED   [ 51%]

01:37:57 tests/integration/project_test.py::ProjectTest::test_project_up_unhealthy_dependency PASSED [ 21%]

01:37:58 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_dependency_removed PASSED [ 37%]

01:37:58 tests/unit/service_test.py::ServiceTest::test_pull_image_with_default_platform PASSED [ 51%]

01:37:58 tests/unit/service_test.py::ServiceTest::test_pull_image_with_platform PASSED [ 52%]

01:37:58 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_dependency_removed PASSED [ 37%]

01:37:58 tests/integration/project_test.py::ProjectTest::test_project_up_volumes PASSED [ 21%]

01:37:58 tests/integration/project_test.py::ProjectTest::test_project_up_named_volumes_in_binds PASSED [ 20%]

01:37:58 tests/unit/service_test.py::ServiceTest::test_pull_image_with_platform_unsupported_api PASSED [ 52%]

01:37:59 tests/unit/service_test.py::ServiceTest::test_recreate_container PASSED  [ 52%]

01:37:59 tests/unit/service_test.py::ServiceTest::test_recreate_container_with_timeout PASSED [ 52%]

01:37:59 tests/unit/service_test.py::ServiceTest::test_remove_image_all_does_remove PASSED [ 52%]

01:38:00 tests/unit/service_test.py::ServiceTest::test_remove_image_local_with_image_name_doesnt_remove PASSED [ 52%]

01:38:00 tests/integration/project_test.py::ProjectTest::test_project_up_networks PASSED [ 20%]

01:38:00 tests/integration/service_test.py::ServiceTest::test_recreate_volume_to_mount PASSED [ 32%]

01:38:00 tests/integration/project_test.py::ProjectTest::test_project_up_with_added_secrets PASSED [ 21%]

01:38:00 tests/unit/service_test.py::ServiceTest::test_remove_image_local_without_image_name_does_remove PASSED [ 52%]

01:38:00 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_with_image_declared_volume_renew PASSED [ 30%]

01:38:00 tests/unit/service_test.py::ServiceTest::test_remove_image_none PASSED   [ 52%]

01:38:00 tests/integration/service_test.py::ServiceTest::test_resolve_env PASSED  [ 32%]

01:38:00 tests/unit/service_test.py::ServiceTest::test_remove_image_with_error PASSED [ 52%]

01:38:00 tests/integration/project_test.py::ProjectTest::test_project_up_with_network_internal PASSED [ 21%]

01:38:01 tests/integration/project_test.py::ProjectTest::test_project_up_no_healthcheck_dependency PASSED [ 20%]

01:38:01 tests/unit/service_test.py::ServiceTest::test_remove_non_existing_image PASSED [ 52%]

01:38:01 tests/integration/service_test.py::ServiceTest::test_restart_always_value PASSED [ 32%]

01:38:01 tests/unit/service_test.py::ServiceTest::test_self_reference_external_link PASSED [ 52%]

01:38:01 tests/integration/project_test.py::ProjectTest::test_project_up_with_network_label PASSED [ 21%]

01:38:01 tests/integration/service_test.py::ServiceTest::test_restart_on_failure_value PASSED [ 32%]

01:38:02 tests/unit/service_test.py::ServiceTest::test_service_ignore_default_platform_with_unsupported_api PASSED [ 52%]

01:38:02 tests/unit/service_test.py::ServiceTest::test_service_platform_precedence PASSED [ 53%]

01:38:02 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_container_port PASSED [ 53%]

01:38:02 tests/integration/project_test.py::ProjectTest::test_project_up_with_no_deps PASSED [ 21%]

01:38:02 tests/integration/project_test.py::ProjectTest::test_project_up_orphans PASSED [ 20%]

01:38:02 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_container_port_range PASSED [ 53%]

01:38:03 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_and_port PASSED [ 53%]

01:38:03 tests/integration/service_test.py::ServiceTest::test_scale PASSED        [ 32%]

01:38:03 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_and_port_range PASSED [ 53%]

01:38:03 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_no_port PASSED [ 53%]

01:38:03 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_without_start PASSED [ 30%]

01:38:03 tests/integration/service_test.py::ServiceTest::test_expose_does_not_publish_ports PASSED [ 30%]

01:38:03 tests/integration/project_test.py::ProjectTest::test_project_up_with_no_recreate_running PASSED [ 21%]

01:38:03 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_no_port_range PASSED [ 53%]

01:38:03 tests/integration/project_test.py::ProjectTest::test_project_up_port_mappings_with_multiple_files PASSED [ 20%]

01:38:04 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_port PASSED [ 53%]

01:38:04 tests/integration/service_test.py::ServiceTest::test_scale_sets_ports PASSED [ 32%]

01:38:04 tests/integration/service_test.py::ServiceTest::test_group_add_value PASSED [ 30%]

01:38:04 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_port_range PASSED [ 53%]

01:38:04 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_service_removed_while_down PASSED [ 37%]

01:38:04 tests/integration/service_test.py::ServiceTest::test_labels PASSED       [ 30%]

01:38:04 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_service_removed_while_down PASSED [ 37%]

01:38:04 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_no_ports PASSED [ 53%]

01:38:04 tests/unit/service_test.py::ServiceTest::test_split_domainname_both PASSED [ 53%]

01:38:05 tests/integration/service_test.py::ServiceTest::test_scale_with_api_error PASSED [ 32%]

01:38:05 tests/integration/project_test.py::ProjectTest::test_project_up_with_no_recreate_stopped PASSED [ 21%]

01:38:05 tests/integration/project_test.py::ProjectTest::test_project_up_recreate_with_tmpfs_volume PASSED [ 20%]

01:38:05 tests/integration/service_test.py::ServiceTest::test_log_drive_empty_default_jsonfile PASSED [ 30%]

01:38:05 tests/integration/service_test.py::ServiceTest::test_log_drive_invalid SKIPPED [ 30%]

01:38:05 tests/unit/service_test.py::ServiceTest::test_split_domainname_fqdn PASSED [ 54%]

01:38:05 tests/integration/service_test.py::ServiceTest::test_scale_with_custom_container_name_outputs_warning PASSED [ 32%]

01:38:05 tests/unit/service_test.py::ServiceTest::test_split_domainname_none PASSED [ 54%]

01:38:05 tests/integration/service_test.py::ServiceTest::test_log_drive_none PASSED [ 31%]

01:38:05 tests/unit/service_test.py::ServiceTest::test_split_domainname_weird PASSED [ 54%]

01:38:06 tests/integration/service_test.py::ServiceTest::test_scale_with_desired_number_already_achieved PASSED [ 32%]

01:38:06 tests/unit/service_test.py::ServiceTest::test_stop_grace_period PASSED   [ 54%]

01:38:06 tests/integration/project_test.py::ProjectTest::test_project_up_with_secrets PASSED [ 21%]

01:38:06 tests/integration/project_test.py::ProjectTest::test_project_up_seccomp_profile PASSED [ 20%]

01:38:06 tests/unit/service_test.py::ServiceTest::test_volumes_order_is_preserved PASSED [ 54%]

01:38:06 tests/integration/service_test.py::ServiceTest::test_mem_reservation PASSED [ 31%]

01:38:06 tests/unit/service_test.py::TestServiceNetwork::test_connect_container_to_networks_short_aliase_exists PASSED [ 54%]

01:38:06 tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_dict PASSED [ 54%]

01:38:06 tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_integers_and_dicts PASSED [ 54%]

01:38:06 tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_ints PASSED [ 54%]

01:38:06 tests/integration/project_test.py::ProjectTest::test_project_up_with_volume_labels PASSED [ 21%]

01:38:07 tests/unit/service_test.py::NetTestCase::test_network_mode PASSED        [ 54%]

01:38:07 tests/integration/service_test.py::ServiceTest::test_mem_swappiness PASSED [ 31%]

01:38:07 tests/integration/service_test.py::ServiceTest::test_scale_with_immediate_exit PASSED [ 32%]

01:38:07 tests/integration/service_test.py::ServiceTest::test_network_mode_bridged PASSED [ 31%]

01:38:07 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_service_removed_while_up PASSED [ 37%]

01:38:07 tests/unit/service_test.py::NetTestCase::test_network_mode_container PASSED [ 54%]

01:38:07 tests/unit/service_test.py::NetTestCase::test_network_mode_service PASSED [ 55%]

01:38:07 tests/integration/project_test.py::ProjectTest::test_project_up_without_all_services PASSED [ 21%]

01:38:07 tests/integration/service_test.py::ServiceTest::test_network_mode_host PASSED [ 31%]

01:38:08 tests/integration/service_test.py::ServiceTest::test_scale_with_stopped_containers PASSED [ 32%]

01:38:08 tests/unit/service_test.py::NetTestCase::test_network_mode_service_no_containers PASSED [ 55%]

01:38:08 tests/unit/service_test.py::ServicePortsTest::test_formatted_ports PASSED [ 55%]

01:38:08 tests/integration/service_test.py::ServiceTest::test_network_mode_none PASSED [ 31%]

01:38:08 tests/unit/service_test.py::ServiceVolumesTest::test_build_volume_binding PASSED [ 55%]

01:38:08 tests/unit/service_test.py::ServiceVolumesTest::test_create_with_special_volume_mode PASSED [ 55%]

01:38:08 tests/integration/service_test.py::ServiceTest::test_oom_score_adj_value PASSED [ 31%]

01:38:08 tests/integration/project_test.py::ProjectTest::test_project_up_starts_depends PASSED [ 20%]

01:38:08 tests/unit/service_test.py::ServiceVolumesTest::test_get_container_create_options_with_different_host_path_in_container_json PASSED [ 55%]

01:38:09 tests/unit/service_test.py::ServiceVolumesTest::test_get_container_data_volumes PASSED [ 55%]

01:38:09 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_up PASSED [ 37%]

01:38:09 tests/integration/service_test.py::ServiceTest::test_pid_mode_host PASSED [ 31%]

01:38:09 tests/unit/service_test.py::ServiceVolumesTest::test_merge_volume_bindings PASSED [ 55%]

01:38:09 tests/integration/service_test.py::ServiceTest::test_scale_with_stopped_containers_and_needing_creation PASSED [ 33%]

01:38:09 tests/unit/service_test.py::ServiceVolumesTest::test_mount_same_host_path_to_two_volumes PASSED [ 55%]

01:38:09 tests/integration/service_test.py::ServiceTest::test_scale_with_unexpected_exception PASSED [ 33%]

01:38:09 tests/integration/project_test.py::ProjectTest::test_recreate_preserves_mounts PASSED [ 22%]

01:38:09 tests/integration/project_test.py::ProjectTest::test_project_up_starts_links PASSED [ 20%]

01:38:09 tests/integration/service_test.py::ServiceTest::test_pid_mode_none_defined PASSED [ 31%]

01:38:09 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_no_warning_with_container_only_option PASSED [ 55%]

01:38:10 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_service_removed_while_up PASSED [ 37%]

01:38:10 tests/integration/service_test.py::ServiceTest::test_split_env PASSED    [ 33%]

01:38:10 tests/integration/service_test.py::ServiceTest::test_port_with_explicit_interface PASSED [ 31%]

01:38:10 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_no_warning_with_same_path PASSED [ 55%]

01:38:10 tests/integration/state_test.py::ServiceStateTest::test_image_changed_to_build PASSED [ 37%]

01:38:10 tests/integration/state_test.py::ServiceStateTest::test_trigger_create PASSED [ 37%]

01:38:10 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_volume_no_warning_when_no_container_volumes PASSED [ 55%]

01:38:10 tests/integration/service_test.py::ServiceTest::test_start_container_becomes_privileged PASSED [ 33%]

01:38:10 tests/integration/service_test.py::ServiceTest::test_project_is_added_to_container_name PASSED [ 31%]

01:38:10 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_volume_when_masked PASSED [ 56%]

01:38:11 tests/integration/project_test.py::ProjectTest::test_recreate_preserves_volumes PASSED [ 22%]

01:38:11 tests/integration/project_test.py::ProjectTest::test_project_up_starts_uncreated_services PASSED [ 21%]

01:38:11 tests/integration/state_test.py::ServiceStateTest::test_trigger_noop PASSED [ 37%]

01:38:11 tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes PASSED [ 56%]

01:38:11 tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes_abspath PASSED [ 56%]

01:38:11 tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes_no_target PASSED [ 56%]

01:38:11 tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_unix_path PASSED [ 56%]

01:38:11 tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_url_no_prefix PASSED [ 56%]

01:38:11 tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_windows_path PASSED [ 56%]

01:38:11 tests/unit/split_buffer_test.py::SplitBufferTest::test_chunked_line PASSED [ 56%]

01:38:11 tests/unit/split_buffer_test.py::SplitBufferTest::test_multiple_line_chunk PASSED [ 56%]

01:38:11 tests/unit/split_buffer_test.py::SplitBufferTest::test_no_end_separator PASSED [ 56%]

01:38:11 tests/unit/split_buffer_test.py::SplitBufferTest::test_preserves_unicode_sequences_within_lines PASSED [ 56%]

01:38:11 tests/unit/split_buffer_test.py::SplitBufferTest::test_single_line_chunks PASSED [ 57%]

01:38:11 tests/unit/timeparse_test.py::test_milli PASSED                          [ 57%]

01:38:11 tests/unit/timeparse_test.py::test_milli_float PASSED                    [ 57%]

01:38:11 tests/unit/timeparse_test.py::test_second_milli PASSED                   [ 57%]

01:38:11 tests/unit/timeparse_test.py::test_second_milli_micro PASSED             [ 57%]

01:38:11 tests/unit/timeparse_test.py::test_second PASSED                         [ 57%]

01:38:11 tests/unit/timeparse_test.py::test_second_as_float PASSED                [ 57%]

01:38:11 tests/unit/timeparse_test.py::test_minute PASSED                         [ 57%]

01:38:11 tests/unit/timeparse_test.py::test_hour_minute PASSED                    [ 57%]

01:38:11 tests/unit/timeparse_test.py::test_minute_as_float PASSED                [ 57%]

01:38:11 tests/unit/timeparse_test.py::test_hour_minute_second PASSED             [ 57%]

01:38:11 tests/unit/timeparse_test.py::test_invalid_with_space PASSED             [ 57%]

01:38:11 tests/unit/timeparse_test.py::test_invalid_with_comma PASSED             [ 58%]

01:38:11 tests/unit/timeparse_test.py::test_invalid_with_empty_string PASSED      [ 58%]

01:38:11 tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_no_object PASSED [ 58%]

01:38:11 tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_with_object PASSED [ 58%]

01:38:11 tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_leading_whitespace PASSED [ 58%]

01:38:11 tests/unit/utils_test.py::TestStreamAsText::test_stream_with_non_utf_unicode_character PASSED [ 58%]

01:38:11 tests/unit/utils_test.py::TestStreamAsText::test_stream_with_utf_character PASSED [ 58%]

01:38:11 tests/unit/utils_test.py::TestJsonStream::test_with_falsy_entries PASSED [ 58%]

01:38:11 tests/unit/utils_test.py::TestJsonStream::test_with_leading_whitespace PASSED [ 58%]

01:38:11 tests/unit/utils_test.py::TestParseBytes::test_parse_bytes PASSED        [ 58%]

01:38:11 tests/unit/utils_test.py::TestMoreItertools::test_unique_everseen PASSED [ 58%]

01:38:11 tests/integration/service_test.py::ServiceTest::test_recreate_preserves_volume_with_trailing_slash PASSED [ 31%]

01:38:12 tests/unit/volume_test.py::TestVolume::test_remove_local_volume PASSED   [ 59%]

01:38:12 tests/unit/volume_test.py::TestVolume::test_remove_external_volume PASSED [ 59%]

01:38:12 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_path_from_options PASSED [ 59%]

01:38:12 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_single_path_from_env PASSED [ 59%]

01:38:12 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env PASSED [ 59%]

01:38:12 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env_windows SKIPPED [ 59%]

01:38:12 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env_custom_separator PASSED [ 59%]

01:38:12 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_no_path PASSED [ 59%]

01:38:12 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_unicode_path_from_options PASSED [ 59%]

01:38:12 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_unicode_path_from_env PASSED [ 59%]

01:38:12 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_custom_timeout_error PASSED [ 59%]

01:38:12 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_docker_client_no_home PASSED [ 60%]

01:38:12 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_docker_client_with_custom_timeout PASSED [ 60%]

01:38:12 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_user_agent PASSED [ 60%]

01:38:12 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_assert_hostname_explicit_skip PASSED [ 60%]

01:38:12 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_simple_tls PASSED [ 60%]

01:38:12 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_ca_cert PASSED [ 60%]

01:38:12 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_ca_cert_explicit PASSED [ 60%]

01:38:12 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca PASSED [ 60%]

01:38:12 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca_explicit PASSED [ 60%]

01:38:12 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca_quoted_paths PASSED [ 60%]

01:38:12 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_cert PASSED [ 60%]

01:38:12 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_cert_explicit PASSED [ 60%]

01:38:12 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_missing_key PASSED [ 61%]

01:38:12 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_flags_override_environment PASSED [ 61%]

01:38:12 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_mixed_environment_and_flags PASSED [ 61%]

01:38:12 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_simple_with_tls_version PASSED [ 61%]

01:38:12 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_default_cert_path PASSED [ 61%]

01:38:12 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_env_falsy_value PASSED [ 61%]

01:38:12 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_flag_no_override PASSED [ 61%]

01:38:12 tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_default PASSED [ 61%]

01:38:12 tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_upgrade PASSED [ 61%]

01:38:12 tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_unavailable PASSED [ 61%]

01:38:12 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_generic_connection_error PASSED [ 61%]

01:38:12 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_mismatch PASSED [ 62%]

01:38:12 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_mismatch_unicode_explanation PASSED [ 62%]

01:38:12 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_other PASSED [ 62%]

01:38:12 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_other_unicode_explanation PASSED [ 62%]

01:38:12 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_no_data SKIPPED [ 62%]

01:38:12 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_misc SKIPPED [ 62%]

01:38:12 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_encoding_issue SKIPPED [ 62%]

01:38:12 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_error PASSED [ 62%]

01:38:12 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_info PASSED [ 62%]

01:38:12 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_error PASSED [ 62%]

01:38:12 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_info PASSED [ 62%]

01:38:12 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_warn PASSED [ 63%]

01:38:12 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_warn PASSED [ 63%]

01:38:12 tests/unit/cli/log_printer_test.py::TestLogPresenter::test_monochrome PASSED [ 63%]

01:38:12 tests/unit/cli/log_printer_test.py::TestLogPresenter::test_polychrome PASSED [ 63%]

01:38:12 tests/unit/cli/log_printer_test.py::test_wait_on_exit PASSED             [ 63%]

01:38:12 tests/unit/cli/log_printer_test.py::test_wait_on_exit_raises PASSED      [ 63%]

01:38:12 tests/unit/cli/log_printer_test.py::test_build_no_log_generator PASSED   [ 63%]

01:38:12 tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_no_log_stream PASSED [ 63%]

01:38:12 tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_with_log_stream PASSED [ 63%]

01:38:12 tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_unicode PASSED [ 63%]

01:38:12 tests/unit/cli/log_printer_test.py::TestWatchEvents::test_stop_event PASSED [ 63%]

01:38:12 tests/unit/cli/log_printer_test.py::TestWatchEvents::test_start_event PASSED [ 63%]

01:38:12 tests/unit/cli/log_printer_test.py::TestWatchEvents::test_other_event PASSED [ 64%]

01:38:12 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_an_exception PASSED [ 64%]

01:38:12 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_stop_without_cascade_stop PASSED [ 64%]

01:38:12 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_stop_with_cascade_stop PASSED [ 64%]

01:38:12 tests/integration/service_test.py::ServiceTest::test_start_container_builds_images PASSED [ 33%]

01:38:12 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_none_when_timeout_is_hit PASSED [ 64%]

01:38:12 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_filter_containers_to_service_names PASSED [ 64%]

01:38:12 tests/integration/project_test.py::ProjectTest::test_start_pause_unpause_stop_kill_remove PASSED [ 22%]

01:38:13 tests/integration/project_test.py::ProjectTest::test_project_up_unhealthy_dependency PASSED [ 21%]

01:38:13 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_build PASSED [ 37%]

01:38:13 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_filter_containers_to_service_names_all PASSED [ 64%]

01:38:13 tests/integration/service_test.py::ServiceTest::test_start_container_creates_fixed_external_ports PASSED [ 33%]

01:38:13 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_config_change PASSED [ 37%]

01:38:13 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_warning_in_swarm_mode PASSED [ 64%]

01:38:13 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_build_one_off_container_options PASSED [ 64%]

01:38:13 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_get_docker_start_call PASSED [ 64%]

01:38:13 tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_tty_verbose PASSED [ 64%]

01:38:13 tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_tty_not_verbose PASSED [ 65%]

01:38:13 tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_not_a_tty PASSED [ 65%]

01:38:13 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_invalid_opts PASSED [ 65%]

01:38:13 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_always PASSED [ 65%]

01:38:13 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_never PASSED [ 65%]

01:38:13 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_changed PASSED [ 65%]

01:38:13 tests/unit/cli/main_test.py::TestCallDocker::test_simple_no_options PASSED [ 65%]

01:38:13 tests/unit/cli/main_test.py::TestCallDocker::test_simple_tls_option PASSED [ 65%]

01:38:13 tests/unit/cli/main_test.py::TestCallDocker::test_advanced_tls_options PASSED [ 65%]

01:38:13 tests/unit/cli/main_test.py::TestCallDocker::test_with_host_option PASSED [ 65%]

01:38:13 tests/unit/cli/main_test.py::TestCallDocker::test_with_http_host PASSED  [ 65%]

01:38:13 tests/unit/cli/main_test.py::TestCallDocker::test_with_host_option_shorthand_equal PASSED [ 65%]

01:38:13 tests/unit/cli/main_test.py::TestCallDocker::test_with_env PASSED        [ 66%]

01:38:13 tests/unit/cli/utils_test.py::UnquotePathTest::test_nested_quotes PASSED [ 66%]

01:38:13 tests/unit/cli/utils_test.py::UnquotePathTest::test_no_quotes PASSED     [ 66%]

01:38:13 tests/unit/cli/utils_test.py::UnquotePathTest::test_simple_quotes PASSED [ 66%]

01:38:13 tests/unit/cli/utils_test.py::UnquotePathTest::test_uneven_quotes PASSED [ 66%]

01:38:13 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_100b PASSED [ 66%]

01:38:13 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_1023b PASSED [ 66%]

01:38:13 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_1kb PASSED [ 66%]

01:38:13 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_units PASSED [ 66%]

01:38:13 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_call PASSED [ 66%]

01:38:13 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return PASSED [ 66%]

01:38:13 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return_no_result PASSED [ 67%]

01:38:13 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return_sequence PASSED [ 67%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_build_args_allow_empty_properties PASSED [ 67%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_build_args_check_zero_preserved PASSED [ 67%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_config_build_configuration PASSED [ 67%]

01:38:13 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_up PASSED [ 37%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_config_build_configuration_v2 PASSED [ 67%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_config_convertible_label_types PASSED [ 67%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_config_duplicate_cache_from_values_validation_error PASSED [ 67%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_config_duplicate_mount_points PASSED [ 67%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_config_extra_hosts_list_of_dicts_validation_error PASSED [ 67%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_config_extra_hosts_string_raises_validation_error PASSED [ 67%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_config_hint PASSED    [ 68%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error PASSED [ 68%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error_v2 PASSED [ 68%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error_v2_when_no_interpolate PASSED [ 68%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_property_raise_validation_error PASSED [ 68%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_config_invalid_ipam_config PASSED [ 68%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_config_invalid_label_types PASSED [ 68%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_config_invalid_service_name_raise_validation_error PASSED [ 68%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_invalid_keys_validation_error PASSED [ 68%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_required_keys_validation_error PASSED [ 68%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_soft_greater_than_hard_error PASSED [ 68%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_config_valid_environment_dict_key_contains_dashes PASSED [ 68%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_config_valid_ipam_config PASSED [ 69%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_config_valid_service_label_validation PASSED [ 69%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_config_valid_service_names PASSED [ 69%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_depends_on_orders_services PASSED [ 69%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_depends_on_unknown_service_errors PASSED [ 69%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_dns_opt_option PASSED [ 69%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_empty_environment_key_allowed PASSED [ 69%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_external_volume_config PASSED [ 69%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_external_volume_invalid_config PASSED [ 69%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_group_add_option PASSED [ 69%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_build_and_image_specified_v1 PASSED [ 69%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_not_a_dictionary PASSED [ 70%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_not_unique_items PASSED [ 70%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_type_should_be_an_array PASSED [ 70%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_v1 PASSED [ 70%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_v2 PASSED [ 70%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_invalid_list_of_strings_format PASSED [ 70%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_isolation_option PASSED [ 70%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_linked_service_is_undefined PASSED [ 70%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load PASSED           [ 70%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_bind_mount_relative_path PASSED [ 70%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_bind_mount_relative_path_with_tilde PASSED [ 70%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_build_labels_dict PASSED [ 71%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_build_labels_list PASSED [ 71%]

01:38:13 tests/integration/service_test.py::ServiceTest::test_start_container_creates_fixed_external_ports_when_it_is_different_to_internal_port PASSED [ 33%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_config_custom_resource_names PASSED [ 71%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_config_dockerfile_without_build_raises_error_v1 PASSED [ 71%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_config_invalid_service_names PASSED [ 71%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_config_invalid_service_names_v2 PASSED [ 71%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_config_link_local_ips_network PASSED [ 71%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_config_service_labels PASSED [ 71%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_config_volume_and_network_labels PASSED [ 71%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_configs PASSED   [ 71%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_configs_multi_file PASSED [ 71%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_dockerfile_without_context PASSED [ 71%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_errors_on_uppercase_with_no_image PASSED [ 72%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_invalid_service_definition PASSED [ 72%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_mixed_extends_resolution PASSED [ 72%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_secrets PASSED   [ 72%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_secrets_multi_file PASSED [ 72%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_service_with_name_version PASSED [ 72%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_sorts_in_dependency_order PASSED [ 72%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_when_not_dict PASSED [ 72%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_when_not_dict_v2 PASSED [ 72%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_with_invalid_network_fields PASSED [ 72%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_v2 PASSED        [ 72%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_with_buildargs PASSED [ 73%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_with_empty_build_args PASSED [ 73%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_with_extensions PASSED [ 73%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_with_invalid_field_name PASSED [ 73%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_with_invalid_field_name_v1 PASSED [ 73%]

01:38:13 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_base PASSED [ 73%]

01:38:14 tests/integration/state_test.py::ServiceStateTest::test_image_changed_to_build PASSED [ 37%]

01:38:14 tests/integration/state_test.py::ServiceStateTest::test_trigger_create PASSED [ 37%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_base_v2 PASSED [ 73%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_override PASSED [ 73%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_override_v2 PASSED [ 73%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_extends_in_override_file PASSED [ 73%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_invalid_override PASSED [ 73%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_mismatched_networks_format PASSED [ 73%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_mismatched_networks_format_inverse_order PASSED [ 74%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v1 PASSED [ 74%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v2 PASSED [ 74%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v3_2 PASSED [ 74%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_load_yaml_with_bom PASSED [ 74%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_load_yaml_with_yaml_error PASSED [ 74%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_logs_warning_for_boolean_in_environment PASSED [ 74%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_blkio_config PASSED [ 74%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_configs_override PASSED [ 74%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_credential_spec PASSED [ 74%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_depends_on_mixed_syntax PASSED [ 74%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_depends_on_no_override PASSED [ 75%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_deploy PASSED   [ 75%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_deploy_override PASSED [ 75%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_device_cgroup_rules PASSED [ 75%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_different_configs PASSED [ 75%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_different_secrets PASSED [ 75%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_extra_hosts PASSED [ 75%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_config PASSED [ 75%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_override_disables PASSED [ 75%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_override_enables PASSED [ 75%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_isolation PASSED [ 75%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v1 PASSED [ 76%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2 PASSED [ 76%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_base PASSED [ 76%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_base_driver PASSED [ 76%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_drivers PASSED [ 76%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_override PASSED [ 76%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_override_options PASSED [ 76%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_override_driver PASSED [ 76%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_mixed_ports PASSED [ 76%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_pid PASSED      [ 76%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_scale PASSED    [ 76%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_secrets_override PASSED [ 76%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_from_files_with_extends_in_base PASSED [ 77%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_from_files_with_extends_in_override PASSED [ 77%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous PASSED [ 77%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous_2 PASSED [ 77%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous_volumes PASSED [ 77%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_ports_sorting PASSED [ 77%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_merge_storage_opt PASSED [ 77%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_named_volume_config_empty PASSED [ 77%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_named_volume_invalid_type_list PASSED [ 77%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_named_volume_numeric_driver_opt PASSED [ 77%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_networks_invalid_type_list PASSED [ 77%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_normalize_dns_options PASSED [ 78%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_oom_score_adj_option PASSED [ 78%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_runtime_option PASSED [ 78%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_service_volume_invalid_config PASSED [ 78%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_swappiness_option PASSED [ 78%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_tmpfs_option PASSED   [ 78%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_undeclared_volume_v1 PASSED [ 78%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_undeclared_volume_v2 PASSED [ 78%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_unsupported_version PASSED [ 78%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_v1_file_version PASSED [ 78%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_v1_file_with_version_is_invalid PASSED [ 78%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_valid_config_oneof_string_or_list PASSED [ 78%]

01:38:14 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_image_change PASSED [ 37%]

01:38:14 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_nonexistent_image_tag PASSED [ 38%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_valid_config_which_allows_two_type_definitions PASSED [ 79%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_valid_versions PASSED [ 79%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_validate_extra_hosts_invalid PASSED [ 79%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_validate_extra_hosts_invalid_list PASSED [ 79%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_version_1_is_invalid PASSED [ 79%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_volume_invalid_driver_opt PASSED [ 79%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_volume_mode_override PASSED [ 79%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_volumes_long_syntax PASSED [ 79%]

01:38:14 tests/unit/config/config_test.py::ConfigTest::test_wrong_version_type PASSED [ 79%]

01:38:14 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_container PASSED [ 79%]

01:38:14 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_container_v1 PASSED [ 79%]

01:38:14 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_plus_networks_is_invalid PASSED [ 80%]

01:38:14 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service PASSED [ 80%]

01:38:14 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service_nonexistent PASSED [ 80%]

01:38:14 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service_v1 PASSED [ 80%]

01:38:14 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_standard PASSED [ 80%]

01:38:14 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_standard_v1 PASSED [ 80%]

01:38:14 tests/unit/config/config_test.py::PortsTest::test_config_invalid_expose_format_validation PASSED [ 80%]

01:38:14 tests/unit/config/config_test.py::PortsTest::test_config_invalid_expose_type_validation PASSED [ 80%]

01:38:14 tests/unit/config/config_test.py::PortsTest::test_config_invalid_ports_format_validation PASSED [ 80%]

01:38:14 tests/unit/config/config_test.py::PortsTest::test_config_invalid_ports_type_validation PASSED [ 80%]

01:38:14 tests/unit/config/config_test.py::PortsTest::test_config_non_unique_expose_validation PASSED [ 80%]

01:38:14 tests/unit/config/config_test.py::PortsTest::test_config_non_unique_ports_validation PASSED [ 81%]

01:38:14 tests/unit/config/config_test.py::PortsTest::test_config_valid_expose_format_validation PASSED [ 81%]

01:38:14 tests/unit/config/config_test.py::PortsTest::test_config_valid_ports_format_validation PASSED [ 81%]

01:38:14 tests/unit/config/config_test.py::SubnetTest::test_config_invalid_subnet_format_validation PASSED [ 81%]

01:38:14 tests/unit/config/config_test.py::SubnetTest::test_config_invalid_subnet_type_validation PASSED [ 81%]

01:38:14 tests/integration/project_test.py::ProjectTest::test_project_up_volumes PASSED [ 21%]

01:38:14 tests/integration/state_test.py::ServiceStateTest::test_trigger_noop PASSED [ 37%]

01:38:14 tests/unit/config/config_test.py::SubnetTest::test_config_valid_subnet_format_validation PASSED [ 81%]

01:38:14 tests/unit/config/config_test.py::InterpolationTest::test_compatibility_mode_load PASSED [ 81%]

01:38:14 tests/unit/config/config_test.py::InterpolationTest::test_compatibility_mode_warnings PASSED [ 81%]

01:38:14 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_file PASSED [ 81%]

01:38:14 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_variable PASSED [ 81%]

01:38:14 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_variable_with_defaults PASSED [ 81%]

01:38:14 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_options_environment_file PASSED [ 81%]

01:38:14 tests/unit/config/config_test.py::InterpolationTest::test_interpolation_configs_section PASSED [ 82%]

01:38:14 tests/unit/config/config_test.py::InterpolationTest::test_interpolation_secrets_section PASSED [ 82%]

01:38:14 tests/unit/config/config_test.py::InterpolationTest::test_invalid_interpolation PASSED [ 82%]

01:38:14 tests/unit/config/config_test.py::InterpolationTest::test_unset_variable_produces_warning PASSED [ 82%]

01:38:14 tests/unit/config/config_test.py::VolumeConfigTest::test_absolute_posix_path_does_not_expand PASSED [ 82%]

01:38:14 tests/unit/config/config_test.py::VolumeConfigTest::test_absolute_windows_path_does_not_expand PASSED [ 82%]

01:38:14 tests/unit/config/config_test.py::VolumeConfigTest::test_home_directory_with_driver_does_not_expand PASSED [ 82%]

01:38:14 tests/unit/config/config_test.py::VolumeConfigTest::test_name_does_not_expand PASSED [ 82%]

01:38:14 tests/unit/config/config_test.py::VolumeConfigTest::test_no_binding PASSED [ 82%]

01:38:14 tests/unit/config/config_test.py::VolumeConfigTest::test_relative_path_does_expand_posix PASSED [ 82%]

01:38:14 tests/unit/config/config_test.py::VolumeConfigTest::test_relative_path_does_expand_windows SKIPPED [ 82%]

01:38:14 tests/unit/config/config_test.py::VolumeConfigTest::test_volume_binding_with_environment_variable PASSED [ 83%]

01:38:14 tests/unit/config/config_test.py::VolumeConfigTest::test_volume_binding_with_home PASSED [ 83%]

01:38:14 tests/unit/config/config_test.py::VolumeConfigTest::test_volume_path_with_non_ascii_directory PASSED [ 83%]

01:38:14 tests/unit/config/config_test.py::VolumeConfigTest::test_volumes_order_is_preserved PASSED [ 83%]

01:38:14 tests/unit/config/config_test.py::MergeVolumesTest::test_add_explicit_path PASSED [ 83%]

01:38:14 tests/unit/config/config_test.py::MergeVolumesTest::test_empty PASSED    [ 83%]

01:38:14 tests/unit/config/config_test.py::MergeVolumesTest::test_no_base PASSED  [ 83%]

01:38:14 tests/unit/config/config_test.py::MergeVolumesTest::test_no_override PASSED [ 83%]

01:38:14 tests/unit/config/config_test.py::MergeVolumesTest::test_override_explicit_path PASSED [ 83%]

01:38:14 tests/unit/config/config_test.py::MergeVolumesTest::test_remove_explicit_path PASSED [ 83%]

01:38:14 tests/unit/config/config_test.py::MergeDevicesTest::test_add_explicit_path PASSED [ 83%]

01:38:14 tests/unit/config/config_test.py::MergeDevicesTest::test_empty PASSED    [ 84%]

01:38:14 tests/unit/config/config_test.py::MergeDevicesTest::test_no_base PASSED  [ 84%]

01:38:14 tests/unit/config/config_test.py::MergeDevicesTest::test_no_override PASSED [ 84%]

01:38:14 tests/unit/config/config_test.py::MergeDevicesTest::test_override_explicit_path PASSED [ 84%]

01:38:14 tests/unit/config/config_test.py::MergeDevicesTest::test_remove_explicit_path PASSED [ 84%]

01:38:14 tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_no_override PASSED [ 84%]

01:38:14 tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_override_with_other PASSED [ 84%]

01:38:14 tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_override_with_same PASSED [ 84%]

01:38:14 tests/unit/config/config_test.py::MergePortsTest::test_add_item PASSED   [ 84%]

01:38:14 tests/unit/config/config_test.py::MergePortsTest::test_duplicate_port_mappings PASSED [ 84%]

01:38:14 tests/unit/config/config_test.py::MergePortsTest::test_empty PASSED      [ 84%]

01:38:14 tests/unit/config/config_test.py::MergePortsTest::test_no_base PASSED    [ 84%]

01:38:14 tests/unit/config/config_test.py::MergePortsTest::test_no_override PASSED [ 85%]

01:38:14 tests/unit/config/config_test.py::MergeNetworksTest::test_add_item PASSED [ 85%]

01:38:14 tests/unit/config/config_test.py::MergeNetworksTest::test_all_properties PASSED [ 85%]

01:38:14 tests/unit/config/config_test.py::MergeNetworksTest::test_empty PASSED   [ 85%]

01:38:14 tests/unit/config/config_test.py::MergeNetworksTest::test_network_has_none_value PASSED [ 85%]

01:38:14 tests/unit/config/config_test.py::MergeNetworksTest::test_no_base PASSED [ 85%]

01:38:14 tests/unit/config/config_test.py::MergeNetworksTest::test_no_network_name_overrides PASSED [ 85%]

01:38:14 tests/unit/config/config_test.py::MergeNetworksTest::test_no_network_overrides PASSED [ 85%]

01:38:14 tests/unit/config/config_test.py::MergeNetworksTest::test_no_override PASSED [ 85%]

01:38:14 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_add_list PASSED [ 85%]

01:38:14 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_add_string PASSED [ 85%]

01:38:14 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_no_base PASSED [ 86%]

01:38:14 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_no_override PASSED [ 86%]

01:38:14 tests/unit/config/config_test.py::MergeLabelsTest::test_add_explicit_value PASSED [ 86%]

01:38:14 tests/unit/config/config_test.py::MergeLabelsTest::test_empty PASSED     [ 86%]

01:38:14 tests/unit/config/config_test.py::MergeLabelsTest::test_no_base PASSED   [ 86%]

01:38:14 tests/unit/config/config_test.py::MergeLabelsTest::test_no_override PASSED [ 86%]

01:38:14 tests/unit/config/config_test.py::MergeLabelsTest::test_override_explicit_value PASSED [ 86%]

01:38:14 tests/unit/config/config_test.py::MergeLabelsTest::test_remove_explicit_value PASSED [ 86%]

01:38:14 tests/unit/config/config_test.py::MergeBuildTest::test_empty_base PASSED [ 86%]

01:38:14 tests/unit/config/config_test.py::MergeBuildTest::test_empty_override PASSED [ 86%]

01:38:14 tests/unit/config/config_test.py::MergeBuildTest::test_full PASSED       [ 86%]

01:38:14 tests/unit/config/config_test.py::MemoryOptionsTest::test_memswap_can_be_a_string PASSED [ 86%]

01:38:14 tests/unit/config/config_test.py::MemoryOptionsTest::test_validation_fails_with_just_memswap_limit PASSED [ 87%]

01:38:14 tests/unit/config/config_test.py::MemoryOptionsTest::test_validation_with_correct_memswap_values PASSED [ 87%]

01:38:14 tests/unit/config/config_test.py::EnvTest::test_environment_overrides_env_file PASSED [ 87%]

01:38:14 tests/unit/config/config_test.py::EnvTest::test_parse_environment_as_dict PASSED [ 87%]

01:38:14 tests/unit/config/config_test.py::EnvTest::test_parse_environment_as_list PASSED [ 87%]

01:38:14 tests/unit/config/config_test.py::EnvTest::test_parse_environment_empty PASSED [ 87%]

01:38:14 tests/unit/config/config_test.py::EnvTest::test_parse_environment_invalid PASSED [ 87%]

01:38:14 tests/unit/config/config_test.py::EnvTest::test_resolve_build_args PASSED [ 87%]

01:38:14 tests/unit/config/config_test.py::EnvTest::test_resolve_environment PASSED [ 87%]

01:38:14 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_from_env_file PASSED [ 87%]

01:38:14 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_from_env_file_with_empty_values PASSED [ 87%]

01:38:14 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_nonexistent_file PASSED [ 88%]

01:38:14 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_with_multiple_env_files PASSED [ 88%]

01:38:14 tests/unit/config/config_test.py::EnvTest::test_resolve_path PASSED      [ 88%]

01:38:14 tests/unit/config/config_test.py::ExtendsTest::test_circular PASSED      [ 88%]

01:38:14 tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_invalid_config PASSED [ 88%]

01:38:14 tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_valid_config PASSED [ 88%]

01:38:14 tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_verbose_and_shorthand_way PASSED [ 88%]

01:38:14 tests/unit/config/config_test.py::ExtendsTest::test_extends PASSED       [ 88%]

01:38:14 tests/unit/config/config_test.py::ExtendsTest::test_extends_file_defaults_to_self PASSED [ 88%]

01:38:14 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_empty_dictionary PASSED [ 88%]

01:38:14 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_invalid_key PASSED [ 88%]

01:38:14 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_missing_service_key PASSED [ 89%]

01:38:14 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_no_file_key_no_filename_set PASSED [ 89%]

01:38:14 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_sub_property_key PASSED [ 89%]

01:38:14 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_valid_config PASSED [ 89%]

01:38:14 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_defined_version_passes PASSED [ 89%]

01:38:14 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_depends_on PASSED [ 89%]

01:38:14 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_environment_and_env_files PASSED [ 89%]

01:38:14 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_healthcheck PASSED [ 89%]

01:38:14 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_mixed_versions_is_error PASSED [ 89%]

01:38:15 tests/integration/service_test.py::ServiceTest::test_recreate_volume_to_mount PASSED [ 32%]

01:38:15 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_ports PASSED [ 89%]

01:38:15 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_security_opt PASSED [ 89%]

01:38:15 tests/unit/config/config_test.py::ExtendsTest::test_invalid_links_in_extended_service PASSED [ 89%]

01:38:15 tests/unit/config/config_test.py::ExtendsTest::test_invalid_net_in_extended_service PASSED [ 90%]

01:38:15 tests/unit/config/config_test.py::ExtendsTest::test_invalid_volumes_from_in_extended_service PASSED [ 90%]

01:38:15 tests/unit/config/config_test.py::ExtendsTest::test_load_config_runs_interpolation_in_extended_service PASSED [ 90%]

01:38:15 tests/unit/config/config_test.py::ExtendsTest::test_load_throws_error_when_base_service_does_not_exist PASSED [ 90%]

01:38:15 tests/unit/config/config_test.py::ExtendsTest::test_merging_env_labels_ulimits PASSED [ 90%]

01:38:15 tests/unit/config/config_test.py::ExtendsTest::test_nested PASSED        [ 90%]

01:38:15 tests/unit/config/config_test.py::ExtendsTest::test_parent_build_path_dne PASSED [ 90%]

01:38:15 tests/unit/config/config_test.py::ExtendsTest::test_partial_service_config_in_extends_is_still_valid PASSED [ 90%]

01:38:15 tests/unit/config/config_test.py::ExtendsTest::test_self_referencing_file PASSED [ 90%]

01:38:15 tests/unit/config/config_test.py::ExtendsTest::test_volume_path PASSED   [ 90%]

01:38:15 tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_absolute PASSED [ 90%]

01:38:15 tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_normal PASSED [ 91%]

01:38:15 tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_with_tilde PASSED [ 91%]

01:38:15 tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_root_mount PASSED [ 91%]

01:38:15 tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_windows_path PASSED [ 91%]

01:38:15 tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_windows_path_in_container PASSED [ 91%]

01:38:15 tests/unit/config/config_test.py::BuildPathTest::test_absolute_path PASSED [ 91%]

01:38:15 tests/unit/config/config_test.py::BuildPathTest::test_from_file PASSED   [ 91%]

01:38:15 tests/unit/config/config_test.py::BuildPathTest::test_from_file_override_dir PASSED [ 91%]

01:38:15 tests/unit/config/config_test.py::BuildPathTest::test_invalid_url_in_build_path PASSED [ 91%]

01:38:15 tests/unit/config/config_test.py::BuildPathTest::test_nonexistent_path PASSED [ 91%]

01:38:15 tests/unit/config/config_test.py::BuildPathTest::test_relative_path PASSED [ 91%]

01:38:15 tests/unit/config/config_test.py::BuildPathTest::test_valid_url_in_build_path PASSED [ 92%]

01:38:15 tests/unit/config/config_test.py::HealthcheckTest::test_disable PASSED   [ 92%]

01:38:15 tests/unit/config/config_test.py::HealthcheckTest::test_disable_with_other_config_is_invalid PASSED [ 92%]

01:38:15 tests/unit/config/config_test.py::HealthcheckTest::test_healthcheck PASSED [ 92%]

01:38:15 tests/unit/config/config_test.py::HealthcheckTest::test_healthcheck_with_invalid_test PASSED [ 92%]

01:38:15 tests/unit/config/config_test.py::GetDefaultConfigFilesTestCase::test_get_config_path_default_file_in_basedir PASSED [ 92%]

01:38:15 tests/unit/config/config_test.py::GetDefaultConfigFilesTestCase::test_get_config_path_default_file_in_parent_dir PASSED [ 92%]

01:38:15 tests/unit/config/config_test.py::SerializeTest::test_denormalize_depends_on_v2_1 PASSED [ 92%]

01:38:15 tests/unit/config/config_test.py::SerializeTest::test_denormalize_depends_on_v3 PASSED [ 92%]

01:38:15 tests/unit/config/config_test.py::SerializeTest::test_denormalize_healthcheck PASSED [ 92%]

01:38:15 tests/unit/config/config_test.py::SerializeTest::test_denormalize_image_has_digest PASSED [ 92%]

01:38:15 tests/unit/config/config_test.py::SerializeTest::test_denormalize_image_no_digest PASSED [ 92%]

01:38:15 tests/integration/state_test.py::ServiceStateTest::test_trigger_start PASSED [ 38%]

01:38:15 tests/integration/volume_test.py::VolumeTest::test_create_volume PASSED  [ 38%]

01:38:15 tests/integration/volume_test.py::VolumeTest::test_create_volume_custom_name PASSED [ 38%]

01:38:15 tests/integration/volume_test.py::VolumeTest::test_exists PASSED         [ 38%]

01:38:15 tests/unit/config/config_test.py::SerializeTest::test_serialize_bool_string PASSED [ 93%]

01:38:15 tests/unit/config/config_test.py::SerializeTest::test_serialize_configs PASSED [ 93%]

01:38:15 tests/unit/config/config_test.py::SerializeTest::test_serialize_escape_dollar_sign PASSED [ 93%]

01:38:15 tests/unit/config/config_test.py::SerializeTest::test_serialize_escape_dont_interpolate PASSED [ 93%]

01:38:15 tests/unit/config/config_test.py::SerializeTest::test_serialize_external_false PASSED [ 93%]

01:38:15 tests/unit/config/config_test.py::SerializeTest::test_serialize_ports PASSED [ 93%]

01:38:15 tests/unit/config/config_test.py::SerializeTest::test_serialize_ports_with_ext_ip PASSED [ 93%]

01:38:15 tests/unit/config/config_test.py::SerializeTest::test_serialize_secrets PASSED [ 93%]

01:38:15 tests/unit/config/config_test.py::SerializeTest::test_serialize_time PASSED [ 93%]

01:38:15 tests/unit/config/config_test.py::SerializeTest::test_serialize_unicode_values PASSED [ 93%]

01:38:15 tests/unit/config/environment_test.py::EnvironmentTest::test_env_vars_from_file_bom PASSED [ 93%]

01:38:15 tests/unit/config/environment_test.py::EnvironmentTest::test_env_vars_from_file_whitespace PASSED [ 94%]

01:38:15 tests/unit/config/environment_test.py::EnvironmentTest::test_get_boolean PASSED [ 94%]

01:38:15 tests/unit/config/environment_test.py::EnvironmentTest::test_get_simple PASSED [ 94%]

01:38:15 tests/unit/config/environment_test.py::EnvironmentTest::test_get_undefined PASSED [ 94%]

01:38:15 tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_services PASSED [ 94%]

01:38:15 tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_volumes PASSED [ 94%]

01:38:15 tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_secrets PASSED [ 94%]

01:38:15 tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_v2 PASSED [ 94%]

01:38:15 tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_v3 PASSED [ 94%]

01:38:15 tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_invalid PASSED [ 94%]

01:38:15 tests/unit/config/interpolation_test.py::test_interpolate_environment_network_convert_types PASSED [ 94%]

01:38:15 tests/unit/config/interpolation_test.py::test_interpolate_environment_external_resource_convert_types PASSED [ 94%]

01:38:15 tests/unit/config/interpolation_test.py::test_interpolate_service_name_uses_dot PASSED [ 95%]

01:38:15 tests/unit/config/interpolation_test.py::test_escaped_interpolation PASSED [ 95%]

01:38:15 tests/unit/config/interpolation_test.py::test_invalid_interpolation PASSED [ 95%]

01:38:15 tests/unit/config/interpolation_test.py::test_interpolate_missing_no_default PASSED [ 95%]

01:38:15 tests/unit/config/interpolation_test.py::test_interpolate_with_value PASSED [ 95%]

01:38:15 tests/unit/config/interpolation_test.py::test_interpolate_missing_with_default PASSED [ 95%]

01:38:15 tests/unit/config/interpolation_test.py::test_interpolate_with_empty_and_default_value PASSED [ 95%]

01:38:15 tests/unit/config/interpolation_test.py::test_interpolate_mandatory_values PASSED [ 95%]

01:38:15 tests/unit/config/interpolation_test.py::test_interpolate_mandatory_no_err_msg PASSED [ 95%]

01:38:15 tests/unit/config/interpolation_test.py::test_interpolate_mixed_separators PASSED [ 95%]

01:38:15 tests/unit/config/interpolation_test.py::test_unbraced_separators PASSED [ 95%]

01:38:15 tests/unit/config/interpolation_test.py::test_interpolate_unicode_values PASSED [ 96%]

01:38:15 tests/unit/config/interpolation_test.py::test_interpolate_no_fallthrough PASSED [ 96%]

01:38:15 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_1 PASSED [ 96%]

01:38:15 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_2 PASSED [ 96%]

01:38:15 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_3 PASSED [ 96%]

01:38:15 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_4 PASSED [ 96%]

01:38:15 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_5 PASSED [ 96%]

01:38:15 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_6 PASSED [ 96%]

01:38:15 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_7 PASSED [ 96%]

01:38:15 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports PASSED [ 96%]

01:38:15 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports_2 PASSED [ 96%]

01:38:15 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports_3 PASSED [ 97%]

01:38:15 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_self_imports PASSED [ 97%]

01:38:15 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_depends_on_self PASSED [ 97%]

01:38:15 tests/unit/config/types_test.py::test_parse_extra_hosts_list PASSED      [ 97%]

01:38:15 tests/unit/config/types_test.py::test_parse_extra_hosts_dict PASSED      [ 97%]

01:38:15 tests/unit/config/types_test.py::TestServicePort::test_parse_dict PASSED [ 97%]

01:38:15 tests/unit/config/types_test.py::TestServicePort::test_parse_simple_target_port PASSED [ 97%]

01:38:15 tests/unit/config/types_test.py::TestServicePort::test_parse_complete_port_definition PASSED [ 97%]

01:38:15 tests/unit/config/types_test.py::TestServicePort::test_parse_ext_ip_no_published_port PASSED [ 97%]

01:38:15 tests/unit/config/types_test.py::TestServicePort::test_repr_published_port_0 PASSED [ 97%]

01:38:15 tests/unit/config/types_test.py::TestServicePort::test_parse_port_range PASSED [ 97%]

01:38:15 tests/unit/config/types_test.py::TestServicePort::test_parse_port_publish_range PASSED [ 97%]

01:38:15 tests/unit/config/types_test.py::TestServicePort::test_parse_invalid_port PASSED [ 98%]

01:38:15 tests/unit/config/types_test.py::TestServicePort::test_parse_invalid_publish_range PASSED [ 98%]

01:38:15 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_only_one_path PASSED [ 98%]

01:38:15 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_internal_and_external PASSED [ 98%]

01:38:15 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_with_mode PASSED [ 98%]

01:38:15 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_too_many_parts PASSED [ 98%]

01:38:15 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_absolute_path_normalized PASSED [ 98%]

01:38:15 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_absolute_path_native PASSED [ 98%]

01:38:15 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_internal_path_normalized PASSED [ 98%]

01:38:15 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_internal_path_native PASSED [ 98%]

01:38:15 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_just_drives_normalized PASSED [ 98%]

01:38:15 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_just_drives_native PASSED [ 99%]

01:38:15 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_mixed_notations_normalized PASSED [ 99%]

01:38:15 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_mixed_notations_native PASSED [ 99%]

01:38:15 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_from_service PASSED [ 99%]

01:38:15 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_from_container PASSED [ 99%]

01:38:15 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_invalid PASSED [ 99%]

01:38:15 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_service PASSED [ 99%]

01:38:15 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_service_with_mode PASSED [ 99%]

01:38:15 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_container PASSED [ 99%]

01:38:15 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_container_with_mode PASSED [ 99%]

01:38:15 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_invalid_type PASSED [ 99%]

01:38:15 tests/integration/volume_test.py::VolumeTest::test_exists_external PASSED [ 38%]

01:38:15 tests/integration/volume_test.py::VolumeTest::test_exists_external_aliased PASSED [ 38%]

01:38:15 tests/integration/volume_test.py::VolumeTest::test_external_aliased_volume PASSED [ 38%]

01:38:15 tests/integration/volume_test.py::VolumeTest::test_external_volume PASSED [ 38%]

01:38:15 tests/integration/volume_test.py::VolumeTest::test_inspect_volume PASSED [ 38%]

01:38:15 tests/integration/volume_test.py::VolumeTest::test_recreate_existing_volume PASSED [ 38%]

01:38:15 tests/integration/volume_test.py::VolumeTest::test_remove_volume PASSED  [ 39%]

01:38:15 tests/integration/volume_test.py::VolumeTest::test_volume_default_labels PASSED [ 39%]

01:38:15 tests/integration/service_test.py::ServiceTest::test_resolve_env PASSED  [ 32%]

01:38:15 tests/unit/bundle_test.py::test_get_image_digest_exists PASSED           [ 39%]

01:38:15 tests/integration/service_test.py::ServiceTest::test_start_container_creates_links <- tests/integration/testcases.py PASSED [ 33%]

01:38:15 tests/unit/bundle_test.py::test_get_image_digest_image_uses_digest PASSED [ 39%]

01:38:16 tests/unit/bundle_test.py::test_get_image_digest_from_repository PASSED  [ 39%]

01:38:16 tests/integration/service_test.py::ServiceTest::test_restart_always_value PASSED [ 32%]

01:38:16 tests/integration/project_test.py::ProjectTest::test_unscale_after_restart PASSED [ 22%]

01:38:16 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_build PASSED [ 37%]

01:38:16 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_config_change PASSED [ 37%]

01:38:16 tests/unit/bundle_test.py::test_get_image_digest_no_image PASSED         [ 39%]

01:38:16 tests/integration/project_test.py::ProjectTest::test_up_with_custom_name_resources PASSED [ 22%]

01:38:16 tests/unit/bundle_test.py::test_push_image_with_saved_digest PASSED      [ 39%]

01:38:16 tests/unit/bundle_test.py::test_push_image PASSED                        [ 39%]

01:38:16 tests/unit/bundle_test.py::test_to_bundle PASSED                         [ 39%]

01:38:16 tests/integration/service_test.py::ServiceTest::test_restart_on_failure_value PASSED [ 32%]

01:38:16 tests/integration/project_test.py::ProjectTest::test_project_up_with_added_secrets PASSED [ 21%]

01:38:16 tests/unit/bundle_test.py::test_convert_service_to_bundle PASSED         [ 39%]

01:38:16 tests/unit/bundle_test.py::test_set_command_and_args_none PASSED         [ 39%]

01:38:16 tests/unit/bundle_test.py::test_set_command_and_args_from_command PASSED [ 39%]

01:38:16 tests/unit/bundle_test.py::test_set_command_and_args_from_entrypoint PASSED [ 40%]

01:38:16 tests/unit/bundle_test.py::test_set_command_and_args_from_both PASSED    [ 40%]

01:38:16 tests/unit/bundle_test.py::test_make_service_networks_default PASSED     [ 40%]

01:38:16 tests/unit/bundle_test.py::test_make_service_networks PASSED             [ 40%]

01:38:16 tests/unit/bundle_test.py::test_make_port_specs PASSED                   [ 40%]

01:38:16 tests/unit/bundle_test.py::test_make_port_spec_with_protocol PASSED      [ 40%]

01:38:16 tests/unit/bundle_test.py::test_make_port_spec_default_protocol PASSED   [ 40%]

01:38:16 tests/unit/cli_test.py::CLITestCase::test_command_help PASSED            [ 40%]

01:38:16 tests/unit/cli_test.py::CLITestCase::test_command_help_nonexistent PASSED [ 40%]

01:38:16 tests/unit/cli_test.py::CLITestCase::test_command_manual_and_service_ports_together PASSED [ 40%]

01:38:16 tests/unit/cli_test.py::CLITestCase::test_default_project_name PASSED    [ 40%]

01:38:16 tests/unit/cli_test.py::CLITestCase::test_get_project PASSED             [ 41%]

01:38:16 tests/unit/cli_test.py::CLITestCase::test_project_name_from_environment_new_var PASSED [ 41%]

01:38:16 tests/unit/cli_test.py::CLITestCase::test_project_name_with_empty_environment_var PASSED [ 41%]

01:38:16 tests/unit/cli_test.py::CLITestCase::test_project_name_with_environment_file PASSED [ 41%]

01:38:16 tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_base_dir PASSED [ 41%]

01:38:16 tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_project_name PASSED [ 41%]

01:38:16 tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_uppercase_base_dir PASSED [ 41%]

01:38:16 tests/unit/cli_test.py::CLITestCase::test_run_interactive_passes_logs_false PASSED [ 41%]

01:38:17 tests/integration/service_test.py::ServiceTest::test_start_container_creates_links_with_names <- tests/integration/testcases.py PASSED [ 33%]

01:38:17 tests/unit/cli_test.py::CLITestCase::test_run_service_with_restart_always PASSED [ 41%]

01:38:17 tests/unit/container_test.py::ContainerTest::test_environment PASSED     [ 41%]

01:38:17 tests/unit/container_test.py::ContainerTest::test_from_ps PASSED         [ 41%]

01:38:17 tests/unit/container_test.py::ContainerTest::test_from_ps_prefixed PASSED [ 42%]

01:38:17 tests/unit/container_test.py::ContainerTest::test_get PASSED             [ 42%]

01:38:17 tests/unit/container_test.py::ContainerTest::test_get_local_port PASSED  [ 42%]

01:38:17 tests/unit/container_test.py::ContainerTest::test_has_api_logs PASSED    [ 42%]

01:38:17 tests/unit/container_test.py::ContainerTest::test_human_readable_ports_none PASSED [ 42%]

01:38:17 tests/unit/container_test.py::ContainerTest::test_human_readable_ports_public_and_private PASSED [ 42%]

01:38:17 tests/unit/container_test.py::ContainerTest::test_human_readable_states_healthy PASSED [ 42%]

01:38:17 tests/unit/container_test.py::ContainerTest::test_human_readable_states_no_health PASSED [ 42%]

01:38:17 tests/unit/container_test.py::ContainerTest::test_human_readable_states_starting PASSED [ 42%]

01:38:17 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_image_change PASSED [ 37%]

01:38:17 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_nonexistent_image_tag PASSED [ 38%]

01:38:17 tests/integration/project_test.py::ProjectTest::test_up_with_enable_ipv6 PASSED [ 22%]

01:38:17 tests/integration/project_test.py::ProjectTest::test_up_with_invalid_isolation PASSED [ 22%]

01:38:17 tests/integration/project_test.py::ProjectTest::test_up_with_invalid_runtime PASSED [ 22%]

01:38:17 tests/integration/project_test.py::ProjectTest::test_project_up_with_network_internal PASSED [ 21%]

01:38:17 tests/unit/container_test.py::ContainerTest::test_inspect_if_not_inspected PASSED [ 42%]

01:38:17 tests/unit/container_test.py::ContainerTest::test_name PASSED            [ 42%]

01:38:17 tests/unit/container_test.py::ContainerTest::test_name_without_project PASSED [ 42%]

01:38:17 tests/unit/container_test.py::ContainerTest::test_name_without_project_custom_container_name PASSED [ 43%]

01:38:17 tests/unit/container_test.py::ContainerTest::test_name_without_project_one_off PASSED [ 43%]

01:38:17 tests/unit/container_test.py::ContainerTest::test_number PASSED          [ 43%]

01:38:17 tests/unit/container_test.py::ContainerTest::test_short_id PASSED        [ 43%]

01:38:17 tests/unit/container_test.py::GetContainerNameTestCase::test_get_container_name PASSED [ 43%]

01:38:17 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_driver_mismatch PASSED [ 43%]

01:38:17 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_null_remote PASSED [ 43%]

01:38:17 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_null_remote_ipam_options PASSED [ 43%]

01:38:17 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_options_mismatch PASSED [ 43%]

01:38:17 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_success PASSED [ 43%]

01:38:17 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_whitelist PASSED [ 43%]

01:38:17 tests/unit/network_test.py::NetworkTest::test_check_remote_network_labels_mismatch PASSED [ 44%]

01:38:17 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute PASSED  [ 44%]

01:38:17 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_deps PASSED [ 44%]

01:38:17 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_global_limit PASSED [ 44%]

01:38:17 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_limit PASSED [ 44%]

01:38:17 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_upstream_errors PASSED [ 44%]

01:38:17 tests/unit/parallel_test.py::test_parallel_execute_alignment PASSED      [ 44%]

01:38:17 tests/unit/parallel_test.py::test_parallel_execute_ansi PASSED           [ 44%]

01:38:17 tests/unit/parallel_test.py::test_parallel_execute_noansi PASSED         [ 44%]

01:38:17 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_get_digest_from_pull PASSED [ 44%]

01:38:17 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_get_digest_from_push PASSED [ 44%]

01:38:17 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_mismatched_encoding_stream_write PASSED [ 44%]

01:38:17 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output PASSED [ 45%]

01:38:17 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_div_zero PASSED [ 45%]

01:38:17 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_no_progress_event_no_tty PASSED [ 45%]

01:38:17 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_null_total PASSED [ 45%]

01:38:17 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_progress_event_no_tty PASSED [ 45%]

01:38:17 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_progress_event_tty PASSED [ 45%]

01:38:17 tests/integration/service_test.py::ServiceTest::test_start_container_creates_port_with_explicit_protocol PASSED [ 33%]

01:38:17 tests/unit/project_test.py::ProjectTest::test_avoid_multiple_push PASSED [ 45%]

01:38:18 tests/unit/project_test.py::ProjectTest::test_build_container_operation_with_timeout_func_does_not_mutate_options_with_timeout PASSED [ 45%]

01:38:18 tests/unit/project_test.py::ProjectTest::test_container_without_name PASSED [ 45%]

01:38:18 tests/integration/service_test.py::ServiceTest::test_scale PASSED        [ 32%]

01:38:18 tests/integration/service_test.py::ServiceTest::test_start_container_creates_ports PASSED [ 33%]

01:38:18 tests/unit/project_test.py::ProjectTest::test_down_with_no_resources PASSED [ 45%]

01:38:18 tests/integration/project_test.py::ProjectTest::test_up_with_ipam_config PASSED [ 22%]

01:38:18 tests/integration/project_test.py::ProjectTest::test_project_up_with_network_label PASSED [ 21%]

01:38:18 tests/unit/project_test.py::ProjectTest::test_error_parallel_pull PASSED [ 45%]

01:38:18 tests/unit/project_test.py::ProjectTest::test_events PASSED              [ 46%]

01:38:18 tests/integration/state_test.py::ServiceStateTest::test_trigger_start PASSED [ 38%]

01:38:18 tests/integration/volume_test.py::VolumeTest::test_create_volume PASSED  [ 38%]

01:38:18 tests/integration/volume_test.py::VolumeTest::test_create_volume_custom_name PASSED [ 38%]

01:38:18 tests/integration/volume_test.py::VolumeTest::test_exists PASSED         [ 38%]

01:38:18 tests/integration/volume_test.py::VolumeTest::test_exists_external PASSED [ 38%]

01:38:18 tests/integration/volume_test.py::VolumeTest::test_exists_external_aliased PASSED [ 38%]

01:38:18 tests/integration/volume_test.py::VolumeTest::test_external_aliased_volume PASSED [ 38%]

01:38:18 tests/integration/volume_test.py::VolumeTest::test_external_volume PASSED [ 38%]

01:38:18 tests/integration/volume_test.py::VolumeTest::test_inspect_volume PASSED [ 38%]

01:38:18 tests/integration/volume_test.py::VolumeTest::test_recreate_existing_volume PASSED [ 38%]

01:38:18 tests/integration/volume_test.py::VolumeTest::test_remove_volume PASSED  [ 39%]

01:38:18 tests/integration/volume_test.py::VolumeTest::test_volume_default_labels PASSED [ 39%]

01:38:18 tests/unit/project_test.py::ProjectTest::test_events_legacy PASSED       [ 46%]

01:38:18 tests/unit/project_test.py::ProjectTest::test_from_config_v1 PASSED      [ 46%]

01:38:18 tests/integration/service_test.py::ServiceTest::test_start_container_inherits_options_from_constructor PASSED [ 34%]

01:38:18 tests/integration/project_test.py::ProjectTest::test_up_with_ipam_options PASSED [ 22%]

01:38:19 tests/unit/bundle_test.py::test_get_image_digest_exists PASSED           [ 39%]

01:38:19 tests/unit/project_test.py::ProjectTest::test_from_config_v2 PASSED      [ 46%]

01:38:19 tests/unit/bundle_test.py::test_get_image_digest_image_uses_digest PASSED [ 39%]

01:38:19 tests/integration/service_test.py::ServiceTest::test_scale_sets_ports PASSED [ 32%]

01:38:19 tests/unit/project_test.py::ProjectTest::test_get_service PASSED         [ 46%]

01:38:19 tests/integration/service_test.py::ServiceTest::test_start_container_passes_through_options PASSED [ 34%]

01:38:19 tests/integration/project_test.py::ProjectTest::test_up_with_isolation PASSED [ 22%]

01:38:19 tests/unit/bundle_test.py::test_get_image_digest_from_repository PASSED  [ 39%]

01:38:19 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_invalid PASSED [100%]

01:38:19 

01:38:19 ---------- coverage: platform linux2, python 2.7.16-final-0 ----------

01:38:19 Name                              Stmts   Miss Branch BrPart  Cover   Missing

01:38:19 -----------------------------------------------------------------------------

01:38:19 compose/__init__.py                   3      0      0      0   100%

01:38:19 compose/__main__.py                   4      4      0      0     0%   1-6

01:38:19 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

01:38:19 compose/cli/__init__.py               0      0      0      0   100%

01:38:19 compose/cli/colors.py                23      2     10      2    88%   37-38, 36->37, 48->exit

01:38:19 compose/cli/command.py               93     14     26      4    82%   71-81, 88, 125-130, 174, 70->71, 87->88, 124->125, 171->174

01:38:19 compose/cli/docker_client.py         75      5     24      2    93%   24, 98-99, 107, 123, 106->107, 122->123

01:38:19 compose/cli/docopt_command.py        38      4      8      2    87%   13-14, 29, 35, 28->29, 34->35

01:38:19 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

01:38:19 compose/cli/formatter.py             34      2      8      1    93%   17-18, 15->17

01:38:19 compose/cli/log_printer.py          144     14     50      6    89%   76, 103, 110-115, 162-164, 173, 226-229, 233-234, 253, 43->exit, 75->76, 98->103, 171->173, 225->226, 232->233

01:38:19 compose/cli/main.py                 695     90    292     40    84%   83-84, 86-87, 168, 328, 360-362, 445, 505, 509, 514-515, 525-554, 566, 584-586, 657-658, 696-697, 715, 736-737, 749, 772, 790, 837, 1069, 1078, 1104-1113, 1153-1156, 1164-1168, 1170-1175, 1198, 1220-1249, 1256-1257, 1259-1261, 1276, 1282, 1466, 1484, 1500, 1504-1505, 1516, 1521, 1524, 1550, 1569-1571, 1581, 1592, 60->63, 82->83, 85->86, 167->168, 327->328, 359->360, 444->445, 504->505, 508->509, 519->525, 563->566, 583->584, 655->657, 714->715, 735->736, 748->749, 771->772, 827->837, 829->exit, 1068->1069, 1077->1078, 1163->1164, 1169->1170, 1197->1198, 1255->1256, 1258->1259, 1275->1276, 1281->1282, 1465->1466, 1483->1484, 1499->1500, 1515->1516, 1520->1521, 1523->1524, 1542->exit, 1549->1550, 1563->1571, 1565->1569, 1580->1581, 1590->1592

01:38:19 compose/cli/signals.py               23      0      4      2    93%   36->exit, 43->exit

01:38:19 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

01:38:19 compose/cli/verbose_proxy.py         35     12     10      0    69%   36-39, 42-47, 50-60

01:38:19 compose/config/__init__.py           13      0      0      0   100%

01:38:19 compose/config/config.py            826     30    388     18    95%   266, 277, 508, 621-622, 714, 757, 812-830, 952-953, 959, 979, 982, 1335, 1366, 1412, 265->266, 276->277, 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

01:38:19 compose/config/environment.py       100      7     34      4    92%   41, 104-107, 120, 127, 40->41, 103->104, 119->120, 126->127

01:38:19 compose/config/errors.py             25      2      0      0    92%   36-40

01:38:19 compose/config/interpolation.py     148      7     62      4    94%   66, 148, 196, 222, 227-229, 121->exit, 146->148, 195->196, 221->222

01:38:19 compose/config/serialize.py          97      1     50      2    98%   76, 75->76, 82->85

01:38:19 compose/config/sort_services.py      44      1     18      1    97%   57, 56->57

01:38:19 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

01:38:19 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

01:38:19 compose/const.py                     36      0      0      0   100%

01:38:19 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

01:38:19 compose/errors.py                    17      1      0      0    94%   12

01:38:19 compose/network.py                  190     19     92      5    87%   184, 186-200, 206, 224, 226, 183->184, 185->186, 205->206, 223->224, 225->226

01:38:19 compose/parallel.py                 199      2     56      1    99%   187, 326, 325->326

01:38:19 compose/progress_stream.py           79      8     40      9    86%   40, 71, 74, 80, 85, 90-91, 116, 39->40, 42->46, 53->57, 70->71, 73->74, 79->80, 84->85, 89->90, 112->116

01:38:19 compose/project.py                  424     29    170     16    92%   60, 156, 212-213, 254-255, 364-365, 378-381, 434, 485, 489, 615, 621, 624-627, 752-753, 759-762, 777, 782-785, 788, 809, 57->60, 152->156, 331->333, 362->364, 377->378, 433->434, 484->485, 488->489, 614->615, 620->621, 623->624, 671->exit, 755->762, 776->777, 781->782, 787->788

01:38:19 compose/service.py                  854     48    380     24    94%   271-272, 293, 366-369, 417-422, 428-430, 470-471, 485, 488, 506, 573, 618-619, 727, 946-947, 967-968, 1069, 1115, 1176, 1218, 1240-1255, 1295, 1334-1338, 1526, 1530, 1686, 216->exit, 269->271, 292->293, 427->428, 469->470, 484->485, 487->488, 505->506, 563->573, 722->727, 945->946, 966->967, 1068->1069, 1114->1115, 1175->1176, 1217->1218, 1294->1295, 1331->1334, 1525->1526, 1529->1530, 1578->exit, 1586->1585, 1623->1620, 1685->1686

01:38:19 compose/state.py                      0      0      0      0   100%

01:38:19 compose/timeparse.py                 22      0      4      0   100%

01:38:19 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

01:38:19 compose/version.py                    6      0      0      0   100%

01:38:19 compose/volume.py                   126      4     44      4    94%   150, 200, 211-212, 141->150, 199->200, 201->198, 209->211

01:38:19 -----------------------------------------------------------------------------

01:38:19 TOTAL                              5553    433   2224    203    90%

01:38:19 Coverage HTML written to dir coverage-html

01:38:19 

01:38:19 =========================== short test summary info ============================

01:38:19 XFAIL tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_rt

01:38:19   not supported by kernel

01:38:19 XFAIL tests/integration/service_test.py::ServiceTest::test_create_container_with_storage_opt

01:38:19   Not supported on most drivers

01:38:19 SKIP [1] tests/integration/service_test.py:1635: Broken on 1.11.0 - 17.03.0

01:38:19 SKIP [1] tests/unit/config/config_test.py:3777: windows paths

01:38:19 SKIP [1] tests/acceptance/cli_test.py:2424: race condition between up and logs

01:38:19 SKIP [1] tests/unit/cli/errors_test.py:90: Needs pywin32

01:38:19 SKIP [1] tests/integration/service_test.py:148: cpu_percent is not supported for Linux

01:38:19 SKIP [1] tests/unit/cli/errors_test.py:80: Needs pywin32

01:38:19 SKIP [1] tests/unit/cli/errors_test.py:70: Needs pywin32

01:38:19 SKIP [1] /code/tests/integration/testcases.py:167: This daemon does not support the 'nvidia'' runtime

01:38:19 SKIP [1] tests/unit/cli/command_test.py:39: windows separator

01:38:19 SKIP [1] tests/acceptance/cli_test.py:2403: race condition between up and logs

01:38:19 SKIP [1] tests/acceptance/cli_test.py:2376: race condition between up and logs

01:38:19 

01:38:19 ======= 1122 passed, 11 skipped, 2 xfailed, 3 xpassed in 782.42 seconds ========

01:38:19 ___________________________________ summary ____________________________________

01:38:19   py27: commands succeeded

01:38:19   congratulations :)

01:38:19 tests/integration/project_test.py::ProjectTest::test_project_up_with_no_deps PASSED [ 21%]

01:38:19 tests/unit/project_test.py::ProjectTest::test_get_services_removes_duplicates_following_links PASSED [ 46%]

01:38:19 tests/unit/project_test.py::ProjectTest::test_get_services_returns_all_services_without_args PASSED [ 46%]

01:38:19 tests/unit/bundle_test.py::test_get_image_digest_no_image PASSED         [ 39%]

01:38:19 tests/unit/bundle_test.py::test_push_image_with_saved_digest PASSED      [ 39%]

01:38:19 + on_exit
01:38:19 + [[ 0 != \0 ]]
01:38:19 + docker rm -vf compose-dind-18.09.9-rc1-jenkins-compose-PR-6850-2
01:38:19 tests/integration/service_test.py::ServiceTest::test_scale_with_api_error PASSED [ 32%]

01:38:19 tests/unit/project_test.py::ProjectTest::test_get_services_returns_listed_services_with_args PASSED [ 46%]

01:38:19 tests/unit/project_test.py::ProjectTest::test_get_services_with_include_links PASSED [ 46%]

01:38:20 tests/unit/bundle_test.py::test_push_image PASSED                        [ 39%]

01:38:20 tests/unit/bundle_test.py::test_to_bundle PASSED                         [ 39%]

01:38:20 tests/unit/bundle_test.py::test_convert_service_to_bundle PASSED         [ 39%]

01:38:20 tests/unit/bundle_test.py::test_set_command_and_args_none PASSED         [ 39%]

01:38:20 tests/unit/bundle_test.py::test_set_command_and_args_from_command PASSED [ 39%]

01:38:20 tests/unit/bundle_test.py::test_set_command_and_args_from_entrypoint PASSED [ 40%]

01:38:20 tests/unit/bundle_test.py::test_set_command_and_args_from_both PASSED    [ 40%]

01:38:20 tests/unit/bundle_test.py::test_make_service_networks_default PASSED     [ 40%]

01:38:20 tests/unit/bundle_test.py::test_make_service_networks PASSED             [ 40%]

01:38:20 tests/unit/bundle_test.py::test_make_port_specs PASSED                   [ 40%]

01:38:20 tests/unit/bundle_test.py::test_make_port_spec_with_protocol PASSED      [ 40%]

01:38:20 tests/unit/bundle_test.py::test_make_port_spec_default_protocol PASSED   [ 40%]

01:38:20 tests/unit/cli_test.py::CLITestCase::test_command_help PASSED            [ 40%]

01:38:20 tests/unit/cli_test.py::CLITestCase::test_command_help_nonexistent PASSED [ 40%]

01:38:20 tests/unit/cli_test.py::CLITestCase::test_command_manual_and_service_ports_together PASSED [ 40%]

01:38:20 tests/unit/cli_test.py::CLITestCase::test_default_project_name PASSED    [ 40%]

01:38:20 tests/unit/cli_test.py::CLITestCase::test_get_project PASSED             [ 41%]

01:38:20 tests/unit/cli_test.py::CLITestCase::test_project_name_from_environment_new_var PASSED [ 41%]

01:38:20 tests/unit/cli_test.py::CLITestCase::test_project_name_with_empty_environment_var PASSED [ 41%]

01:38:20 tests/unit/cli_test.py::CLITestCase::test_project_name_with_environment_file PASSED [ 41%]

01:38:20 tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_base_dir PASSED [ 41%]

01:38:20 tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_project_name PASSED [ 41%]

01:38:20 tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_uppercase_base_dir PASSED [ 41%]

01:38:20 tests/integration/service_test.py::ServiceTest::test_start_container_stays_unprivileged PASSED [ 34%]

01:38:20 tests/unit/project_test.py::ProjectTest::test_net_unset PASSED           [ 46%]

01:38:20 tests/unit/cli_test.py::CLITestCase::test_run_interactive_passes_logs_false PASSED [ 41%]

01:38:20 compose-dind-18.09.9-rc1-jenkins-compose-PR-6850-2
01:38:20 tests/integration/service_test.py::ServiceTest::test_scale_with_custom_container_name_outputs_warning PASSED [ 32%]

01:38:20 tests/unit/project_test.py::ProjectTest::test_no_such_service_unicode PASSED [ 46%]

01:38:20 tests/integration/project_test.py::ProjectTest::test_up_with_network_link_local_ips PASSED [ 23%]

01:38:20 tests/unit/cli_test.py::CLITestCase::test_run_service_with_restart_always PASSED [ 41%]

01:38:20 tests/unit/container_test.py::ContainerTest::test_environment PASSED     [ 41%]

01:38:20 tests/unit/container_test.py::ContainerTest::test_from_ps PASSED         [ 41%]

01:38:20 tests/unit/container_test.py::ContainerTest::test_from_ps_prefixed PASSED [ 42%]

01:38:20 tests/unit/container_test.py::ContainerTest::test_get PASSED             [ 42%]

01:38:20 tests/unit/container_test.py::ContainerTest::test_get_local_port PASSED  [ 42%]

01:38:20 tests/unit/container_test.py::ContainerTest::test_has_api_logs PASSED    [ 42%]

01:38:20 tests/unit/container_test.py::ContainerTest::test_human_readable_ports_none PASSED [ 42%]

01:38:20 tests/unit/container_test.py::ContainerTest::test_human_readable_ports_public_and_private PASSED [ 42%]

01:38:20 tests/unit/container_test.py::ContainerTest::test_human_readable_states_healthy PASSED [ 42%]

01:38:20 tests/unit/container_test.py::ContainerTest::test_human_readable_states_no_health PASSED [ 42%]

01:38:20 tests/unit/container_test.py::ContainerTest::test_human_readable_states_starting PASSED [ 42%]

[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // withDockerRegistry
[Pipeline] }
[Pipeline] // node
[Pipeline] }
01:38:20 tests/unit/project_test.py::ProjectTest::test_no_warning_in_normal_mode PASSED [ 47%]

01:38:20 tests/unit/project_test.py::ProjectTest::test_no_warning_on_stop PASSED  [ 47%]

01:38:20 tests/unit/container_test.py::ContainerTest::test_inspect_if_not_inspected PASSED [ 42%]

01:38:20 tests/unit/container_test.py::ContainerTest::test_name PASSED            [ 42%]

01:38:20 tests/unit/container_test.py::ContainerTest::test_name_without_project PASSED [ 42%]

01:38:20 tests/unit/container_test.py::ContainerTest::test_name_without_project_custom_container_name PASSED [ 43%]

01:38:20 tests/unit/container_test.py::ContainerTest::test_name_without_project_one_off PASSED [ 43%]

01:38:20 tests/unit/container_test.py::ContainerTest::test_number PASSED          [ 43%]

01:38:20 tests/unit/container_test.py::ContainerTest::test_short_id PASSED        [ 43%]

01:38:20 tests/unit/container_test.py::GetContainerNameTestCase::test_get_container_name PASSED [ 43%]

01:38:20 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_driver_mismatch PASSED [ 43%]

01:38:20 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_null_remote PASSED [ 43%]

01:38:20 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_null_remote_ipam_options PASSED [ 43%]

01:38:20 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_options_mismatch PASSED [ 43%]

01:38:20 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_success PASSED [ 43%]

01:38:20 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_whitelist PASSED [ 43%]

01:38:20 tests/unit/network_test.py::NetworkTest::test_check_remote_network_labels_mismatch PASSED [ 44%]

01:38:20 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute PASSED  [ 44%]

01:38:20 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_deps PASSED [ 44%]

01:38:20 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_global_limit PASSED [ 44%]

01:38:20 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_limit PASSED [ 44%]

01:38:20 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_upstream_errors PASSED [ 44%]

01:38:20 tests/unit/parallel_test.py::test_parallel_execute_alignment PASSED      [ 44%]

01:38:20 tests/unit/parallel_test.py::test_parallel_execute_ansi PASSED           [ 44%]

01:38:20 tests/unit/parallel_test.py::test_parallel_execute_noansi PASSED         [ 44%]

01:38:20 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_get_digest_from_pull PASSED [ 44%]

01:38:20 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_get_digest_from_push PASSED [ 44%]

01:38:20 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_mismatched_encoding_stream_write PASSED [ 44%]

01:38:20 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output PASSED [ 45%]

01:38:20 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_div_zero PASSED [ 45%]

01:38:20 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_no_progress_event_no_tty PASSED [ 45%]

01:38:20 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_null_total PASSED [ 45%]

01:38:20 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_progress_event_no_tty PASSED [ 45%]

01:38:20 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_progress_event_tty PASSED [ 45%]

01:38:20 tests/integration/project_test.py::ProjectTest::test_project_up_with_no_recreate_running PASSED [ 21%]

01:38:20 tests/unit/project_test.py::ProjectTest::test_no_warning_with_no_swarm_info PASSED [ 47%]

01:38:20 tests/unit/project_test.py::ProjectTest::test_project_platform_value PASSED [ 47%]

01:38:20 tests/integration/service_test.py::ServiceTest::test_scale_with_desired_number_already_achieved PASSED [ 32%]

01:38:21 tests/unit/project_test.py::ProjectTest::test_avoid_multiple_push PASSED [ 45%]

01:38:21 tests/unit/project_test.py::ProjectTest::test_use_net_from_container PASSED [ 47%]

01:38:21 tests/unit/project_test.py::ProjectTest::test_build_container_operation_with_timeout_func_does_not_mutate_options_with_timeout PASSED [ 45%]

01:38:21 tests/unit/project_test.py::ProjectTest::test_container_without_name PASSED [ 45%]

01:38:21 tests/unit/project_test.py::ProjectTest::test_use_net_from_service PASSED [ 47%]

01:38:21 tests/unit/project_test.py::ProjectTest::test_down_with_no_resources PASSED [ 45%]

01:38:21 tests/unit/project_test.py::ProjectTest::test_use_volumes_from_container PASSED [ 47%]

01:38:21 tests/unit/project_test.py::ProjectTest::test_use_volumes_from_service_container PASSED [ 47%]

01:38:21 tests/unit/project_test.py::ProjectTest::test_error_parallel_pull PASSED [ 45%]

01:38:21 tests/unit/project_test.py::ProjectTest::test_events PASSED              [ 46%]

01:38:21 tests/integration/service_test.py::ServiceTest::test_scale_with_immediate_exit PASSED [ 32%]

01:38:21 tests/integration/service_test.py::ServiceTest::test_start_container_uses_tagged_image_if_it_exists PASSED [ 34%]

01:38:21 tests/unit/project_test.py::ProjectTest::test_use_volumes_from_service_no_container PASSED [ 47%]

01:38:21 tests/unit/project_test.py::ProjectTest::test_uses_default_network_false PASSED [ 47%]

01:38:22 tests/unit/project_test.py::ProjectTest::test_events_legacy PASSED       [ 46%]

01:38:22 tests/unit/project_test.py::ProjectTest::test_uses_default_network_true PASSED [ 47%]

01:38:22 tests/integration/project_test.py::ProjectTest::test_project_up_with_no_recreate_stopped PASSED [ 21%]

01:38:22 tests/unit/project_test.py::ProjectTest::test_from_config_v1 PASSED      [ 46%]

01:38:22 tests/unit/project_test.py::ProjectTest::test_from_config_v2 PASSED      [ 46%]

01:38:22 tests/unit/service_test.py::ServiceTest::test_build_does_not_pull PASSED [ 47%]

01:38:22 tests/unit/project_test.py::ProjectTest::test_get_service PASSED         [ 46%]

01:38:22 tests/unit/service_test.py::ServiceTest::test_build_isolation_from_build_override_service_config PASSED [ 48%]

01:38:22 tests/unit/service_test.py::ServiceTest::test_build_service_with_proxy_config PASSED [ 48%]

01:38:22 tests/integration/service_test.py::ServiceTest::test_scale_with_stopped_containers PASSED [ 32%]

Terminated
01:38:22 tests/unit/project_test.py::ProjectTest::test_get_services_removes_duplicates_following_links PASSED [ 46%]

01:38:22 tests/unit/service_test.py::ServiceTest::test_build_volume_options_duplicate_binds PASSED [ 48%]

01:38:22 tests/unit/service_test.py::ServiceTest::test_build_with_default_platform PASSED [ 48%]

01:38:23 tests/integration/project_test.py::ProjectTest::test_up_with_network_priorities PASSED [ 23%]

01:38:23 tests/unit/project_test.py::ProjectTest::test_get_services_returns_all_services_without_args PASSED [ 46%]

01:38:23 tests/unit/project_test.py::ProjectTest::test_get_services_returns_listed_services_with_args PASSED [ 46%]

01:38:23 tests/unit/service_test.py::ServiceTest::test_build_with_isolation_from_service_config PASSED [ 48%]

01:38:23 tests/unit/project_test.py::ProjectTest::test_get_services_with_include_links PASSED [ 46%]

01:38:23 tests/unit/project_test.py::ProjectTest::test_net_unset PASSED           [ 46%]

01:38:23 tests/unit/service_test.py::ServiceTest::test_build_with_override_build_args PASSED [ 48%]

01:38:23 tests/unit/service_test.py::ServiceTest::test_build_with_platform PASSED [ 48%]

01:38:23 tests/unit/project_test.py::ProjectTest::test_no_such_service_unicode PASSED [ 46%]

01:38:23 tests/integration/service_test.py::ServiceTest::test_scale_with_stopped_containers_and_needing_creation PASSED [ 33%]

01:38:23 tests/unit/service_test.py::ServiceTest::test_cgroup_parent PASSED       [ 48%]

01:38:23 tests/integration/service_test.py::ServiceTest::test_start_container_with_external_links <- tests/integration/testcases.py PASSED [ 34%]

01:38:23 tests/unit/project_test.py::ProjectTest::test_no_warning_in_normal_mode PASSED [ 47%]

01:38:23 tests/unit/project_test.py::ProjectTest::test_no_warning_on_stop PASSED  [ 47%]

01:38:23 tests/integration/project_test.py::ProjectTest::test_up_with_network_static_addresses PASSED [ 23%]

01:38:24 tests/unit/service_test.py::ServiceTest::test_config_dict PASSED         [ 48%]

01:38:24 tests/unit/service_test.py::ServiceTest::test_config_dict_with_network_mode_from_container PASSED [ 48%]

01:38:24 tests/integration/project_test.py::ProjectTest::test_project_up_with_secrets PASSED [ 21%]

01:38:24 tests/unit/project_test.py::ProjectTest::test_no_warning_with_no_swarm_info PASSED [ 47%]

01:38:24 tests/integration/project_test.py::ProjectTest::test_up_with_network_static_addresses_missing_subnet PASSED [ 23%]

01:38:24 tests/integration/project_test.py::ProjectTest::test_up_with_nvidia_runtime <- tests/integration/testcases.py SKIPPED [ 23%]

01:38:24 tests/unit/service_test.py::ServiceTest::test_config_hash_matches_label PASSED [ 48%]

01:38:24 tests/integration/service_test.py::ServiceTest::test_scale_with_unexpected_exception PASSED [ 33%]

01:38:24 tests/unit/project_test.py::ProjectTest::test_project_platform_value PASSED [ 47%]

01:38:24 tests/unit/project_test.py::ProjectTest::test_use_net_from_container PASSED [ 47%]

01:38:24 tests/unit/service_test.py::ServiceTest::test_container_without_name PASSED [ 49%]

01:38:24 tests/unit/project_test.py::ProjectTest::test_use_net_from_service PASSED [ 47%]

01:38:24 tests/unit/service_test.py::ServiceTest::test_containers PASSED          [ 49%]

01:38:24 tests/unit/service_test.py::ServiceTest::test_containers_with_containers PASSED [ 49%]

01:38:24 tests/integration/service_test.py::ServiceTest::test_split_env PASSED    [ 33%]

01:38:24 tests/unit/project_test.py::ProjectTest::test_use_volumes_from_container PASSED [ 47%]

01:38:25 tests/unit/service_test.py::ServiceTest::test_create_container PASSED    [ 49%]

01:38:25 tests/integration/project_test.py::ProjectTest::test_project_up_with_volume_labels PASSED [ 21%]

01:38:25 tests/integration/project_test.py::ProjectTest::test_up_with_runtime <- tests/integration/testcases.py PASSED [ 23%]

01:38:25 tests/integration/project_test.py::ProjectTest::test_volumes_from_container PASSED [ 23%]

01:38:25 tests/integration/project_test.py::ProjectTest::test_volumes_from_service PASSED [ 23%]

01:38:25 tests/unit/project_test.py::ProjectTest::test_use_volumes_from_service_container PASSED [ 47%]

01:38:25 tests/unit/project_test.py::ProjectTest::test_use_volumes_from_service_no_container PASSED [ 47%]

01:38:25 tests/unit/service_test.py::ServiceTest::test_create_when_removed_containers_are_listed PASSED [ 49%]

01:38:25 tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_force_build PASSED [ 49%]

01:38:25 tests/integration/service_test.py::ServiceTest::test_start_container_becomes_privileged PASSED [ 33%]

01:38:25 tests/unit/project_test.py::ProjectTest::test_uses_default_network_false PASSED [ 47%]

01:38:25 tests/unit/project_test.py::ProjectTest::test_uses_default_network_true PASSED [ 47%]

01:38:25 tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_no_build PASSED [ 49%]

01:38:25 tests/unit/service_test.py::ServiceTest::test_build_does_not_pull PASSED [ 47%]

01:38:25 tests/integration/service_test.py::ServiceTest::test_start_normal_container_does_not_create_links_to_its_own_service <- tests/integration/testcases.py PASSED [ 34%]

01:38:25 tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_no_build_but_needs_build PASSED [ 49%]

01:38:25 tests/unit/service_test.py::ServiceTest::test_get_container PASSED       [ 49%]

01:38:25 tests/unit/service_test.py::ServiceTest::test_build_isolation_from_build_override_service_config PASSED [ 48%]

01:38:26 tests/integration/resilience_test.py::ResilienceTest::test_create_failure PASSED [ 23%]

01:38:26 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_does_not_mutate_options PASSED [ 49%]

01:38:26 tests/unit/service_test.py::ServiceTest::test_build_service_with_proxy_config PASSED [ 48%]

01:38:26 tests/unit/service_test.py::ServiceTest::test_build_volume_options_duplicate_binds PASSED [ 48%]

01:38:26 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_no_affinity_without_binds PASSED [ 49%]

01:38:26 tests/integration/project_test.py::ProjectTest::test_project_up_without_all_services PASSED [ 21%]

01:38:26 tests/unit/service_test.py::ServiceTest::test_build_with_default_platform PASSED [ 48%]

01:38:26 tests/unit/service_test.py::ServiceTest::test_build_with_isolation_from_service_config PASSED [ 48%]

01:38:26 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_sets_affinity_with_binds PASSED [ 50%]

01:38:26 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_with_name_option PASSED [ 50%]

01:38:26 tests/unit/service_test.py::ServiceTest::test_build_with_override_build_args PASSED [ 48%]

01:38:26 tests/unit/service_test.py::ServiceTest::test_get_container_not_found PASSED [ 50%]

01:38:26 tests/unit/service_test.py::ServiceTest::test_get_create_options_with_proxy_config PASSED [ 50%]

01:38:27 tests/unit/service_test.py::ServiceTest::test_build_with_platform PASSED [ 48%]

01:38:27 tests/integration/service_test.py::ServiceTest::test_start_one_off_container_creates_links_to_its_own_service <- tests/integration/testcases.py PASSED [ 34%]

01:38:27 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_container PASSED [ 50%]

01:38:27 tests/unit/service_test.py::ServiceTest::test_cgroup_parent PASSED       [ 48%]

01:38:27 tests/unit/service_test.py::ServiceTest::test_config_dict PASSED         [ 48%]

01:38:27 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_container_read_only PASSED [ 50%]

01:38:27 tests/integration/resilience_test.py::ResilienceTest::test_start_failure PASSED [ 23%]

01:38:27 tests/unit/service_test.py::ServiceTest::test_config_dict_with_network_mode_from_container PASSED [ 48%]

01:38:27 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_container_exists PASSED [ 50%]

01:38:27 tests/integration/service_test.py::ServiceTest::test_stop_signal PASSED  [ 34%]

01:38:27 tests/unit/service_test.py::ServiceTest::test_config_hash_matches_label PASSED [ 48%]

01:38:27 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_container_exists_with_flags PASSED [ 50%]

01:38:27 tests/integration/service_test.py::ServiceTest::test_start_container_builds_images PASSED [ 33%]

01:38:28 tests/unit/service_test.py::ServiceTest::test_container_without_name PASSED [ 49%]

01:38:28 tests/unit/service_test.py::ServiceTest::test_containers PASSED          [ 49%]

01:38:28 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_no_container PASSED [ 50%]

01:38:28 tests/integration/service_test.py::ServiceTest::test_start_container_creates_fixed_external_ports PASSED [ 33%]

01:38:28 tests/integration/service_test.py::ServiceTest::test_tmpfs PASSED        [ 34%]

01:38:28 tests/unit/service_test.py::ServiceTest::test_containers_with_containers PASSED [ 49%]

01:38:28 tests/integration/resilience_test.py::ResilienceTest::test_successful_recreate PASSED [ 23%]

01:38:28 tests/integration/service_test.py::ServiceTest::test_build PASSED        [ 23%]

01:38:28 tests/integration/service_test.py::ServiceTest::test_build_non_ascii_filename PASSED [ 24%]

01:38:28 tests/unit/service_test.py::ServiceTest::test_image_name_default PASSED  [ 50%]

01:38:28 tests/integration/project_test.py::ProjectTest::test_recreate_preserves_mounts PASSED [ 22%]

01:38:28 tests/unit/service_test.py::ServiceTest::test_create_container PASSED    [ 49%]

01:38:28 tests/unit/service_test.py::ServiceTest::test_create_when_removed_containers_are_listed PASSED [ 49%]

01:38:28 tests/unit/service_test.py::ServiceTest::test_image_name_from_config PASSED [ 50%]

01:38:28 tests/unit/service_test.py::ServiceTest::test_log_opt PASSED             [ 50%]

01:38:28 tests/integration/service_test.py::ServiceTest::test_start_container_creates_fixed_external_ports_when_it_is_different_to_internal_port PASSED [ 33%]

01:38:28 tests/integration/service_test.py::ServiceTest::test_userns_mode_host PASSED [ 34%]

01:38:28 tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_force_build PASSED [ 49%]

01:38:28 tests/unit/service_test.py::ServiceTest::test_mem_reservation PASSED     [ 51%]

01:38:28 tests/unit/service_test.py::ServiceTest::test_memory_swap_limit PASSED   [ 51%]

01:38:29 tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_no_build PASSED [ 49%]

01:38:29 tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_no_build_but_needs_build PASSED [ 49%]

01:38:29 tests/unit/service_test.py::ServiceTest::test_no_default_hostname_when_not_using_networking PASSED [ 51%]

01:38:29 tests/unit/service_test.py::ServiceTest::test_get_container PASSED       [ 49%]

01:38:29 tests/integration/service_test.py::ServiceTest::test_userns_mode_none_defined PASSED [ 34%]

01:38:29 tests/integration/service_test.py::ServiceTest::test_with_high_enough_api_version_we_get_default_network_mode PASSED [ 34%]

01:38:29 tests/integration/service_test.py::ServiceTest::test_working_dir_param PASSED [ 35%]

01:38:29 tests/unit/service_test.py::ServiceTest::test_only_log_warning_when_host_ports_clash PASSED [ 51%]

01:38:29 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_does_not_mutate_options PASSED [ 49%]

01:38:29 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_no_affinity_without_binds PASSED [ 49%]

01:38:29 tests/unit/service_test.py::ServiceTest::test_parse_proxy_config PASSED  [ 51%]

01:38:29 tests/unit/service_test.py::ServiceTest::test_parse_proxy_config_per_host PASSED [ 51%]

01:38:29 tests/integration/project_test.py::ProjectTest::test_recreate_preserves_volumes PASSED [ 22%]

01:38:29 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_sets_affinity_with_binds PASSED [ 50%]

01:38:29 tests/unit/service_test.py::ServiceTest::test_parse_repository_tag PASSED [ 51%]

01:38:29 tests/unit/service_test.py::ServiceTest::test_pull_image PASSED          [ 51%]

01:38:30 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_with_name_option PASSED [ 50%]

01:38:30 tests/unit/service_test.py::ServiceTest::test_pull_image_digest PASSED   [ 51%]

01:38:30 tests/integration/service_test.py::ServiceTest::test_build_with_build_args PASSED [ 24%]

01:38:30 tests/unit/service_test.py::ServiceTest::test_get_container_not_found PASSED [ 50%]

01:38:30 tests/unit/service_test.py::ServiceTest::test_get_create_options_with_proxy_config PASSED [ 50%]

01:38:30 tests/unit/service_test.py::ServiceTest::test_pull_image_no_tag PASSED   [ 51%]

01:38:30 tests/integration/service_test.py::ServiceTest::test_start_container_creates_links PASSED [ 33%]

01:38:30 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_container PASSED [ 50%]

01:38:30 tests/unit/service_test.py::ServiceTest::test_pull_image_with_default_platform PASSED [ 51%]

01:38:30 tests/unit/service_test.py::ServiceTest::test_pull_image_with_platform PASSED [ 52%]

01:38:30 tests/integration/service_test.py::ConfigHashTest::test_config_hash_sticks_around PASSED [ 35%]

01:38:30 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_container_read_only PASSED [ 50%]

01:38:30 tests/unit/service_test.py::ServiceTest::test_pull_image_with_platform_unsupported_api PASSED [ 52%]

01:38:30 tests/integration/service_test.py::ConfigHashTest::test_config_hash_with_custom_labels PASSED [ 35%]

01:38:31 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_container_exists PASSED [ 50%]

01:38:31 tests/unit/service_test.py::ServiceTest::test_recreate_container PASSED  [ 52%]

01:38:31 tests/integration/service_test.py::ConfigHashTest::test_no_config_hash_when_one_off PASSED [ 35%]

01:38:31 tests/integration/service_test.py::ConfigHashTest::test_no_config_hash_when_overriding_options PASSED [ 35%]

01:38:31 tests/unit/service_test.py::ServiceTest::test_recreate_container_with_timeout PASSED [ 52%]

01:38:31 tests/unit/service_test.py::ServiceTest::test_remove_image_all_does_remove PASSED [ 52%]

01:38:31 tests/integration/project_test.py::ProjectTest::test_start_pause_unpause_stop_kill_remove PASSED [ 22%]

01:38:31 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_container_exists_with_flags PASSED [ 50%]

01:38:31 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_no_container PASSED [ 50%]

01:38:31 tests/unit/service_test.py::ServiceTest::test_remove_image_local_with_image_name_doesnt_remove PASSED [ 52%]

01:38:31 tests/unit/service_test.py::ServiceTest::test_image_name_default PASSED  [ 50%]

01:38:32 tests/unit/service_test.py::ServiceTest::test_remove_image_local_without_image_name_does_remove PASSED [ 52%]

01:38:32 tests/unit/service_test.py::ServiceTest::test_remove_image_none PASSED   [ 52%]

01:38:32 tests/integration/service_test.py::ServiceTest::test_start_container_creates_links_with_names PASSED [ 33%]

01:38:32 tests/integration/service_test.py::ServiceTest::test_build_with_build_args_override PASSED [ 24%]

01:38:32 tests/unit/service_test.py::ServiceTest::test_image_name_from_config PASSED [ 50%]

01:38:32 tests/unit/service_test.py::ServiceTest::test_log_opt PASSED             [ 50%]

01:38:32 tests/unit/service_test.py::ServiceTest::test_remove_image_with_error PASSED [ 52%]

01:38:32 tests/unit/service_test.py::ServiceTest::test_mem_reservation PASSED     [ 51%]

01:38:32 tests/unit/service_test.py::ServiceTest::test_remove_non_existing_image PASSED [ 52%]

01:38:32 tests/unit/service_test.py::ServiceTest::test_self_reference_external_link PASSED [ 52%]

01:38:32 tests/unit/service_test.py::ServiceTest::test_service_ignore_default_platform_with_unsupported_api PASSED [ 52%]

01:38:32 tests/integration/service_test.py::ServiceTest::test_start_container_creates_port_with_explicit_protocol PASSED [ 33%]

01:38:32 tests/unit/service_test.py::ServiceTest::test_memory_swap_limit PASSED   [ 51%]

01:38:32 tests/unit/service_test.py::ServiceTest::test_no_default_hostname_when_not_using_networking PASSED [ 51%]

01:38:32 tests/unit/service_test.py::ServiceTest::test_service_platform_precedence PASSED [ 53%]

01:38:33 tests/integration/service_test.py::ServiceTest::test_start_container_creates_ports PASSED [ 33%]

01:38:33 tests/unit/service_test.py::ServiceTest::test_only_log_warning_when_host_ports_clash PASSED [ 51%]

01:38:33 tests/integration/service_test.py::ServiceTest::test_build_with_build_labels PASSED [ 24%]

01:38:33 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_container_port PASSED [ 53%]

01:38:33 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_container_port_range PASSED [ 53%]

01:38:33 tests/unit/service_test.py::ServiceTest::test_parse_proxy_config PASSED  [ 51%]

01:38:33 tests/integration/state_test.py::BasicProjectTest::test_all_change PASSED [ 35%]

01:38:33 tests/integration/service_test.py::ServiceTest::test_build_with_cachefrom PASSED [ 24%]

01:38:33 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_and_port PASSED [ 53%]

01:38:33 tests/unit/service_test.py::ServiceTest::test_parse_proxy_config_per_host PASSED [ 51%]

01:38:33 tests/unit/service_test.py::ServiceTest::test_parse_repository_tag PASSED [ 51%]

01:38:33 tests/integration/service_test.py::ServiceTest::test_start_container_inherits_options_from_constructor PASSED [ 34%]

01:38:33 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_and_port_range PASSED [ 53%]

01:38:33 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_no_port PASSED [ 53%]

01:38:33 tests/unit/service_test.py::ServiceTest::test_pull_image PASSED          [ 51%]

01:38:34 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_no_port_range PASSED [ 53%]

01:38:34 tests/unit/service_test.py::ServiceTest::test_pull_image_digest PASSED   [ 51%]

01:38:34 tests/unit/service_test.py::ServiceTest::test_pull_image_no_tag PASSED   [ 51%]

01:38:34 tests/integration/service_test.py::ServiceTest::test_start_container_passes_through_options PASSED [ 34%]

01:38:34 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_port PASSED [ 53%]

01:38:34 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_port_range PASSED [ 53%]

01:38:34 tests/unit/service_test.py::ServiceTest::test_pull_image_with_default_platform PASSED [ 51%]

01:38:34 tests/integration/state_test.py::BasicProjectTest::test_no_change PASSED [ 35%]

01:38:34 tests/integration/service_test.py::ServiceTest::test_start_container_stays_unprivileged PASSED [ 34%]

01:38:34 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_no_ports PASSED [ 53%]

01:38:34 tests/unit/service_test.py::ServiceTest::test_pull_image_with_platform PASSED [ 52%]

01:38:34 tests/unit/service_test.py::ServiceTest::test_split_domainname_both PASSED [ 53%]

01:38:34 tests/unit/service_test.py::ServiceTest::test_split_domainname_fqdn PASSED [ 54%]

01:38:34 tests/unit/service_test.py::ServiceTest::test_pull_image_with_platform_unsupported_api PASSED [ 52%]

01:38:34 tests/unit/service_test.py::ServiceTest::test_recreate_container PASSED  [ 52%]

01:38:35 tests/unit/service_test.py::ServiceTest::test_split_domainname_none PASSED [ 54%]

01:38:35 tests/unit/service_test.py::ServiceTest::test_recreate_container_with_timeout PASSED [ 52%]

01:38:35 tests/integration/project_test.py::ProjectTest::test_unscale_after_restart PASSED [ 22%]

01:38:35 tests/integration/service_test.py::ServiceTest::test_build_with_extra_hosts PASSED [ 24%]

01:38:35 tests/unit/service_test.py::ServiceTest::test_split_domainname_weird PASSED [ 54%]

01:38:35 tests/unit/service_test.py::ServiceTest::test_stop_grace_period PASSED   [ 54%]

01:38:35 tests/unit/service_test.py::ServiceTest::test_remove_image_all_does_remove PASSED [ 52%]

01:38:35 tests/unit/service_test.py::ServiceTest::test_volumes_order_is_preserved PASSED [ 54%]

01:38:35 tests/unit/service_test.py::ServiceTest::test_remove_image_local_with_image_name_doesnt_remove PASSED [ 52%]

01:38:35 tests/unit/service_test.py::ServiceTest::test_remove_image_local_without_image_name_does_remove PASSED [ 52%]

01:38:35 tests/integration/project_test.py::ProjectTest::test_up_with_custom_name_resources PASSED [ 22%]

01:38:35 tests/unit/service_test.py::TestServiceNetwork::test_connect_container_to_networks_short_aliase_exists PASSED [ 54%]

01:38:35 tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_dict PASSED [ 54%]

01:38:35 tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_integers_and_dicts PASSED [ 54%]

01:38:35 tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_ints PASSED [ 54%]

01:38:35 tests/unit/service_test.py::NetTestCase::test_network_mode PASSED        [ 54%]

01:38:35 tests/unit/service_test.py::ServiceTest::test_remove_image_none PASSED   [ 52%]

01:38:36 tests/unit/service_test.py::NetTestCase::test_network_mode_container PASSED [ 54%]

01:38:36 tests/unit/service_test.py::ServiceTest::test_remove_image_with_error PASSED [ 52%]

01:38:36 tests/integration/service_test.py::ServiceTest::test_build_with_git_url PASSED [ 24%]

01:38:36 tests/integration/state_test.py::BasicProjectTest::test_partial_change PASSED [ 35%]

01:38:36 tests/unit/service_test.py::NetTestCase::test_network_mode_service PASSED [ 55%]

01:38:36 tests/unit/service_test.py::NetTestCase::test_network_mode_service_no_containers PASSED [ 55%]

01:38:36 tests/unit/service_test.py::ServicePortsTest::test_formatted_ports PASSED [ 55%]

01:38:36 tests/unit/service_test.py::ServiceTest::test_remove_non_existing_image PASSED [ 52%]

01:38:36 tests/unit/service_test.py::ServiceTest::test_self_reference_external_link PASSED [ 52%]

01:38:36 tests/unit/service_test.py::ServiceVolumesTest::test_build_volume_binding PASSED [ 55%]

01:38:36 tests/unit/service_test.py::ServiceTest::test_service_ignore_default_platform_with_unsupported_api PASSED [ 52%]

01:38:36 tests/unit/service_test.py::ServiceVolumesTest::test_create_with_special_volume_mode PASSED [ 55%]

01:38:36 tests/unit/service_test.py::ServiceVolumesTest::test_get_container_create_options_with_different_host_path_in_container_json PASSED [ 55%]

01:38:36 tests/unit/service_test.py::ServiceTest::test_service_platform_precedence PASSED [ 53%]

01:38:36 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_container_port PASSED [ 53%]

01:38:36 tests/integration/service_test.py::ServiceTest::test_start_container_uses_tagged_image_if_it_exists PASSED [ 34%]

01:38:37 tests/integration/project_test.py::ProjectTest::test_up_with_enable_ipv6 PASSED [ 22%]

01:38:37 tests/integration/project_test.py::ProjectTest::test_up_with_invalid_isolation PASSED [ 22%]

01:38:37 tests/integration/project_test.py::ProjectTest::test_up_with_invalid_runtime PASSED [ 22%]

01:38:37 tests/unit/service_test.py::ServiceVolumesTest::test_get_container_data_volumes PASSED [ 55%]

01:38:37 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_container_port_range PASSED [ 53%]

01:38:37 tests/unit/service_test.py::ServiceVolumesTest::test_merge_volume_bindings PASSED [ 55%]

01:38:37 tests/unit/service_test.py::ServiceVolumesTest::test_mount_same_host_path_to_two_volumes PASSED [ 55%]

01:38:37 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_and_port PASSED [ 53%]

01:38:37 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_no_warning_with_container_only_option PASSED [ 55%]

01:38:37 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_and_port_range PASSED [ 53%]

01:38:37 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_no_port PASSED [ 53%]

01:38:37 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_no_warning_with_same_path PASSED [ 55%]

01:38:37 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_volume_no_warning_when_no_container_volumes PASSED [ 55%]

01:38:37 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_no_port_range PASSED [ 53%]

01:38:37 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_port PASSED [ 53%]

01:38:38 tests/integration/service_test.py::ServiceTest::test_build_with_gzip PASSED [ 24%]

01:38:38 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_volume_when_masked PASSED [ 56%]

01:38:38 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_port_range PASSED [ 53%]

01:38:38 tests/integration/project_test.py::ProjectTest::test_up_with_ipam_config PASSED [ 22%]

01:38:38 tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes PASSED [ 56%]

01:38:38 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_no_ports PASSED [ 53%]

01:38:38 tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes_abspath PASSED [ 56%]

01:38:38 tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes_no_target PASSED [ 56%]

01:38:38 tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_unix_path PASSED [ 56%]

01:38:38 tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_url_no_prefix PASSED [ 56%]

01:38:38 tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_windows_path PASSED [ 56%]

01:38:38 tests/unit/split_buffer_test.py::SplitBufferTest::test_chunked_line PASSED [ 56%]

01:38:38 tests/unit/split_buffer_test.py::SplitBufferTest::test_multiple_line_chunk PASSED [ 56%]

01:38:38 tests/unit/split_buffer_test.py::SplitBufferTest::test_no_end_separator PASSED [ 56%]

01:38:38 tests/unit/split_buffer_test.py::SplitBufferTest::test_preserves_unicode_sequences_within_lines PASSED [ 56%]

01:38:38 tests/unit/split_buffer_test.py::SplitBufferTest::test_single_line_chunks PASSED [ 57%]

01:38:38 tests/unit/timeparse_test.py::test_milli PASSED                          [ 57%]

01:38:38 tests/unit/timeparse_test.py::test_milli_float PASSED                    [ 57%]

01:38:38 tests/unit/timeparse_test.py::test_second_milli PASSED                   [ 57%]

01:38:38 tests/unit/timeparse_test.py::test_second_milli_micro PASSED             [ 57%]

01:38:38 tests/unit/timeparse_test.py::test_second PASSED                         [ 57%]

01:38:38 tests/unit/timeparse_test.py::test_second_as_float PASSED                [ 57%]

01:38:38 tests/unit/timeparse_test.py::test_minute PASSED                         [ 57%]

01:38:38 tests/unit/timeparse_test.py::test_hour_minute PASSED                    [ 57%]

01:38:38 tests/unit/timeparse_test.py::test_minute_as_float PASSED                [ 57%]

01:38:38 tests/unit/timeparse_test.py::test_hour_minute_second PASSED             [ 57%]

01:38:38 tests/unit/timeparse_test.py::test_invalid_with_space PASSED             [ 57%]

01:38:38 tests/unit/timeparse_test.py::test_invalid_with_comma PASSED             [ 58%]

01:38:38 tests/unit/timeparse_test.py::test_invalid_with_empty_string PASSED      [ 58%]

01:38:38 tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_no_object PASSED [ 58%]

01:38:38 tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_with_object PASSED [ 58%]

01:38:38 tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_leading_whitespace PASSED [ 58%]

01:38:38 tests/unit/utils_test.py::TestStreamAsText::test_stream_with_non_utf_unicode_character PASSED [ 58%]

01:38:38 tests/unit/utils_test.py::TestStreamAsText::test_stream_with_utf_character PASSED [ 58%]

01:38:38 tests/unit/utils_test.py::TestJsonStream::test_with_falsy_entries PASSED [ 58%]

01:38:38 tests/unit/utils_test.py::TestJsonStream::test_with_leading_whitespace PASSED [ 58%]

01:38:38 tests/unit/utils_test.py::TestParseBytes::test_parse_bytes PASSED        [ 58%]

01:38:38 tests/unit/utils_test.py::TestMoreItertools::test_unique_everseen PASSED [ 58%]

01:38:38 tests/unit/service_test.py::ServiceTest::test_split_domainname_both PASSED [ 53%]

01:38:38 tests/unit/service_test.py::ServiceTest::test_split_domainname_fqdn PASSED [ 54%]

01:38:38 tests/integration/service_test.py::ServiceTest::test_start_container_with_external_links PASSED [ 34%]

01:38:38 tests/unit/volume_test.py::TestVolume::test_remove_local_volume PASSED   [ 59%]

01:38:38 tests/unit/service_test.py::ServiceTest::test_split_domainname_none PASSED [ 54%]

01:38:39 tests/unit/volume_test.py::TestVolume::test_remove_external_volume PASSED [ 59%]

01:38:39 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_path_from_options PASSED [ 59%]

01:38:39 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_single_path_from_env PASSED [ 59%]

01:38:39 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env PASSED [ 59%]

01:38:39 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env_windows SKIPPED [ 59%]

01:38:39 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env_custom_separator PASSED [ 59%]

01:38:39 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_no_path PASSED [ 59%]

01:38:39 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_unicode_path_from_options PASSED [ 59%]

01:38:39 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_unicode_path_from_env SKIPPED [ 59%]

01:38:39 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_custom_timeout_error PASSED [ 59%]

01:38:39 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_docker_client_no_home PASSED [ 60%]

01:38:39 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_docker_client_with_custom_timeout PASSED [ 60%]

01:38:39 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_user_agent PASSED [ 60%]

01:38:39 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_assert_hostname_explicit_skip PASSED [ 60%]

01:38:39 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_simple_tls PASSED [ 60%]

01:38:39 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_ca_cert PASSED [ 60%]

01:38:39 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_ca_cert_explicit PASSED [ 60%]

01:38:39 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca PASSED [ 60%]

01:38:39 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca_explicit PASSED [ 60%]

01:38:39 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca_quoted_paths PASSED [ 60%]

01:38:39 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_cert PASSED [ 60%]

01:38:39 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_cert_explicit PASSED [ 60%]

01:38:39 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_missing_key PASSED [ 61%]

01:38:39 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_flags_override_environment PASSED [ 61%]

01:38:39 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_mixed_environment_and_flags PASSED [ 61%]

01:38:39 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_simple_with_tls_version PASSED [ 61%]

01:38:39 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_default_cert_path PASSED [ 61%]

01:38:39 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_env_falsy_value PASSED [ 61%]

01:38:39 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_flag_no_override PASSED [ 61%]

01:38:39 tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_default PASSED [ 61%]

01:38:39 tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_upgrade PASSED [ 61%]

01:38:39 tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_unavailable PASSED [ 61%]

01:38:39 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_generic_connection_error PASSED [ 61%]

01:38:39 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_mismatch PASSED [ 62%]

01:38:39 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_mismatch_unicode_explanation PASSED [ 62%]

01:38:39 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_other PASSED [ 62%]

01:38:39 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_other_unicode_explanation PASSED [ 62%]

01:38:39 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_no_data SKIPPED [ 62%]

01:38:39 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_misc SKIPPED [ 62%]

01:38:39 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_encoding_issue SKIPPED [ 62%]

01:38:39 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_error PASSED [ 62%]

01:38:39 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_info PASSED [ 62%]

01:38:39 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_error PASSED [ 62%]

01:38:39 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_info PASSED [ 62%]

01:38:39 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_warn PASSED [ 63%]

01:38:39 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_warn PASSED [ 63%]

01:38:39 tests/unit/cli/log_printer_test.py::TestLogPresenter::test_monochrome PASSED [ 63%]

01:38:39 tests/unit/cli/log_printer_test.py::TestLogPresenter::test_polychrome PASSED [ 63%]

01:38:39 tests/unit/cli/log_printer_test.py::test_wait_on_exit PASSED             [ 63%]

01:38:39 tests/unit/cli/log_printer_test.py::test_wait_on_exit_raises PASSED      [ 63%]

01:38:39 tests/unit/cli/log_printer_test.py::test_build_no_log_generator PASSED   [ 63%]

01:38:39 tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_no_log_stream PASSED [ 63%]

01:38:39 tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_with_log_stream PASSED [ 63%]

01:38:39 tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_unicode PASSED [ 63%]

01:38:39 tests/unit/cli/log_printer_test.py::TestWatchEvents::test_stop_event PASSED [ 63%]

01:38:39 tests/unit/cli/log_printer_test.py::TestWatchEvents::test_start_event PASSED [ 63%]

01:38:39 tests/unit/cli/log_printer_test.py::TestWatchEvents::test_other_event PASSED [ 64%]

01:38:39 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_an_exception PASSED [ 64%]

01:38:39 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_stop_without_cascade_stop PASSED [ 64%]

01:38:39 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_stop_with_cascade_stop PASSED [ 64%]

01:38:39 tests/unit/service_test.py::ServiceTest::test_split_domainname_weird PASSED [ 54%]

01:38:39 tests/unit/service_test.py::ServiceTest::test_stop_grace_period PASSED   [ 54%]

01:38:39 tests/integration/project_test.py::ProjectTest::test_up_with_ipam_options PASSED [ 22%]

01:38:39 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_none_when_timeout_is_hit PASSED [ 64%]

01:38:39 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_filter_containers_to_service_names PASSED [ 64%]

01:38:39 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_filter_containers_to_service_names_all PASSED [ 64%]

01:38:39 tests/integration/service_test.py::ServiceTest::test_build_with_illegal_leading_chars PASSED [ 24%]

01:38:39 tests/integration/service_test.py::ServiceTest::test_build_with_image_name PASSED [ 24%]

01:38:39 tests/integration/service_test.py::ServiceTest::test_build_with_isolation PASSED [ 24%]

01:38:39 tests/unit/service_test.py::ServiceTest::test_volumes_order_is_preserved PASSED [ 54%]

01:38:39 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_warning_in_swarm_mode PASSED [ 64%]

01:38:39 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_build_one_off_container_options PASSED [ 64%]

01:38:39 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_get_docker_start_call PASSED [ 64%]

01:38:39 tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_tty_verbose PASSED [ 64%]

01:38:39 tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_tty_not_verbose PASSED [ 65%]

01:38:39 tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_not_a_tty PASSED [ 65%]

01:38:39 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_invalid_opts PASSED [ 65%]

01:38:39 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_always PASSED [ 65%]

01:38:39 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_never PASSED [ 65%]

01:38:39 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_changed PASSED [ 65%]

01:38:39 tests/unit/cli/main_test.py::TestCallDocker::test_simple_no_options PASSED [ 65%]

01:38:39 tests/unit/cli/main_test.py::TestCallDocker::test_simple_tls_option PASSED [ 65%]

01:38:39 tests/unit/cli/main_test.py::TestCallDocker::test_advanced_tls_options PASSED [ 65%]

01:38:39 tests/unit/cli/main_test.py::TestCallDocker::test_with_host_option PASSED [ 65%]

01:38:39 tests/unit/cli/main_test.py::TestCallDocker::test_with_http_host PASSED  [ 65%]

01:38:39 tests/unit/cli/main_test.py::TestCallDocker::test_with_host_option_shorthand_equal PASSED [ 65%]

01:38:39 tests/unit/cli/main_test.py::TestCallDocker::test_with_env PASSED        [ 66%]

01:38:39 tests/unit/cli/utils_test.py::UnquotePathTest::test_nested_quotes PASSED [ 66%]

01:38:39 tests/unit/cli/utils_test.py::UnquotePathTest::test_no_quotes PASSED     [ 66%]

01:38:39 tests/unit/cli/utils_test.py::UnquotePathTest::test_simple_quotes PASSED [ 66%]

01:38:39 tests/unit/cli/utils_test.py::UnquotePathTest::test_uneven_quotes PASSED [ 66%]

01:38:39 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_100b PASSED [ 66%]

01:38:39 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_1023b PASSED [ 66%]

01:38:39 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_1kb PASSED [ 66%]

01:38:39 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_units PASSED [ 66%]

01:38:39 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_call PASSED [ 66%]

01:38:39 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return PASSED [ 66%]

01:38:39 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return_no_result PASSED [ 67%]

01:38:39 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return_sequence PASSED [ 67%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_build_args_allow_empty_properties PASSED [ 67%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_build_args_check_zero_preserved PASSED [ 67%]

01:38:39 tests/unit/service_test.py::TestServiceNetwork::test_connect_container_to_networks_short_aliase_exists PASSED [ 54%]

01:38:39 tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_dict PASSED [ 54%]

01:38:39 tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_integers_and_dicts PASSED [ 54%]

01:38:39 tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_ints PASSED [ 54%]

01:38:39 tests/unit/service_test.py::NetTestCase::test_network_mode PASSED        [ 54%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_config_build_configuration PASSED [ 67%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_config_build_configuration_v2 PASSED [ 67%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_config_convertible_label_types PASSED [ 67%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_config_duplicate_cache_from_values_validation_error PASSED [ 67%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_config_duplicate_mount_points PASSED [ 67%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_config_extra_hosts_list_of_dicts_validation_error PASSED [ 67%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_config_extra_hosts_string_raises_validation_error PASSED [ 67%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_config_hint PASSED    [ 68%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error PASSED [ 68%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error_v2 PASSED [ 68%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error_v2_when_no_interpolate PASSED [ 68%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_property_raise_validation_error PASSED [ 68%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_config_invalid_ipam_config PASSED [ 68%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_config_invalid_label_types PASSED [ 68%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_config_invalid_service_name_raise_validation_error PASSED [ 68%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_invalid_keys_validation_error PASSED [ 68%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_required_keys_validation_error PASSED [ 68%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_soft_greater_than_hard_error PASSED [ 68%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_config_valid_environment_dict_key_contains_dashes PASSED [ 68%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_config_valid_ipam_config PASSED [ 69%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_config_valid_service_label_validation PASSED [ 69%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_config_valid_service_names PASSED [ 69%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_depends_on_orders_services PASSED [ 69%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_depends_on_unknown_service_errors PASSED [ 69%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_dns_opt_option PASSED [ 69%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_empty_environment_key_allowed PASSED [ 69%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_external_volume_config PASSED [ 69%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_external_volume_invalid_config PASSED [ 69%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_group_add_option PASSED [ 69%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_build_and_image_specified_v1 PASSED [ 69%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_not_a_dictionary PASSED [ 70%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_not_unique_items PASSED [ 70%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_type_should_be_an_array PASSED [ 70%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_v1 PASSED [ 70%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_v2 PASSED [ 70%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_invalid_list_of_strings_format PASSED [ 70%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_isolation_option PASSED [ 70%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_linked_service_is_undefined PASSED [ 70%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_load PASSED           [ 70%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_load_bind_mount_relative_path PASSED [ 70%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_load_bind_mount_relative_path_with_tilde PASSED [ 70%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_load_build_labels_dict PASSED [ 71%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_load_build_labels_list PASSED [ 71%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_load_config_custom_resource_names PASSED [ 71%]

01:38:39 tests/unit/config/config_test.py::ConfigTest::test_load_config_dockerfile_without_build_raises_error_v1 PASSED [ 71%]

01:38:39 tests/unit/service_test.py::NetTestCase::test_network_mode_container PASSED [ 54%]

01:38:40 tests/integration/service_test.py::ServiceTest::test_start_normal_container_does_not_create_links_to_its_own_service PASSED [ 34%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_config_invalid_service_names PASSED [ 71%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_config_invalid_service_names_v2 PASSED [ 71%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_config_link_local_ips_network PASSED [ 71%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_config_service_labels PASSED [ 71%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_config_volume_and_network_labels PASSED [ 71%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_configs PASSED   [ 71%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_configs_multi_file PASSED [ 71%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_dockerfile_without_context PASSED [ 71%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_errors_on_uppercase_with_no_image PASSED [ 72%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_invalid_service_definition PASSED [ 72%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_mixed_extends_resolution PASSED [ 72%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_secrets PASSED   [ 72%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_secrets_multi_file PASSED [ 72%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_service_with_name_version PASSED [ 72%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_sorts_in_dependency_order PASSED [ 72%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_when_not_dict PASSED [ 72%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_when_not_dict_v2 PASSED [ 72%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_with_invalid_network_fields PASSED [ 72%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_v2 PASSED        [ 72%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_with_buildargs PASSED [ 73%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_with_empty_build_args PASSED [ 73%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_with_extensions PASSED [ 73%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_with_invalid_field_name PASSED [ 73%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_with_invalid_field_name_v1 PASSED [ 73%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_base PASSED [ 73%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_base_v2 PASSED [ 73%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_override PASSED [ 73%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_override_v2 PASSED [ 73%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_extends_in_override_file PASSED [ 73%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_invalid_override PASSED [ 73%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_mismatched_networks_format PASSED [ 73%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_mismatched_networks_format_inverse_order PASSED [ 74%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v1 PASSED [ 74%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v2 PASSED [ 74%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v3_2 PASSED [ 74%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_yaml_with_bom PASSED [ 74%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_load_yaml_with_yaml_error PASSED [ 74%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_logs_warning_for_boolean_in_environment PASSED [ 74%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_blkio_config PASSED [ 74%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_configs_override PASSED [ 74%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_credential_spec PASSED [ 74%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_depends_on_mixed_syntax PASSED [ 74%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_depends_on_no_override PASSED [ 75%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_deploy PASSED   [ 75%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_deploy_override PASSED [ 75%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_device_cgroup_rules PASSED [ 75%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_different_configs PASSED [ 75%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_different_secrets PASSED [ 75%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_extra_hosts PASSED [ 75%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_config PASSED [ 75%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_override_disables PASSED [ 75%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_override_enables PASSED [ 75%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_isolation PASSED [ 75%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v1 PASSED [ 76%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2 PASSED [ 76%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_base PASSED [ 76%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_base_driver PASSED [ 76%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_drivers PASSED [ 76%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_override PASSED [ 76%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_override_options PASSED [ 76%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_override_driver PASSED [ 76%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_mixed_ports PASSED [ 76%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_pid PASSED      [ 76%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_scale PASSED    [ 76%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_secrets_override PASSED [ 76%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_from_files_with_extends_in_base PASSED [ 77%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_from_files_with_extends_in_override PASSED [ 77%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous PASSED [ 77%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous_2 PASSED [ 77%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous_volumes PASSED [ 77%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_ports_sorting PASSED [ 77%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_merge_storage_opt PASSED [ 77%]

01:38:40 tests/integration/project_test.py::ProjectTest::test_up_with_isolation PASSED [ 22%]

01:38:40 tests/unit/service_test.py::NetTestCase::test_network_mode_service PASSED [ 55%]

01:38:40 tests/unit/service_test.py::NetTestCase::test_network_mode_service_no_containers PASSED [ 55%]

01:38:40 tests/unit/service_test.py::ServicePortsTest::test_formatted_ports PASSED [ 55%]

01:38:40 tests/integration/service_test.py::ServiceTest::test_build_with_network <- tests/integration/testcases.py PASSED [ 25%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_named_volume_config_empty PASSED [ 77%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_named_volume_invalid_type_list PASSED [ 77%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_named_volume_numeric_driver_opt PASSED [ 77%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_networks_invalid_type_list PASSED [ 77%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_normalize_dns_options PASSED [ 78%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_oom_score_adj_option PASSED [ 78%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_runtime_option PASSED [ 78%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_service_volume_invalid_config PASSED [ 78%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_swappiness_option PASSED [ 78%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_tmpfs_option PASSED   [ 78%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_undeclared_volume_v1 PASSED [ 78%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_undeclared_volume_v2 PASSED [ 78%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_unsupported_version PASSED [ 78%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_v1_file_version PASSED [ 78%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_v1_file_with_version_is_invalid PASSED [ 78%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_valid_config_oneof_string_or_list PASSED [ 78%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_valid_config_which_allows_two_type_definitions PASSED [ 79%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_valid_versions PASSED [ 79%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_validate_extra_hosts_invalid PASSED [ 79%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_validate_extra_hosts_invalid_list PASSED [ 79%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_version_1_is_invalid PASSED [ 79%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_volume_invalid_driver_opt PASSED [ 79%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_volume_mode_override PASSED [ 79%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_volumes_long_syntax PASSED [ 79%]

01:38:40 tests/unit/config/config_test.py::ConfigTest::test_wrong_version_type PASSED [ 79%]

01:38:40 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_container PASSED [ 79%]

01:38:40 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_container_v1 PASSED [ 79%]

01:38:40 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_plus_networks_is_invalid PASSED [ 80%]

01:38:40 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service PASSED [ 80%]

01:38:40 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service_nonexistent PASSED [ 80%]

01:38:40 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service_v1 PASSED [ 80%]

01:38:40 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_standard PASSED [ 80%]

01:38:40 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_standard_v1 PASSED [ 80%]

01:38:40 tests/unit/config/config_test.py::PortsTest::test_config_invalid_expose_format_validation PASSED [ 80%]

01:38:40 tests/unit/config/config_test.py::PortsTest::test_config_invalid_expose_type_validation PASSED [ 80%]

01:38:40 tests/unit/config/config_test.py::PortsTest::test_config_invalid_ports_format_validation PASSED [ 80%]

01:38:40 tests/unit/config/config_test.py::PortsTest::test_config_invalid_ports_type_validation PASSED [ 80%]

01:38:40 tests/unit/config/config_test.py::PortsTest::test_config_non_unique_expose_validation PASSED [ 80%]

01:38:40 tests/unit/config/config_test.py::PortsTest::test_config_non_unique_ports_validation PASSED [ 81%]

01:38:40 tests/unit/config/config_test.py::PortsTest::test_config_valid_expose_format_validation PASSED [ 81%]

01:38:40 tests/unit/config/config_test.py::PortsTest::test_config_valid_ports_format_validation PASSED [ 81%]

01:38:40 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_leaf PASSED [ 35%]

01:38:40 tests/unit/service_test.py::ServiceVolumesTest::test_build_volume_binding PASSED [ 55%]

01:38:40 tests/unit/config/config_test.py::SubnetTest::test_config_invalid_subnet_format_validation PASSED [ 81%]

01:38:40 tests/unit/config/config_test.py::SubnetTest::test_config_invalid_subnet_type_validation PASSED [ 81%]

01:38:40 tests/unit/config/config_test.py::SubnetTest::test_config_valid_subnet_format_validation PASSED [ 81%]

01:38:40 tests/unit/config/config_test.py::InterpolationTest::test_compatibility_mode_load PASSED [ 81%]

01:38:40 tests/unit/config/config_test.py::InterpolationTest::test_compatibility_mode_warnings PASSED [ 81%]

01:38:40 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_file PASSED [ 81%]

01:38:40 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_variable PASSED [ 81%]

01:38:40 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_variable_with_defaults PASSED [ 81%]

01:38:40 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_options_environment_file PASSED [ 81%]

01:38:40 tests/unit/config/config_test.py::InterpolationTest::test_interpolation_configs_section PASSED [ 82%]

01:38:40 tests/unit/config/config_test.py::InterpolationTest::test_interpolation_secrets_section PASSED [ 82%]

01:38:40 tests/unit/config/config_test.py::InterpolationTest::test_invalid_interpolation PASSED [ 82%]

01:38:40 tests/unit/config/config_test.py::InterpolationTest::test_unset_variable_produces_warning PASSED [ 82%]

01:38:40 tests/unit/config/config_test.py::VolumeConfigTest::test_absolute_posix_path_does_not_expand PASSED [ 82%]

01:38:40 tests/unit/config/config_test.py::VolumeConfigTest::test_absolute_windows_path_does_not_expand PASSED [ 82%]

01:38:40 tests/unit/config/config_test.py::VolumeConfigTest::test_home_directory_with_driver_does_not_expand PASSED [ 82%]

01:38:40 tests/unit/config/config_test.py::VolumeConfigTest::test_name_does_not_expand PASSED [ 82%]

01:38:40 tests/unit/config/config_test.py::VolumeConfigTest::test_no_binding PASSED [ 82%]

01:38:40 tests/unit/config/config_test.py::VolumeConfigTest::test_relative_path_does_expand_posix PASSED [ 82%]

01:38:40 tests/unit/config/config_test.py::VolumeConfigTest::test_relative_path_does_expand_windows SKIPPED [ 82%]

01:38:40 tests/unit/config/config_test.py::VolumeConfigTest::test_volume_binding_with_environment_variable PASSED [ 83%]

01:38:40 tests/unit/config/config_test.py::VolumeConfigTest::test_volume_binding_with_home PASSED [ 83%]

01:38:40 tests/unit/config/config_test.py::VolumeConfigTest::test_volume_path_with_non_ascii_directory PASSED [ 83%]

01:38:40 tests/unit/config/config_test.py::VolumeConfigTest::test_volumes_order_is_preserved PASSED [ 83%]

01:38:40 tests/unit/config/config_test.py::MergeVolumesTest::test_add_explicit_path PASSED [ 83%]

01:38:40 tests/unit/config/config_test.py::MergeVolumesTest::test_empty PASSED    [ 83%]

01:38:40 tests/unit/config/config_test.py::MergeVolumesTest::test_no_base PASSED  [ 83%]

01:38:40 tests/unit/config/config_test.py::MergeVolumesTest::test_no_override PASSED [ 83%]

01:38:40 tests/unit/config/config_test.py::MergeVolumesTest::test_override_explicit_path PASSED [ 83%]

01:38:40 tests/unit/config/config_test.py::MergeVolumesTest::test_remove_explicit_path PASSED [ 83%]

01:38:40 tests/unit/config/config_test.py::MergeDevicesTest::test_add_explicit_path PASSED [ 83%]

01:38:40 tests/unit/config/config_test.py::MergeDevicesTest::test_empty PASSED    [ 84%]

01:38:40 tests/unit/config/config_test.py::MergeDevicesTest::test_no_base PASSED  [ 84%]

01:38:40 tests/unit/config/config_test.py::MergeDevicesTest::test_no_override PASSED [ 84%]

01:38:40 tests/unit/config/config_test.py::MergeDevicesTest::test_override_explicit_path PASSED [ 84%]

01:38:40 tests/unit/config/config_test.py::MergeDevicesTest::test_remove_explicit_path PASSED [ 84%]

01:38:40 tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_no_override PASSED [ 84%]

01:38:40 tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_override_with_other PASSED [ 84%]

01:38:40 tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_override_with_same PASSED [ 84%]

01:38:40 tests/unit/config/config_test.py::MergePortsTest::test_add_item PASSED   [ 84%]

01:38:40 tests/unit/config/config_test.py::MergePortsTest::test_duplicate_port_mappings PASSED [ 84%]

01:38:40 tests/unit/config/config_test.py::MergePortsTest::test_empty PASSED      [ 84%]

01:38:40 tests/unit/config/config_test.py::MergePortsTest::test_no_base PASSED    [ 84%]

01:38:40 tests/unit/config/config_test.py::MergePortsTest::test_no_override PASSED [ 85%]

01:38:40 tests/unit/config/config_test.py::MergeNetworksTest::test_add_item PASSED [ 85%]

01:38:40 tests/unit/config/config_test.py::MergeNetworksTest::test_all_properties PASSED [ 85%]

01:38:40 tests/unit/config/config_test.py::MergeNetworksTest::test_empty PASSED   [ 85%]

01:38:40 tests/unit/config/config_test.py::MergeNetworksTest::test_network_has_none_value PASSED [ 85%]

01:38:40 tests/unit/config/config_test.py::MergeNetworksTest::test_no_base PASSED [ 85%]

01:38:40 tests/unit/config/config_test.py::MergeNetworksTest::test_no_network_name_overrides PASSED [ 85%]

01:38:40 tests/unit/config/config_test.py::MergeNetworksTest::test_no_network_overrides PASSED [ 85%]

01:38:40 tests/unit/config/config_test.py::MergeNetworksTest::test_no_override PASSED [ 85%]

01:38:40 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_add_list PASSED [ 85%]

01:38:40 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_add_string PASSED [ 85%]

01:38:40 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_no_base PASSED [ 86%]

01:38:40 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_no_override PASSED [ 86%]

01:38:40 tests/unit/config/config_test.py::MergeLabelsTest::test_add_explicit_value PASSED [ 86%]

01:38:40 tests/unit/config/config_test.py::MergeLabelsTest::test_empty PASSED     [ 86%]

01:38:40 tests/unit/config/config_test.py::MergeLabelsTest::test_no_base PASSED   [ 86%]

01:38:40 tests/unit/config/config_test.py::MergeLabelsTest::test_no_override PASSED [ 86%]

01:38:40 tests/unit/config/config_test.py::MergeLabelsTest::test_override_explicit_value PASSED [ 86%]

01:38:40 tests/unit/config/config_test.py::MergeLabelsTest::test_remove_explicit_value PASSED [ 86%]

01:38:40 tests/unit/config/config_test.py::MergeBuildTest::test_empty_base PASSED [ 86%]

01:38:40 tests/unit/config/config_test.py::MergeBuildTest::test_empty_override PASSED [ 86%]

01:38:40 tests/unit/config/config_test.py::MergeBuildTest::test_full PASSED       [ 86%]

01:38:40 tests/unit/config/config_test.py::MemoryOptionsTest::test_memswap_can_be_a_string PASSED [ 86%]

01:38:40 tests/unit/config/config_test.py::MemoryOptionsTest::test_validation_fails_with_just_memswap_limit PASSED [ 87%]

01:38:40 tests/unit/config/config_test.py::MemoryOptionsTest::test_validation_with_correct_memswap_values PASSED [ 87%]

01:38:40 tests/unit/config/config_test.py::EnvTest::test_environment_overrides_env_file PASSED [ 87%]

01:38:40 tests/unit/config/config_test.py::EnvTest::test_parse_environment_as_dict PASSED [ 87%]

01:38:40 tests/unit/config/config_test.py::EnvTest::test_parse_environment_as_list PASSED [ 87%]

01:38:40 tests/unit/config/config_test.py::EnvTest::test_parse_environment_empty PASSED [ 87%]

01:38:40 tests/unit/config/config_test.py::EnvTest::test_parse_environment_invalid PASSED [ 87%]

01:38:40 tests/unit/config/config_test.py::EnvTest::test_resolve_build_args PASSED [ 87%]

01:38:40 tests/unit/config/config_test.py::EnvTest::test_resolve_environment PASSED [ 87%]

01:38:40 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_from_env_file PASSED [ 87%]

01:38:40 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_from_env_file_with_empty_values PASSED [ 87%]

01:38:40 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_nonexistent_file PASSED [ 88%]

01:38:40 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_with_multiple_env_files PASSED [ 88%]

01:38:40 tests/unit/config/config_test.py::EnvTest::test_resolve_path PASSED      [ 88%]

01:38:40 tests/unit/service_test.py::ServiceVolumesTest::test_create_with_special_volume_mode PASSED [ 55%]

01:38:40 tests/unit/service_test.py::ServiceVolumesTest::test_get_container_create_options_with_different_host_path_in_container_json PASSED [ 55%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_circular PASSED      [ 88%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_invalid_config PASSED [ 88%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_valid_config PASSED [ 88%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_verbose_and_shorthand_way PASSED [ 88%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_extends PASSED       [ 88%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_file_defaults_to_self PASSED [ 88%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_empty_dictionary PASSED [ 88%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_invalid_key PASSED [ 88%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_missing_service_key PASSED [ 89%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_no_file_key_no_filename_set PASSED [ 89%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_sub_property_key PASSED [ 89%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_valid_config PASSED [ 89%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_defined_version_passes PASSED [ 89%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_depends_on PASSED [ 89%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_environment_and_env_files PASSED [ 89%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_healthcheck PASSED [ 89%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_mixed_versions_is_error PASSED [ 89%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_ports PASSED [ 89%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_security_opt PASSED [ 89%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_invalid_links_in_extended_service PASSED [ 89%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_invalid_net_in_extended_service PASSED [ 90%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_invalid_volumes_from_in_extended_service PASSED [ 90%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_load_config_runs_interpolation_in_extended_service PASSED [ 90%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_load_throws_error_when_base_service_does_not_exist PASSED [ 90%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_merging_env_labels_ulimits PASSED [ 90%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_nested PASSED        [ 90%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_parent_build_path_dne PASSED [ 90%]

01:38:40 tests/unit/config/config_test.py::ExtendsTest::test_partial_service_config_in_extends_is_still_valid PASSED [ 90%]

01:38:41 tests/unit/service_test.py::ServiceVolumesTest::test_get_container_data_volumes PASSED [ 55%]

01:38:41 tests/integration/project_test.py::ProjectTest::test_up_with_network_link_local_ips PASSED [ 23%]

01:38:41 tests/unit/config/config_test.py::ExtendsTest::test_self_referencing_file PASSED [ 90%]

01:38:41 tests/unit/config/config_test.py::ExtendsTest::test_volume_path PASSED   [ 90%]

01:38:41 tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_absolute PASSED [ 90%]

01:38:41 tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_normal PASSED [ 91%]

01:38:41 tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_with_tilde PASSED [ 91%]

01:38:41 tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_root_mount PASSED [ 91%]

01:38:41 tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_windows_path PASSED [ 91%]

01:38:41 tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_windows_path_in_container PASSED [ 91%]

01:38:41 tests/unit/config/config_test.py::BuildPathTest::test_absolute_path PASSED [ 91%]

01:38:41 tests/unit/config/config_test.py::BuildPathTest::test_from_file PASSED   [ 91%]

01:38:41 tests/unit/config/config_test.py::BuildPathTest::test_from_file_override_dir PASSED [ 91%]

01:38:41 tests/unit/config/config_test.py::BuildPathTest::test_invalid_url_in_build_path PASSED [ 91%]

01:38:41 tests/unit/config/config_test.py::BuildPathTest::test_nonexistent_path PASSED [ 91%]

01:38:41 tests/unit/config/config_test.py::BuildPathTest::test_relative_path PASSED [ 91%]

01:38:41 tests/unit/config/config_test.py::BuildPathTest::test_valid_url_in_build_path PASSED [ 92%]

01:38:41 tests/unit/config/config_test.py::HealthcheckTest::test_disable PASSED   [ 92%]

01:38:41 tests/unit/config/config_test.py::HealthcheckTest::test_disable_with_other_config_is_invalid PASSED [ 92%]

01:38:41 tests/unit/config/config_test.py::HealthcheckTest::test_healthcheck PASSED [ 92%]

01:38:41 tests/unit/config/config_test.py::HealthcheckTest::test_healthcheck_with_invalid_test PASSED [ 92%]

01:38:41 tests/unit/config/config_test.py::GetDefaultConfigFilesTestCase::test_get_config_path_default_file_in_basedir PASSED [ 92%]

01:38:41 tests/unit/config/config_test.py::GetDefaultConfigFilesTestCase::test_get_config_path_default_file_in_parent_dir PASSED [ 92%]

01:38:41 tests/unit/config/config_test.py::SerializeTest::test_denormalize_depends_on_v2_1 PASSED [ 92%]

01:38:41 tests/unit/config/config_test.py::SerializeTest::test_denormalize_depends_on_v3 PASSED [ 92%]

01:38:41 tests/unit/config/config_test.py::SerializeTest::test_denormalize_healthcheck PASSED [ 92%]

01:38:41 tests/unit/config/config_test.py::SerializeTest::test_denormalize_image_has_digest PASSED [ 92%]

01:38:41 tests/unit/config/config_test.py::SerializeTest::test_denormalize_image_no_digest PASSED [ 92%]

01:38:41 tests/unit/config/config_test.py::SerializeTest::test_serialize_bool_string PASSED [ 93%]

01:38:41 tests/unit/config/config_test.py::SerializeTest::test_serialize_configs PASSED [ 93%]

01:38:41 tests/unit/config/config_test.py::SerializeTest::test_serialize_escape_dollar_sign PASSED [ 93%]

01:38:41 tests/unit/config/config_test.py::SerializeTest::test_serialize_escape_dont_interpolate PASSED [ 93%]

01:38:41 tests/unit/config/config_test.py::SerializeTest::test_serialize_external_false PASSED [ 93%]

01:38:41 tests/unit/config/config_test.py::SerializeTest::test_serialize_ports PASSED [ 93%]

01:38:41 tests/unit/config/config_test.py::SerializeTest::test_serialize_ports_with_ext_ip PASSED [ 93%]

01:38:41 tests/unit/config/config_test.py::SerializeTest::test_serialize_secrets PASSED [ 93%]

01:38:41 tests/unit/config/config_test.py::SerializeTest::test_serialize_time PASSED [ 93%]

01:38:41 tests/unit/config/config_test.py::SerializeTest::test_serialize_unicode_values PASSED [ 93%]

01:38:41 tests/unit/config/environment_test.py::EnvironmentTest::test_env_vars_from_file_bom PASSED [ 93%]

01:38:41 tests/unit/config/environment_test.py::EnvironmentTest::test_env_vars_from_file_whitespace PASSED [ 94%]

01:38:41 tests/unit/config/environment_test.py::EnvironmentTest::test_get_boolean PASSED [ 94%]

01:38:41 tests/unit/config/environment_test.py::EnvironmentTest::test_get_simple PASSED [ 94%]

01:38:41 tests/unit/config/environment_test.py::EnvironmentTest::test_get_undefined PASSED [ 94%]

01:38:41 tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_services PASSED [ 94%]

01:38:41 tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_volumes PASSED [ 94%]

01:38:41 tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_secrets PASSED [ 94%]

01:38:41 tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_v2 PASSED [ 94%]

01:38:41 tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_v3 PASSED [ 94%]

01:38:41 tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_invalid PASSED [ 94%]

01:38:41 tests/unit/config/interpolation_test.py::test_interpolate_environment_network_convert_types PASSED [ 94%]

01:38:41 tests/unit/config/interpolation_test.py::test_interpolate_environment_external_resource_convert_types PASSED [ 94%]

01:38:41 tests/unit/config/interpolation_test.py::test_interpolate_service_name_uses_dot PASSED [ 95%]

01:38:41 tests/unit/config/interpolation_test.py::test_escaped_interpolation PASSED [ 95%]

01:38:41 tests/unit/config/interpolation_test.py::test_invalid_interpolation PASSED [ 95%]

01:38:41 tests/unit/config/interpolation_test.py::test_interpolate_missing_no_default PASSED [ 95%]

01:38:41 tests/unit/config/interpolation_test.py::test_interpolate_with_value PASSED [ 95%]

01:38:41 tests/unit/config/interpolation_test.py::test_interpolate_missing_with_default PASSED [ 95%]

01:38:41 tests/unit/config/interpolation_test.py::test_interpolate_with_empty_and_default_value PASSED [ 95%]

01:38:41 tests/unit/config/interpolation_test.py::test_interpolate_mandatory_values PASSED [ 95%]

01:38:41 tests/unit/config/interpolation_test.py::test_interpolate_mandatory_no_err_msg PASSED [ 95%]

01:38:41 tests/unit/config/interpolation_test.py::test_interpolate_mixed_separators PASSED [ 95%]

01:38:41 tests/unit/config/interpolation_test.py::test_unbraced_separators PASSED [ 95%]

01:38:41 tests/unit/config/interpolation_test.py::test_interpolate_unicode_values PASSED [ 96%]

01:38:41 tests/unit/config/interpolation_test.py::test_interpolate_no_fallthrough PASSED [ 96%]

01:38:41 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_1 PASSED [ 96%]

01:38:41 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_2 PASSED [ 96%]

01:38:41 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_3 PASSED [ 96%]

01:38:41 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_4 PASSED [ 96%]

01:38:41 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_5 PASSED [ 96%]

01:38:41 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_6 PASSED [ 96%]

01:38:41 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_7 PASSED [ 96%]

01:38:41 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports PASSED [ 96%]

01:38:41 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports_2 PASSED [ 96%]

01:38:41 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports_3 PASSED [ 97%]

01:38:41 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_self_imports PASSED [ 97%]

01:38:41 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_depends_on_self PASSED [ 97%]

01:38:41 tests/unit/config/types_test.py::test_parse_extra_hosts_list PASSED      [ 97%]

01:38:41 tests/unit/config/types_test.py::test_parse_extra_hosts_dict PASSED      [ 97%]

01:38:41 tests/unit/config/types_test.py::TestServicePort::test_parse_dict PASSED [ 97%]

01:38:41 tests/unit/config/types_test.py::TestServicePort::test_parse_simple_target_port PASSED [ 97%]

01:38:41 tests/unit/config/types_test.py::TestServicePort::test_parse_complete_port_definition PASSED [ 97%]

01:38:41 tests/unit/config/types_test.py::TestServicePort::test_parse_ext_ip_no_published_port PASSED [ 97%]

01:38:41 tests/unit/config/types_test.py::TestServicePort::test_repr_published_port_0 PASSED [ 97%]

01:38:41 tests/unit/config/types_test.py::TestServicePort::test_parse_port_range PASSED [ 97%]

01:38:41 tests/unit/config/types_test.py::TestServicePort::test_parse_port_publish_range PASSED [ 97%]

01:38:41 tests/unit/config/types_test.py::TestServicePort::test_parse_invalid_port PASSED [ 98%]

01:38:41 tests/unit/config/types_test.py::TestServicePort::test_parse_invalid_publish_range PASSED [ 98%]

01:38:41 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_only_one_path PASSED [ 98%]

01:38:41 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_internal_and_external PASSED [ 98%]

01:38:41 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_with_mode PASSED [ 98%]

01:38:41 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_too_many_parts PASSED [ 98%]

01:38:41 tests/unit/service_test.py::ServiceVolumesTest::test_merge_volume_bindings PASSED [ 55%]

01:38:41 tests/unit/service_test.py::ServiceVolumesTest::test_mount_same_host_path_to_two_volumes PASSED [ 55%]

01:38:41 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_absolute_path_normalized PASSED [ 98%]

01:38:41 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_absolute_path_native PASSED [ 98%]

01:38:41 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_internal_path_normalized PASSED [ 98%]

01:38:41 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_internal_path_native PASSED [ 98%]

01:38:41 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_just_drives_normalized PASSED [ 98%]

01:38:41 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_just_drives_native PASSED [ 99%]

01:38:41 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_mixed_notations_normalized PASSED [ 99%]

01:38:41 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_mixed_notations_native PASSED [ 99%]

01:38:41 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_from_service PASSED [ 99%]

01:38:41 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_from_container PASSED [ 99%]

01:38:41 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_invalid PASSED [ 99%]

01:38:41 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_service PASSED [ 99%]

01:38:41 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_service_with_mode PASSED [ 99%]

01:38:41 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_container PASSED [ 99%]

01:38:41 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_container_with_mode PASSED [ 99%]

01:38:41 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_invalid_type PASSED [ 99%]

01:38:41 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_no_warning_with_container_only_option PASSED [ 55%]

01:38:41 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_no_warning_with_same_path PASSED [ 55%]

01:38:42 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_volume_no_warning_when_no_container_volumes PASSED [ 55%]

01:38:42 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_volume_when_masked PASSED [ 56%]

01:38:42 tests/integration/service_test.py::ServiceTest::test_start_one_off_container_creates_links_to_its_own_service PASSED [ 34%]

01:38:42 tests/integration/service_test.py::ServiceTest::test_build_with_target <- tests/integration/testcases.py PASSED [ 25%]

01:38:42 tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes PASSED [ 56%]

01:38:42 tests/integration/service_test.py::ServiceTest::test_stop_signal PASSED  [ 34%]

01:38:42 tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes_abspath PASSED [ 56%]

01:38:42 tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes_no_target PASSED [ 56%]

01:38:42 tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_unix_path PASSED [ 56%]

01:38:42 tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_url_no_prefix PASSED [ 56%]

01:38:42 tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_windows_path PASSED [ 56%]

01:38:42 tests/unit/split_buffer_test.py::SplitBufferTest::test_chunked_line PASSED [ 56%]

01:38:42 tests/unit/split_buffer_test.py::SplitBufferTest::test_multiple_line_chunk PASSED [ 56%]

01:38:42 tests/unit/split_buffer_test.py::SplitBufferTest::test_no_end_separator PASSED [ 56%]

01:38:42 tests/unit/split_buffer_test.py::SplitBufferTest::test_preserves_unicode_sequences_within_lines PASSED [ 56%]

01:38:42 tests/unit/split_buffer_test.py::SplitBufferTest::test_single_line_chunks PASSED [ 57%]

01:38:42 tests/unit/timeparse_test.py::test_milli PASSED                          [ 57%]

01:38:42 tests/unit/timeparse_test.py::test_milli_float PASSED                    [ 57%]

01:38:42 tests/unit/timeparse_test.py::test_second_milli PASSED                   [ 57%]

01:38:42 tests/unit/timeparse_test.py::test_second_milli_micro PASSED             [ 57%]

01:38:42 tests/unit/timeparse_test.py::test_second PASSED                         [ 57%]

01:38:42 tests/unit/timeparse_test.py::test_second_as_float PASSED                [ 57%]

01:38:42 tests/unit/timeparse_test.py::test_minute PASSED                         [ 57%]

01:38:42 tests/unit/timeparse_test.py::test_hour_minute PASSED                    [ 57%]

01:38:42 tests/unit/timeparse_test.py::test_minute_as_float PASSED                [ 57%]

01:38:42 tests/unit/timeparse_test.py::test_hour_minute_second PASSED             [ 57%]

01:38:42 tests/unit/timeparse_test.py::test_invalid_with_space PASSED             [ 57%]

01:38:42 tests/unit/timeparse_test.py::test_invalid_with_comma PASSED             [ 58%]

01:38:42 tests/unit/timeparse_test.py::test_invalid_with_empty_string PASSED      [ 58%]

01:38:42 tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_no_object PASSED [ 58%]

01:38:42 tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_with_object PASSED [ 58%]

01:38:42 tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_leading_whitespace PASSED [ 58%]

01:38:42 tests/unit/utils_test.py::TestStreamAsText::test_stream_with_non_utf_unicode_character PASSED [ 58%]

01:38:42 tests/unit/utils_test.py::TestStreamAsText::test_stream_with_utf_character PASSED [ 58%]

01:38:42 tests/unit/utils_test.py::TestJsonStream::test_with_falsy_entries PASSED [ 58%]

01:38:42 tests/unit/utils_test.py::TestJsonStream::test_with_leading_whitespace PASSED [ 58%]

01:38:42 tests/unit/utils_test.py::TestParseBytes::test_parse_bytes PASSED        [ 58%]

01:38:42 tests/unit/utils_test.py::TestMoreItertools::test_unique_everseen PASSED [ 58%]

01:38:42 tests/unit/volume_test.py::TestVolume::test_remove_local_volume PASSED   [ 59%]

01:38:42 tests/integration/service_test.py::ServiceTest::test_cap_add_list PASSED [ 25%]

01:38:42 tests/integration/service_test.py::ServiceTest::test_tmpfs PASSED        [ 34%]

01:38:43 tests/unit/volume_test.py::TestVolume::test_remove_external_volume PASSED [ 59%]

01:38:43 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_path_from_options PASSED [ 59%]

01:38:43 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_single_path_from_env PASSED [ 59%]

01:38:43 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env PASSED [ 59%]

01:38:43 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env_windows SKIPPED [ 59%]

01:38:43 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env_custom_separator PASSED [ 59%]

01:38:43 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_no_path PASSED [ 59%]

01:38:43 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_unicode_path_from_options PASSED [ 59%]

01:38:43 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_unicode_path_from_env SKIPPED [ 59%]

01:38:43 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_custom_timeout_error PASSED [ 59%]

01:38:43 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_docker_client_no_home PASSED [ 60%]

01:38:43 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_docker_client_with_custom_timeout PASSED [ 60%]

01:38:43 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_user_agent PASSED [ 60%]

01:38:43 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_assert_hostname_explicit_skip PASSED [ 60%]

01:38:43 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_simple_tls PASSED [ 60%]

01:38:43 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_ca_cert PASSED [ 60%]

01:38:43 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_ca_cert_explicit PASSED [ 60%]

01:38:43 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca PASSED [ 60%]

01:38:43 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca_explicit PASSED [ 60%]

01:38:43 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca_quoted_paths PASSED [ 60%]

01:38:43 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_cert PASSED [ 60%]

01:38:43 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_cert_explicit PASSED [ 60%]

01:38:43 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_missing_key PASSED [ 61%]

01:38:43 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_flags_override_environment PASSED [ 61%]

01:38:43 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_mixed_environment_and_flags PASSED [ 61%]

01:38:43 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_simple_with_tls_version PASSED [ 61%]

01:38:43 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_default_cert_path PASSED [ 61%]

01:38:43 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_env_falsy_value PASSED [ 61%]

01:38:43 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_flag_no_override PASSED [ 61%]

01:38:43 tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_default PASSED [ 61%]

01:38:43 tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_upgrade PASSED [ 61%]

01:38:43 tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_unavailable PASSED [ 61%]

01:38:43 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_generic_connection_error PASSED [ 61%]

01:38:43 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_mismatch PASSED [ 62%]

01:38:43 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_mismatch_unicode_explanation PASSED [ 62%]

01:38:43 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_other PASSED [ 62%]

01:38:43 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_other_unicode_explanation PASSED [ 62%]

01:38:43 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_no_data SKIPPED [ 62%]

01:38:43 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_misc SKIPPED [ 62%]

01:38:43 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_encoding_issue SKIPPED [ 62%]

01:38:43 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_error PASSED [ 62%]

01:38:43 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_info PASSED [ 62%]

01:38:43 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_error PASSED [ 62%]

01:38:43 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_info PASSED [ 62%]

01:38:43 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_warn PASSED [ 63%]

01:38:43 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_warn PASSED [ 63%]

01:38:43 tests/unit/cli/log_printer_test.py::TestLogPresenter::test_monochrome PASSED [ 63%]

01:38:43 tests/unit/cli/log_printer_test.py::TestLogPresenter::test_polychrome PASSED [ 63%]

01:38:43 tests/unit/cli/log_printer_test.py::test_wait_on_exit PASSED             [ 63%]

01:38:43 tests/unit/cli/log_printer_test.py::test_wait_on_exit_raises PASSED      [ 63%]

01:38:43 tests/unit/cli/log_printer_test.py::test_build_no_log_generator PASSED   [ 63%]

01:38:43 tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_no_log_stream PASSED [ 63%]

01:38:43 tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_with_log_stream PASSED [ 63%]

01:38:43 tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_unicode PASSED [ 63%]

01:38:43 tests/unit/cli/log_printer_test.py::TestWatchEvents::test_stop_event PASSED [ 63%]

01:38:43 tests/unit/cli/log_printer_test.py::TestWatchEvents::test_start_event PASSED [ 63%]

01:38:43 tests/unit/cli/log_printer_test.py::TestWatchEvents::test_other_event PASSED [ 64%]

01:38:43 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_an_exception PASSED [ 64%]

01:38:43 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_stop_without_cascade_stop PASSED [ 64%]

01:38:43 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_stop_with_cascade_stop PASSED [ 64%]

01:38:43 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_none_when_timeout_is_hit PASSED [ 64%]

01:38:43 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_filter_containers_to_service_names PASSED [ 64%]

01:38:43 tests/integration/service_test.py::ServiceTest::test_cap_drop_list PASSED [ 25%]

01:38:43 tests/integration/service_test.py::ServiceTest::test_userns_mode_host PASSED [ 34%]

01:38:43 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_filter_containers_to_service_names_all PASSED [ 64%]

01:38:43 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_middle PASSED [ 35%]

01:38:43 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_warning_in_swarm_mode PASSED [ 64%]

01:38:43 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_build_one_off_container_options PASSED [ 64%]

01:38:43 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_get_docker_start_call PASSED [ 64%]

01:38:43 tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_tty_verbose PASSED [ 64%]

01:38:43 tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_tty_not_verbose PASSED [ 65%]

01:38:43 tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_not_a_tty PASSED [ 65%]

01:38:43 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_invalid_opts PASSED [ 65%]

01:38:43 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_always PASSED [ 65%]

01:38:43 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_never PASSED [ 65%]

01:38:43 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_changed PASSED [ 65%]

01:38:43 tests/unit/cli/main_test.py::TestCallDocker::test_simple_no_options PASSED [ 65%]

01:38:43 tests/unit/cli/main_test.py::TestCallDocker::test_simple_tls_option PASSED [ 65%]

01:38:43 tests/unit/cli/main_test.py::TestCallDocker::test_advanced_tls_options PASSED [ 65%]

01:38:43 tests/unit/cli/main_test.py::TestCallDocker::test_with_host_option PASSED [ 65%]

01:38:43 tests/unit/cli/main_test.py::TestCallDocker::test_with_http_host PASSED  [ 65%]

01:38:43 tests/unit/cli/main_test.py::TestCallDocker::test_with_host_option_shorthand_equal PASSED [ 65%]

01:38:43 tests/unit/cli/main_test.py::TestCallDocker::test_with_env PASSED        [ 66%]

01:38:43 tests/unit/cli/utils_test.py::UnquotePathTest::test_nested_quotes PASSED [ 66%]

01:38:43 tests/unit/cli/utils_test.py::UnquotePathTest::test_no_quotes PASSED     [ 66%]

01:38:43 tests/unit/cli/utils_test.py::UnquotePathTest::test_simple_quotes PASSED [ 66%]

01:38:43 tests/unit/cli/utils_test.py::UnquotePathTest::test_uneven_quotes PASSED [ 66%]

01:38:43 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_100b PASSED [ 66%]

01:38:43 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_1023b PASSED [ 66%]

01:38:43 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_1kb PASSED [ 66%]

01:38:43 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_units PASSED [ 66%]

01:38:43 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_call PASSED [ 66%]

01:38:43 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return PASSED [ 66%]

01:38:43 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return_no_result PASSED [ 67%]

01:38:43 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return_sequence PASSED [ 67%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_build_args_allow_empty_properties PASSED [ 67%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_build_args_check_zero_preserved PASSED [ 67%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_config_build_configuration PASSED [ 67%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_config_build_configuration_v2 PASSED [ 67%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_config_convertible_label_types PASSED [ 67%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_config_duplicate_cache_from_values_validation_error PASSED [ 67%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_config_duplicate_mount_points PASSED [ 67%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_config_extra_hosts_list_of_dicts_validation_error PASSED [ 67%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_config_extra_hosts_string_raises_validation_error PASSED [ 67%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_config_hint PASSED    [ 68%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error PASSED [ 68%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error_v2 PASSED [ 68%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error_v2_when_no_interpolate PASSED [ 68%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_property_raise_validation_error PASSED [ 68%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_config_invalid_ipam_config PASSED [ 68%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_config_invalid_label_types PASSED [ 68%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_config_invalid_service_name_raise_validation_error PASSED [ 68%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_invalid_keys_validation_error PASSED [ 68%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_required_keys_validation_error PASSED [ 68%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_soft_greater_than_hard_error PASSED [ 68%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_config_valid_environment_dict_key_contains_dashes PASSED [ 68%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_config_valid_ipam_config PASSED [ 69%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_config_valid_service_label_validation PASSED [ 69%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_config_valid_service_names PASSED [ 69%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_depends_on_orders_services PASSED [ 69%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_depends_on_unknown_service_errors PASSED [ 69%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_dns_opt_option PASSED [ 69%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_empty_environment_key_allowed PASSED [ 69%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_external_volume_config PASSED [ 69%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_external_volume_invalid_config PASSED [ 69%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_group_add_option PASSED [ 69%]

01:38:43 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_build_and_image_specified_v1 PASSED [ 69%]

01:38:43 tests/integration/service_test.py::ServiceTest::test_userns_mode_none_defined PASSED [ 34%]

01:38:43 tests/integration/service_test.py::ServiceTest::test_with_high_enough_api_version_we_get_default_network_mode PASSED [ 34%]

01:38:43 tests/integration/service_test.py::ServiceTest::test_working_dir_param PASSED [ 35%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_not_a_dictionary PASSED [ 70%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_not_unique_items PASSED [ 70%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_type_should_be_an_array PASSED [ 70%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_v1 PASSED [ 70%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_v2 PASSED [ 70%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_invalid_list_of_strings_format PASSED [ 70%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_isolation_option PASSED [ 70%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_linked_service_is_undefined PASSED [ 70%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load PASSED           [ 70%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_bind_mount_relative_path PASSED [ 70%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_bind_mount_relative_path_with_tilde PASSED [ 70%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_build_labels_dict PASSED [ 71%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_build_labels_list PASSED [ 71%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_config_custom_resource_names PASSED [ 71%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_config_dockerfile_without_build_raises_error_v1 PASSED [ 71%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_config_invalid_service_names PASSED [ 71%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_config_invalid_service_names_v2 PASSED [ 71%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_config_link_local_ips_network PASSED [ 71%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_config_service_labels PASSED [ 71%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_config_volume_and_network_labels PASSED [ 71%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_configs PASSED   [ 71%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_configs_multi_file PASSED [ 71%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_dockerfile_without_context PASSED [ 71%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_errors_on_uppercase_with_no_image PASSED [ 72%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_invalid_service_definition PASSED [ 72%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_mixed_extends_resolution PASSED [ 72%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_secrets PASSED   [ 72%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_secrets_multi_file PASSED [ 72%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_service_with_name_version PASSED [ 72%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_sorts_in_dependency_order PASSED [ 72%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_when_not_dict PASSED [ 72%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_when_not_dict_v2 PASSED [ 72%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_with_invalid_network_fields PASSED [ 72%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_v2 PASSED        [ 72%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_with_buildargs PASSED [ 73%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_with_empty_build_args PASSED [ 73%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_with_extensions PASSED [ 73%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_with_invalid_field_name PASSED [ 73%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_with_invalid_field_name_v1 PASSED [ 73%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_base PASSED [ 73%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_base_v2 PASSED [ 73%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_override PASSED [ 73%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_override_v2 PASSED [ 73%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_extends_in_override_file PASSED [ 73%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_invalid_override PASSED [ 73%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_mismatched_networks_format PASSED [ 73%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_mismatched_networks_format_inverse_order PASSED [ 74%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v1 PASSED [ 74%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v2 PASSED [ 74%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v3_2 PASSED [ 74%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_yaml_with_bom PASSED [ 74%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_load_yaml_with_yaml_error PASSED [ 74%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_logs_warning_for_boolean_in_environment PASSED [ 74%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_blkio_config PASSED [ 74%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_configs_override PASSED [ 74%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_credential_spec PASSED [ 74%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_depends_on_mixed_syntax PASSED [ 74%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_depends_on_no_override PASSED [ 75%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_deploy PASSED   [ 75%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_deploy_override PASSED [ 75%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_device_cgroup_rules PASSED [ 75%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_different_configs PASSED [ 75%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_different_secrets PASSED [ 75%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_extra_hosts PASSED [ 75%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_config PASSED [ 75%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_override_disables PASSED [ 75%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_override_enables PASSED [ 75%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_isolation PASSED [ 75%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v1 PASSED [ 76%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2 PASSED [ 76%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_base PASSED [ 76%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_base_driver PASSED [ 76%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_drivers PASSED [ 76%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_override PASSED [ 76%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_override_options PASSED [ 76%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_override_driver PASSED [ 76%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_mixed_ports PASSED [ 76%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_pid PASSED      [ 76%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_scale PASSED    [ 76%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_secrets_override PASSED [ 76%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_from_files_with_extends_in_base PASSED [ 77%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_from_files_with_extends_in_override PASSED [ 77%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous PASSED [ 77%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous_2 PASSED [ 77%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous_volumes PASSED [ 77%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_ports_sorting PASSED [ 77%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_merge_storage_opt PASSED [ 77%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_named_volume_config_empty PASSED [ 77%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_named_volume_invalid_type_list PASSED [ 77%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_named_volume_numeric_driver_opt PASSED [ 77%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_networks_invalid_type_list PASSED [ 77%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_normalize_dns_options PASSED [ 78%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_oom_score_adj_option PASSED [ 78%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_runtime_option PASSED [ 78%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_service_volume_invalid_config PASSED [ 78%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_swappiness_option PASSED [ 78%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_tmpfs_option PASSED   [ 78%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_undeclared_volume_v1 PASSED [ 78%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_undeclared_volume_v2 PASSED [ 78%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_unsupported_version PASSED [ 78%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_v1_file_version PASSED [ 78%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_v1_file_with_version_is_invalid PASSED [ 78%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_valid_config_oneof_string_or_list PASSED [ 78%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_valid_config_which_allows_two_type_definitions PASSED [ 79%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_valid_versions PASSED [ 79%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_validate_extra_hosts_invalid PASSED [ 79%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_validate_extra_hosts_invalid_list PASSED [ 79%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_version_1_is_invalid PASSED [ 79%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_volume_invalid_driver_opt PASSED [ 79%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_volume_mode_override PASSED [ 79%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_volumes_long_syntax PASSED [ 79%]

01:38:44 tests/unit/config/config_test.py::ConfigTest::test_wrong_version_type PASSED [ 79%]

01:38:44 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_container PASSED [ 79%]

01:38:44 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_container_v1 PASSED [ 79%]

01:38:44 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_plus_networks_is_invalid PASSED [ 80%]

01:38:44 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service PASSED [ 80%]

01:38:44 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service_nonexistent PASSED [ 80%]

01:38:44 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service_v1 PASSED [ 80%]

01:38:44 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_standard PASSED [ 80%]

01:38:44 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_standard_v1 PASSED [ 80%]

01:38:44 tests/unit/config/config_test.py::PortsTest::test_config_invalid_expose_format_validation PASSED [ 80%]

01:38:44 tests/unit/config/config_test.py::PortsTest::test_config_invalid_expose_type_validation PASSED [ 80%]

01:38:44 tests/unit/config/config_test.py::PortsTest::test_config_invalid_ports_format_validation PASSED [ 80%]

01:38:44 tests/unit/config/config_test.py::PortsTest::test_config_invalid_ports_type_validation PASSED [ 80%]

01:38:44 tests/unit/config/config_test.py::PortsTest::test_config_non_unique_expose_validation PASSED [ 80%]

01:38:44 tests/unit/config/config_test.py::PortsTest::test_config_non_unique_ports_validation PASSED [ 81%]

01:38:44 tests/unit/config/config_test.py::PortsTest::test_config_valid_expose_format_validation PASSED [ 81%]

01:38:44 tests/unit/config/config_test.py::PortsTest::test_config_valid_ports_format_validation PASSED [ 81%]

01:38:44 tests/unit/config/config_test.py::SubnetTest::test_config_invalid_subnet_format_validation PASSED [ 81%]

01:38:44 tests/unit/config/config_test.py::SubnetTest::test_config_invalid_subnet_type_validation PASSED [ 81%]

01:38:44 tests/unit/config/config_test.py::SubnetTest::test_config_valid_subnet_format_validation PASSED [ 81%]

01:38:44 tests/unit/config/config_test.py::InterpolationTest::test_compatibility_mode_load PASSED [ 81%]

01:38:44 tests/unit/config/config_test.py::InterpolationTest::test_compatibility_mode_warnings PASSED [ 81%]

01:38:44 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_file PASSED [ 81%]

01:38:44 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_variable PASSED [ 81%]

01:38:44 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_variable_with_defaults PASSED [ 81%]

01:38:44 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_options_environment_file PASSED [ 81%]

01:38:44 tests/unit/config/config_test.py::InterpolationTest::test_interpolation_configs_section PASSED [ 82%]

01:38:44 tests/unit/config/config_test.py::InterpolationTest::test_interpolation_secrets_section PASSED [ 82%]

01:38:44 tests/unit/config/config_test.py::InterpolationTest::test_invalid_interpolation PASSED [ 82%]

01:38:44 tests/unit/config/config_test.py::InterpolationTest::test_unset_variable_produces_warning PASSED [ 82%]

01:38:44 tests/unit/config/config_test.py::VolumeConfigTest::test_absolute_posix_path_does_not_expand PASSED [ 82%]

01:38:44 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_invalid PASSED [100%]

01:38:44 

01:38:44 ----------- coverage: platform linux, python 3.7.4-final-0 -----------

01:38:44 Name                              Stmts   Miss Branch BrPart  Cover   Missing

01:38:44 -----------------------------------------------------------------------------

01:38:44 compose/__init__.py                   3      0      0      0   100%

01:38:44 compose/__main__.py                   4      4      0      0     0%   1-6

01:38:44 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

01:38:44 compose/cli/__init__.py               0      0      0      0   100%

01:38:44 compose/cli/colors.py                23      2     10      2    88%   37-38, 36->37, 48->exit

01:38:44 compose/cli/command.py               93     14     28      4    82%   71-81, 88, 125-130, 174, 70->71, 87->88, 124->125, 171->174

01:38:44 compose/cli/docker_client.py         75      5     24      2    93%   24, 98-99, 107, 123, 106->107, 122->123

01:38:44 compose/cli/docopt_command.py        38      4      8      2    87%   13-14, 29, 35, 28->29, 34->35

01:38:44 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

01:38:44 compose/cli/formatter.py             34      2     10      1    93%   17-18, 15->17

01:38:44 compose/cli/log_printer.py          144     14     52      6    89%   76, 103, 110-115, 162-164, 173, 226-229, 233-234, 253, 43->exit, 75->76, 98->103, 171->173, 225->226, 232->233

01:38:44 compose/cli/main.py                 695     90    307     40    85%   83-84, 86-87, 168, 328, 360-362, 445, 505, 509, 514-515, 525-554, 566, 584-586, 657-658, 696-697, 715, 736-737, 749, 772, 790, 837, 1069, 1078, 1104-1113, 1153-1156, 1164-1168, 1170-1175, 1198, 1220-1249, 1256-1257, 1259-1261, 1276, 1282, 1466, 1484, 1500, 1504-1505, 1516, 1521, 1524, 1550, 1569-1571, 1581, 1592, 60->63, 82->83, 85->86, 167->168, 327->328, 359->360, 444->445, 504->505, 508->509, 519->525, 563->566, 583->584, 655->657, 714->715, 735->736, 748->749, 771->772, 827->837, 829->exit, 1068->1069, 1077->1078, 1163->1164, 1169->1170, 1197->1198, 1255->1256, 1258->1259, 1275->1276, 1281->1282, 1465->1466, 1483->1484, 1499->1500, 1515->1516, 1520->1521, 1523->1524, 1542->exit, 1549->1550, 1563->1571, 1565->1569, 1580->1581, 1590->1592

01:38:44 compose/cli/signals.py               23      0      4      2    93%   36->exit, 43->exit

01:38:44 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

01:38:44 compose/cli/verbose_proxy.py         35     12     10      0    69%   36-39, 42-47, 50-60

01:38:44 compose/config/__init__.py           13      0      0      0   100%

01:38:44 compose/config/config.py            826     30    428     18    95%   266, 277, 508, 621-622, 714, 757, 812-830, 952-953, 959, 979, 982, 1335, 1366, 1412, 265->266, 276->277, 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

01:38:44 compose/config/environment.py       100      8     34      5    90%   21, 41, 104-107, 120, 127, 20->21, 40->41, 103->104, 119->120, 126->127

01:38:44 compose/config/errors.py             25      2      2      0    85%   36-40

01:38:44 compose/config/interpolation.py     148      6     64      3    95%   66, 148, 222, 227-229, 121->exit, 146->148, 221->222

01:38:44 compose/config/serialize.py          97      2     58      3    97%   31, 76, 30->31, 75->76, 82->85

01:38:44 compose/config/sort_services.py      44      1     24      1    97%   57, 56->57

01:38:44 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

01:38:44 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

01:38:44 compose/const.py                     36      0      0      0   100%

01:38:44 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

01:38:44 compose/errors.py                    17      1      0      0    94%   12

01:38:44 compose/network.py                  190     19     95      5    87%   184, 186-200, 206, 224, 226, 183->184, 185->186, 205->206, 223->224, 225->226

01:38:44 compose/parallel.py                 199      2     58      1    99%   187, 326, 325->326

01:38:44 compose/progress_stream.py           79      8     40      9    86%   40, 71, 74, 80, 85, 90-91, 116, 39->40, 42->46, 53->57, 70->71, 73->74, 79->80, 84->85, 89->90, 112->116

01:38:44 compose/project.py                  424     29    201     16    92%   60, 156, 212-213, 254-255, 364-365, 378-381, 434, 485, 489, 615, 621, 624-627, 752-753, 759-762, 777, 782-785, 788, 809, 57->60, 152->156, 331->333, 362->364, 377->378, 433->434, 484->485, 488->489, 614->615, 620->621, 623->624, 671->exit, 755->762, 776->777, 781->782, 787->788

01:38:44 compose/service.py                  854     50    433     26    93%   271-272, 293, 366-369, 417-422, 428-430, 470-471, 485, 488, 506, 573, 618-619, 727, 946-947, 967-968, 1069, 1115, 1176, 1218, 1240-1255, 1295, 1334-1338, 1526, 1530, 1646, 1686, 1698, 216->exit, 269->271, 292->293, 427->428, 469->470, 484->485, 487->488, 505->506, 563->573, 722->727, 945->946, 966->967, 1068->1069, 1114->1115, 1175->1176, 1217->1218, 1294->1295, 1331->1334, 1525->1526, 1529->1530, 1578->exit, 1586->1585, 1623->1620, 1645->1646, 1685->1686, 1697->1698

01:38:44 compose/state.py                      0      0      0      0   100%

01:38:44 compose/timeparse.py                 22      0      4      0   100%

01:38:44 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

01:38:44 compose/version.py                    6      0      0      0   100%

01:38:44 compose/volume.py                   126      4     44      3    95%   150, 200, 211-212, 141->150, 199->200, 209->211

01:38:44 -----------------------------------------------------------------------------

01:38:44 TOTAL                              5553    436   2401    205    91%

01:38:44 Coverage HTML written to dir coverage-html

01:38:44 

01:38:44 =========================== short test summary info ============================

01:38:44 XFAIL tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_rt

01:38:44   not supported by kernel

01:38:44 XFAIL tests/integration/service_test.py::ServiceTest::test_create_container_with_storage_opt

01:38:44   Not supported on most drivers

01:38:44 SKIP [1] tests/acceptance/cli_test.py:2424: race condition between up and logs

01:38:44 SKIP [1] tests/acceptance/cli_test.py:2376: race condition between up and logs

01:38:44 SKIP [1] tests/acceptance/cli_test.py:2403: race condition between up and logs

01:38:44 SKIP [1] /code/tests/integration/testcases.py:167: This daemon does not support the 'nvidia'' runtime

01:38:44 SKIP [1] tests/integration/service_test.py:148: cpu_percent is not supported for Linux

01:38:44 SKIP [1] tests/integration/service_test.py:1635: Broken on 1.11.0 - 17.03.0

01:38:44 SKIP [1] tests/unit/cli/command_test.py:39: windows separator

01:38:44 SKIP [1] tests/unit/cli/command_test.py:69: Env values in Python 3 are already Unicode

01:38:44 SKIP [1] tests/unit/cli/errors_test.py:70: Needs pywin32

01:38:44 SKIP [1] tests/unit/cli/errors_test.py:80: Needs pywin32

01:38:44 SKIP [1] tests/unit/cli/errors_test.py:90: Needs pywin32

01:38:44 SKIP [1] tests/unit/config/config_test.py:3777: windows paths

01:38:44 

01:38:44 ======= 1121 passed, 12 skipped, 2 xfailed, 3 xpassed in 739.38 seconds ========

01:38:44 ___________________________________ summary ____________________________________

01:38:44   py37: commands succeeded

01:38:44   congratulations :)

01:38:44 tests/integration/service_test.py::ServiceTest::test_containers PASSED   [ 25%]

01:38:44 tests/integration/service_test.py::ServiceTest::test_containers_one_off PASSED [ 25%]

01:38:44 tests/unit/config/config_test.py::VolumeConfigTest::test_absolute_windows_path_does_not_expand PASSED [ 82%]

01:38:44 tests/unit/config/config_test.py::VolumeConfigTest::test_home_directory_with_driver_does_not_expand PASSED [ 82%]

01:38:44 tests/unit/config/config_test.py::VolumeConfigTest::test_name_does_not_expand PASSED [ 82%]

01:38:44 tests/unit/config/config_test.py::VolumeConfigTest::test_no_binding PASSED [ 82%]

01:38:44 tests/unit/config/config_test.py::VolumeConfigTest::test_relative_path_does_expand_posix PASSED [ 82%]

01:38:44 tests/unit/config/config_test.py::VolumeConfigTest::test_relative_path_does_expand_windows SKIPPED [ 82%]

01:38:44 tests/unit/config/config_test.py::VolumeConfigTest::test_volume_binding_with_environment_variable PASSED [ 83%]

01:38:44 tests/unit/config/config_test.py::VolumeConfigTest::test_volume_binding_with_home PASSED [ 83%]

01:38:44 tests/unit/config/config_test.py::VolumeConfigTest::test_volume_path_with_non_ascii_directory PASSED [ 83%]

01:38:44 tests/unit/config/config_test.py::VolumeConfigTest::test_volumes_order_is_preserved PASSED [ 83%]

01:38:44 tests/unit/config/config_test.py::MergeVolumesTest::test_add_explicit_path PASSED [ 83%]

01:38:44 tests/unit/config/config_test.py::MergeVolumesTest::test_empty PASSED    [ 83%]

01:38:44 tests/unit/config/config_test.py::MergeVolumesTest::test_no_base PASSED  [ 83%]

01:38:44 tests/unit/config/config_test.py::MergeVolumesTest::test_no_override PASSED [ 83%]

01:38:44 tests/unit/config/config_test.py::MergeVolumesTest::test_override_explicit_path PASSED [ 83%]

01:38:44 tests/unit/config/config_test.py::MergeVolumesTest::test_remove_explicit_path PASSED [ 83%]

01:38:44 tests/unit/config/config_test.py::MergeDevicesTest::test_add_explicit_path PASSED [ 83%]

01:38:44 tests/unit/config/config_test.py::MergeDevicesTest::test_empty PASSED    [ 84%]

01:38:44 tests/unit/config/config_test.py::MergeDevicesTest::test_no_base PASSED  [ 84%]

01:38:44 tests/unit/config/config_test.py::MergeDevicesTest::test_no_override PASSED [ 84%]

01:38:44 tests/unit/config/config_test.py::MergeDevicesTest::test_override_explicit_path PASSED [ 84%]

01:38:44 tests/unit/config/config_test.py::MergeDevicesTest::test_remove_explicit_path PASSED [ 84%]

01:38:44 tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_no_override PASSED [ 84%]

01:38:44 tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_override_with_other PASSED [ 84%]

01:38:44 tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_override_with_same PASSED [ 84%]

01:38:44 tests/unit/config/config_test.py::MergePortsTest::test_add_item PASSED   [ 84%]

01:38:44 tests/unit/config/config_test.py::MergePortsTest::test_duplicate_port_mappings PASSED [ 84%]

01:38:44 tests/unit/config/config_test.py::MergePortsTest::test_empty PASSED      [ 84%]

01:38:44 tests/unit/config/config_test.py::MergePortsTest::test_no_base PASSED    [ 84%]

01:38:44 tests/unit/config/config_test.py::MergePortsTest::test_no_override PASSED [ 85%]

01:38:44 tests/unit/config/config_test.py::MergeNetworksTest::test_add_item PASSED [ 85%]

01:38:44 tests/unit/config/config_test.py::MergeNetworksTest::test_all_properties PASSED [ 85%]

01:38:44 tests/unit/config/config_test.py::MergeNetworksTest::test_empty PASSED   [ 85%]

01:38:44 tests/unit/config/config_test.py::MergeNetworksTest::test_network_has_none_value PASSED [ 85%]

01:38:44 tests/unit/config/config_test.py::MergeNetworksTest::test_no_base PASSED [ 85%]

01:38:44 tests/unit/config/config_test.py::MergeNetworksTest::test_no_network_name_overrides PASSED [ 85%]

01:38:44 tests/unit/config/config_test.py::MergeNetworksTest::test_no_network_overrides PASSED [ 85%]

01:38:44 tests/unit/config/config_test.py::MergeNetworksTest::test_no_override PASSED [ 85%]

01:38:44 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_add_list PASSED [ 85%]

01:38:44 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_add_string PASSED [ 85%]

01:38:44 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_no_base PASSED [ 86%]

01:38:44 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_no_override PASSED [ 86%]

01:38:44 tests/unit/config/config_test.py::MergeLabelsTest::test_add_explicit_value PASSED [ 86%]

01:38:44 tests/unit/config/config_test.py::MergeLabelsTest::test_empty PASSED     [ 86%]

01:38:44 tests/unit/config/config_test.py::MergeLabelsTest::test_no_base PASSED   [ 86%]

01:38:44 tests/unit/config/config_test.py::MergeLabelsTest::test_no_override PASSED [ 86%]

01:38:44 tests/unit/config/config_test.py::MergeLabelsTest::test_override_explicit_value PASSED [ 86%]

01:38:44 tests/unit/config/config_test.py::MergeLabelsTest::test_remove_explicit_value PASSED [ 86%]

01:38:44 tests/unit/config/config_test.py::MergeBuildTest::test_empty_base PASSED [ 86%]

01:38:44 tests/unit/config/config_test.py::MergeBuildTest::test_empty_override PASSED [ 86%]

01:38:44 tests/unit/config/config_test.py::MergeBuildTest::test_full PASSED       [ 86%]

01:38:44 tests/unit/config/config_test.py::MemoryOptionsTest::test_memswap_can_be_a_string PASSED [ 86%]

01:38:44 tests/unit/config/config_test.py::MemoryOptionsTest::test_validation_fails_with_just_memswap_limit PASSED [ 87%]

01:38:44 tests/unit/config/config_test.py::MemoryOptionsTest::test_validation_with_correct_memswap_values PASSED [ 87%]

01:38:44 tests/unit/config/config_test.py::EnvTest::test_environment_overrides_env_file PASSED [ 87%]

01:38:44 tests/unit/config/config_test.py::EnvTest::test_parse_environment_as_dict PASSED [ 87%]

01:38:44 tests/unit/config/config_test.py::EnvTest::test_parse_environment_as_list PASSED [ 87%]

01:38:44 tests/unit/config/config_test.py::EnvTest::test_parse_environment_empty PASSED [ 87%]

01:38:44 tests/unit/config/config_test.py::EnvTest::test_parse_environment_invalid PASSED [ 87%]

01:38:44 tests/unit/config/config_test.py::EnvTest::test_resolve_build_args PASSED [ 87%]

01:38:44 tests/unit/config/config_test.py::EnvTest::test_resolve_environment PASSED [ 87%]

01:38:44 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_from_env_file PASSED [ 87%]

01:38:44 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_from_env_file_with_empty_values PASSED [ 87%]

01:38:44 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_nonexistent_file PASSED [ 88%]

01:38:44 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_with_multiple_env_files PASSED [ 88%]

01:38:44 tests/unit/config/config_test.py::EnvTest::test_resolve_path PASSED      [ 88%]

01:38:44 tests/unit/config/config_test.py::ExtendsTest::test_circular PASSED      [ 88%]

01:38:44 tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_invalid_config PASSED [ 88%]

01:38:44 tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_valid_config PASSED [ 88%]

01:38:44 tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_verbose_and_shorthand_way PASSED [ 88%]

01:38:44 tests/unit/config/config_test.py::ExtendsTest::test_extends PASSED       [ 88%]

01:38:44 tests/unit/config/config_test.py::ExtendsTest::test_extends_file_defaults_to_self PASSED [ 88%]

01:38:44 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_empty_dictionary PASSED [ 88%]

01:38:44 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_invalid_key PASSED [ 88%]

01:38:44 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_missing_service_key PASSED [ 89%]

01:38:44 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_no_file_key_no_filename_set PASSED [ 89%]

01:38:44 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_sub_property_key PASSED [ 89%]

01:38:45 tests/integration/service_test.py::ServiceTest::test_create_container_with_blkio_config PASSED [ 25%]

01:38:45 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_valid_config PASSED [ 89%]

01:38:45 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_defined_version_passes PASSED [ 89%]

01:38:45 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_depends_on PASSED [ 89%]

01:38:45 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_environment_and_env_files PASSED [ 89%]

01:38:45 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_healthcheck PASSED [ 89%]

01:38:45 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_mixed_versions_is_error PASSED [ 89%]

01:38:45 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_ports PASSED [ 89%]

01:38:45 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_security_opt PASSED [ 89%]

01:38:45 tests/unit/config/config_test.py::ExtendsTest::test_invalid_links_in_extended_service PASSED [ 89%]

01:38:45 tests/unit/config/config_test.py::ExtendsTest::test_invalid_net_in_extended_service PASSED [ 90%]

01:38:45 tests/unit/config/config_test.py::ExtendsTest::test_invalid_volumes_from_in_extended_service PASSED [ 90%]

01:38:45 tests/unit/config/config_test.py::ExtendsTest::test_load_config_runs_interpolation_in_extended_service PASSED [ 90%]

01:38:45 tests/unit/config/config_test.py::ExtendsTest::test_load_throws_error_when_base_service_does_not_exist PASSED [ 90%]

01:38:45 tests/unit/config/config_test.py::ExtendsTest::test_merging_env_labels_ulimits PASSED [ 90%]

01:38:45 tests/unit/config/config_test.py::ExtendsTest::test_nested PASSED        [ 90%]

01:38:45 tests/unit/config/config_test.py::ExtendsTest::test_parent_build_path_dne PASSED [ 90%]

01:38:45 tests/unit/config/config_test.py::ExtendsTest::test_partial_service_config_in_extends_is_still_valid PASSED [ 90%]

01:38:45 tests/unit/config/config_test.py::ExtendsTest::test_self_referencing_file PASSED [ 90%]

01:38:45 tests/unit/config/config_test.py::ExtendsTest::test_volume_path PASSED   [ 90%]

01:38:45 tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_absolute PASSED [ 90%]

01:38:45 tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_normal PASSED [ 91%]

01:38:45 tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_with_tilde PASSED [ 91%]

01:38:45 tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_root_mount PASSED [ 91%]

01:38:45 tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_windows_path PASSED [ 91%]

01:38:45 tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_windows_path_in_container PASSED [ 91%]

01:38:45 tests/unit/config/config_test.py::BuildPathTest::test_absolute_path PASSED [ 91%]

01:38:45 tests/unit/config/config_test.py::BuildPathTest::test_from_file PASSED   [ 91%]

01:38:45 tests/unit/config/config_test.py::BuildPathTest::test_from_file_override_dir PASSED [ 91%]

01:38:45 tests/unit/config/config_test.py::BuildPathTest::test_invalid_url_in_build_path PASSED [ 91%]

01:38:45 tests/unit/config/config_test.py::BuildPathTest::test_nonexistent_path PASSED [ 91%]

01:38:45 tests/unit/config/config_test.py::BuildPathTest::test_relative_path PASSED [ 91%]

01:38:45 tests/unit/config/config_test.py::BuildPathTest::test_valid_url_in_build_path PASSED [ 92%]

01:38:45 + on_exit
01:38:45 + [[ 0 != \0 ]]
01:38:45 + docker rm -vf compose-dind-18.09.9-rc1-jenkins-compose-PR-6850-2
01:38:45 tests/integration/project_test.py::ProjectTest::test_up_with_network_priorities PASSED [ 23%]

01:38:45 tests/integration/service_test.py::ConfigHashTest::test_config_hash_sticks_around PASSED [ 35%]

01:38:45 tests/unit/config/config_test.py::HealthcheckTest::test_disable PASSED   [ 92%]

01:38:45 tests/unit/config/config_test.py::HealthcheckTest::test_disable_with_other_config_is_invalid PASSED [ 92%]

01:38:45 tests/unit/config/config_test.py::HealthcheckTest::test_healthcheck PASSED [ 92%]

01:38:45 tests/unit/config/config_test.py::HealthcheckTest::test_healthcheck_with_invalid_test PASSED [ 92%]

01:38:45 tests/unit/config/config_test.py::GetDefaultConfigFilesTestCase::test_get_config_path_default_file_in_basedir PASSED [ 92%]

01:38:45 tests/unit/config/config_test.py::GetDefaultConfigFilesTestCase::test_get_config_path_default_file_in_parent_dir PASSED [ 92%]

01:38:45 tests/unit/config/config_test.py::SerializeTest::test_denormalize_depends_on_v2_1 PASSED [ 92%]

01:38:45 tests/unit/config/config_test.py::SerializeTest::test_denormalize_depends_on_v3 PASSED [ 92%]

01:38:45 tests/unit/config/config_test.py::SerializeTest::test_denormalize_healthcheck PASSED [ 92%]

01:38:45 tests/unit/config/config_test.py::SerializeTest::test_denormalize_image_has_digest PASSED [ 92%]

01:38:45 tests/unit/config/config_test.py::SerializeTest::test_denormalize_image_no_digest PASSED [ 92%]

01:38:45 tests/unit/config/config_test.py::SerializeTest::test_serialize_bool_string PASSED [ 93%]

01:38:45 tests/unit/config/config_test.py::SerializeTest::test_serialize_configs PASSED [ 93%]

01:38:45 tests/unit/config/config_test.py::SerializeTest::test_serialize_escape_dollar_sign PASSED [ 93%]

01:38:45 tests/unit/config/config_test.py::SerializeTest::test_serialize_escape_dont_interpolate PASSED [ 93%]

01:38:45 tests/unit/config/config_test.py::SerializeTest::test_serialize_external_false PASSED [ 93%]

01:38:45 tests/unit/config/config_test.py::SerializeTest::test_serialize_ports PASSED [ 93%]

01:38:45 tests/unit/config/config_test.py::SerializeTest::test_serialize_ports_with_ext_ip PASSED [ 93%]

01:38:45 tests/unit/config/config_test.py::SerializeTest::test_serialize_secrets PASSED [ 93%]

01:38:45 tests/unit/config/config_test.py::SerializeTest::test_serialize_time PASSED [ 93%]

01:38:45 tests/unit/config/config_test.py::SerializeTest::test_serialize_unicode_values PASSED [ 93%]

01:38:45 tests/unit/config/environment_test.py::EnvironmentTest::test_env_vars_from_file_bom PASSED [ 93%]

01:38:45 tests/unit/config/environment_test.py::EnvironmentTest::test_env_vars_from_file_whitespace PASSED [ 94%]

01:38:45 tests/unit/config/environment_test.py::EnvironmentTest::test_get_boolean PASSED [ 94%]

01:38:45 tests/unit/config/environment_test.py::EnvironmentTest::test_get_simple PASSED [ 94%]

01:38:45 tests/unit/config/environment_test.py::EnvironmentTest::test_get_undefined PASSED [ 94%]

01:38:45 tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_services PASSED [ 94%]

01:38:45 tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_volumes PASSED [ 94%]

01:38:45 tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_secrets PASSED [ 94%]

01:38:45 tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_v2 PASSED [ 94%]

01:38:45 tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_v3 PASSED [ 94%]

01:38:45 tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_invalid PASSED [ 94%]

01:38:45 tests/unit/config/interpolation_test.py::test_interpolate_environment_network_convert_types PASSED [ 94%]

01:38:45 tests/unit/config/interpolation_test.py::test_interpolate_environment_external_resource_convert_types PASSED [ 94%]

01:38:45 tests/unit/config/interpolation_test.py::test_interpolate_service_name_uses_dot PASSED [ 95%]

01:38:45 tests/unit/config/interpolation_test.py::test_escaped_interpolation PASSED [ 95%]

01:38:45 tests/unit/config/interpolation_test.py::test_invalid_interpolation PASSED [ 95%]

01:38:45 tests/unit/config/interpolation_test.py::test_interpolate_missing_no_default PASSED [ 95%]

01:38:45 tests/unit/config/interpolation_test.py::test_interpolate_with_value PASSED [ 95%]

01:38:45 tests/unit/config/interpolation_test.py::test_interpolate_missing_with_default PASSED [ 95%]

01:38:45 tests/unit/config/interpolation_test.py::test_interpolate_with_empty_and_default_value PASSED [ 95%]

01:38:45 tests/unit/config/interpolation_test.py::test_interpolate_mandatory_values PASSED [ 95%]

01:38:45 tests/unit/config/interpolation_test.py::test_interpolate_mandatory_no_err_msg PASSED [ 95%]

01:38:45 tests/unit/config/interpolation_test.py::test_interpolate_mixed_separators PASSED [ 95%]

01:38:45 tests/unit/config/interpolation_test.py::test_unbraced_separators PASSED [ 95%]

01:38:45 tests/unit/config/interpolation_test.py::test_interpolate_unicode_values PASSED [ 96%]

01:38:45 tests/unit/config/interpolation_test.py::test_interpolate_no_fallthrough PASSED [ 96%]

01:38:45 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_1 PASSED [ 96%]

01:38:45 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_2 PASSED [ 96%]

01:38:45 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_3 PASSED [ 96%]

01:38:45 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_4 PASSED [ 96%]

01:38:45 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_5 PASSED [ 96%]

01:38:45 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_6 PASSED [ 96%]

01:38:45 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_7 PASSED [ 96%]

01:38:45 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports PASSED [ 96%]

01:38:45 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports_2 PASSED [ 96%]

01:38:45 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports_3 PASSED [ 97%]

01:38:45 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_self_imports PASSED [ 97%]

01:38:45 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_depends_on_self PASSED [ 97%]

01:38:45 tests/unit/config/types_test.py::test_parse_extra_hosts_list PASSED      [ 97%]

01:38:45 tests/unit/config/types_test.py::test_parse_extra_hosts_dict PASSED      [ 97%]

01:38:45 tests/unit/config/types_test.py::TestServicePort::test_parse_dict PASSED [ 97%]

01:38:45 tests/unit/config/types_test.py::TestServicePort::test_parse_simple_target_port PASSED [ 97%]

01:38:45 tests/unit/config/types_test.py::TestServicePort::test_parse_complete_port_definition PASSED [ 97%]

01:38:45 tests/unit/config/types_test.py::TestServicePort::test_parse_ext_ip_no_published_port PASSED [ 97%]

01:38:45 tests/unit/config/types_test.py::TestServicePort::test_repr_published_port_0 PASSED [ 97%]

01:38:45 tests/unit/config/types_test.py::TestServicePort::test_parse_port_range PASSED [ 97%]

01:38:45 tests/unit/config/types_test.py::TestServicePort::test_parse_port_publish_range PASSED [ 97%]

01:38:45 tests/unit/config/types_test.py::TestServicePort::test_parse_invalid_port PASSED [ 98%]

01:38:45 tests/unit/config/types_test.py::TestServicePort::test_parse_invalid_publish_range PASSED [ 98%]

01:38:45 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_only_one_path PASSED [ 98%]

01:38:45 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_internal_and_external PASSED [ 98%]

01:38:45 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_with_mode PASSED [ 98%]

01:38:45 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_too_many_parts PASSED [ 98%]

01:38:45 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_absolute_path_normalized PASSED [ 98%]

01:38:45 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_absolute_path_native PASSED [ 98%]

01:38:45 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_internal_path_normalized PASSED [ 98%]

01:38:45 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_internal_path_native PASSED [ 98%]

01:38:45 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_just_drives_normalized PASSED [ 98%]

01:38:45 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_just_drives_native PASSED [ 99%]

01:38:45 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_mixed_notations_normalized PASSED [ 99%]

01:38:45 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_mixed_notations_native PASSED [ 99%]

01:38:45 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_from_service PASSED [ 99%]

01:38:45 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_from_container PASSED [ 99%]

01:38:45 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_invalid PASSED [ 99%]

01:38:45 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_service PASSED [ 99%]

01:38:45 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_service_with_mode PASSED [ 99%]

01:38:45 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_container PASSED [ 99%]

01:38:45 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_container_with_mode PASSED [ 99%]

01:38:45 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_invalid_type PASSED [ 99%]

01:38:45 compose-dind-18.09.9-rc1-jenkins-compose-PR-6850-2
01:38:45 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_count PASSED [ 25%]

01:38:45 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_percent SKIPPED [ 25%]

01:38:45 tests/integration/service_test.py::ConfigHashTest::test_config_hash_with_custom_labels PASSED [ 35%]

01:38:45 tests/integration/service_test.py::ConfigHashTest::test_no_config_hash_when_one_off PASSED [ 35%]

01:38:45 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_quota PASSED [ 25%]

[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // withDockerRegistry
[Pipeline] }
[Pipeline] // node
01:38:45 tests/integration/service_test.py::ConfigHashTest::test_no_config_hash_when_overriding_options PASSED [ 35%]

[Pipeline] }
01:38:46 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_rt xfail [ 25%]

01:38:46 tests/integration/project_test.py::ProjectTest::test_up_with_network_static_addresses PASSED [ 23%]

01:38:46 tests/integration/project_test.py::ProjectTest::test_up_with_network_static_addresses_missing_subnet PASSED [ 23%]

01:38:46 tests/integration/project_test.py::ProjectTest::test_up_with_nvidia_runtime SKIPPED [ 23%]

01:38:46 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_set PASSED [ 26%]

01:38:47 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_shares PASSED [ 26%]

01:38:47 tests/integration/state_test.py::BasicProjectTest::test_all_change PASSED [ 35%]

01:38:47 tests/integration/project_test.py::ProjectTest::test_up_with_runtime PASSED [ 23%]

01:38:47 tests/integration/project_test.py::ProjectTest::test_volumes_from_container PASSED [ 23%]

01:38:47 tests/integration/project_test.py::ProjectTest::test_volumes_from_service PASSED [ 23%]

01:38:47 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpus PASSED [ 26%]

01:38:47 tests/integration/service_test.py::ServiceTest::test_create_container_with_device_cgroup_rules PASSED [ 26%]

01:38:48 tests/integration/service_test.py::ServiceTest::test_create_container_with_extra_hosts_dicts PASSED [ 26%]

01:38:48 tests/integration/state_test.py::BasicProjectTest::test_no_change PASSED [ 35%]

01:38:48 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_invalid PASSED [100%]

01:38:48 

01:38:48 ----------- coverage: platform linux, python 3.7.4-final-0 -----------

01:38:48 Name                              Stmts   Miss Branch BrPart  Cover   Missing

01:38:48 -----------------------------------------------------------------------------

01:38:48 compose/__init__.py                   3      0      0      0   100%

01:38:48 compose/__main__.py                   4      4      0      0     0%   1-6

01:38:48 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

01:38:48 compose/cli/__init__.py               0      0      0      0   100%

01:38:48 compose/cli/colors.py                23      2     10      2    88%   37-38, 36->37, 48->exit

01:38:48 compose/cli/command.py               93     14     28      4    82%   71-81, 88, 125-130, 174, 70->71, 87->88, 124->125, 171->174

01:38:48 compose/cli/docker_client.py         75      5     24      2    93%   24, 98-99, 107, 123, 106->107, 122->123

01:38:48 compose/cli/docopt_command.py        38      4      8      2    87%   13-14, 29, 35, 28->29, 34->35

01:38:48 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

01:38:48 compose/cli/formatter.py             34      2     10      1    93%   17-18, 15->17

01:38:48 compose/cli/log_printer.py          144     14     52      6    89%   76, 103, 110-115, 162-164, 173, 226-229, 233-234, 253, 43->exit, 75->76, 98->103, 171->173, 225->226, 232->233

01:38:48 compose/cli/main.py                 695     90    307     40    85%   83-84, 86-87, 168, 328, 360-362, 445, 505, 509, 514-515, 525-554, 566, 584-586, 657-658, 696-697, 715, 736-737, 749, 772, 790, 837, 1069, 1078, 1104-1113, 1153-1156, 1164-1168, 1170-1175, 1198, 1220-1249, 1256-1257, 1259-1261, 1276, 1282, 1466, 1484, 1500, 1504-1505, 1516, 1521, 1524, 1550, 1569-1571, 1581, 1592, 60->63, 82->83, 85->86, 167->168, 327->328, 359->360, 444->445, 504->505, 508->509, 519->525, 563->566, 583->584, 655->657, 714->715, 735->736, 748->749, 771->772, 827->837, 829->exit, 1068->1069, 1077->1078, 1163->1164, 1169->1170, 1197->1198, 1255->1256, 1258->1259, 1275->1276, 1281->1282, 1465->1466, 1483->1484, 1499->1500, 1515->1516, 1520->1521, 1523->1524, 1542->exit, 1549->1550, 1563->1571, 1565->1569, 1580->1581, 1590->1592

01:38:48 compose/cli/signals.py               23      0      4      2    93%   36->exit, 43->exit

01:38:48 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

01:38:48 compose/cli/verbose_proxy.py         35     12     10      0    69%   36-39, 42-47, 50-60

01:38:48 compose/config/__init__.py           13      0      0      0   100%

01:38:48 compose/config/config.py            826     30    428     18    95%   266, 277, 508, 621-622, 714, 757, 812-830, 952-953, 959, 979, 982, 1335, 1366, 1412, 265->266, 276->277, 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

01:38:48 compose/config/environment.py       100      8     34      5    90%   21, 41, 104-107, 120, 127, 20->21, 40->41, 103->104, 119->120, 126->127

01:38:48 compose/config/errors.py             25      2      2      0    85%   36-40

01:38:48 compose/config/interpolation.py     148      6     64      3    95%   66, 148, 222, 227-229, 121->exit, 146->148, 221->222

01:38:48 compose/config/serialize.py          97      2     58      3    97%   31, 76, 30->31, 75->76, 82->85

01:38:48 compose/config/sort_services.py      44      1     24      1    97%   57, 56->57

01:38:48 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

01:38:48 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

01:38:48 compose/const.py                     36      0      0      0   100%

01:38:48 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

01:38:48 compose/errors.py                    17      1      0      0    94%   12

01:38:48 compose/network.py                  190     19     95      5    87%   184, 186-200, 206, 224, 226, 183->184, 185->186, 205->206, 223->224, 225->226

01:38:48 compose/parallel.py                 199      2     58      1    99%   187, 326, 325->326

01:38:48 compose/progress_stream.py           79      8     40      9    86%   40, 71, 74, 80, 85, 90-91, 116, 39->40, 42->46, 53->57, 70->71, 73->74, 79->80, 84->85, 89->90, 112->116

01:38:48 compose/project.py                  424     29    201     16    92%   60, 156, 212-213, 254-255, 364-365, 378-381, 434, 485, 489, 615, 621, 624-627, 752-753, 759-762, 777, 782-785, 788, 809, 57->60, 152->156, 331->333, 362->364, 377->378, 433->434, 484->485, 488->489, 614->615, 620->621, 623->624, 671->exit, 755->762, 776->777, 781->782, 787->788

01:38:48 compose/service.py                  854     50    433     26    93%   271-272, 293, 366-369, 417-422, 428-430, 470-471, 485, 488, 506, 573, 618-619, 727, 946-947, 967-968, 1069, 1115, 1176, 1218, 1240-1255, 1295, 1334-1338, 1526, 1530, 1646, 1686, 1698, 216->exit, 269->271, 292->293, 427->428, 469->470, 484->485, 487->488, 505->506, 563->573, 722->727, 945->946, 966->967, 1068->1069, 1114->1115, 1175->1176, 1217->1218, 1294->1295, 1331->1334, 1525->1526, 1529->1530, 1578->exit, 1586->1585, 1623->1620, 1645->1646, 1685->1686, 1697->1698

01:38:48 compose/state.py                      0      0      0      0   100%

01:38:48 compose/timeparse.py                 22      0      4      0   100%

01:38:48 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

01:38:48 compose/version.py                    6      0      0      0   100%

01:38:48 compose/volume.py                   126      4     44      3    95%   150, 200, 211-212, 141->150, 199->200, 209->211

01:38:48 -----------------------------------------------------------------------------

01:38:48 TOTAL                              5553    436   2401    205    91%

01:38:48 Coverage HTML written to dir coverage-html

01:38:48 

01:38:48 =========================== short test summary info ============================

01:38:48 XFAIL tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_rt

01:38:48   not supported by kernel

01:38:48 XFAIL tests/integration/service_test.py::ServiceTest::test_create_container_with_storage_opt

01:38:48   Not supported on most drivers

01:38:48 SKIP [1] tests/acceptance/cli_test.py:2424: race condition between up and logs

01:38:48 SKIP [1] tests/acceptance/cli_test.py:2376: race condition between up and logs

01:38:48 SKIP [1] tests/acceptance/cli_test.py:2403: race condition between up and logs

01:38:48 SKIP [1] /code/tests/integration/testcases.py:167: This daemon does not support the 'nvidia'' runtime

01:38:48 SKIP [1] tests/integration/service_test.py:148: cpu_percent is not supported for Linux

01:38:48 SKIP [1] tests/integration/service_test.py:1635: Broken on 1.11.0 - 17.03.0

01:38:48 SKIP [1] tests/unit/cli/command_test.py:39: windows separator

01:38:48 SKIP [1] tests/unit/cli/command_test.py:69: Env values in Python 3 are already Unicode

01:38:48 SKIP [1] tests/unit/cli/errors_test.py:70: Needs pywin32

01:38:48 SKIP [1] tests/unit/cli/errors_test.py:80: Needs pywin32

01:38:48 SKIP [1] tests/unit/cli/errors_test.py:90: Needs pywin32

01:38:48 SKIP [1] tests/unit/config/config_test.py:3777: windows paths

01:38:48 

01:38:48 ======= 1121 passed, 12 skipped, 2 xfailed, 3 xpassed in 854.28 seconds ========

01:38:48 tests/integration/resilience_test.py::ResilienceTest::test_create_failure PASSED [ 23%]

01:38:48 tests/integration/service_test.py::ServiceTest::test_create_container_with_extra_hosts_list PASSED [ 26%]

01:38:48 tests/integration/service_test.py::ServiceTest::test_create_container_with_healthcheck_config PASSED [ 26%]

01:38:48 ___________________________________ summary ____________________________________

01:38:48   py37: commands succeeded

01:38:48   congratulations :)

01:38:48 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_middle_always_recreate_deps PASSED [ 35%]

01:38:49 + on_exit
01:38:49 + [[ 0 != \0 ]]
01:38:49 + docker rm -vf compose-dind-19.03.2-rc1-jenkins-compose-PR-6850-2
01:38:49 compose-dind-19.03.2-rc1-jenkins-compose-PR-6850-2
01:38:49 tests/integration/service_test.py::ServiceTest::test_create_container_with_host_mount PASSED [ 26%]

01:38:49 tests/integration/state_test.py::BasicProjectTest::test_partial_change PASSED [ 35%]

01:38:50 tests/integration/service_test.py::ServiceTest::test_create_container_with_init_bool PASSED [ 26%]

01:38:50 tests/integration/resilience_test.py::ResilienceTest::test_start_failure PASSED [ 23%]

[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // withDockerRegistry
[Pipeline] }
[Pipeline] // node
[Pipeline] }
01:38:50 tests/integration/service_test.py::ServiceTest::test_create_container_with_init_path XPASS [ 26%]

01:38:51 tests/integration/service_test.py::ServiceTest::test_create_container_with_legacy_mount PASSED [ 26%]

01:38:51 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root PASSED [ 36%]

01:38:51 tests/integration/resilience_test.py::ResilienceTest::test_successful_recreate PASSED [ 23%]

01:38:51 tests/integration/service_test.py::ServiceTest::test_build PASSED        [ 23%]

01:38:51 tests/integration/service_test.py::ServiceTest::test_build_non_ascii_filename PASSED [ 24%]

01:38:51 tests/integration/service_test.py::ServiceTest::test_create_container_with_legacy_tmpfs_mount PASSED [ 26%]

01:38:52 tests/integration/service_test.py::ServiceTest::test_create_container_with_mac_address PASSED [ 27%]

01:38:52 tests/integration/service_test.py::ServiceTest::test_create_container_with_one_off PASSED [ 27%]

01:38:52 tests/integration/service_test.py::ServiceTest::test_create_container_with_one_off_when_existing_container_is_running PASSED [ 27%]

01:38:52 tests/integration/service_test.py::ServiceTest::test_create_container_with_oom_kill_disable PASSED [ 27%]

01:38:53 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_leaf PASSED [ 35%]

01:38:53 tests/integration/service_test.py::ServiceTest::test_create_container_with_pids_limit XPASS [ 27%]

01:38:53 tests/integration/service_test.py::ServiceTest::test_build_with_build_args PASSED [ 24%]

01:38:53 tests/integration/service_test.py::ServiceTest::test_create_container_with_read_only_root_fs PASSED [ 27%]

01:38:54 tests/integration/service_test.py::ServiceTest::test_create_container_with_security_opt PASSED [ 27%]

Terminated
01:38:54 tests/integration/service_test.py::ServiceTest::test_create_container_with_shm_size PASSED [ 27%]

01:38:55 tests/integration/service_test.py::ServiceTest::test_create_container_with_specified_volume PASSED [ 27%]

01:38:55 tests/integration/service_test.py::ServiceTest::test_create_container_with_storage_opt xfail [ 27%]

01:38:55 tests/integration/service_test.py::ServiceTest::test_build_with_build_args_override PASSED [ 24%]

01:38:55 tests/integration/service_test.py::ServiceTest::test_create_container_with_tmpfs_mount PASSED [ 27%]

01:38:56 tests/integration/service_test.py::ServiceTest::test_build_with_build_labels PASSED [ 24%]

01:38:56 tests/integration/service_test.py::ServiceTest::test_build_with_cachefrom PASSED [ 24%]

01:38:56 tests/integration/service_test.py::ServiceTest::test_create_container_with_tmpfs_mount_tmpfs_size PASSED [ 28%]

01:38:56 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_middle PASSED [ 35%]

01:38:56 tests/integration/service_test.py::ServiceTest::test_create_container_with_unspecified_volume PASSED [ 28%]

01:38:57 tests/integration/service_test.py::ServiceTest::test_create_container_with_volume_driver PASSED [ 28%]

01:38:58 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root_always_recreate_deps PASSED [ 36%]

01:38:58 tests/integration/service_test.py::ServiceTest::test_create_container_with_volume_mount PASSED [ 28%]

01:38:58 tests/integration/service_test.py::ServiceTest::test_build_with_extra_hosts PASSED [ 24%]

01:38:58 tests/integration/service_test.py::ServiceTest::test_create_container_with_volumes_from PASSED [ 28%]

01:38:58 tests/integration/service_test.py::ServiceTest::test_create_with_image_id PASSED [ 28%]

Terminated
01:38:59 tests/integration/service_test.py::ServiceTest::test_custom_container_name PASSED [ 28%]

01:38:59 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root_no_recreate PASSED [ 36%]

01:39:00 tests/integration/service_test.py::ServiceTest::test_devices PASSED      [ 28%]

01:39:00 tests/integration/service_test.py::ServiceTest::test_build_with_git_url PASSED [ 24%]

01:39:00 tests/integration/service_test.py::ServiceTest::test_dns_list PASSED     [ 28%]

01:39:00 tests/integration/service_test.py::ServiceTest::test_dns_no_value PASSED [ 28%]

01:39:01 tests/integration/service_test.py::ServiceTest::test_dns_opt_value PASSED [ 28%]

01:39:01 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_middle_always_recreate_deps PASSED [ 35%]

01:39:01 tests/integration/service_test.py::ServiceTest::test_dns_search PASSED   [ 28%]

01:39:02 tests/integration/service_test.py::ServiceTest::test_build_with_gzip PASSED [ 24%]

01:39:02 tests/integration/service_test.py::ServiceTest::test_duplicate_containers PASSED [ 29%]

01:39:03 tests/integration/state_test.py::ProjectWithDependenciesTest::test_service_recreated_when_dependency_created PASSED [ 36%]

01:39:03 tests/integration/service_test.py::ServiceTest::test_build_with_illegal_leading_chars PASSED [ 24%]

01:39:03 tests/integration/service_test.py::ServiceTest::test_build_with_image_name PASSED [ 24%]

01:39:03 tests/integration/service_test.py::ServiceTest::test_build_with_isolation PASSED [ 24%]

01:39:04 tests/integration/service_test.py::ServiceTest::test_duplicate_volume_trailing_slash PASSED [ 29%]

01:39:04 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root PASSED [ 36%]

01:39:04 tests/integration/service_test.py::ServiceTest::test_empty_labels PASSED [ 29%]

01:39:04 tests/integration/service_test.py::ServiceTest::test_build_with_network PASSED [ 25%]

01:39:05 tests/integration/service_test.py::ServiceTest::test_env_from_file_combined_with_env PASSED [ 29%]

01:39:06 tests/integration/service_test.py::ServiceTest::test_build_with_target PASSED [ 25%]

01:39:06 tests/integration/service_test.py::ServiceTest::test_cap_add_list PASSED [ 25%]

01:39:07 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_anonymous_volume_recreate_then_renew PASSED [ 29%]

01:39:07 tests/integration/service_test.py::ServiceTest::test_cap_drop_list PASSED [ 25%]

01:39:08 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_anonymous_volume_renew PASSED [ 29%]

01:39:09 tests/integration/service_test.py::ServiceTest::test_containers PASSED   [ 25%]

01:39:09 tests/integration/service_test.py::ServiceTest::test_containers_one_off PASSED [ 25%]

01:39:09 tests/integration/service_test.py::ServiceTest::test_create_container_with_blkio_config PASSED [ 25%]

01:39:09 tests/integration/state_test.py::ProjectWithDependenciesTest::test_service_removed_while_down PASSED [ 36%]

01:39:09 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_count PASSED [ 25%]

01:39:09 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_percent SKIPPED [ 25%]

01:39:10 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_quota PASSED [ 25%]

01:39:10 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_rt xfail [ 25%]

01:39:10 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root_always_recreate_deps PASSED [ 36%]

01:39:11 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_set PASSED [ 26%]

01:39:11 tests/integration/state_test.py::ProjectWithDependenciesTest::test_up PASSED [ 36%]

01:39:11 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_shares PASSED [ 26%]

01:39:12 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root_no_recreate PASSED [ 36%]

01:39:12 tests/integration/service_test.py::ServiceTest::test_create_container_with_cpus PASSED [ 26%]

01:39:12 tests/integration/service_test.py::ServiceTest::test_create_container_with_device_cgroup_rules PASSED [ 26%]

01:39:13 tests/integration/service_test.py::ServiceTest::test_create_container_with_extra_hosts_dicts PASSED [ 26%]

01:39:14 tests/integration/service_test.py::ServiceTest::test_create_container_with_extra_hosts_list PASSED [ 26%]

01:39:14 tests/integration/service_test.py::ServiceTest::test_create_container_with_healthcheck_config PASSED [ 26%]

01:39:14 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_image_with_volume_is_removed PASSED [ 29%]

01:39:14 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate PASSED [ 29%]

01:39:15 tests/integration/service_test.py::ServiceTest::test_create_container_with_host_mount PASSED [ 26%]

01:39:15 tests/integration/service_test.py::ServiceTest::test_create_container_with_init_bool PASSED [ 26%]

01:39:15 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_change_mount_target PASSED [ 29%]

01:39:15 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_leaf PASSED [ 36%]

01:39:16 tests/integration/state_test.py::ProjectWithDependenciesTest::test_service_recreated_when_dependency_created PASSED [ 36%]

01:39:16 tests/integration/service_test.py::ServiceTest::test_create_container_with_init_path XPASS [ 26%]

01:39:17 tests/integration/service_test.py::ServiceTest::test_create_container_with_legacy_mount PASSED [ 26%]

01:39:17 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_twice PASSED [ 29%]

01:39:17 tests/integration/service_test.py::ServiceTest::test_create_container_with_legacy_tmpfs_mount PASSED [ 26%]

01:39:18 tests/integration/service_test.py::ServiceTest::test_create_container_with_mac_address PASSED [ 27%]

01:39:18 tests/integration/service_test.py::ServiceTest::test_create_container_with_one_off PASSED [ 27%]

01:39:18 tests/integration/service_test.py::ServiceTest::test_create_container_with_one_off_when_existing_container_is_running PASSED [ 27%]

01:39:18 tests/integration/service_test.py::ServiceTest::test_create_container_with_oom_kill_disable PASSED [ 27%]

01:39:19 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_twice_with_mount PASSED [ 29%]

01:39:19 tests/integration/service_test.py::ServiceTest::test_create_container_with_pids_limit XPASS [ 27%]

01:39:19 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_middle PASSED [ 36%]

01:39:19 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_containers_are_stopped PASSED [ 30%]

01:39:19 tests/integration/service_test.py::ServiceTest::test_create_container_with_read_only_root_fs PASSED [ 27%]

01:39:20 tests/integration/service_test.py::ServiceTest::test_create_container_with_security_opt PASSED [ 27%]

01:39:21 tests/integration/service_test.py::ServiceTest::test_create_container_with_shm_size PASSED [ 27%]

01:39:21 tests/integration/state_test.py::ProjectWithDependenciesTest::test_service_removed_while_down PASSED [ 36%]

01:39:21 tests/integration/service_test.py::ServiceTest::test_create_container_with_specified_volume PASSED [ 27%]

01:39:21 tests/integration/service_test.py::ServiceTest::test_create_container_with_storage_opt xfail [ 27%]

01:39:22 tests/integration/service_test.py::ServiceTest::test_create_container_with_tmpfs_mount PASSED [ 27%]

01:39:22 tests/integration/service_test.py::ServiceTest::test_create_container_with_tmpfs_mount_tmpfs_size PASSED [ 28%]

01:39:23 tests/integration/state_test.py::ProjectWithDependenciesTest::test_up PASSED [ 36%]

01:39:23 tests/integration/service_test.py::ServiceTest::test_create_container_with_unspecified_volume PASSED [ 28%]

01:39:23 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_host_volume_is_removed PASSED [ 30%]

01:39:24 tests/integration/service_test.py::ServiceTest::test_create_container_with_volume_driver PASSED [ 28%]

01:39:24 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_middle_always_recreate_deps PASSED [ 36%]

01:39:24 tests/integration/service_test.py::ServiceTest::test_create_container_with_volume_mount PASSED [ 28%]

01:39:25 tests/integration/service_test.py::ServiceTest::test_create_container_with_volumes_from PASSED [ 28%]

01:39:25 tests/integration/service_test.py::ServiceTest::test_create_with_image_id PASSED [ 28%]

01:39:26 tests/integration/service_test.py::ServiceTest::test_custom_container_name PASSED [ 28%]

01:39:26 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_leaf PASSED [ 36%]

01:39:26 tests/integration/service_test.py::ServiceTest::test_devices PASSED      [ 28%]

01:39:27 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_image_volume_masks_config PASSED [ 30%]

01:39:27 tests/integration/service_test.py::ServiceTest::test_dns_list PASSED     [ 28%]

01:39:28 tests/integration/service_test.py::ServiceTest::test_dns_no_value PASSED [ 28%]

01:39:28 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root PASSED [ 36%]

01:39:28 tests/integration/service_test.py::ServiceTest::test_dns_opt_value PASSED [ 28%]

01:39:29 tests/integration/service_test.py::ServiceTest::test_dns_search PASSED   [ 28%]

01:39:29 tests/integration/service_test.py::ServiceTest::test_duplicate_containers PASSED [ 29%]

01:39:30 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_middle PASSED [ 36%]

01:39:31 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_with_image_declared_volume PASSED [ 30%]

01:39:31 tests/integration/service_test.py::ServiceTest::test_duplicate_volume_trailing_slash PASSED [ 29%]

01:39:31 tests/integration/service_test.py::ServiceTest::test_empty_labels PASSED [ 29%]

01:39:32 tests/integration/service_test.py::ServiceTest::test_env_from_file_combined_with_env PASSED [ 29%]

01:39:34 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_anonymous_volume_recreate_then_renew PASSED [ 29%]

01:39:35 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_with_image_declared_volume_renew PASSED [ 30%]

01:39:35 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_anonymous_volume_renew PASSED [ 29%]

01:39:35 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_middle_always_recreate_deps PASSED [ 36%]

01:39:36 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root_always_recreate_deps PASSED [ 36%]

01:39:37 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root_no_recreate PASSED [ 36%]

01:39:38 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_without_start PASSED [ 30%]

01:39:39 tests/integration/service_test.py::ServiceTest::test_expose_does_not_publish_ports PASSED [ 30%]

01:39:39 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root PASSED [ 36%]

01:39:39 tests/integration/service_test.py::ServiceTest::test_group_add_value PASSED [ 30%]

01:39:39 tests/integration/service_test.py::ServiceTest::test_labels PASSED       [ 30%]

01:39:40 tests/integration/service_test.py::ServiceTest::test_log_drive_empty_default_jsonfile PASSED [ 30%]

01:39:40 tests/integration/service_test.py::ServiceTest::test_log_drive_invalid SKIPPED [ 30%]

01:39:40 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_dependency_added PASSED [ 37%]

01:39:40 tests/integration/service_test.py::ServiceTest::test_log_drive_none PASSED [ 31%]

01:39:41 tests/integration/service_test.py::ServiceTest::test_mem_reservation PASSED [ 31%]

01:39:42 tests/integration/service_test.py::ServiceTest::test_mem_swappiness PASSED [ 31%]

01:39:42 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_image_with_volume_is_removed PASSED [ 29%]

01:39:42 tests/integration/service_test.py::ServiceTest::test_network_mode_bridged PASSED [ 31%]

01:39:42 tests/integration/service_test.py::ServiceTest::test_network_mode_host PASSED [ 31%]

01:39:43 tests/integration/service_test.py::ServiceTest::test_network_mode_none PASSED [ 31%]

01:39:43 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate PASSED [ 29%]

01:39:43 tests/integration/service_test.py::ServiceTest::test_oom_score_adj_value PASSED [ 31%]

01:39:44 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_change_mount_target PASSED [ 29%]

01:39:44 tests/integration/service_test.py::ServiceTest::test_pid_mode_host PASSED [ 31%]

01:39:44 tests/integration/service_test.py::ServiceTest::test_pid_mode_none_defined PASSED [ 31%]

01:39:45 tests/integration/service_test.py::ServiceTest::test_port_with_explicit_interface PASSED [ 31%]

01:39:45 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root_always_recreate_deps PASSED [ 36%]

01:39:45 tests/integration/service_test.py::ServiceTest::test_project_is_added_to_container_name PASSED [ 31%]

01:39:46 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_twice PASSED [ 29%]

01:39:47 tests/integration/service_test.py::ServiceTest::test_recreate_preserves_volume_with_trailing_slash PASSED [ 31%]

01:39:47 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root_no_recreate PASSED [ 36%]

01:39:47 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_dependency_removed PASSED [ 37%]

01:39:48 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_recreate_twice_with_mount PASSED [ 29%]

01:39:48 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_containers_are_stopped PASSED [ 30%]

01:39:50 tests/integration/service_test.py::ServiceTest::test_recreate_volume_to_mount PASSED [ 32%]

01:39:50 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_dependency_added PASSED [ 37%]

01:39:50 tests/integration/service_test.py::ServiceTest::test_resolve_env PASSED  [ 32%]

01:39:51 tests/integration/service_test.py::ServiceTest::test_restart_always_value PASSED [ 32%]

01:39:51 tests/integration/service_test.py::ServiceTest::test_restart_on_failure_value PASSED [ 32%]

01:39:52 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_host_volume_is_removed PASSED [ 30%]

01:39:53 tests/integration/service_test.py::ServiceTest::test_scale PASSED        [ 32%]

01:39:54 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_service_removed_while_down PASSED [ 37%]

01:39:54 tests/integration/service_test.py::ServiceTest::test_scale_sets_ports PASSED [ 32%]

01:39:55 tests/integration/service_test.py::ServiceTest::test_scale_with_api_error PASSED [ 32%]

01:39:55 tests/integration/service_test.py::ServiceTest::test_scale_with_custom_container_name_outputs_warning PASSED [ 32%]

01:39:55 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_dependency_removed PASSED [ 37%]

01:39:56 tests/integration/service_test.py::ServiceTest::test_scale_with_desired_number_already_achieved PASSED [ 32%]

01:39:56 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_service_removed_while_up PASSED [ 37%]

01:39:56 tests/integration/service_test.py::ServiceTest::test_scale_with_immediate_exit PASSED [ 32%]

01:39:56 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_when_image_volume_masks_config PASSED [ 30%]

01:39:58 tests/integration/service_test.py::ServiceTest::test_scale_with_stopped_containers PASSED [ 32%]

01:39:59 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_up PASSED [ 37%]

01:39:59 tests/integration/service_test.py::ServiceTest::test_scale_with_stopped_containers_and_needing_creation PASSED [ 33%]

01:39:59 tests/integration/state_test.py::ServiceStateTest::test_image_changed_to_build PASSED [ 37%]

01:39:59 tests/integration/state_test.py::ServiceStateTest::test_trigger_create PASSED [ 37%]

01:39:59 tests/integration/service_test.py::ServiceTest::test_scale_with_unexpected_exception PASSED [ 33%]

01:40:00 tests/integration/state_test.py::ServiceStateTest::test_trigger_noop PASSED [ 37%]

01:40:00 tests/integration/service_test.py::ServiceTest::test_split_env PASSED    [ 33%]

01:40:00 tests/integration/service_test.py::ServiceTest::test_start_container_becomes_privileged PASSED [ 33%]

01:40:01 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_with_image_declared_volume PASSED [ 30%]

01:40:02 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_build <- tests/integration/testcases.py PASSED [ 37%]

01:40:02 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_service_removed_while_down PASSED [ 37%]

01:40:02 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_config_change PASSED [ 37%]

01:40:03 tests/integration/service_test.py::ServiceTest::test_start_container_builds_images PASSED [ 33%]

01:40:03 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_image_change PASSED [ 37%]

01:40:03 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_nonexistent_image_tag PASSED [ 38%]

01:40:03 tests/integration/service_test.py::ServiceTest::test_start_container_creates_fixed_external_ports PASSED [ 33%]

01:40:03 tests/integration/service_test.py::ServiceTest::test_start_container_creates_fixed_external_ports_when_it_is_different_to_internal_port PASSED [ 33%]

01:40:04 tests/integration/state_test.py::ServiceStateTest::test_trigger_start PASSED [ 38%]

01:40:04 tests/integration/volume_test.py::VolumeTest::test_create_volume PASSED  [ 38%]

01:40:04 tests/integration/volume_test.py::VolumeTest::test_create_volume_custom_name PASSED [ 38%]

01:40:04 tests/integration/volume_test.py::VolumeTest::test_exists <- tests/integration/testcases.py PASSED [ 38%]

01:40:04 tests/integration/volume_test.py::VolumeTest::test_exists_external <- tests/integration/testcases.py PASSED [ 38%]

01:40:04 tests/integration/volume_test.py::VolumeTest::test_exists_external_aliased <- tests/integration/testcases.py PASSED [ 38%]

01:40:04 tests/integration/volume_test.py::VolumeTest::test_external_aliased_volume <- tests/integration/testcases.py PASSED [ 38%]

01:40:04 tests/integration/volume_test.py::VolumeTest::test_external_volume <- tests/integration/testcases.py PASSED [ 38%]

01:40:04 tests/integration/volume_test.py::VolumeTest::test_inspect_volume <- tests/integration/testcases.py PASSED [ 38%]

01:40:04 tests/integration/volume_test.py::VolumeTest::test_recreate_existing_volume PASSED [ 38%]

01:40:04 tests/integration/volume_test.py::VolumeTest::test_remove_volume <- tests/integration/testcases.py PASSED [ 39%]

01:40:04 tests/integration/volume_test.py::VolumeTest::test_volume_default_labels <- tests/integration/testcases.py PASSED [ 39%]

01:40:05 tests/unit/bundle_test.py::test_get_image_digest_exists PASSED           [ 39%]

01:40:05 tests/integration/service_test.py::ServiceTest::test_start_container_creates_links <- tests/integration/testcases.py PASSED [ 33%]

01:40:05 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_with_image_declared_volume_renew PASSED [ 30%]

01:40:05 tests/unit/bundle_test.py::test_get_image_digest_image_uses_digest PASSED [ 39%]

01:40:05 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_service_removed_while_up PASSED [ 37%]

01:40:05 tests/unit/bundle_test.py::test_get_image_digest_from_repository PASSED  [ 39%]

01:40:05 tests/unit/bundle_test.py::test_get_image_digest_no_image PASSED         [ 39%]

01:40:06 tests/unit/bundle_test.py::test_push_image_with_saved_digest PASSED      [ 39%]

01:40:06 tests/unit/bundle_test.py::test_push_image PASSED                        [ 39%]

01:40:06 tests/unit/bundle_test.py::test_to_bundle PASSED                         [ 39%]

01:40:06 tests/unit/bundle_test.py::test_convert_service_to_bundle PASSED         [ 39%]

01:40:06 tests/unit/bundle_test.py::test_set_command_and_args_none PASSED         [ 39%]

01:40:06 tests/unit/bundle_test.py::test_set_command_and_args_from_command PASSED [ 39%]

01:40:06 tests/unit/bundle_test.py::test_set_command_and_args_from_entrypoint PASSED [ 40%]

01:40:06 tests/unit/bundle_test.py::test_set_command_and_args_from_both PASSED    [ 40%]

01:40:06 tests/unit/bundle_test.py::test_make_service_networks_default PASSED     [ 40%]

01:40:06 tests/unit/bundle_test.py::test_make_service_networks PASSED             [ 40%]

01:40:06 tests/unit/bundle_test.py::test_make_port_specs PASSED                   [ 40%]

01:40:06 tests/unit/bundle_test.py::test_make_port_spec_with_protocol PASSED      [ 40%]

01:40:06 tests/unit/bundle_test.py::test_make_port_spec_default_protocol PASSED   [ 40%]

01:40:06 tests/unit/cli_test.py::CLITestCase::test_command_help PASSED            [ 40%]

01:40:06 tests/unit/cli_test.py::CLITestCase::test_command_help_nonexistent PASSED [ 40%]

01:40:06 tests/unit/cli_test.py::CLITestCase::test_command_manual_and_service_ports_together PASSED [ 40%]

01:40:06 tests/unit/cli_test.py::CLITestCase::test_default_project_name PASSED    [ 40%]

01:40:06 tests/unit/cli_test.py::CLITestCase::test_get_project PASSED             [ 41%]

01:40:06 tests/unit/cli_test.py::CLITestCase::test_project_name_from_environment_new_var PASSED [ 41%]

01:40:06 tests/unit/cli_test.py::CLITestCase::test_project_name_with_empty_environment_var PASSED [ 41%]

01:40:06 tests/unit/cli_test.py::CLITestCase::test_project_name_with_environment_file PASSED [ 41%]

01:40:06 tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_base_dir PASSED [ 41%]

01:40:06 tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_project_name PASSED [ 41%]

01:40:06 tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_uppercase_base_dir PASSED [ 41%]

01:40:06 tests/unit/cli_test.py::CLITestCase::test_run_interactive_passes_logs_false PASSED [ 41%]

01:40:07 tests/integration/service_test.py::ServiceTest::test_start_container_creates_links_with_names <- tests/integration/testcases.py PASSED [ 33%]

01:40:07 tests/unit/cli_test.py::CLITestCase::test_run_service_with_restart_always PASSED [ 41%]

01:40:07 tests/unit/container_test.py::ContainerTest::test_environment PASSED     [ 41%]

01:40:07 tests/unit/container_test.py::ContainerTest::test_from_ps PASSED         [ 41%]

01:40:07 tests/unit/container_test.py::ContainerTest::test_from_ps_prefixed PASSED [ 42%]

01:40:07 tests/unit/container_test.py::ContainerTest::test_get PASSED             [ 42%]

01:40:07 tests/unit/container_test.py::ContainerTest::test_get_local_port PASSED  [ 42%]

01:40:07 tests/unit/container_test.py::ContainerTest::test_has_api_logs PASSED    [ 42%]

01:40:07 tests/unit/container_test.py::ContainerTest::test_human_readable_ports_none PASSED [ 42%]

01:40:07 tests/unit/container_test.py::ContainerTest::test_human_readable_ports_public_and_private PASSED [ 42%]

01:40:07 tests/unit/container_test.py::ContainerTest::test_human_readable_states_healthy PASSED [ 42%]

01:40:07 tests/unit/container_test.py::ContainerTest::test_human_readable_states_no_health PASSED [ 42%]

01:40:07 tests/unit/container_test.py::ContainerTest::test_human_readable_states_starting PASSED [ 42%]

01:40:07 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_up PASSED [ 37%]

01:40:07 tests/integration/service_test.py::ServiceTest::test_start_container_creates_port_with_explicit_protocol PASSED [ 33%]

01:40:07 tests/unit/container_test.py::ContainerTest::test_inspect_if_not_inspected PASSED [ 42%]

01:40:07 tests/unit/container_test.py::ContainerTest::test_name PASSED            [ 42%]

01:40:07 tests/unit/container_test.py::ContainerTest::test_name_without_project PASSED [ 42%]

01:40:07 tests/unit/container_test.py::ContainerTest::test_name_without_project_custom_container_name PASSED [ 43%]

01:40:07 tests/unit/container_test.py::ContainerTest::test_name_without_project_one_off PASSED [ 43%]

01:40:07 tests/unit/container_test.py::ContainerTest::test_number PASSED          [ 43%]

01:40:07 tests/unit/container_test.py::ContainerTest::test_short_id PASSED        [ 43%]

01:40:07 tests/unit/container_test.py::GetContainerNameTestCase::test_get_container_name PASSED [ 43%]

01:40:07 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_driver_mismatch PASSED [ 43%]

01:40:07 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_null_remote PASSED [ 43%]

01:40:07 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_null_remote_ipam_options PASSED [ 43%]

01:40:07 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_options_mismatch PASSED [ 43%]

01:40:07 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_success PASSED [ 43%]

01:40:07 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_whitelist PASSED [ 43%]

01:40:07 tests/unit/network_test.py::NetworkTest::test_check_remote_network_labels_mismatch PASSED [ 44%]

01:40:07 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute PASSED  [ 44%]

01:40:07 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_deps PASSED [ 44%]

01:40:07 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_global_limit PASSED [ 44%]

01:40:07 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_limit PASSED [ 44%]

01:40:07 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_upstream_errors PASSED [ 44%]

01:40:07 tests/unit/parallel_test.py::test_parallel_execute_alignment PASSED      [ 44%]

01:40:07 tests/unit/parallel_test.py::test_parallel_execute_ansi PASSED           [ 44%]

01:40:07 tests/unit/parallel_test.py::test_parallel_execute_noansi PASSED         [ 44%]

01:40:07 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_get_digest_from_pull PASSED [ 44%]

01:40:07 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_get_digest_from_push PASSED [ 44%]

01:40:07 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_mismatched_encoding_stream_write PASSED [ 44%]

01:40:07 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output PASSED [ 45%]

01:40:07 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_div_zero PASSED [ 45%]

01:40:07 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_no_progress_event_no_tty PASSED [ 45%]

01:40:07 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_null_total PASSED [ 45%]

01:40:07 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_progress_event_no_tty PASSED [ 45%]

01:40:07 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_progress_event_tty PASSED [ 45%]

01:40:07 tests/unit/project_test.py::ProjectTest::test_avoid_multiple_push PASSED [ 45%]

01:40:07 tests/integration/service_test.py::ServiceTest::test_execute_convergence_plan_without_start PASSED [ 30%]

01:40:07 tests/unit/project_test.py::ProjectTest::test_build_container_operation_with_timeout_func_does_not_mutate_options_with_timeout PASSED [ 45%]

01:40:07 tests/integration/service_test.py::ServiceTest::test_start_container_creates_ports PASSED [ 33%]

01:40:08 tests/integration/service_test.py::ServiceTest::test_expose_does_not_publish_ports PASSED [ 30%]

01:40:08 tests/unit/project_test.py::ProjectTest::test_container_without_name PASSED [ 45%]

01:40:08 tests/unit/project_test.py::ProjectTest::test_down_with_no_resources PASSED [ 45%]

01:40:08 tests/integration/service_test.py::ServiceTest::test_start_container_inherits_options_from_constructor PASSED [ 34%]

01:40:08 tests/integration/service_test.py::ServiceTest::test_group_add_value PASSED [ 30%]

01:40:08 tests/unit/project_test.py::ProjectTest::test_error_parallel_pull PASSED [ 45%]

01:40:08 tests/integration/state_test.py::ServiceStateTest::test_image_changed_to_build PASSED [ 37%]

01:40:08 tests/integration/state_test.py::ServiceStateTest::test_trigger_create PASSED [ 37%]

01:40:08 tests/unit/project_test.py::ProjectTest::test_events PASSED              [ 46%]

01:40:09 tests/integration/service_test.py::ServiceTest::test_start_container_passes_through_options PASSED [ 34%]

01:40:09 tests/unit/project_test.py::ProjectTest::test_events_legacy PASSED       [ 46%]

01:40:09 tests/integration/state_test.py::ServiceStateTest::test_trigger_noop PASSED [ 37%]

01:40:09 tests/unit/project_test.py::ProjectTest::test_from_config_v1 PASSED      [ 46%]

01:40:09 tests/integration/service_test.py::ServiceTest::test_labels PASSED       [ 30%]

01:40:09 tests/integration/service_test.py::ServiceTest::test_start_container_stays_unprivileged PASSED [ 34%]

01:40:09 tests/unit/project_test.py::ProjectTest::test_from_config_v2 PASSED      [ 46%]

01:40:09 tests/unit/project_test.py::ProjectTest::test_get_service PASSED         [ 46%]

01:40:10 tests/integration/service_test.py::ServiceTest::test_log_drive_empty_default_jsonfile PASSED [ 30%]

01:40:10 tests/integration/service_test.py::ServiceTest::test_log_drive_invalid SKIPPED [ 30%]

01:40:10 tests/unit/project_test.py::ProjectTest::test_get_services_removes_duplicates_following_links PASSED [ 46%]

01:40:10 tests/unit/project_test.py::ProjectTest::test_get_services_returns_all_services_without_args PASSED [ 46%]

01:40:10 tests/integration/service_test.py::ServiceTest::test_log_drive_none PASSED [ 31%]

01:40:10 tests/unit/project_test.py::ProjectTest::test_get_services_returns_listed_services_with_args PASSED [ 46%]

01:40:10 tests/unit/project_test.py::ProjectTest::test_get_services_with_include_links PASSED [ 46%]

01:40:11 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_build PASSED [ 37%]

01:40:11 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_config_change PASSED [ 37%]

01:40:11 tests/integration/service_test.py::ServiceTest::test_mem_reservation PASSED [ 31%]

01:40:11 tests/unit/project_test.py::ProjectTest::test_net_unset PASSED           [ 46%]

01:40:11 tests/unit/project_test.py::ProjectTest::test_no_such_service_unicode PASSED [ 46%]

01:40:11 tests/unit/project_test.py::ProjectTest::test_no_warning_in_normal_mode PASSED [ 47%]

01:40:11 tests/integration/service_test.py::ServiceTest::test_mem_swappiness PASSED [ 31%]

01:40:12 tests/unit/project_test.py::ProjectTest::test_no_warning_on_stop PASSED  [ 47%]

01:40:12 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_image_change PASSED [ 37%]

01:40:12 tests/integration/service_test.py::ServiceTest::test_start_container_uses_tagged_image_if_it_exists PASSED [ 34%]

01:40:12 tests/unit/project_test.py::ProjectTest::test_no_warning_with_no_swarm_info PASSED [ 47%]

01:40:12 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_nonexistent_image_tag PASSED [ 38%]

01:40:12 tests/integration/service_test.py::ServiceTest::test_network_mode_bridged PASSED [ 31%]

01:40:12 tests/unit/project_test.py::ProjectTest::test_project_platform_value PASSED [ 47%]

01:40:12 tests/unit/project_test.py::ProjectTest::test_use_net_from_container PASSED [ 47%]

01:40:12 tests/integration/service_test.py::ServiceTest::test_network_mode_host PASSED [ 31%]

01:40:13 tests/unit/project_test.py::ProjectTest::test_use_net_from_service PASSED [ 47%]

01:40:13 tests/integration/state_test.py::ServiceStateTest::test_trigger_start PASSED [ 38%]

01:40:13 tests/integration/volume_test.py::VolumeTest::test_create_volume PASSED  [ 38%]

01:40:13 tests/integration/volume_test.py::VolumeTest::test_create_volume_custom_name PASSED [ 38%]

01:40:13 tests/integration/volume_test.py::VolumeTest::test_exists PASSED         [ 38%]

01:40:13 tests/unit/project_test.py::ProjectTest::test_use_volumes_from_container PASSED [ 47%]

01:40:13 tests/integration/service_test.py::ServiceTest::test_network_mode_none PASSED [ 31%]

01:40:13 tests/integration/volume_test.py::VolumeTest::test_exists_external PASSED [ 38%]

01:40:13 tests/integration/volume_test.py::VolumeTest::test_exists_external_aliased PASSED [ 38%]

01:40:13 tests/integration/volume_test.py::VolumeTest::test_external_aliased_volume PASSED [ 38%]

01:40:13 tests/integration/volume_test.py::VolumeTest::test_external_volume PASSED [ 38%]

01:40:13 tests/integration/volume_test.py::VolumeTest::test_inspect_volume PASSED [ 38%]

01:40:13 tests/integration/volume_test.py::VolumeTest::test_recreate_existing_volume PASSED [ 38%]

01:40:13 tests/integration/volume_test.py::VolumeTest::test_remove_volume PASSED  [ 39%]

01:40:13 tests/integration/volume_test.py::VolumeTest::test_volume_default_labels PASSED [ 39%]

01:40:13 tests/unit/project_test.py::ProjectTest::test_use_volumes_from_service_container PASSED [ 47%]

01:40:13 tests/unit/bundle_test.py::test_get_image_digest_exists PASSED           [ 39%]

01:40:13 tests/unit/project_test.py::ProjectTest::test_use_volumes_from_service_no_container PASSED [ 47%]

01:40:14 tests/unit/bundle_test.py::test_get_image_digest_image_uses_digest PASSED [ 39%]

01:40:14 tests/integration/service_test.py::ServiceTest::test_start_container_with_external_links <- tests/integration/testcases.py PASSED [ 34%]

01:40:14 tests/integration/service_test.py::ServiceTest::test_oom_score_adj_value PASSED [ 31%]

01:40:14 tests/unit/project_test.py::ProjectTest::test_uses_default_network_false PASSED [ 47%]

01:40:14 tests/unit/project_test.py::ProjectTest::test_uses_default_network_true PASSED [ 47%]

01:40:14 tests/unit/bundle_test.py::test_get_image_digest_from_repository PASSED  [ 39%]

01:40:14 tests/unit/bundle_test.py::test_get_image_digest_no_image PASSED         [ 39%]

01:40:14 tests/unit/bundle_test.py::test_push_image_with_saved_digest PASSED      [ 39%]

01:40:14 tests/integration/service_test.py::ServiceTest::test_pid_mode_host PASSED [ 31%]

01:40:14 tests/unit/service_test.py::ServiceTest::test_build_does_not_pull PASSED [ 47%]

01:40:14 tests/unit/service_test.py::ServiceTest::test_build_isolation_from_build_override_service_config PASSED [ 48%]

01:40:14 tests/unit/bundle_test.py::test_push_image PASSED                        [ 39%]

01:40:14 tests/unit/bundle_test.py::test_to_bundle PASSED                         [ 39%]

01:40:14 tests/unit/bundle_test.py::test_convert_service_to_bundle PASSED         [ 39%]

01:40:14 tests/unit/bundle_test.py::test_set_command_and_args_none PASSED         [ 39%]

01:40:14 tests/unit/bundle_test.py::test_set_command_and_args_from_command PASSED [ 39%]

01:40:14 tests/unit/bundle_test.py::test_set_command_and_args_from_entrypoint PASSED [ 40%]

01:40:14 tests/unit/bundle_test.py::test_set_command_and_args_from_both PASSED    [ 40%]

01:40:14 tests/unit/bundle_test.py::test_make_service_networks_default PASSED     [ 40%]

01:40:14 tests/unit/bundle_test.py::test_make_service_networks PASSED             [ 40%]

01:40:14 tests/unit/bundle_test.py::test_make_port_specs PASSED                   [ 40%]

01:40:14 tests/unit/bundle_test.py::test_make_port_spec_with_protocol PASSED      [ 40%]

01:40:14 tests/unit/bundle_test.py::test_make_port_spec_default_protocol PASSED   [ 40%]

01:40:14 tests/unit/cli_test.py::CLITestCase::test_command_help PASSED            [ 40%]

01:40:14 tests/unit/cli_test.py::CLITestCase::test_command_help_nonexistent PASSED [ 40%]

01:40:14 tests/unit/cli_test.py::CLITestCase::test_command_manual_and_service_ports_together PASSED [ 40%]

01:40:14 tests/unit/cli_test.py::CLITestCase::test_default_project_name PASSED    [ 40%]

01:40:14 tests/unit/cli_test.py::CLITestCase::test_get_project PASSED             [ 41%]

01:40:14 tests/unit/cli_test.py::CLITestCase::test_project_name_from_environment_new_var PASSED [ 41%]

01:40:14 tests/unit/cli_test.py::CLITestCase::test_project_name_with_empty_environment_var PASSED [ 41%]

01:40:14 tests/unit/cli_test.py::CLITestCase::test_project_name_with_environment_file PASSED [ 41%]

01:40:14 tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_base_dir PASSED [ 41%]

01:40:14 tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_project_name PASSED [ 41%]

01:40:14 tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_uppercase_base_dir PASSED [ 41%]

01:40:14 tests/unit/service_test.py::ServiceTest::test_build_service_with_proxy_config PASSED [ 48%]

01:40:15 tests/unit/cli_test.py::CLITestCase::test_run_interactive_passes_logs_false PASSED [ 41%]

01:40:15 tests/unit/service_test.py::ServiceTest::test_build_volume_options_duplicate_binds PASSED [ 48%]

01:40:15 tests/integration/service_test.py::ServiceTest::test_pid_mode_none_defined PASSED [ 31%]

01:40:15 tests/unit/cli_test.py::CLITestCase::test_run_service_with_restart_always PASSED [ 41%]

01:40:15 tests/unit/container_test.py::ContainerTest::test_environment PASSED     [ 41%]

01:40:15 tests/unit/container_test.py::ContainerTest::test_from_ps PASSED         [ 41%]

01:40:15 tests/unit/container_test.py::ContainerTest::test_from_ps_prefixed PASSED [ 42%]

01:40:15 tests/unit/container_test.py::ContainerTest::test_get PASSED             [ 42%]

01:40:15 tests/unit/container_test.py::ContainerTest::test_get_local_port PASSED  [ 42%]

01:40:15 tests/unit/container_test.py::ContainerTest::test_has_api_logs PASSED    [ 42%]

01:40:15 tests/unit/container_test.py::ContainerTest::test_human_readable_ports_none PASSED [ 42%]

01:40:15 tests/unit/container_test.py::ContainerTest::test_human_readable_ports_public_and_private PASSED [ 42%]

01:40:15 tests/unit/container_test.py::ContainerTest::test_human_readable_states_healthy PASSED [ 42%]

01:40:15 tests/unit/container_test.py::ContainerTest::test_human_readable_states_no_health PASSED [ 42%]

01:40:15 tests/unit/container_test.py::ContainerTest::test_human_readable_states_starting PASSED [ 42%]

01:40:15 tests/unit/container_test.py::ContainerTest::test_inspect_if_not_inspected PASSED [ 42%]

01:40:15 tests/unit/container_test.py::ContainerTest::test_name PASSED            [ 42%]

01:40:15 tests/unit/container_test.py::ContainerTest::test_name_without_project PASSED [ 42%]

01:40:15 tests/unit/container_test.py::ContainerTest::test_name_without_project_custom_container_name PASSED [ 43%]

01:40:15 tests/unit/container_test.py::ContainerTest::test_name_without_project_one_off PASSED [ 43%]

01:40:15 tests/unit/container_test.py::ContainerTest::test_number PASSED          [ 43%]

01:40:15 tests/unit/container_test.py::ContainerTest::test_short_id PASSED        [ 43%]

01:40:15 tests/unit/container_test.py::GetContainerNameTestCase::test_get_container_name PASSED [ 43%]

01:40:15 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_driver_mismatch PASSED [ 43%]

01:40:15 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_null_remote PASSED [ 43%]

01:40:15 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_null_remote_ipam_options PASSED [ 43%]

01:40:15 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_options_mismatch PASSED [ 43%]

01:40:15 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_success PASSED [ 43%]

01:40:15 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_whitelist PASSED [ 43%]

01:40:15 tests/unit/network_test.py::NetworkTest::test_check_remote_network_labels_mismatch PASSED [ 44%]

01:40:15 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute PASSED  [ 44%]

01:40:15 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_deps PASSED [ 44%]

01:40:15 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_global_limit PASSED [ 44%]

01:40:15 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_limit PASSED [ 44%]

01:40:15 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_upstream_errors PASSED [ 44%]

01:40:15 tests/unit/parallel_test.py::test_parallel_execute_alignment PASSED      [ 44%]

01:40:15 tests/unit/parallel_test.py::test_parallel_execute_ansi PASSED           [ 44%]

01:40:15 tests/unit/parallel_test.py::test_parallel_execute_noansi PASSED         [ 44%]

01:40:15 tests/integration/service_test.py::ServiceTest::test_start_normal_container_does_not_create_links_to_its_own_service <- tests/integration/testcases.py PASSED [ 34%]

01:40:15 tests/unit/service_test.py::ServiceTest::test_build_with_default_platform PASSED [ 48%]

01:40:15 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_get_digest_from_pull PASSED [ 44%]

01:40:15 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_get_digest_from_push PASSED [ 44%]

01:40:15 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_mismatched_encoding_stream_write PASSED [ 44%]

01:40:15 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output PASSED [ 45%]

01:40:15 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_div_zero PASSED [ 45%]

01:40:15 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_no_progress_event_no_tty PASSED [ 45%]

01:40:15 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_null_total PASSED [ 45%]

01:40:15 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_progress_event_no_tty PASSED [ 45%]

01:40:15 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_progress_event_tty PASSED [ 45%]

01:40:15 tests/unit/project_test.py::ProjectTest::test_avoid_multiple_push PASSED [ 45%]

01:40:15 tests/unit/service_test.py::ServiceTest::test_build_with_isolation_from_service_config PASSED [ 48%]

01:40:15 tests/integration/service_test.py::ServiceTest::test_port_with_explicit_interface PASSED [ 31%]

01:40:15 tests/unit/project_test.py::ProjectTest::test_build_container_operation_with_timeout_func_does_not_mutate_options_with_timeout PASSED [ 45%]

01:40:15 tests/unit/service_test.py::ServiceTest::test_build_with_override_build_args PASSED [ 48%]

01:40:16 tests/unit/project_test.py::ProjectTest::test_container_without_name PASSED [ 45%]

01:40:16 tests/unit/project_test.py::ProjectTest::test_down_with_no_resources PASSED [ 45%]

01:40:16 tests/unit/service_test.py::ServiceTest::test_build_with_platform PASSED [ 48%]

01:40:16 tests/unit/project_test.py::ProjectTest::test_error_parallel_pull PASSED [ 45%]

01:40:16 tests/unit/service_test.py::ServiceTest::test_cgroup_parent PASSED       [ 48%]

01:40:16 tests/unit/project_test.py::ProjectTest::test_events PASSED              [ 46%]

01:40:16 tests/unit/project_test.py::ProjectTest::test_events_legacy PASSED       [ 46%]

01:40:16 tests/integration/service_test.py::ServiceTest::test_project_is_added_to_container_name PASSED [ 31%]

01:40:16 tests/unit/service_test.py::ServiceTest::test_config_dict PASSED         [ 48%]

01:40:16 tests/integration/service_test.py::ServiceTest::test_start_one_off_container_creates_links_to_its_own_service <- tests/integration/testcases.py PASSED [ 34%]

01:40:16 tests/unit/project_test.py::ProjectTest::test_from_config_v1 PASSED      [ 46%]

01:40:16 tests/unit/service_test.py::ServiceTest::test_config_dict_with_network_mode_from_container PASSED [ 48%]

01:40:17 tests/unit/project_test.py::ProjectTest::test_from_config_v2 PASSED      [ 46%]

01:40:17 tests/unit/project_test.py::ProjectTest::test_get_service PASSED         [ 46%]

01:40:17 tests/unit/service_test.py::ServiceTest::test_config_hash_matches_label PASSED [ 48%]

01:40:17 tests/integration/service_test.py::ServiceTest::test_stop_signal PASSED  [ 34%]

01:40:17 tests/unit/project_test.py::ProjectTest::test_get_services_removes_duplicates_following_links PASSED [ 46%]

01:40:17 tests/unit/service_test.py::ServiceTest::test_container_without_name PASSED [ 49%]

01:40:17 tests/integration/service_test.py::ServiceTest::test_recreate_preserves_volume_with_trailing_slash PASSED [ 31%]

01:40:17 tests/unit/project_test.py::ProjectTest::test_get_services_returns_all_services_without_args PASSED [ 46%]

01:40:17 tests/unit/project_test.py::ProjectTest::test_get_services_returns_listed_services_with_args PASSED [ 46%]

01:40:17 tests/unit/service_test.py::ServiceTest::test_containers PASSED          [ 49%]

01:40:17 tests/integration/service_test.py::ServiceTest::test_tmpfs PASSED        [ 34%]

01:40:17 tests/unit/project_test.py::ProjectTest::test_get_services_with_include_links PASSED [ 46%]

01:40:17 tests/unit/project_test.py::ProjectTest::test_net_unset PASSED           [ 46%]

01:40:18 tests/unit/service_test.py::ServiceTest::test_containers_with_containers PASSED [ 49%]

01:40:18 tests/unit/project_test.py::ProjectTest::test_no_such_service_unicode PASSED [ 46%]

01:40:18 tests/unit/service_test.py::ServiceTest::test_create_container PASSED    [ 49%]

01:40:18 tests/unit/project_test.py::ProjectTest::test_no_warning_in_normal_mode PASSED [ 47%]

01:40:18 tests/integration/service_test.py::ServiceTest::test_userns_mode_host PASSED [ 34%]

01:40:18 tests/unit/service_test.py::ServiceTest::test_create_when_removed_containers_are_listed PASSED [ 49%]

01:40:18 tests/unit/project_test.py::ProjectTest::test_no_warning_on_stop PASSED  [ 47%]

01:40:18 tests/unit/project_test.py::ProjectTest::test_no_warning_with_no_swarm_info PASSED [ 47%]

01:40:18 tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_force_build PASSED [ 49%]

01:40:18 tests/unit/project_test.py::ProjectTest::test_project_platform_value PASSED [ 47%]

01:40:18 tests/unit/project_test.py::ProjectTest::test_use_net_from_container PASSED [ 47%]

01:40:19 tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_no_build PASSED [ 49%]

01:40:19 tests/integration/service_test.py::ServiceTest::test_userns_mode_none_defined PASSED [ 34%]

01:40:19 tests/integration/service_test.py::ServiceTest::test_with_high_enough_api_version_we_get_default_network_mode PASSED [ 34%]

01:40:19 tests/integration/service_test.py::ServiceTest::test_working_dir_param PASSED [ 35%]

01:40:19 tests/unit/project_test.py::ProjectTest::test_use_net_from_service PASSED [ 47%]

01:40:19 tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_no_build_but_needs_build PASSED [ 49%]

01:40:19 tests/unit/project_test.py::ProjectTest::test_use_volumes_from_container PASSED [ 47%]

01:40:19 tests/unit/project_test.py::ProjectTest::test_use_volumes_from_service_container PASSED [ 47%]

01:40:19 tests/unit/service_test.py::ServiceTest::test_get_container PASSED       [ 49%]

01:40:19 tests/unit/project_test.py::ProjectTest::test_use_volumes_from_service_no_container PASSED [ 47%]

01:40:19 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_does_not_mutate_options PASSED [ 49%]

01:40:19 tests/unit/project_test.py::ProjectTest::test_uses_default_network_false PASSED [ 47%]

01:40:19 tests/unit/project_test.py::ProjectTest::test_uses_default_network_true PASSED [ 47%]

01:40:20 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_no_affinity_without_binds PASSED [ 49%]

01:40:20 tests/unit/service_test.py::ServiceTest::test_build_does_not_pull PASSED [ 47%]

01:40:20 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_sets_affinity_with_binds PASSED [ 50%]

01:40:20 tests/integration/service_test.py::ConfigHashTest::test_config_hash_sticks_around PASSED [ 35%]

01:40:20 tests/unit/service_test.py::ServiceTest::test_build_isolation_from_build_override_service_config PASSED [ 48%]

01:40:20 tests/unit/service_test.py::ServiceTest::test_build_service_with_proxy_config PASSED [ 48%]

01:40:20 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_with_name_option PASSED [ 50%]

01:40:20 tests/integration/service_test.py::ConfigHashTest::test_config_hash_with_custom_labels PASSED [ 35%]

01:40:20 tests/integration/service_test.py::ConfigHashTest::test_no_config_hash_when_one_off PASSED [ 35%]

01:40:20 tests/unit/service_test.py::ServiceTest::test_build_volume_options_duplicate_binds PASSED [ 48%]

01:40:20 tests/unit/service_test.py::ServiceTest::test_get_container_not_found PASSED [ 50%]

01:40:21 tests/integration/service_test.py::ConfigHashTest::test_no_config_hash_when_overriding_options PASSED [ 35%]

01:40:21 tests/unit/service_test.py::ServiceTest::test_build_with_default_platform PASSED [ 48%]

01:40:21 tests/unit/service_test.py::ServiceTest::test_build_with_isolation_from_service_config PASSED [ 48%]

01:40:21 tests/unit/service_test.py::ServiceTest::test_get_create_options_with_proxy_config PASSED [ 50%]

01:40:21 tests/unit/service_test.py::ServiceTest::test_build_with_override_build_args PASSED [ 48%]

01:40:21 tests/unit/service_test.py::ServiceTest::test_build_with_platform PASSED [ 48%]

01:40:21 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_container PASSED [ 50%]

01:40:21 tests/unit/service_test.py::ServiceTest::test_cgroup_parent PASSED       [ 48%]

01:40:21 tests/unit/service_test.py::ServiceTest::test_config_dict PASSED         [ 48%]

01:40:21 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_container_read_only PASSED [ 50%]

01:40:21 tests/integration/service_test.py::ServiceTest::test_recreate_volume_to_mount PASSED [ 32%]

01:40:21 tests/unit/service_test.py::ServiceTest::test_config_dict_with_network_mode_from_container PASSED [ 48%]

01:40:21 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_container_exists PASSED [ 50%]

01:40:22 tests/integration/service_test.py::ServiceTest::test_resolve_env PASSED  [ 32%]

01:40:22 tests/unit/service_test.py::ServiceTest::test_config_hash_matches_label PASSED [ 48%]

01:40:22 tests/unit/service_test.py::ServiceTest::test_container_without_name PASSED [ 49%]

01:40:22 tests/unit/service_test.py::ServiceTest::test_containers PASSED          [ 49%]

01:40:22 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_container_exists_with_flags PASSED [ 50%]

01:40:22 tests/integration/state_test.py::BasicProjectTest::test_all_change PASSED [ 35%]

01:40:22 tests/integration/service_test.py::ServiceTest::test_restart_always_value PASSED [ 32%]

01:40:22 tests/unit/service_test.py::ServiceTest::test_containers_with_containers PASSED [ 49%]

01:40:22 tests/unit/service_test.py::ServiceTest::test_create_container PASSED    [ 49%]

01:40:22 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_no_container PASSED [ 50%]

01:40:22 tests/unit/service_test.py::ServiceTest::test_create_when_removed_containers_are_listed PASSED [ 49%]

01:40:22 tests/unit/service_test.py::ServiceTest::test_image_name_default PASSED  [ 50%]

01:40:23 tests/integration/service_test.py::ServiceTest::test_restart_on_failure_value PASSED [ 32%]

01:40:23 tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_force_build PASSED [ 49%]

01:40:23 tests/unit/service_test.py::ServiceTest::test_image_name_from_config PASSED [ 50%]

01:40:23 tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_no_build PASSED [ 49%]

01:40:23 tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_no_build_but_needs_build PASSED [ 49%]

01:40:23 tests/unit/service_test.py::ServiceTest::test_log_opt PASSED             [ 50%]

01:40:23 tests/unit/service_test.py::ServiceTest::test_get_container PASSED       [ 49%]

01:40:23 tests/unit/service_test.py::ServiceTest::test_mem_reservation PASSED     [ 51%]

01:40:23 tests/integration/state_test.py::BasicProjectTest::test_no_change PASSED [ 35%]

01:40:23 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_does_not_mutate_options PASSED [ 49%]

01:40:23 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_no_affinity_without_binds PASSED [ 49%]

01:40:24 tests/unit/service_test.py::ServiceTest::test_memory_swap_limit PASSED   [ 51%]

01:40:24 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_sets_affinity_with_binds PASSED [ 50%]

01:40:24 tests/unit/service_test.py::ServiceTest::test_no_default_hostname_when_not_using_networking PASSED [ 51%]

01:40:24 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_with_name_option PASSED [ 50%]

01:40:24 tests/unit/service_test.py::ServiceTest::test_get_container_not_found PASSED [ 50%]

01:40:24 tests/unit/service_test.py::ServiceTest::test_only_log_warning_when_host_ports_clash PASSED [ 51%]

01:40:24 tests/unit/service_test.py::ServiceTest::test_get_create_options_with_proxy_config PASSED [ 50%]

01:40:24 tests/unit/service_test.py::ServiceTest::test_parse_proxy_config PASSED  [ 51%]

01:40:24 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_container PASSED [ 50%]

01:40:24 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_container_read_only PASSED [ 50%]

01:40:25 tests/unit/service_test.py::ServiceTest::test_parse_proxy_config_per_host PASSED [ 51%]

01:40:25 tests/integration/service_test.py::ServiceTest::test_scale PASSED        [ 32%]

01:40:25 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_container_exists PASSED [ 50%]

01:40:25 tests/integration/state_test.py::BasicProjectTest::test_partial_change PASSED [ 35%]

01:40:25 tests/unit/service_test.py::ServiceTest::test_parse_repository_tag PASSED [ 51%]

01:40:25 tests/unit/service_test.py::ServiceTest::test_pull_image PASSED          [ 51%]

01:40:25 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_container_exists_with_flags PASSED [ 50%]

01:40:25 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_no_container PASSED [ 50%]

01:40:25 tests/unit/service_test.py::ServiceTest::test_pull_image_digest PASSED   [ 51%]

01:40:25 tests/integration/service_test.py::ServiceTest::test_scale_sets_ports PASSED [ 32%]

01:40:26 tests/unit/service_test.py::ServiceTest::test_image_name_default PASSED  [ 50%]

01:40:26 tests/unit/service_test.py::ServiceTest::test_pull_image_no_tag PASSED   [ 51%]

01:40:26 tests/unit/service_test.py::ServiceTest::test_image_name_from_config PASSED [ 50%]

01:40:26 tests/unit/service_test.py::ServiceTest::test_log_opt PASSED             [ 50%]

01:40:26 tests/unit/service_test.py::ServiceTest::test_pull_image_with_default_platform PASSED [ 51%]

01:40:26 tests/unit/service_test.py::ServiceTest::test_mem_reservation PASSED     [ 51%]

01:40:26 tests/integration/service_test.py::ServiceTest::test_scale_with_api_error PASSED [ 32%]

01:40:26 tests/unit/service_test.py::ServiceTest::test_pull_image_with_platform PASSED [ 52%]

01:40:26 tests/unit/service_test.py::ServiceTest::test_memory_swap_limit PASSED   [ 51%]

01:40:26 tests/unit/service_test.py::ServiceTest::test_no_default_hostname_when_not_using_networking PASSED [ 51%]

01:40:26 tests/unit/service_test.py::ServiceTest::test_pull_image_with_platform_unsupported_api PASSED [ 52%]

01:40:27 tests/unit/service_test.py::ServiceTest::test_only_log_warning_when_host_ports_clash PASSED [ 51%]

01:40:27 tests/unit/service_test.py::ServiceTest::test_recreate_container PASSED  [ 52%]

01:40:27 tests/integration/service_test.py::ServiceTest::test_scale_with_custom_container_name_outputs_warning PASSED [ 32%]

01:40:27 tests/unit/service_test.py::ServiceTest::test_parse_proxy_config PASSED  [ 51%]

01:40:27 tests/unit/service_test.py::ServiceTest::test_parse_proxy_config_per_host PASSED [ 51%]

01:40:27 tests/unit/service_test.py::ServiceTest::test_parse_repository_tag PASSED [ 51%]

01:40:27 tests/unit/service_test.py::ServiceTest::test_recreate_container_with_timeout PASSED [ 52%]

01:40:27 tests/unit/service_test.py::ServiceTest::test_remove_image_all_does_remove PASSED [ 52%]

01:40:27 tests/integration/service_test.py::ServiceTest::test_scale_with_desired_number_already_achieved PASSED [ 32%]

01:40:27 tests/unit/service_test.py::ServiceTest::test_pull_image PASSED          [ 51%]

01:40:27 tests/unit/service_test.py::ServiceTest::test_pull_image_digest PASSED   [ 51%]

01:40:27 tests/unit/service_test.py::ServiceTest::test_remove_image_local_with_image_name_doesnt_remove PASSED [ 52%]

01:40:28 tests/unit/service_test.py::ServiceTest::test_pull_image_no_tag PASSED   [ 51%]

01:40:28 tests/unit/service_test.py::ServiceTest::test_remove_image_local_without_image_name_does_remove PASSED [ 52%]

01:40:28 tests/unit/service_test.py::ServiceTest::test_pull_image_with_default_platform PASSED [ 51%]

01:40:28 tests/unit/service_test.py::ServiceTest::test_pull_image_with_platform PASSED [ 52%]

01:40:28 tests/unit/service_test.py::ServiceTest::test_remove_image_none PASSED   [ 52%]

01:40:28 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_leaf PASSED [ 35%]

01:40:28 tests/unit/service_test.py::ServiceTest::test_pull_image_with_platform_unsupported_api PASSED [ 52%]

01:40:28 tests/integration/service_test.py::ServiceTest::test_scale_with_immediate_exit PASSED [ 32%]

01:40:28 tests/unit/service_test.py::ServiceTest::test_remove_image_with_error PASSED [ 52%]

01:40:28 tests/unit/service_test.py::ServiceTest::test_recreate_container PASSED  [ 52%]

01:40:28 tests/unit/service_test.py::ServiceTest::test_remove_non_existing_image PASSED [ 52%]

01:40:29 tests/unit/service_test.py::ServiceTest::test_recreate_container_with_timeout PASSED [ 52%]

01:40:29 tests/unit/service_test.py::ServiceTest::test_remove_image_all_does_remove PASSED [ 52%]

01:40:29 tests/unit/service_test.py::ServiceTest::test_self_reference_external_link PASSED [ 52%]

01:40:29 tests/unit/service_test.py::ServiceTest::test_remove_image_local_with_image_name_doesnt_remove PASSED [ 52%]

01:40:29 tests/unit/service_test.py::ServiceTest::test_service_ignore_default_platform_with_unsupported_api PASSED [ 52%]

01:40:29 tests/unit/service_test.py::ServiceTest::test_remove_image_local_without_image_name_does_remove PASSED [ 52%]

01:40:29 tests/unit/service_test.py::ServiceTest::test_remove_image_none PASSED   [ 52%]

01:40:29 tests/unit/service_test.py::ServiceTest::test_service_platform_precedence PASSED [ 53%]

01:40:29 tests/unit/service_test.py::ServiceTest::test_remove_image_with_error PASSED [ 52%]

01:40:29 tests/integration/service_test.py::ServiceTest::test_scale_with_stopped_containers PASSED [ 32%]

01:40:29 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_container_port PASSED [ 53%]

01:40:30 tests/unit/service_test.py::ServiceTest::test_remove_non_existing_image PASSED [ 52%]

01:40:30 tests/unit/service_test.py::ServiceTest::test_self_reference_external_link PASSED [ 52%]

01:40:30 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_container_port_range PASSED [ 53%]

01:40:30 tests/unit/service_test.py::ServiceTest::test_service_ignore_default_platform_with_unsupported_api PASSED [ 52%]

01:40:30 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_and_port PASSED [ 53%]

01:40:30 tests/unit/service_test.py::ServiceTest::test_service_platform_precedence PASSED [ 53%]

01:40:30 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_container_port PASSED [ 53%]

01:40:30 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_and_port_range PASSED [ 53%]

01:40:30 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_container_port_range PASSED [ 53%]

01:40:31 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_no_port PASSED [ 53%]

01:40:31 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_and_port PASSED [ 53%]

01:40:31 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_and_port_range PASSED [ 53%]

01:40:31 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_no_port_range PASSED [ 53%]

01:40:31 tests/integration/service_test.py::ServiceTest::test_scale_with_stopped_containers_and_needing_creation PASSED [ 33%]

01:40:31 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_no_port PASSED [ 53%]

01:40:31 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_port PASSED [ 53%]

01:40:31 tests/integration/service_test.py::ServiceTest::test_scale_with_unexpected_exception PASSED [ 33%]

01:40:31 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_no_port_range PASSED [ 53%]

01:40:31 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_port PASSED [ 53%]

01:40:31 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_middle PASSED [ 35%]

01:40:31 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_port_range PASSED [ 53%]

01:40:31 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_port_range PASSED [ 53%]

01:40:32 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_no_ports PASSED [ 53%]

01:40:32 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_no_ports PASSED [ 53%]

01:40:32 tests/unit/service_test.py::ServiceTest::test_split_domainname_both PASSED [ 53%]

01:40:32 tests/unit/service_test.py::ServiceTest::test_split_domainname_both PASSED [ 53%]

01:40:32 tests/unit/service_test.py::ServiceTest::test_split_domainname_fqdn PASSED [ 54%]

01:40:32 tests/integration/service_test.py::ServiceTest::test_split_env PASSED    [ 33%]

01:40:32 tests/unit/service_test.py::ServiceTest::test_split_domainname_fqdn PASSED [ 54%]

01:40:32 tests/unit/service_test.py::ServiceTest::test_split_domainname_none PASSED [ 54%]

01:40:32 tests/unit/service_test.py::ServiceTest::test_split_domainname_weird PASSED [ 54%]

01:40:32 tests/unit/service_test.py::ServiceTest::test_split_domainname_none PASSED [ 54%]

01:40:32 tests/unit/service_test.py::ServiceTest::test_stop_grace_period PASSED   [ 54%]

01:40:33 tests/integration/service_test.py::ServiceTest::test_start_container_becomes_privileged PASSED [ 33%]

01:40:33 tests/unit/service_test.py::ServiceTest::test_split_domainname_weird PASSED [ 54%]

01:40:33 tests/unit/service_test.py::ServiceTest::test_volumes_order_is_preserved PASSED [ 54%]

01:40:33 tests/unit/service_test.py::TestServiceNetwork::test_connect_container_to_networks_short_aliase_exists PASSED [ 54%]

01:40:33 tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_dict PASSED [ 54%]

01:40:33 tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_integers_and_dicts PASSED [ 54%]

01:40:33 tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_ints PASSED [ 54%]

01:40:33 tests/unit/service_test.py::ServiceTest::test_stop_grace_period PASSED   [ 54%]

01:40:33 tests/unit/service_test.py::NetTestCase::test_network_mode PASSED        [ 54%]

01:40:33 tests/unit/service_test.py::NetTestCase::test_network_mode_container PASSED [ 54%]

01:40:33 tests/unit/service_test.py::ServiceTest::test_volumes_order_is_preserved PASSED [ 54%]

01:40:33 tests/unit/service_test.py::NetTestCase::test_network_mode_service PASSED [ 55%]

01:40:33 tests/unit/service_test.py::TestServiceNetwork::test_connect_container_to_networks_short_aliase_exists PASSED [ 54%]

01:40:33 tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_dict PASSED [ 54%]

01:40:33 tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_integers_and_dicts PASSED [ 54%]

01:40:33 tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_ints PASSED [ 54%]

01:40:33 tests/unit/service_test.py::NetTestCase::test_network_mode_service_no_containers PASSED [ 55%]

01:40:33 tests/unit/service_test.py::ServicePortsTest::test_formatted_ports PASSED [ 55%]

01:40:33 tests/unit/service_test.py::ServiceVolumesTest::test_build_volume_binding PASSED [ 55%]

01:40:34 tests/unit/service_test.py::NetTestCase::test_network_mode PASSED        [ 54%]

01:40:34 tests/unit/service_test.py::ServiceVolumesTest::test_create_with_special_volume_mode PASSED [ 55%]

01:40:34 tests/unit/service_test.py::NetTestCase::test_network_mode_container PASSED [ 54%]

01:40:34 tests/unit/service_test.py::ServiceVolumesTest::test_get_container_create_options_with_different_host_path_in_container_json PASSED [ 55%]

01:40:34 tests/unit/service_test.py::ServiceVolumesTest::test_get_container_data_volumes PASSED [ 55%]

01:40:34 tests/unit/service_test.py::NetTestCase::test_network_mode_service PASSED [ 55%]

01:40:34 tests/unit/service_test.py::ServiceVolumesTest::test_merge_volume_bindings PASSED [ 55%]

01:40:34 tests/unit/service_test.py::NetTestCase::test_network_mode_service_no_containers PASSED [ 55%]

01:40:34 tests/unit/service_test.py::ServicePortsTest::test_formatted_ports PASSED [ 55%]

01:40:34 tests/integration/service_test.py::ServiceTest::test_start_container_builds_images PASSED [ 33%]

01:40:34 tests/unit/service_test.py::ServiceVolumesTest::test_mount_same_host_path_to_two_volumes PASSED [ 55%]

01:40:34 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_no_warning_with_container_only_option PASSED [ 55%]

01:40:35 tests/unit/service_test.py::ServiceVolumesTest::test_build_volume_binding PASSED [ 55%]

01:40:35 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_no_warning_with_same_path PASSED [ 55%]

01:40:35 tests/unit/service_test.py::ServiceVolumesTest::test_create_with_special_volume_mode PASSED [ 55%]

01:40:35 tests/unit/service_test.py::ServiceVolumesTest::test_get_container_create_options_with_different_host_path_in_container_json PASSED [ 55%]

01:40:35 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_volume_no_warning_when_no_container_volumes PASSED [ 55%]

01:40:35 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_volume_when_masked PASSED [ 56%]

01:40:35 tests/integration/service_test.py::ServiceTest::test_start_container_creates_fixed_external_ports PASSED [ 33%]

01:40:35 tests/unit/service_test.py::ServiceVolumesTest::test_get_container_data_volumes PASSED [ 55%]

01:40:35 tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes PASSED [ 56%]

01:40:35 tests/unit/service_test.py::ServiceVolumesTest::test_merge_volume_bindings PASSED [ 55%]

01:40:35 tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes_abspath PASSED [ 56%]

01:40:35 tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes_no_target PASSED [ 56%]

01:40:35 tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_unix_path PASSED [ 56%]

01:40:35 tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_url_no_prefix PASSED [ 56%]

01:40:35 tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_windows_path PASSED [ 56%]

01:40:35 tests/unit/split_buffer_test.py::SplitBufferTest::test_chunked_line PASSED [ 56%]

01:40:35 tests/unit/split_buffer_test.py::SplitBufferTest::test_multiple_line_chunk PASSED [ 56%]

01:40:36 tests/integration/service_test.py::ServiceTest::test_start_container_creates_fixed_external_ports_when_it_is_different_to_internal_port PASSED [ 33%]

01:40:36 tests/unit/service_test.py::ServiceVolumesTest::test_mount_same_host_path_to_two_volumes PASSED [ 55%]

01:40:36 tests/unit/split_buffer_test.py::SplitBufferTest::test_no_end_separator PASSED [ 56%]

01:40:36 tests/unit/split_buffer_test.py::SplitBufferTest::test_preserves_unicode_sequences_within_lines PASSED [ 56%]

01:40:36 tests/unit/split_buffer_test.py::SplitBufferTest::test_single_line_chunks PASSED [ 57%]

01:40:36 tests/unit/timeparse_test.py::test_milli PASSED                          [ 57%]

01:40:36 tests/unit/timeparse_test.py::test_milli_float PASSED                    [ 57%]

01:40:36 tests/unit/timeparse_test.py::test_second_milli PASSED                   [ 57%]

01:40:36 tests/unit/timeparse_test.py::test_second_milli_micro PASSED             [ 57%]

01:40:36 tests/unit/timeparse_test.py::test_second PASSED                         [ 57%]

01:40:36 tests/unit/timeparse_test.py::test_second_as_float PASSED                [ 57%]

01:40:36 tests/unit/timeparse_test.py::test_minute PASSED                         [ 57%]

01:40:36 tests/unit/timeparse_test.py::test_hour_minute PASSED                    [ 57%]

01:40:36 tests/unit/timeparse_test.py::test_minute_as_float PASSED                [ 57%]

01:40:36 tests/unit/timeparse_test.py::test_hour_minute_second PASSED             [ 57%]

01:40:36 tests/unit/timeparse_test.py::test_invalid_with_space PASSED             [ 57%]

01:40:36 tests/unit/timeparse_test.py::test_invalid_with_comma PASSED             [ 58%]

01:40:36 tests/unit/timeparse_test.py::test_invalid_with_empty_string PASSED      [ 58%]

01:40:36 tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_no_object PASSED [ 58%]

01:40:36 tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_with_object PASSED [ 58%]

01:40:36 tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_leading_whitespace PASSED [ 58%]

01:40:36 tests/unit/utils_test.py::TestStreamAsText::test_stream_with_non_utf_unicode_character PASSED [ 58%]

01:40:36 tests/unit/utils_test.py::TestStreamAsText::test_stream_with_utf_character PASSED [ 58%]

01:40:36 tests/unit/utils_test.py::TestJsonStream::test_with_falsy_entries PASSED [ 58%]

01:40:36 tests/unit/utils_test.py::TestJsonStream::test_with_leading_whitespace PASSED [ 58%]

01:40:36 tests/unit/utils_test.py::TestParseBytes::test_parse_bytes PASSED        [ 58%]

01:40:36 tests/unit/utils_test.py::TestMoreItertools::test_unique_everseen PASSED [ 58%]

01:40:36 tests/unit/volume_test.py::TestVolume::test_remove_local_volume PASSED   [ 59%]

01:40:36 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_no_warning_with_container_only_option PASSED [ 55%]

01:40:36 tests/unit/volume_test.py::TestVolume::test_remove_external_volume PASSED [ 59%]

01:40:36 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_path_from_options PASSED [ 59%]

01:40:36 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_single_path_from_env PASSED [ 59%]

01:40:36 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env PASSED [ 59%]

01:40:36 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env_windows SKIPPED [ 59%]

01:40:36 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env_custom_separator PASSED [ 59%]

01:40:36 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_no_path PASSED [ 59%]

01:40:36 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_unicode_path_from_options PASSED [ 59%]

01:40:36 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_unicode_path_from_env SKIPPED [ 59%]

01:40:36 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_custom_timeout_error PASSED [ 59%]

01:40:36 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_docker_client_no_home PASSED [ 60%]

01:40:36 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_docker_client_with_custom_timeout PASSED [ 60%]

01:40:36 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_user_agent PASSED [ 60%]

01:40:36 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_assert_hostname_explicit_skip PASSED [ 60%]

01:40:36 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_simple_tls PASSED [ 60%]

01:40:36 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_ca_cert PASSED [ 60%]

01:40:36 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_ca_cert_explicit PASSED [ 60%]

01:40:36 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca PASSED [ 60%]

01:40:36 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca_explicit PASSED [ 60%]

01:40:36 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca_quoted_paths PASSED [ 60%]

01:40:36 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_cert PASSED [ 60%]

01:40:36 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_cert_explicit PASSED [ 60%]

01:40:36 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_missing_key PASSED [ 61%]

01:40:36 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_flags_override_environment PASSED [ 61%]

01:40:36 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_mixed_environment_and_flags PASSED [ 61%]

01:40:36 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_simple_with_tls_version PASSED [ 61%]

01:40:36 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_default_cert_path PASSED [ 61%]

01:40:36 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_env_falsy_value PASSED [ 61%]

01:40:36 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_flag_no_override PASSED [ 61%]

01:40:36 tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_default PASSED [ 61%]

01:40:36 tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_upgrade PASSED [ 61%]

01:40:36 tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_unavailable PASSED [ 61%]

01:40:36 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_generic_connection_error PASSED [ 61%]

01:40:36 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_mismatch PASSED [ 62%]

01:40:36 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_mismatch_unicode_explanation PASSED [ 62%]

01:40:36 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_other PASSED [ 62%]

01:40:36 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_other_unicode_explanation PASSED [ 62%]

01:40:36 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_no_data SKIPPED [ 62%]

01:40:36 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_misc SKIPPED [ 62%]

01:40:36 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_encoding_issue SKIPPED [ 62%]

01:40:36 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_error PASSED [ 62%]

01:40:36 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_info PASSED [ 62%]

01:40:36 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_error PASSED [ 62%]

01:40:36 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_info PASSED [ 62%]

01:40:36 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_warn PASSED [ 63%]

01:40:36 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_warn PASSED [ 63%]

01:40:36 tests/unit/cli/log_printer_test.py::TestLogPresenter::test_monochrome PASSED [ 63%]

01:40:36 tests/unit/cli/log_printer_test.py::TestLogPresenter::test_polychrome PASSED [ 63%]

01:40:36 tests/unit/cli/log_printer_test.py::test_wait_on_exit PASSED             [ 63%]

01:40:36 tests/unit/cli/log_printer_test.py::test_wait_on_exit_raises PASSED      [ 63%]

01:40:36 tests/unit/cli/log_printer_test.py::test_build_no_log_generator PASSED   [ 63%]

01:40:36 tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_no_log_stream PASSED [ 63%]

01:40:36 tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_with_log_stream PASSED [ 63%]

01:40:36 tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_unicode PASSED [ 63%]

01:40:36 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_no_warning_with_same_path PASSED [ 55%]

01:40:36 tests/unit/cli/log_printer_test.py::TestWatchEvents::test_stop_event PASSED [ 63%]

01:40:36 tests/unit/cli/log_printer_test.py::TestWatchEvents::test_start_event PASSED [ 63%]

01:40:36 tests/unit/cli/log_printer_test.py::TestWatchEvents::test_other_event PASSED [ 64%]

01:40:36 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_an_exception PASSED [ 64%]

01:40:36 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_stop_without_cascade_stop PASSED [ 64%]

01:40:36 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_stop_with_cascade_stop PASSED [ 64%]

01:40:36 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_none_when_timeout_is_hit PASSED [ 64%]

01:40:36 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_filter_containers_to_service_names PASSED [ 64%]

01:40:36 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_volume_no_warning_when_no_container_volumes PASSED [ 55%]

01:40:36 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_filter_containers_to_service_names_all PASSED [ 64%]

01:40:37 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_middle_always_recreate_deps PASSED [ 35%]

01:40:37 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_volume_when_masked PASSED [ 56%]

01:40:37 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_warning_in_swarm_mode PASSED [ 64%]

01:40:37 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_build_one_off_container_options PASSED [ 64%]

01:40:37 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_get_docker_start_call PASSED [ 64%]

01:40:37 tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_tty_verbose PASSED [ 64%]

01:40:37 tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_tty_not_verbose PASSED [ 65%]

01:40:37 tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_not_a_tty PASSED [ 65%]

01:40:37 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_invalid_opts PASSED [ 65%]

01:40:37 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_always PASSED [ 65%]

01:40:37 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_never PASSED [ 65%]

01:40:37 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_changed PASSED [ 65%]

01:40:37 tests/unit/cli/main_test.py::TestCallDocker::test_simple_no_options PASSED [ 65%]

01:40:37 tests/unit/cli/main_test.py::TestCallDocker::test_simple_tls_option PASSED [ 65%]

01:40:37 tests/unit/cli/main_test.py::TestCallDocker::test_advanced_tls_options PASSED [ 65%]

01:40:37 tests/unit/cli/main_test.py::TestCallDocker::test_with_host_option PASSED [ 65%]

01:40:37 tests/unit/cli/main_test.py::TestCallDocker::test_with_http_host PASSED  [ 65%]

01:40:37 tests/unit/cli/main_test.py::TestCallDocker::test_with_host_option_shorthand_equal PASSED [ 65%]

01:40:37 tests/unit/cli/main_test.py::TestCallDocker::test_with_env PASSED        [ 66%]

01:40:37 tests/unit/cli/utils_test.py::UnquotePathTest::test_nested_quotes PASSED [ 66%]

01:40:37 tests/unit/cli/utils_test.py::UnquotePathTest::test_no_quotes PASSED     [ 66%]

01:40:37 tests/unit/cli/utils_test.py::UnquotePathTest::test_simple_quotes PASSED [ 66%]

01:40:37 tests/unit/cli/utils_test.py::UnquotePathTest::test_uneven_quotes PASSED [ 66%]

01:40:37 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_100b PASSED [ 66%]

01:40:37 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_1023b PASSED [ 66%]

01:40:37 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_1kb PASSED [ 66%]

01:40:37 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_units PASSED [ 66%]

01:40:37 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_call PASSED [ 66%]

01:40:37 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return PASSED [ 66%]

01:40:37 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return_no_result PASSED [ 67%]

01:40:37 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return_sequence PASSED [ 67%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_build_args_allow_empty_properties PASSED [ 67%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_build_args_check_zero_preserved PASSED [ 67%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_config_build_configuration PASSED [ 67%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_config_build_configuration_v2 PASSED [ 67%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_config_convertible_label_types PASSED [ 67%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_config_duplicate_cache_from_values_validation_error PASSED [ 67%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_config_duplicate_mount_points PASSED [ 67%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_config_extra_hosts_list_of_dicts_validation_error PASSED [ 67%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_config_extra_hosts_string_raises_validation_error PASSED [ 67%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_config_hint PASSED    [ 68%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error PASSED [ 68%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error_v2 PASSED [ 68%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error_v2_when_no_interpolate PASSED [ 68%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_property_raise_validation_error PASSED [ 68%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_config_invalid_ipam_config PASSED [ 68%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_config_invalid_label_types PASSED [ 68%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_config_invalid_service_name_raise_validation_error PASSED [ 68%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_invalid_keys_validation_error PASSED [ 68%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_required_keys_validation_error PASSED [ 68%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_soft_greater_than_hard_error PASSED [ 68%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_config_valid_environment_dict_key_contains_dashes PASSED [ 68%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_config_valid_ipam_config PASSED [ 69%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_config_valid_service_label_validation PASSED [ 69%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_config_valid_service_names PASSED [ 69%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_depends_on_orders_services PASSED [ 69%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_depends_on_unknown_service_errors PASSED [ 69%]

01:40:37 tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes PASSED [ 56%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_dns_opt_option PASSED [ 69%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_empty_environment_key_allowed PASSED [ 69%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_external_volume_config PASSED [ 69%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_external_volume_invalid_config PASSED [ 69%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_group_add_option PASSED [ 69%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_build_and_image_specified_v1 PASSED [ 69%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_not_a_dictionary PASSED [ 70%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_not_unique_items PASSED [ 70%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_type_should_be_an_array PASSED [ 70%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_v1 PASSED [ 70%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_v2 PASSED [ 70%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_invalid_list_of_strings_format PASSED [ 70%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_isolation_option PASSED [ 70%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_linked_service_is_undefined PASSED [ 70%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load PASSED           [ 70%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_bind_mount_relative_path PASSED [ 70%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_bind_mount_relative_path_with_tilde PASSED [ 70%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_build_labels_dict PASSED [ 71%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_build_labels_list PASSED [ 71%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_config_custom_resource_names PASSED [ 71%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_config_dockerfile_without_build_raises_error_v1 PASSED [ 71%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_config_invalid_service_names PASSED [ 71%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_config_invalid_service_names_v2 PASSED [ 71%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_config_link_local_ips_network PASSED [ 71%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_config_service_labels PASSED [ 71%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_config_volume_and_network_labels PASSED [ 71%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_configs PASSED   [ 71%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_configs_multi_file PASSED [ 71%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_dockerfile_without_context PASSED [ 71%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_errors_on_uppercase_with_no_image PASSED [ 72%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_invalid_service_definition PASSED [ 72%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_mixed_extends_resolution PASSED [ 72%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_secrets PASSED   [ 72%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_secrets_multi_file PASSED [ 72%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_service_with_name_version PASSED [ 72%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_sorts_in_dependency_order PASSED [ 72%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_when_not_dict PASSED [ 72%]

01:40:37 tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes_abspath PASSED [ 56%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_when_not_dict_v2 PASSED [ 72%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_with_invalid_network_fields PASSED [ 72%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_v2 PASSED        [ 72%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_with_buildargs PASSED [ 73%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_with_empty_build_args PASSED [ 73%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_with_extensions PASSED [ 73%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_with_invalid_field_name PASSED [ 73%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_with_invalid_field_name_v1 PASSED [ 73%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_base PASSED [ 73%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_base_v2 PASSED [ 73%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_override PASSED [ 73%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_override_v2 PASSED [ 73%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_extends_in_override_file PASSED [ 73%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_invalid_override PASSED [ 73%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_mismatched_networks_format PASSED [ 73%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_mismatched_networks_format_inverse_order PASSED [ 74%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v1 PASSED [ 74%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v2 PASSED [ 74%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v3_2 PASSED [ 74%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_yaml_with_bom PASSED [ 74%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_load_yaml_with_yaml_error PASSED [ 74%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_logs_warning_for_boolean_in_environment PASSED [ 74%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_blkio_config PASSED [ 74%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_configs_override PASSED [ 74%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_credential_spec PASSED [ 74%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_depends_on_mixed_syntax PASSED [ 74%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_depends_on_no_override PASSED [ 75%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_deploy PASSED   [ 75%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_deploy_override PASSED [ 75%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_device_cgroup_rules PASSED [ 75%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_different_configs PASSED [ 75%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_different_secrets PASSED [ 75%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_extra_hosts PASSED [ 75%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_config PASSED [ 75%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_override_disables PASSED [ 75%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_override_enables PASSED [ 75%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_isolation PASSED [ 75%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v1 PASSED [ 76%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2 PASSED [ 76%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_base PASSED [ 76%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_base_driver PASSED [ 76%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_drivers PASSED [ 76%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_override PASSED [ 76%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_override_options PASSED [ 76%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_override_driver PASSED [ 76%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_mixed_ports PASSED [ 76%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_pid PASSED      [ 76%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_scale PASSED    [ 76%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_secrets_override PASSED [ 76%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_from_files_with_extends_in_base PASSED [ 77%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_from_files_with_extends_in_override PASSED [ 77%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous PASSED [ 77%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous_2 PASSED [ 77%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous_volumes PASSED [ 77%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_ports_sorting PASSED [ 77%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_merge_storage_opt PASSED [ 77%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_named_volume_config_empty PASSED [ 77%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_named_volume_invalid_type_list PASSED [ 77%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_named_volume_numeric_driver_opt PASSED [ 77%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_networks_invalid_type_list PASSED [ 77%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_normalize_dns_options PASSED [ 78%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_oom_score_adj_option PASSED [ 78%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_runtime_option PASSED [ 78%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_service_volume_invalid_config PASSED [ 78%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_swappiness_option PASSED [ 78%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_tmpfs_option PASSED   [ 78%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_undeclared_volume_v1 PASSED [ 78%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_undeclared_volume_v2 PASSED [ 78%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_unsupported_version PASSED [ 78%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_v1_file_version PASSED [ 78%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_v1_file_with_version_is_invalid PASSED [ 78%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_valid_config_oneof_string_or_list PASSED [ 78%]

01:40:37 tests/unit/config/config_test.py::ConfigTest::test_valid_config_which_allows_two_type_definitions PASSED [ 79%]

01:40:37 tests/integration/service_test.py::ServiceTest::test_start_container_creates_links PASSED [ 33%]

01:40:37 tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes_no_target PASSED [ 56%]

01:40:37 tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_unix_path PASSED [ 56%]

01:40:37 tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_url_no_prefix PASSED [ 56%]

01:40:37 tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_windows_path PASSED [ 56%]

01:40:37 tests/unit/split_buffer_test.py::SplitBufferTest::test_chunked_line PASSED [ 56%]

01:40:37 tests/unit/split_buffer_test.py::SplitBufferTest::test_multiple_line_chunk PASSED [ 56%]

01:40:37 tests/unit/split_buffer_test.py::SplitBufferTest::test_no_end_separator PASSED [ 56%]

01:40:37 tests/unit/split_buffer_test.py::SplitBufferTest::test_preserves_unicode_sequences_within_lines PASSED [ 56%]

01:40:37 tests/unit/split_buffer_test.py::SplitBufferTest::test_single_line_chunks PASSED [ 57%]

01:40:37 tests/unit/timeparse_test.py::test_milli PASSED                          [ 57%]

01:40:37 tests/unit/timeparse_test.py::test_milli_float PASSED                    [ 57%]

01:40:37 tests/unit/timeparse_test.py::test_second_milli PASSED                   [ 57%]

01:40:37 tests/unit/timeparse_test.py::test_second_milli_micro PASSED             [ 57%]

01:40:37 tests/unit/timeparse_test.py::test_second PASSED                         [ 57%]

01:40:37 tests/unit/timeparse_test.py::test_second_as_float PASSED                [ 57%]

01:40:37 tests/unit/timeparse_test.py::test_minute PASSED                         [ 57%]

01:40:37 tests/unit/timeparse_test.py::test_hour_minute PASSED                    [ 57%]

01:40:37 tests/unit/timeparse_test.py::test_minute_as_float PASSED                [ 57%]

01:40:37 tests/unit/timeparse_test.py::test_hour_minute_second PASSED             [ 57%]

01:40:37 tests/unit/timeparse_test.py::test_invalid_with_space PASSED             [ 57%]

01:40:37 tests/unit/timeparse_test.py::test_invalid_with_comma PASSED             [ 58%]

01:40:37 tests/unit/timeparse_test.py::test_invalid_with_empty_string PASSED      [ 58%]

01:40:37 tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_no_object PASSED [ 58%]

01:40:37 tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_with_object PASSED [ 58%]

01:40:37 tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_leading_whitespace PASSED [ 58%]

01:40:37 tests/unit/utils_test.py::TestStreamAsText::test_stream_with_non_utf_unicode_character PASSED [ 58%]

01:40:37 tests/unit/utils_test.py::TestStreamAsText::test_stream_with_utf_character PASSED [ 58%]

01:40:37 tests/unit/utils_test.py::TestJsonStream::test_with_falsy_entries PASSED [ 58%]

01:40:37 tests/unit/utils_test.py::TestJsonStream::test_with_leading_whitespace PASSED [ 58%]

01:40:37 tests/unit/utils_test.py::TestParseBytes::test_parse_bytes PASSED        [ 58%]

01:40:37 tests/unit/utils_test.py::TestMoreItertools::test_unique_everseen PASSED [ 58%]

01:40:38 tests/unit/config/config_test.py::ConfigTest::test_valid_versions PASSED [ 79%]

01:40:38 tests/unit/config/config_test.py::ConfigTest::test_validate_extra_hosts_invalid PASSED [ 79%]

01:40:38 tests/unit/config/config_test.py::ConfigTest::test_validate_extra_hosts_invalid_list PASSED [ 79%]

01:40:38 tests/unit/config/config_test.py::ConfigTest::test_version_1_is_invalid PASSED [ 79%]

01:40:38 tests/unit/config/config_test.py::ConfigTest::test_volume_invalid_driver_opt PASSED [ 79%]

01:40:38 tests/unit/config/config_test.py::ConfigTest::test_volume_mode_override PASSED [ 79%]

01:40:38 tests/unit/config/config_test.py::ConfigTest::test_volumes_long_syntax PASSED [ 79%]

01:40:38 tests/unit/config/config_test.py::ConfigTest::test_wrong_version_type PASSED [ 79%]

01:40:38 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_container PASSED [ 79%]

01:40:38 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_container_v1 PASSED [ 79%]

01:40:38 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_plus_networks_is_invalid PASSED [ 80%]

01:40:38 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service PASSED [ 80%]

01:40:38 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service_nonexistent PASSED [ 80%]

01:40:38 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service_v1 PASSED [ 80%]

01:40:38 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_standard PASSED [ 80%]

01:40:38 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_standard_v1 PASSED [ 80%]

01:40:38 tests/unit/config/config_test.py::PortsTest::test_config_invalid_expose_format_validation PASSED [ 80%]

01:40:38 tests/unit/config/config_test.py::PortsTest::test_config_invalid_expose_type_validation PASSED [ 80%]

01:40:38 tests/unit/config/config_test.py::PortsTest::test_config_invalid_ports_format_validation PASSED [ 80%]

01:40:38 tests/unit/config/config_test.py::PortsTest::test_config_invalid_ports_type_validation PASSED [ 80%]

01:40:38 tests/unit/config/config_test.py::PortsTest::test_config_non_unique_expose_validation PASSED [ 80%]

01:40:38 tests/unit/config/config_test.py::PortsTest::test_config_non_unique_ports_validation PASSED [ 81%]

01:40:38 tests/unit/config/config_test.py::PortsTest::test_config_valid_expose_format_validation PASSED [ 81%]

01:40:38 tests/unit/config/config_test.py::PortsTest::test_config_valid_ports_format_validation PASSED [ 81%]

01:40:38 tests/unit/config/config_test.py::SubnetTest::test_config_invalid_subnet_format_validation PASSED [ 81%]

01:40:38 tests/unit/config/config_test.py::SubnetTest::test_config_invalid_subnet_type_validation PASSED [ 81%]

01:40:38 tests/unit/config/config_test.py::SubnetTest::test_config_valid_subnet_format_validation PASSED [ 81%]

01:40:38 tests/unit/config/config_test.py::InterpolationTest::test_compatibility_mode_load PASSED [ 81%]

01:40:38 tests/unit/config/config_test.py::InterpolationTest::test_compatibility_mode_warnings PASSED [ 81%]

01:40:38 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_file PASSED [ 81%]

01:40:38 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_variable PASSED [ 81%]

01:40:38 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_variable_with_defaults PASSED [ 81%]

01:40:38 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_options_environment_file PASSED [ 81%]

01:40:38 tests/unit/config/config_test.py::InterpolationTest::test_interpolation_configs_section PASSED [ 82%]

01:40:38 tests/unit/config/config_test.py::InterpolationTest::test_interpolation_secrets_section PASSED [ 82%]

01:40:38 tests/unit/config/config_test.py::InterpolationTest::test_invalid_interpolation PASSED [ 82%]

01:40:38 tests/unit/config/config_test.py::InterpolationTest::test_unset_variable_produces_warning PASSED [ 82%]

01:40:38 tests/unit/config/config_test.py::VolumeConfigTest::test_absolute_posix_path_does_not_expand PASSED [ 82%]

01:40:38 tests/unit/config/config_test.py::VolumeConfigTest::test_absolute_windows_path_does_not_expand PASSED [ 82%]

01:40:38 tests/unit/config/config_test.py::VolumeConfigTest::test_home_directory_with_driver_does_not_expand PASSED [ 82%]

01:40:38 tests/unit/config/config_test.py::VolumeConfigTest::test_name_does_not_expand PASSED [ 82%]

01:40:38 tests/unit/config/config_test.py::VolumeConfigTest::test_no_binding PASSED [ 82%]

01:40:38 tests/unit/config/config_test.py::VolumeConfigTest::test_relative_path_does_expand_posix PASSED [ 82%]

01:40:38 tests/unit/config/config_test.py::VolumeConfigTest::test_relative_path_does_expand_windows SKIPPED [ 82%]

01:40:38 tests/unit/config/config_test.py::VolumeConfigTest::test_volume_binding_with_environment_variable PASSED [ 83%]

01:40:38 tests/unit/config/config_test.py::VolumeConfigTest::test_volume_binding_with_home PASSED [ 83%]

01:40:38 tests/unit/config/config_test.py::VolumeConfigTest::test_volume_path_with_non_ascii_directory PASSED [ 83%]

01:40:38 tests/unit/config/config_test.py::VolumeConfigTest::test_volumes_order_is_preserved PASSED [ 83%]

01:40:38 tests/unit/config/config_test.py::MergeVolumesTest::test_add_explicit_path PASSED [ 83%]

01:40:38 tests/unit/config/config_test.py::MergeVolumesTest::test_empty PASSED    [ 83%]

01:40:38 tests/unit/config/config_test.py::MergeVolumesTest::test_no_base PASSED  [ 83%]

01:40:38 tests/unit/config/config_test.py::MergeVolumesTest::test_no_override PASSED [ 83%]

01:40:38 tests/unit/config/config_test.py::MergeVolumesTest::test_override_explicit_path PASSED [ 83%]

01:40:38 tests/unit/config/config_test.py::MergeVolumesTest::test_remove_explicit_path PASSED [ 83%]

01:40:38 tests/unit/config/config_test.py::MergeDevicesTest::test_add_explicit_path PASSED [ 83%]

01:40:38 tests/unit/config/config_test.py::MergeDevicesTest::test_empty PASSED    [ 84%]

01:40:38 tests/unit/config/config_test.py::MergeDevicesTest::test_no_base PASSED  [ 84%]

01:40:38 tests/unit/config/config_test.py::MergeDevicesTest::test_no_override PASSED [ 84%]

01:40:38 tests/unit/config/config_test.py::MergeDevicesTest::test_override_explicit_path PASSED [ 84%]

01:40:38 tests/unit/config/config_test.py::MergeDevicesTest::test_remove_explicit_path PASSED [ 84%]

01:40:38 tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_no_override PASSED [ 84%]

01:40:38 tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_override_with_other PASSED [ 84%]

01:40:38 tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_override_with_same PASSED [ 84%]

01:40:38 tests/unit/config/config_test.py::MergePortsTest::test_add_item PASSED   [ 84%]

01:40:38 tests/unit/config/config_test.py::MergePortsTest::test_duplicate_port_mappings PASSED [ 84%]

01:40:38 tests/unit/config/config_test.py::MergePortsTest::test_empty PASSED      [ 84%]

01:40:38 tests/unit/config/config_test.py::MergePortsTest::test_no_base PASSED    [ 84%]

01:40:38 tests/unit/config/config_test.py::MergePortsTest::test_no_override PASSED [ 85%]

01:40:38 tests/unit/config/config_test.py::MergeNetworksTest::test_add_item PASSED [ 85%]

01:40:38 tests/unit/config/config_test.py::MergeNetworksTest::test_all_properties PASSED [ 85%]

01:40:38 tests/unit/config/config_test.py::MergeNetworksTest::test_empty PASSED   [ 85%]

01:40:38 tests/unit/config/config_test.py::MergeNetworksTest::test_network_has_none_value PASSED [ 85%]

01:40:38 tests/unit/config/config_test.py::MergeNetworksTest::test_no_base PASSED [ 85%]

01:40:38 tests/unit/config/config_test.py::MergeNetworksTest::test_no_network_name_overrides PASSED [ 85%]

01:40:38 tests/unit/config/config_test.py::MergeNetworksTest::test_no_network_overrides PASSED [ 85%]

01:40:38 tests/unit/config/config_test.py::MergeNetworksTest::test_no_override PASSED [ 85%]

01:40:38 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_add_list PASSED [ 85%]

01:40:38 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_add_string PASSED [ 85%]

01:40:38 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_no_base PASSED [ 86%]

01:40:38 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_no_override PASSED [ 86%]

01:40:38 tests/unit/config/config_test.py::MergeLabelsTest::test_add_explicit_value PASSED [ 86%]

01:40:38 tests/unit/config/config_test.py::MergeLabelsTest::test_empty PASSED     [ 86%]

01:40:38 tests/unit/config/config_test.py::MergeLabelsTest::test_no_base PASSED   [ 86%]

01:40:38 tests/unit/config/config_test.py::MergeLabelsTest::test_no_override PASSED [ 86%]

01:40:38 tests/unit/config/config_test.py::MergeLabelsTest::test_override_explicit_value PASSED [ 86%]

01:40:38 tests/unit/config/config_test.py::MergeLabelsTest::test_remove_explicit_value PASSED [ 86%]

01:40:38 tests/unit/config/config_test.py::MergeBuildTest::test_empty_base PASSED [ 86%]

01:40:38 tests/unit/config/config_test.py::MergeBuildTest::test_empty_override PASSED [ 86%]

01:40:38 tests/unit/config/config_test.py::MergeBuildTest::test_full PASSED       [ 86%]

01:40:38 tests/unit/config/config_test.py::MemoryOptionsTest::test_memswap_can_be_a_string PASSED [ 86%]

01:40:38 tests/unit/config/config_test.py::MemoryOptionsTest::test_validation_fails_with_just_memswap_limit PASSED [ 87%]

01:40:38 tests/unit/config/config_test.py::MemoryOptionsTest::test_validation_with_correct_memswap_values PASSED [ 87%]

01:40:38 tests/unit/config/config_test.py::EnvTest::test_environment_overrides_env_file PASSED [ 87%]

01:40:38 tests/unit/config/config_test.py::EnvTest::test_parse_environment_as_dict PASSED [ 87%]

01:40:38 tests/unit/config/config_test.py::EnvTest::test_parse_environment_as_list PASSED [ 87%]

01:40:38 tests/unit/config/config_test.py::EnvTest::test_parse_environment_empty PASSED [ 87%]

01:40:38 tests/unit/config/config_test.py::EnvTest::test_parse_environment_invalid PASSED [ 87%]

01:40:38 tests/unit/config/config_test.py::EnvTest::test_resolve_build_args PASSED [ 87%]

01:40:38 tests/unit/config/config_test.py::EnvTest::test_resolve_environment PASSED [ 87%]

01:40:38 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_from_env_file PASSED [ 87%]

01:40:38 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_from_env_file_with_empty_values PASSED [ 87%]

01:40:38 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_nonexistent_file PASSED [ 88%]

01:40:38 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_with_multiple_env_files PASSED [ 88%]

01:40:38 tests/unit/config/config_test.py::EnvTest::test_resolve_path PASSED      [ 88%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_circular PASSED      [ 88%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_invalid_config PASSED [ 88%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_valid_config PASSED [ 88%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_verbose_and_shorthand_way PASSED [ 88%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_extends PASSED       [ 88%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_extends_file_defaults_to_self PASSED [ 88%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_empty_dictionary PASSED [ 88%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_invalid_key PASSED [ 88%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_missing_service_key PASSED [ 89%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_no_file_key_no_filename_set PASSED [ 89%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_sub_property_key PASSED [ 89%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_valid_config PASSED [ 89%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_defined_version_passes PASSED [ 89%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_depends_on PASSED [ 89%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_environment_and_env_files PASSED [ 89%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_healthcheck PASSED [ 89%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_mixed_versions_is_error PASSED [ 89%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_ports PASSED [ 89%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_security_opt PASSED [ 89%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_invalid_links_in_extended_service PASSED [ 89%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_invalid_net_in_extended_service PASSED [ 90%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_invalid_volumes_from_in_extended_service PASSED [ 90%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_load_config_runs_interpolation_in_extended_service PASSED [ 90%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_load_throws_error_when_base_service_does_not_exist PASSED [ 90%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_merging_env_labels_ulimits PASSED [ 90%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_nested PASSED        [ 90%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_parent_build_path_dne PASSED [ 90%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_partial_service_config_in_extends_is_still_valid PASSED [ 90%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_self_referencing_file PASSED [ 90%]

01:40:38 tests/unit/config/config_test.py::ExtendsTest::test_volume_path PASSED   [ 90%]

01:40:38 tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_absolute PASSED [ 90%]

01:40:38 tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_normal PASSED [ 91%]

01:40:38 tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_with_tilde PASSED [ 91%]

01:40:38 tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_root_mount PASSED [ 91%]

01:40:38 tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_windows_path PASSED [ 91%]

01:40:38 tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_windows_path_in_container PASSED [ 91%]

01:40:38 tests/unit/config/config_test.py::BuildPathTest::test_absolute_path PASSED [ 91%]

01:40:38 tests/unit/config/config_test.py::BuildPathTest::test_from_file PASSED   [ 91%]

01:40:38 tests/unit/config/config_test.py::BuildPathTest::test_from_file_override_dir PASSED [ 91%]

01:40:38 tests/unit/config/config_test.py::BuildPathTest::test_invalid_url_in_build_path PASSED [ 91%]

01:40:38 tests/unit/config/config_test.py::BuildPathTest::test_nonexistent_path PASSED [ 91%]

01:40:38 tests/unit/config/config_test.py::BuildPathTest::test_relative_path PASSED [ 91%]

01:40:38 tests/unit/config/config_test.py::BuildPathTest::test_valid_url_in_build_path PASSED [ 92%]

01:40:38 tests/unit/config/config_test.py::HealthcheckTest::test_disable PASSED   [ 92%]

01:40:38 tests/unit/config/config_test.py::HealthcheckTest::test_disable_with_other_config_is_invalid PASSED [ 92%]

01:40:38 tests/unit/config/config_test.py::HealthcheckTest::test_healthcheck PASSED [ 92%]

01:40:38 tests/unit/config/config_test.py::HealthcheckTest::test_healthcheck_with_invalid_test PASSED [ 92%]

01:40:38 tests/unit/config/config_test.py::GetDefaultConfigFilesTestCase::test_get_config_path_default_file_in_basedir PASSED [ 92%]

01:40:38 tests/unit/config/config_test.py::GetDefaultConfigFilesTestCase::test_get_config_path_default_file_in_parent_dir PASSED [ 92%]

01:40:38 tests/unit/volume_test.py::TestVolume::test_remove_local_volume PASSED   [ 59%]

01:40:38 tests/unit/volume_test.py::TestVolume::test_remove_external_volume PASSED [ 59%]

01:40:38 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_path_from_options PASSED [ 59%]

01:40:38 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_single_path_from_env PASSED [ 59%]

01:40:38 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env PASSED [ 59%]

01:40:38 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env_windows SKIPPED [ 59%]

01:40:38 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env_custom_separator PASSED [ 59%]

01:40:38 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_no_path PASSED [ 59%]

01:40:38 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_unicode_path_from_options PASSED [ 59%]

01:40:38 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_unicode_path_from_env PASSED [ 59%]

01:40:38 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_custom_timeout_error PASSED [ 59%]

01:40:38 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_docker_client_no_home PASSED [ 60%]

01:40:38 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_docker_client_with_custom_timeout PASSED [ 60%]

01:40:38 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_user_agent PASSED [ 60%]

01:40:38 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_assert_hostname_explicit_skip PASSED [ 60%]

01:40:38 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_simple_tls PASSED [ 60%]

01:40:38 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_ca_cert PASSED [ 60%]

01:40:38 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_ca_cert_explicit PASSED [ 60%]

01:40:38 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca PASSED [ 60%]

01:40:38 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca_explicit PASSED [ 60%]

01:40:38 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca_quoted_paths PASSED [ 60%]

01:40:38 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_cert PASSED [ 60%]

01:40:38 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_cert_explicit PASSED [ 60%]

01:40:38 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_missing_key PASSED [ 61%]

01:40:38 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_flags_override_environment PASSED [ 61%]

01:40:38 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_mixed_environment_and_flags PASSED [ 61%]

01:40:38 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_simple_with_tls_version PASSED [ 61%]

01:40:38 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_default_cert_path PASSED [ 61%]

01:40:38 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_env_falsy_value PASSED [ 61%]

01:40:38 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_flag_no_override PASSED [ 61%]

01:40:38 tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_default PASSED [ 61%]

01:40:38 tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_upgrade PASSED [ 61%]

01:40:38 tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_unavailable PASSED [ 61%]

01:40:38 tests/unit/config/config_test.py::SerializeTest::test_denormalize_depends_on_v2_1 PASSED [ 92%]

01:40:38 tests/unit/config/config_test.py::SerializeTest::test_denormalize_depends_on_v3 PASSED [ 92%]

01:40:38 tests/unit/config/config_test.py::SerializeTest::test_denormalize_healthcheck PASSED [ 92%]

01:40:38 tests/unit/config/config_test.py::SerializeTest::test_denormalize_image_has_digest PASSED [ 92%]

01:40:38 tests/unit/config/config_test.py::SerializeTest::test_denormalize_image_no_digest PASSED [ 92%]

01:40:38 tests/unit/config/config_test.py::SerializeTest::test_serialize_bool_string PASSED [ 93%]

01:40:38 tests/unit/config/config_test.py::SerializeTest::test_serialize_configs PASSED [ 93%]

01:40:38 tests/unit/config/config_test.py::SerializeTest::test_serialize_escape_dollar_sign PASSED [ 93%]

01:40:38 tests/unit/config/config_test.py::SerializeTest::test_serialize_escape_dont_interpolate PASSED [ 93%]

01:40:38 tests/unit/config/config_test.py::SerializeTest::test_serialize_external_false PASSED [ 93%]

01:40:38 tests/unit/config/config_test.py::SerializeTest::test_serialize_ports PASSED [ 93%]

01:40:38 tests/unit/config/config_test.py::SerializeTest::test_serialize_ports_with_ext_ip PASSED [ 93%]

01:40:38 tests/unit/config/config_test.py::SerializeTest::test_serialize_secrets PASSED [ 93%]

01:40:38 tests/unit/config/config_test.py::SerializeTest::test_serialize_time PASSED [ 93%]

01:40:38 tests/unit/config/config_test.py::SerializeTest::test_serialize_unicode_values PASSED [ 93%]

01:40:38 tests/unit/config/environment_test.py::EnvironmentTest::test_env_vars_from_file_bom PASSED [ 93%]

01:40:38 tests/unit/config/environment_test.py::EnvironmentTest::test_env_vars_from_file_whitespace PASSED [ 94%]

01:40:38 tests/unit/config/environment_test.py::EnvironmentTest::test_get_boolean PASSED [ 94%]

01:40:38 tests/unit/config/environment_test.py::EnvironmentTest::test_get_simple PASSED [ 94%]

01:40:38 tests/unit/config/environment_test.py::EnvironmentTest::test_get_undefined PASSED [ 94%]

01:40:38 tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_services PASSED [ 94%]

01:40:38 tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_volumes PASSED [ 94%]

01:40:38 tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_secrets PASSED [ 94%]

01:40:38 tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_v2 PASSED [ 94%]

01:40:38 tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_v3 PASSED [ 94%]

01:40:38 tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_invalid PASSED [ 94%]

01:40:38 tests/unit/config/interpolation_test.py::test_interpolate_environment_network_convert_types PASSED [ 94%]

01:40:38 tests/unit/config/interpolation_test.py::test_interpolate_environment_external_resource_convert_types PASSED [ 94%]

01:40:38 tests/unit/config/interpolation_test.py::test_interpolate_service_name_uses_dot PASSED [ 95%]

01:40:38 tests/unit/config/interpolation_test.py::test_escaped_interpolation PASSED [ 95%]

01:40:38 tests/unit/config/interpolation_test.py::test_invalid_interpolation PASSED [ 95%]

01:40:38 tests/unit/config/interpolation_test.py::test_interpolate_missing_no_default PASSED [ 95%]

01:40:38 tests/unit/config/interpolation_test.py::test_interpolate_with_value PASSED [ 95%]

01:40:38 tests/unit/config/interpolation_test.py::test_interpolate_missing_with_default PASSED [ 95%]

01:40:38 tests/unit/config/interpolation_test.py::test_interpolate_with_empty_and_default_value PASSED [ 95%]

01:40:38 tests/unit/config/interpolation_test.py::test_interpolate_mandatory_values PASSED [ 95%]

01:40:38 tests/unit/config/interpolation_test.py::test_interpolate_mandatory_no_err_msg PASSED [ 95%]

01:40:38 tests/unit/config/interpolation_test.py::test_interpolate_mixed_separators PASSED [ 95%]

01:40:38 tests/unit/config/interpolation_test.py::test_unbraced_separators PASSED [ 95%]

01:40:38 tests/unit/config/interpolation_test.py::test_interpolate_unicode_values PASSED [ 96%]

01:40:38 tests/unit/config/interpolation_test.py::test_interpolate_no_fallthrough PASSED [ 96%]

01:40:38 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_1 PASSED [ 96%]

01:40:38 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_2 PASSED [ 96%]

01:40:38 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_3 PASSED [ 96%]

01:40:38 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_4 PASSED [ 96%]

01:40:38 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_5 PASSED [ 96%]

01:40:38 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_6 PASSED [ 96%]

01:40:38 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_7 PASSED [ 96%]

01:40:38 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports PASSED [ 96%]

01:40:38 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports_2 PASSED [ 96%]

01:40:38 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports_3 PASSED [ 97%]

01:40:38 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_self_imports PASSED [ 97%]

01:40:38 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_depends_on_self PASSED [ 97%]

01:40:38 tests/unit/config/types_test.py::test_parse_extra_hosts_list PASSED      [ 97%]

01:40:38 tests/unit/config/types_test.py::test_parse_extra_hosts_dict PASSED      [ 97%]

01:40:38 tests/unit/config/types_test.py::TestServicePort::test_parse_dict PASSED [ 97%]

01:40:38 tests/unit/config/types_test.py::TestServicePort::test_parse_simple_target_port PASSED [ 97%]

01:40:38 tests/unit/config/types_test.py::TestServicePort::test_parse_complete_port_definition PASSED [ 97%]

01:40:38 tests/unit/config/types_test.py::TestServicePort::test_parse_ext_ip_no_published_port PASSED [ 97%]

01:40:38 tests/unit/config/types_test.py::TestServicePort::test_repr_published_port_0 PASSED [ 97%]

01:40:38 tests/unit/config/types_test.py::TestServicePort::test_parse_port_range PASSED [ 97%]

01:40:38 tests/unit/config/types_test.py::TestServicePort::test_parse_port_publish_range PASSED [ 97%]

01:40:38 tests/unit/config/types_test.py::TestServicePort::test_parse_invalid_port PASSED [ 98%]

01:40:38 tests/unit/config/types_test.py::TestServicePort::test_parse_invalid_publish_range PASSED [ 98%]

01:40:38 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_only_one_path PASSED [ 98%]

01:40:38 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_internal_and_external PASSED [ 98%]

01:40:38 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_with_mode PASSED [ 98%]

01:40:38 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_too_many_parts PASSED [ 98%]

01:40:38 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_absolute_path_normalized PASSED [ 98%]

01:40:38 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_absolute_path_native PASSED [ 98%]

01:40:38 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_internal_path_normalized PASSED [ 98%]

01:40:38 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_internal_path_native PASSED [ 98%]

01:40:38 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_just_drives_normalized PASSED [ 98%]

01:40:38 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_just_drives_native PASSED [ 99%]

01:40:38 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_mixed_notations_normalized PASSED [ 99%]

01:40:38 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_mixed_notations_native PASSED [ 99%]

01:40:38 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_from_service PASSED [ 99%]

01:40:38 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_from_container PASSED [ 99%]

01:40:38 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_invalid PASSED [ 99%]

01:40:38 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_service PASSED [ 99%]

01:40:38 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_service_with_mode PASSED [ 99%]

01:40:38 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_container PASSED [ 99%]

01:40:38 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_container_with_mode PASSED [ 99%]

01:40:38 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_invalid_type PASSED [ 99%]

01:40:38 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_generic_connection_error PASSED [ 61%]

01:40:38 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_mismatch PASSED [ 62%]

01:40:38 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_mismatch_unicode_explanation PASSED [ 62%]

01:40:38 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_other PASSED [ 62%]

01:40:38 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_other_unicode_explanation PASSED [ 62%]

01:40:38 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_no_data SKIPPED [ 62%]

01:40:38 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_misc SKIPPED [ 62%]

01:40:38 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_encoding_issue SKIPPED [ 62%]

01:40:38 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_error PASSED [ 62%]

01:40:38 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_info PASSED [ 62%]

01:40:38 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_error PASSED [ 62%]

01:40:38 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_info PASSED [ 62%]

01:40:38 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_warn PASSED [ 63%]

01:40:38 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_warn PASSED [ 63%]

01:40:38 tests/unit/cli/log_printer_test.py::TestLogPresenter::test_monochrome PASSED [ 63%]

01:40:38 tests/unit/cli/log_printer_test.py::TestLogPresenter::test_polychrome PASSED [ 63%]

01:40:38 tests/unit/cli/log_printer_test.py::test_wait_on_exit PASSED             [ 63%]

01:40:38 tests/unit/cli/log_printer_test.py::test_wait_on_exit_raises PASSED      [ 63%]

01:40:38 tests/unit/cli/log_printer_test.py::test_build_no_log_generator PASSED   [ 63%]

01:40:38 tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_no_log_stream PASSED [ 63%]

01:40:38 tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_with_log_stream PASSED [ 63%]

01:40:38 tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_unicode PASSED [ 63%]

01:40:38 tests/unit/cli/log_printer_test.py::TestWatchEvents::test_stop_event PASSED [ 63%]

01:40:38 tests/unit/cli/log_printer_test.py::TestWatchEvents::test_start_event PASSED [ 63%]

01:40:38 tests/unit/cli/log_printer_test.py::TestWatchEvents::test_other_event PASSED [ 64%]

01:40:38 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_an_exception PASSED [ 64%]

01:40:38 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_stop_without_cascade_stop PASSED [ 64%]

01:40:38 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_stop_with_cascade_stop PASSED [ 64%]

01:40:38 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_none_when_timeout_is_hit PASSED [ 64%]

01:40:39 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_filter_containers_to_service_names PASSED [ 64%]

01:40:39 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_filter_containers_to_service_names_all PASSED [ 64%]

01:40:39 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_warning_in_swarm_mode PASSED [ 64%]

01:40:39 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_build_one_off_container_options PASSED [ 64%]

01:40:39 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_get_docker_start_call PASSED [ 64%]

01:40:39 tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_tty_verbose PASSED [ 64%]

01:40:39 tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_tty_not_verbose PASSED [ 65%]

01:40:39 tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_not_a_tty PASSED [ 65%]

01:40:39 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_invalid_opts PASSED [ 65%]

01:40:39 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_always PASSED [ 65%]

01:40:39 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_never PASSED [ 65%]

01:40:39 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_changed PASSED [ 65%]

01:40:39 tests/unit/cli/main_test.py::TestCallDocker::test_simple_no_options PASSED [ 65%]

01:40:39 tests/unit/cli/main_test.py::TestCallDocker::test_simple_tls_option PASSED [ 65%]

01:40:39 tests/unit/cli/main_test.py::TestCallDocker::test_advanced_tls_options PASSED [ 65%]

01:40:39 tests/unit/cli/main_test.py::TestCallDocker::test_with_host_option PASSED [ 65%]

01:40:39 tests/unit/cli/main_test.py::TestCallDocker::test_with_http_host PASSED  [ 65%]

01:40:39 tests/unit/cli/main_test.py::TestCallDocker::test_with_host_option_shorthand_equal PASSED [ 65%]

01:40:39 tests/unit/cli/main_test.py::TestCallDocker::test_with_env PASSED        [ 66%]

01:40:39 tests/unit/cli/utils_test.py::UnquotePathTest::test_nested_quotes PASSED [ 66%]

01:40:39 tests/unit/cli/utils_test.py::UnquotePathTest::test_no_quotes PASSED     [ 66%]

01:40:39 tests/unit/cli/utils_test.py::UnquotePathTest::test_simple_quotes PASSED [ 66%]

01:40:39 tests/unit/cli/utils_test.py::UnquotePathTest::test_uneven_quotes PASSED [ 66%]

01:40:39 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_100b PASSED [ 66%]

01:40:39 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_1023b PASSED [ 66%]

01:40:39 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_1kb PASSED [ 66%]

01:40:39 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_units PASSED [ 66%]

01:40:39 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_call PASSED [ 66%]

01:40:39 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return PASSED [ 66%]

01:40:39 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return_no_result PASSED [ 67%]

01:40:39 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return_sequence PASSED [ 67%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_build_args_allow_empty_properties PASSED [ 67%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_build_args_check_zero_preserved PASSED [ 67%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_config_build_configuration PASSED [ 67%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_config_build_configuration_v2 PASSED [ 67%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_config_convertible_label_types PASSED [ 67%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_config_duplicate_cache_from_values_validation_error PASSED [ 67%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_config_duplicate_mount_points PASSED [ 67%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_config_extra_hosts_list_of_dicts_validation_error PASSED [ 67%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_config_extra_hosts_string_raises_validation_error PASSED [ 67%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_config_hint PASSED    [ 68%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error PASSED [ 68%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error_v2 PASSED [ 68%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error_v2_when_no_interpolate PASSED [ 68%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_property_raise_validation_error PASSED [ 68%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_config_invalid_ipam_config PASSED [ 68%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_config_invalid_label_types PASSED [ 68%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_config_invalid_service_name_raise_validation_error PASSED [ 68%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_invalid_keys_validation_error PASSED [ 68%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_required_keys_validation_error PASSED [ 68%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_soft_greater_than_hard_error PASSED [ 68%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_config_valid_environment_dict_key_contains_dashes PASSED [ 68%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_config_valid_ipam_config PASSED [ 69%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_config_valid_service_label_validation PASSED [ 69%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_config_valid_service_names PASSED [ 69%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_depends_on_orders_services PASSED [ 69%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_depends_on_unknown_service_errors PASSED [ 69%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_dns_opt_option PASSED [ 69%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_empty_environment_key_allowed PASSED [ 69%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_external_volume_config PASSED [ 69%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_external_volume_invalid_config PASSED [ 69%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_group_add_option PASSED [ 69%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_build_and_image_specified_v1 PASSED [ 69%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_not_a_dictionary PASSED [ 70%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_not_unique_items PASSED [ 70%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_type_should_be_an_array PASSED [ 70%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_v1 PASSED [ 70%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_v2 PASSED [ 70%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_invalid_list_of_strings_format PASSED [ 70%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_isolation_option PASSED [ 70%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_linked_service_is_undefined PASSED [ 70%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load PASSED           [ 70%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_bind_mount_relative_path PASSED [ 70%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_bind_mount_relative_path_with_tilde PASSED [ 70%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_build_labels_dict PASSED [ 71%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_build_labels_list PASSED [ 71%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_config_custom_resource_names PASSED [ 71%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_config_dockerfile_without_build_raises_error_v1 PASSED [ 71%]

01:40:39 tests/integration/service_test.py::ServiceTest::test_start_container_creates_links_with_names PASSED [ 33%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_config_invalid_service_names PASSED [ 71%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_config_invalid_service_names_v2 PASSED [ 71%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_config_link_local_ips_network PASSED [ 71%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_config_service_labels PASSED [ 71%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_config_volume_and_network_labels PASSED [ 71%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_configs PASSED   [ 71%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_configs_multi_file PASSED [ 71%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_dockerfile_without_context PASSED [ 71%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_errors_on_uppercase_with_no_image PASSED [ 72%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_invalid_service_definition PASSED [ 72%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_mixed_extends_resolution PASSED [ 72%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_secrets PASSED   [ 72%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_secrets_multi_file PASSED [ 72%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_service_with_name_version PASSED [ 72%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_sorts_in_dependency_order PASSED [ 72%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_when_not_dict PASSED [ 72%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_when_not_dict_v2 PASSED [ 72%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_with_invalid_network_fields PASSED [ 72%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_v2 PASSED        [ 72%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_with_buildargs PASSED [ 73%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_with_empty_build_args PASSED [ 73%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_with_extensions PASSED [ 73%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_with_invalid_field_name PASSED [ 73%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_with_invalid_field_name_v1 PASSED [ 73%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_base PASSED [ 73%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_base_v2 PASSED [ 73%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_override PASSED [ 73%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_override_v2 PASSED [ 73%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_extends_in_override_file PASSED [ 73%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_invalid_override PASSED [ 73%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_mismatched_networks_format PASSED [ 73%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_mismatched_networks_format_inverse_order PASSED [ 74%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v1 PASSED [ 74%]

01:40:39 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v2 PASSED [ 74%]

01:40:40 tests/integration/service_test.py::ServiceTest::test_start_container_creates_port_with_explicit_protocol PASSED [ 33%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v3_2 PASSED [ 74%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_load_yaml_with_bom PASSED [ 74%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_load_yaml_with_yaml_error PASSED [ 74%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_logs_warning_for_boolean_in_environment PASSED [ 74%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_blkio_config PASSED [ 74%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_configs_override PASSED [ 74%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_credential_spec PASSED [ 74%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_depends_on_mixed_syntax PASSED [ 74%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_depends_on_no_override PASSED [ 75%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_deploy PASSED   [ 75%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_deploy_override PASSED [ 75%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_device_cgroup_rules PASSED [ 75%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_different_configs PASSED [ 75%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_different_secrets PASSED [ 75%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_extra_hosts PASSED [ 75%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_config PASSED [ 75%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_override_disables PASSED [ 75%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_override_enables PASSED [ 75%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_isolation PASSED [ 75%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v1 PASSED [ 76%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2 PASSED [ 76%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_base PASSED [ 76%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_base_driver PASSED [ 76%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_drivers PASSED [ 76%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_override PASSED [ 76%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_override_options PASSED [ 76%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_override_driver PASSED [ 76%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_mixed_ports PASSED [ 76%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_pid PASSED      [ 76%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_scale PASSED    [ 76%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_secrets_override PASSED [ 76%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_from_files_with_extends_in_base PASSED [ 77%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_from_files_with_extends_in_override PASSED [ 77%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous PASSED [ 77%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous_2 PASSED [ 77%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous_volumes PASSED [ 77%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_ports_sorting PASSED [ 77%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_merge_storage_opt PASSED [ 77%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_named_volume_config_empty PASSED [ 77%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_named_volume_invalid_type_list PASSED [ 77%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_named_volume_numeric_driver_opt PASSED [ 77%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_networks_invalid_type_list PASSED [ 77%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_normalize_dns_options PASSED [ 78%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_oom_score_adj_option PASSED [ 78%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_runtime_option PASSED [ 78%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_service_volume_invalid_config PASSED [ 78%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_swappiness_option PASSED [ 78%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_tmpfs_option PASSED   [ 78%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_undeclared_volume_v1 PASSED [ 78%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_undeclared_volume_v2 PASSED [ 78%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_unsupported_version PASSED [ 78%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_v1_file_version PASSED [ 78%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_v1_file_with_version_is_invalid PASSED [ 78%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_valid_config_oneof_string_or_list PASSED [ 78%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_valid_config_which_allows_two_type_definitions PASSED [ 79%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_valid_versions PASSED [ 79%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_validate_extra_hosts_invalid PASSED [ 79%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_validate_extra_hosts_invalid_list PASSED [ 79%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_version_1_is_invalid PASSED [ 79%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_volume_invalid_driver_opt PASSED [ 79%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_volume_mode_override PASSED [ 79%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_volumes_long_syntax PASSED [ 79%]

01:40:40 tests/unit/config/config_test.py::ConfigTest::test_wrong_version_type PASSED [ 79%]

01:40:40 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_container PASSED [ 79%]

01:40:40 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_container_v1 PASSED [ 79%]

01:40:40 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_plus_networks_is_invalid PASSED [ 80%]

01:40:40 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service PASSED [ 80%]

01:40:40 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service_nonexistent PASSED [ 80%]

01:40:40 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service_v1 PASSED [ 80%]

01:40:40 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_standard PASSED [ 80%]

01:40:40 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_standard_v1 PASSED [ 80%]

01:40:40 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root PASSED [ 36%]

01:40:40 tests/unit/config/config_test.py::PortsTest::test_config_invalid_expose_format_validation PASSED [ 80%]

01:40:40 tests/unit/config/config_test.py::PortsTest::test_config_invalid_expose_type_validation PASSED [ 80%]

01:40:40 tests/unit/config/config_test.py::PortsTest::test_config_invalid_ports_format_validation PASSED [ 80%]

01:40:40 tests/unit/config/config_test.py::PortsTest::test_config_invalid_ports_type_validation PASSED [ 80%]

01:40:40 tests/unit/config/config_test.py::PortsTest::test_config_non_unique_expose_validation PASSED [ 80%]

01:40:40 tests/unit/config/config_test.py::PortsTest::test_config_non_unique_ports_validation PASSED [ 81%]

01:40:40 tests/unit/config/config_test.py::PortsTest::test_config_valid_expose_format_validation PASSED [ 81%]

01:40:40 tests/unit/config/config_test.py::PortsTest::test_config_valid_ports_format_validation PASSED [ 81%]

01:40:40 tests/unit/config/config_test.py::SubnetTest::test_config_invalid_subnet_format_validation PASSED [ 81%]

01:40:40 tests/unit/config/config_test.py::SubnetTest::test_config_invalid_subnet_type_validation PASSED [ 81%]

01:40:40 tests/unit/config/config_test.py::SubnetTest::test_config_valid_subnet_format_validation PASSED [ 81%]

01:40:40 tests/unit/config/config_test.py::InterpolationTest::test_compatibility_mode_load PASSED [ 81%]

01:40:40 tests/unit/config/config_test.py::InterpolationTest::test_compatibility_mode_warnings PASSED [ 81%]

01:40:40 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_file PASSED [ 81%]

01:40:40 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_variable PASSED [ 81%]

01:40:40 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_variable_with_defaults PASSED [ 81%]

01:40:40 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_options_environment_file PASSED [ 81%]

01:40:40 tests/unit/config/config_test.py::InterpolationTest::test_interpolation_configs_section PASSED [ 82%]

01:40:40 tests/unit/config/config_test.py::InterpolationTest::test_interpolation_secrets_section PASSED [ 82%]

01:40:40 tests/unit/config/config_test.py::InterpolationTest::test_invalid_interpolation PASSED [ 82%]

01:40:40 tests/unit/config/config_test.py::InterpolationTest::test_unset_variable_produces_warning PASSED [ 82%]

01:40:40 tests/unit/config/config_test.py::VolumeConfigTest::test_absolute_posix_path_does_not_expand PASSED [ 82%]

01:40:40 tests/unit/config/config_test.py::VolumeConfigTest::test_absolute_windows_path_does_not_expand PASSED [ 82%]

01:40:40 tests/unit/config/config_test.py::VolumeConfigTest::test_home_directory_with_driver_does_not_expand PASSED [ 82%]

01:40:40 tests/unit/config/config_test.py::VolumeConfigTest::test_name_does_not_expand PASSED [ 82%]

01:40:40 tests/unit/config/config_test.py::VolumeConfigTest::test_no_binding PASSED [ 82%]

01:40:40 tests/unit/config/config_test.py::VolumeConfigTest::test_relative_path_does_expand_posix PASSED [ 82%]

01:40:40 tests/unit/config/config_test.py::VolumeConfigTest::test_relative_path_does_expand_windows SKIPPED [ 82%]

01:40:40 tests/unit/config/config_test.py::VolumeConfigTest::test_volume_binding_with_environment_variable PASSED [ 83%]

01:40:40 tests/unit/config/config_test.py::VolumeConfigTest::test_volume_binding_with_home PASSED [ 83%]

01:40:40 tests/unit/config/config_test.py::VolumeConfigTest::test_volume_path_with_non_ascii_directory PASSED [ 83%]

01:40:40 tests/unit/config/config_test.py::VolumeConfigTest::test_volumes_order_is_preserved PASSED [ 83%]

01:40:40 tests/unit/config/config_test.py::MergeVolumesTest::test_add_explicit_path PASSED [ 83%]

01:40:40 tests/unit/config/config_test.py::MergeVolumesTest::test_empty PASSED    [ 83%]

01:40:40 tests/unit/config/config_test.py::MergeVolumesTest::test_no_base PASSED  [ 83%]

01:40:40 tests/unit/config/config_test.py::MergeVolumesTest::test_no_override PASSED [ 83%]

01:40:40 tests/unit/config/config_test.py::MergeVolumesTest::test_override_explicit_path PASSED [ 83%]

01:40:40 tests/unit/config/config_test.py::MergeVolumesTest::test_remove_explicit_path PASSED [ 83%]

01:40:40 tests/unit/config/config_test.py::MergeDevicesTest::test_add_explicit_path PASSED [ 83%]

01:40:40 tests/unit/config/config_test.py::MergeDevicesTest::test_empty PASSED    [ 84%]

01:40:40 tests/unit/config/config_test.py::MergeDevicesTest::test_no_base PASSED  [ 84%]

01:40:40 tests/unit/config/config_test.py::MergeDevicesTest::test_no_override PASSED [ 84%]

01:40:40 tests/unit/config/config_test.py::MergeDevicesTest::test_override_explicit_path PASSED [ 84%]

01:40:40 tests/unit/config/config_test.py::MergeDevicesTest::test_remove_explicit_path PASSED [ 84%]

01:40:40 tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_no_override PASSED [ 84%]

01:40:40 tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_override_with_other PASSED [ 84%]

01:40:40 tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_override_with_same PASSED [ 84%]

01:40:40 tests/unit/config/config_test.py::MergePortsTest::test_add_item PASSED   [ 84%]

01:40:40 tests/unit/config/config_test.py::MergePortsTest::test_duplicate_port_mappings PASSED [ 84%]

01:40:40 tests/unit/config/config_test.py::MergePortsTest::test_empty PASSED      [ 84%]

01:40:40 tests/unit/config/config_test.py::MergePortsTest::test_no_base PASSED    [ 84%]

01:40:40 tests/unit/config/config_test.py::MergePortsTest::test_no_override PASSED [ 85%]

01:40:40 tests/unit/config/config_test.py::MergeNetworksTest::test_add_item PASSED [ 85%]

01:40:40 tests/unit/config/config_test.py::MergeNetworksTest::test_all_properties PASSED [ 85%]

01:40:40 tests/unit/config/config_test.py::MergeNetworksTest::test_empty PASSED   [ 85%]

01:40:40 tests/unit/config/config_test.py::MergeNetworksTest::test_network_has_none_value PASSED [ 85%]

01:40:40 tests/unit/config/config_test.py::MergeNetworksTest::test_no_base PASSED [ 85%]

01:40:40 tests/unit/config/config_test.py::MergeNetworksTest::test_no_network_name_overrides PASSED [ 85%]

01:40:40 tests/unit/config/config_test.py::MergeNetworksTest::test_no_network_overrides PASSED [ 85%]

01:40:40 tests/unit/config/config_test.py::MergeNetworksTest::test_no_override PASSED [ 85%]

01:40:40 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_add_list PASSED [ 85%]

01:40:40 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_add_string PASSED [ 85%]

01:40:40 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_no_base PASSED [ 86%]

01:40:40 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_no_override PASSED [ 86%]

01:40:40 tests/unit/config/config_test.py::MergeLabelsTest::test_add_explicit_value PASSED [ 86%]

01:40:40 tests/unit/config/config_test.py::MergeLabelsTest::test_empty PASSED     [ 86%]

01:40:40 tests/unit/config/config_test.py::MergeLabelsTest::test_no_base PASSED   [ 86%]

01:40:40 tests/unit/config/config_test.py::MergeLabelsTest::test_no_override PASSED [ 86%]

01:40:40 tests/unit/config/config_test.py::MergeLabelsTest::test_override_explicit_value PASSED [ 86%]

01:40:40 tests/unit/config/config_test.py::MergeLabelsTest::test_remove_explicit_value PASSED [ 86%]

01:40:40 tests/unit/config/config_test.py::MergeBuildTest::test_empty_base PASSED [ 86%]

01:40:40 tests/unit/config/config_test.py::MergeBuildTest::test_empty_override PASSED [ 86%]

01:40:40 tests/unit/config/config_test.py::MergeBuildTest::test_full PASSED       [ 86%]

01:40:40 tests/unit/config/config_test.py::MemoryOptionsTest::test_memswap_can_be_a_string PASSED [ 86%]

01:40:40 tests/unit/config/config_test.py::MemoryOptionsTest::test_validation_fails_with_just_memswap_limit PASSED [ 87%]

01:40:40 tests/unit/config/config_test.py::MemoryOptionsTest::test_validation_with_correct_memswap_values PASSED [ 87%]

01:40:40 tests/unit/config/config_test.py::EnvTest::test_environment_overrides_env_file PASSED [ 87%]

01:40:40 tests/unit/config/config_test.py::EnvTest::test_parse_environment_as_dict PASSED [ 87%]

01:40:40 tests/unit/config/config_test.py::EnvTest::test_parse_environment_as_list PASSED [ 87%]

01:40:40 tests/unit/config/config_test.py::EnvTest::test_parse_environment_empty PASSED [ 87%]

01:40:40 tests/unit/config/config_test.py::EnvTest::test_parse_environment_invalid PASSED [ 87%]

01:40:40 tests/unit/config/config_test.py::EnvTest::test_resolve_build_args PASSED [ 87%]

01:40:40 tests/unit/config/config_test.py::EnvTest::test_resolve_environment PASSED [ 87%]

01:40:40 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_from_env_file PASSED [ 87%]

01:40:40 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_from_env_file_with_empty_values PASSED [ 87%]

01:40:40 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_nonexistent_file PASSED [ 88%]

01:40:40 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_with_multiple_env_files PASSED [ 88%]

01:40:40 tests/unit/config/config_test.py::EnvTest::test_resolve_path PASSED      [ 88%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_circular PASSED      [ 88%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_invalid_config PASSED [ 88%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_valid_config PASSED [ 88%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_verbose_and_shorthand_way PASSED [ 88%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_extends PASSED       [ 88%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_file_defaults_to_self PASSED [ 88%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_empty_dictionary PASSED [ 88%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_invalid_key PASSED [ 88%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_missing_service_key PASSED [ 89%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_no_file_key_no_filename_set PASSED [ 89%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_sub_property_key PASSED [ 89%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_valid_config PASSED [ 89%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_defined_version_passes PASSED [ 89%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_depends_on PASSED [ 89%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_environment_and_env_files PASSED [ 89%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_healthcheck PASSED [ 89%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_mixed_versions_is_error PASSED [ 89%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_ports PASSED [ 89%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_security_opt PASSED [ 89%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_invalid_links_in_extended_service PASSED [ 89%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_invalid_net_in_extended_service PASSED [ 90%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_invalid_volumes_from_in_extended_service PASSED [ 90%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_load_config_runs_interpolation_in_extended_service PASSED [ 90%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_load_throws_error_when_base_service_does_not_exist PASSED [ 90%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_merging_env_labels_ulimits PASSED [ 90%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_nested PASSED        [ 90%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_parent_build_path_dne PASSED [ 90%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_partial_service_config_in_extends_is_still_valid PASSED [ 90%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_self_referencing_file PASSED [ 90%]

01:40:40 tests/unit/config/config_test.py::ExtendsTest::test_volume_path PASSED   [ 90%]

01:40:40 tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_absolute PASSED [ 90%]

01:40:40 tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_normal PASSED [ 91%]

01:40:40 tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_with_tilde PASSED [ 91%]

01:40:40 tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_root_mount PASSED [ 91%]

01:40:40 tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_windows_path PASSED [ 91%]

01:40:40 tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_windows_path_in_container PASSED [ 91%]

01:40:40 tests/unit/config/config_test.py::BuildPathTest::test_absolute_path PASSED [ 91%]

01:40:40 tests/unit/config/config_test.py::BuildPathTest::test_from_file PASSED   [ 91%]

01:40:40 tests/unit/config/config_test.py::BuildPathTest::test_from_file_override_dir PASSED [ 91%]

01:40:40 tests/unit/config/config_test.py::BuildPathTest::test_invalid_url_in_build_path PASSED [ 91%]

01:40:40 tests/unit/config/config_test.py::BuildPathTest::test_nonexistent_path PASSED [ 91%]

01:40:40 tests/unit/config/config_test.py::BuildPathTest::test_relative_path PASSED [ 91%]

01:40:40 tests/unit/config/config_test.py::BuildPathTest::test_valid_url_in_build_path PASSED [ 92%]

01:40:41 tests/integration/service_test.py::ServiceTest::test_start_container_creates_ports PASSED [ 33%]

01:40:41 tests/unit/config/config_test.py::HealthcheckTest::test_disable PASSED   [ 92%]

01:40:41 tests/unit/config/config_test.py::HealthcheckTest::test_disable_with_other_config_is_invalid PASSED [ 92%]

01:40:41 tests/unit/config/config_test.py::HealthcheckTest::test_healthcheck PASSED [ 92%]

01:40:41 tests/unit/config/config_test.py::HealthcheckTest::test_healthcheck_with_invalid_test PASSED [ 92%]

01:40:41 tests/unit/config/config_test.py::GetDefaultConfigFilesTestCase::test_get_config_path_default_file_in_basedir PASSED [ 92%]

01:40:41 tests/unit/config/config_test.py::GetDefaultConfigFilesTestCase::test_get_config_path_default_file_in_parent_dir PASSED [ 92%]

01:40:41 tests/unit/config/config_test.py::SerializeTest::test_denormalize_depends_on_v2_1 PASSED [ 92%]

01:40:41 tests/unit/config/config_test.py::SerializeTest::test_denormalize_depends_on_v3 PASSED [ 92%]

01:40:41 tests/unit/config/config_test.py::SerializeTest::test_denormalize_healthcheck PASSED [ 92%]

01:40:41 tests/unit/config/config_test.py::SerializeTest::test_denormalize_image_has_digest PASSED [ 92%]

01:40:41 tests/unit/config/config_test.py::SerializeTest::test_denormalize_image_no_digest PASSED [ 92%]

01:40:41 tests/unit/config/config_test.py::SerializeTest::test_serialize_bool_string PASSED [ 93%]

01:40:41 tests/unit/config/config_test.py::SerializeTest::test_serialize_configs PASSED [ 93%]

01:40:41 tests/unit/config/config_test.py::SerializeTest::test_serialize_escape_dollar_sign PASSED [ 93%]

01:40:41 tests/unit/config/config_test.py::SerializeTest::test_serialize_escape_dont_interpolate PASSED [ 93%]

01:40:41 tests/unit/config/config_test.py::SerializeTest::test_serialize_external_false PASSED [ 93%]

01:40:41 tests/unit/config/config_test.py::SerializeTest::test_serialize_ports PASSED [ 93%]

01:40:41 tests/unit/config/config_test.py::SerializeTest::test_serialize_ports_with_ext_ip PASSED [ 93%]

01:40:41 tests/unit/config/config_test.py::SerializeTest::test_serialize_secrets PASSED [ 93%]

01:40:41 tests/unit/config/config_test.py::SerializeTest::test_serialize_time PASSED [ 93%]

01:40:41 tests/unit/config/config_test.py::SerializeTest::test_serialize_unicode_values PASSED [ 93%]

01:40:41 tests/unit/config/environment_test.py::EnvironmentTest::test_env_vars_from_file_bom PASSED [ 93%]

01:40:41 tests/unit/config/environment_test.py::EnvironmentTest::test_env_vars_from_file_whitespace PASSED [ 94%]

01:40:41 tests/unit/config/environment_test.py::EnvironmentTest::test_get_boolean PASSED [ 94%]

01:40:41 tests/unit/config/environment_test.py::EnvironmentTest::test_get_simple PASSED [ 94%]

01:40:41 tests/unit/config/environment_test.py::EnvironmentTest::test_get_undefined PASSED [ 94%]

01:40:41 tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_services PASSED [ 94%]

01:40:41 tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_volumes PASSED [ 94%]

01:40:41 tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_secrets PASSED [ 94%]

01:40:41 tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_v2 PASSED [ 94%]

01:40:41 tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_v3 PASSED [ 94%]

01:40:41 tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_invalid PASSED [ 94%]

01:40:41 tests/unit/config/interpolation_test.py::test_interpolate_environment_network_convert_types PASSED [ 94%]

01:40:41 tests/unit/config/interpolation_test.py::test_interpolate_environment_external_resource_convert_types PASSED [ 94%]

01:40:41 tests/unit/config/interpolation_test.py::test_interpolate_service_name_uses_dot PASSED [ 95%]

01:40:41 tests/unit/config/interpolation_test.py::test_escaped_interpolation PASSED [ 95%]

01:40:41 tests/unit/config/interpolation_test.py::test_invalid_interpolation PASSED [ 95%]

01:40:41 tests/unit/config/interpolation_test.py::test_interpolate_missing_no_default PASSED [ 95%]

01:40:41 tests/unit/config/interpolation_test.py::test_interpolate_with_value PASSED [ 95%]

01:40:41 tests/unit/config/interpolation_test.py::test_interpolate_missing_with_default PASSED [ 95%]

01:40:41 tests/unit/config/interpolation_test.py::test_interpolate_with_empty_and_default_value PASSED [ 95%]

01:40:41 tests/unit/config/interpolation_test.py::test_interpolate_mandatory_values PASSED [ 95%]

01:40:41 tests/unit/config/interpolation_test.py::test_interpolate_mandatory_no_err_msg PASSED [ 95%]

01:40:41 tests/unit/config/interpolation_test.py::test_interpolate_mixed_separators PASSED [ 95%]

01:40:41 tests/unit/config/interpolation_test.py::test_unbraced_separators PASSED [ 95%]

01:40:41 tests/unit/config/interpolation_test.py::test_interpolate_unicode_values PASSED [ 96%]

01:40:41 tests/unit/config/interpolation_test.py::test_interpolate_no_fallthrough PASSED [ 96%]

01:40:41 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_1 PASSED [ 96%]

01:40:41 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_2 PASSED [ 96%]

01:40:41 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_3 PASSED [ 96%]

01:40:41 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_4 PASSED [ 96%]

01:40:41 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_5 PASSED [ 96%]

01:40:41 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_6 PASSED [ 96%]

01:40:41 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_7 PASSED [ 96%]

01:40:41 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports PASSED [ 96%]

01:40:41 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports_2 PASSED [ 96%]

01:40:41 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports_3 PASSED [ 97%]

01:40:41 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_self_imports PASSED [ 97%]

01:40:41 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_depends_on_self PASSED [ 97%]

01:40:41 tests/unit/config/types_test.py::test_parse_extra_hosts_list PASSED      [ 97%]

01:40:41 tests/unit/config/types_test.py::test_parse_extra_hosts_dict PASSED      [ 97%]

01:40:41 tests/unit/config/types_test.py::TestServicePort::test_parse_dict PASSED [ 97%]

01:40:41 tests/unit/config/types_test.py::TestServicePort::test_parse_simple_target_port PASSED [ 97%]

01:40:41 tests/unit/config/types_test.py::TestServicePort::test_parse_complete_port_definition PASSED [ 97%]

01:40:41 tests/unit/config/types_test.py::TestServicePort::test_parse_ext_ip_no_published_port PASSED [ 97%]

01:40:41 tests/unit/config/types_test.py::TestServicePort::test_repr_published_port_0 PASSED [ 97%]

01:40:41 tests/unit/config/types_test.py::TestServicePort::test_parse_port_range PASSED [ 97%]

01:40:41 tests/unit/config/types_test.py::TestServicePort::test_parse_port_publish_range PASSED [ 97%]

01:40:41 tests/unit/config/types_test.py::TestServicePort::test_parse_invalid_port PASSED [ 98%]

01:40:41 tests/unit/config/types_test.py::TestServicePort::test_parse_invalid_publish_range PASSED [ 98%]

01:40:41 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_only_one_path PASSED [ 98%]

01:40:41 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_internal_and_external PASSED [ 98%]

01:40:41 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_with_mode PASSED [ 98%]

01:40:41 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_too_many_parts PASSED [ 98%]

01:40:41 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_absolute_path_normalized PASSED [ 98%]

01:40:41 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_absolute_path_native PASSED [ 98%]

01:40:41 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_internal_path_normalized PASSED [ 98%]

01:40:41 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_internal_path_native PASSED [ 98%]

01:40:41 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_just_drives_normalized PASSED [ 98%]

01:40:41 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_just_drives_native PASSED [ 99%]

01:40:41 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_mixed_notations_normalized PASSED [ 99%]

01:40:41 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_mixed_notations_native PASSED [ 99%]

01:40:41 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_from_service PASSED [ 99%]

01:40:41 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_from_container PASSED [ 99%]

01:40:41 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_invalid PASSED [ 99%]

01:40:41 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_service PASSED [ 99%]

01:40:41 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_service_with_mode PASSED [ 99%]

01:40:41 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_container PASSED [ 99%]

01:40:41 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_container_with_mode PASSED [ 99%]

01:40:41 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_invalid_type PASSED [ 99%]

01:40:41 tests/integration/service_test.py::ServiceTest::test_start_container_inherits_options_from_constructor PASSED [ 34%]

01:40:42 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_invalid PASSED [100%]

01:40:42 

01:40:42 ----------- coverage: platform linux, python 3.7.4-final-0 -----------

01:40:42 Name                              Stmts   Miss Branch BrPart  Cover   Missing

01:40:42 -----------------------------------------------------------------------------

01:40:42 compose/__init__.py                   3      0      0      0   100%

01:40:42 compose/__main__.py                   4      4      0      0     0%   1-6

01:40:42 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

01:40:42 compose/cli/__init__.py               0      0      0      0   100%

01:40:42 compose/cli/colors.py                23      2     10      2    88%   37-38, 36->37, 48->exit

01:40:42 compose/cli/command.py               93     14     28      4    82%   71-81, 88, 125-130, 174, 70->71, 87->88, 124->125, 171->174

01:40:42 compose/cli/docker_client.py         75      5     24      2    93%   24, 98-99, 107, 123, 106->107, 122->123

01:40:42 compose/cli/docopt_command.py        38      4      8      2    87%   13-14, 29, 35, 28->29, 34->35

01:40:42 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

01:40:42 compose/cli/formatter.py             34      2     10      1    93%   17-18, 15->17

01:40:42 compose/cli/log_printer.py          144     14     52      6    89%   76, 103, 110-115, 162-164, 173, 226-229, 233-234, 253, 43->exit, 75->76, 98->103, 171->173, 225->226, 232->233

01:40:42 compose/cli/main.py                 695     90    307     40    85%   83-84, 86-87, 168, 328, 360-362, 445, 505, 509, 514-515, 525-554, 566, 584-586, 657-658, 696-697, 715, 736-737, 749, 772, 790, 837, 1069, 1078, 1104-1113, 1153-1156, 1164-1168, 1170-1175, 1198, 1220-1249, 1256-1257, 1259-1261, 1276, 1282, 1466, 1484, 1500, 1504-1505, 1516, 1521, 1524, 1550, 1569-1571, 1581, 1592, 60->63, 82->83, 85->86, 167->168, 327->328, 359->360, 444->445, 504->505, 508->509, 519->525, 563->566, 583->584, 655->657, 714->715, 735->736, 748->749, 771->772, 827->837, 829->exit, 1068->1069, 1077->1078, 1163->1164, 1169->1170, 1197->1198, 1255->1256, 1258->1259, 1275->1276, 1281->1282, 1465->1466, 1483->1484, 1499->1500, 1515->1516, 1520->1521, 1523->1524, 1542->exit, 1549->1550, 1563->1571, 1565->1569, 1580->1581, 1590->1592

01:40:42 compose/cli/signals.py               23      0      4      2    93%   36->exit, 43->exit

01:40:42 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

01:40:42 compose/cli/verbose_proxy.py         35     12     10      0    69%   36-39, 42-47, 50-60

01:40:42 compose/config/__init__.py           13      0      0      0   100%

01:40:42 compose/config/config.py            826     30    428     18    95%   266, 277, 508, 621-622, 714, 757, 812-830, 952-953, 959, 979, 982, 1335, 1366, 1412, 265->266, 276->277, 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

01:40:42 compose/config/environment.py       100      8     34      5    90%   21, 41, 104-107, 120, 127, 20->21, 40->41, 103->104, 119->120, 126->127

01:40:42 compose/config/errors.py             25      2      2      0    85%   36-40

01:40:42 compose/config/interpolation.py     148      6     64      3    95%   66, 148, 222, 227-229, 121->exit, 146->148, 221->222

01:40:42 compose/config/serialize.py          97      2     58      3    97%   31, 76, 30->31, 75->76, 82->85

01:40:42 compose/config/sort_services.py      44      1     24      1    97%   57, 56->57

01:40:42 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

01:40:42 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

01:40:42 compose/const.py                     36      0      0      0   100%

01:40:42 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

01:40:42 compose/errors.py                    17      1      0      0    94%   12

01:40:42 compose/network.py                  190     19     95      5    87%   184, 186-200, 206, 224, 226, 183->184, 185->186, 205->206, 223->224, 225->226

01:40:42 compose/parallel.py                 199      2     58      1    99%   187, 326, 325->326

01:40:42 compose/progress_stream.py           79      8     40      9    86%   40, 71, 74, 80, 85, 90-91, 116, 39->40, 42->46, 53->57, 70->71, 73->74, 79->80, 84->85, 89->90, 112->116

01:40:42 compose/project.py                  424     29    201     16    92%   60, 156, 212-213, 254-255, 364-365, 378-381, 434, 485, 489, 615, 621, 624-627, 752-753, 759-762, 777, 782-785, 788, 809, 57->60, 152->156, 331->333, 362->364, 377->378, 433->434, 484->485, 488->489, 614->615, 620->621, 623->624, 671->exit, 755->762, 776->777, 781->782, 787->788

01:40:42 compose/service.py                  854     50    433     26    93%   271-272, 293, 366-369, 417-422, 428-430, 470-471, 485, 488, 506, 573, 618-619, 727, 946-947, 967-968, 1069, 1115, 1176, 1218, 1240-1255, 1295, 1334-1338, 1526, 1530, 1646, 1686, 1698, 216->exit, 269->271, 292->293, 427->428, 469->470, 484->485, 487->488, 505->506, 563->573, 722->727, 945->946, 966->967, 1068->1069, 1114->1115, 1175->1176, 1217->1218, 1294->1295, 1331->1334, 1525->1526, 1529->1530, 1578->exit, 1586->1585, 1623->1620, 1645->1646, 1685->1686, 1697->1698

01:40:42 compose/state.py                      0      0      0      0   100%

01:40:42 compose/timeparse.py                 22      0      4      0   100%

01:40:42 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

01:40:42 compose/version.py                    6      0      0      0   100%

01:40:42 compose/volume.py                   126      4     44      3    95%   150, 200, 211-212, 141->150, 199->200, 209->211

01:40:42 -----------------------------------------------------------------------------

01:40:42 TOTAL                              5553    436   2401    205    91%

01:40:42 Coverage HTML written to dir coverage-html

01:40:42 

01:40:42 =========================== short test summary info ============================

01:40:42 XFAIL tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_rt

01:40:42   not supported by kernel

01:40:42 XFAIL tests/integration/service_test.py::ServiceTest::test_create_container_with_storage_opt

01:40:42   Not supported on most drivers

01:40:42 SKIP [1] tests/acceptance/cli_test.py:2424: race condition between up and logs

01:40:42 SKIP [1] tests/acceptance/cli_test.py:2376: race condition between up and logs

01:40:42 SKIP [1] tests/acceptance/cli_test.py:2403: race condition between up and logs

01:40:42 SKIP [1] /code/tests/integration/testcases.py:167: This daemon does not support the 'nvidia'' runtime

01:40:42 SKIP [1] tests/integration/service_test.py:148: cpu_percent is not supported for Linux

01:40:42 SKIP [1] tests/integration/service_test.py:1635: Broken on 1.11.0 - 17.03.0

01:40:42 SKIP [1] tests/unit/cli/command_test.py:39: windows separator

01:40:42 SKIP [1] tests/unit/cli/command_test.py:69: Env values in Python 3 are already Unicode

01:40:42 SKIP [1] tests/unit/cli/errors_test.py:70: Needs pywin32

01:40:42 SKIP [1] tests/unit/cli/errors_test.py:80: Needs pywin32

01:40:42 SKIP [1] tests/unit/cli/errors_test.py:90: Needs pywin32

01:40:42 SKIP [1] tests/unit/config/config_test.py:3777: windows paths

01:40:42 

01:40:42 ======= 1121 passed, 12 skipped, 2 xfailed, 3 xpassed in 735.24 seconds ========

01:40:42 ___________________________________ summary ____________________________________

01:40:42   py37: commands succeeded

01:40:42   congratulations :)

01:40:42 tests/integration/service_test.py::ServiceTest::test_start_container_passes_through_options PASSED [ 34%]

01:40:42 + on_exit
01:40:42 + [[ 0 != \0 ]]
01:40:42 + docker rm -vf compose-dind-19.03.2-rc1-jenkins-compose-PR-6850-2
01:40:42 tests/integration/service_test.py::ServiceTest::test_start_container_stays_unprivileged PASSED [ 34%]

01:40:42 compose-dind-19.03.2-rc1-jenkins-compose-PR-6850-2
[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // withDockerRegistry
[Pipeline] }
[Pipeline] // node
[Pipeline] }
01:40:45 tests/integration/service_test.py::ServiceTest::test_start_container_uses_tagged_image_if_it_exists PASSED [ 34%]

01:40:45 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_invalid PASSED [100%]

01:40:45 

01:40:45 ---------- coverage: platform linux2, python 2.7.13-final-0 ----------

01:40:45 Name                              Stmts   Miss Branch BrPart  Cover   Missing

01:40:45 -----------------------------------------------------------------------------

01:40:45 compose/__init__.py                   3      0      0      0   100%

01:40:45 compose/__main__.py                   4      4      0      0     0%   1-6

01:40:45 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

01:40:45 compose/cli/__init__.py               0      0      0      0   100%

01:40:45 compose/cli/colors.py                23      2     10      2    88%   37-38, 36->37, 48->exit

01:40:45 compose/cli/command.py               93     14     26      4    82%   71-81, 88, 125-130, 174, 70->71, 87->88, 124->125, 171->174

01:40:45 compose/cli/docker_client.py         75      5     24      2    93%   24, 98-99, 107, 123, 106->107, 122->123

01:40:45 compose/cli/docopt_command.py        38      4      8      2    87%   13-14, 29, 35, 28->29, 34->35

01:40:45 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

01:40:45 compose/cli/formatter.py             34      2      8      1    93%   17-18, 15->17

01:40:45 compose/cli/log_printer.py          144     14     50      6    89%   76, 103, 110-115, 162-164, 173, 226-229, 233-234, 253, 43->exit, 75->76, 98->103, 171->173, 225->226, 232->233

01:40:45 compose/cli/main.py                 695     90    292     40    84%   83-84, 86-87, 168, 328, 360-362, 445, 505, 509, 514-515, 525-554, 566, 584-586, 657-658, 696-697, 715, 736-737, 749, 772, 790, 837, 1069, 1078, 1104-1113, 1153-1156, 1164-1168, 1170-1175, 1198, 1220-1249, 1256-1257, 1259-1261, 1276, 1282, 1466, 1484, 1500, 1504-1505, 1516, 1521, 1524, 1550, 1569-1571, 1581, 1592, 60->63, 82->83, 85->86, 167->168, 327->328, 359->360, 444->445, 504->505, 508->509, 519->525, 563->566, 583->584, 655->657, 714->715, 735->736, 748->749, 771->772, 827->837, 829->exit, 1068->1069, 1077->1078, 1163->1164, 1169->1170, 1197->1198, 1255->1256, 1258->1259, 1275->1276, 1281->1282, 1465->1466, 1483->1484, 1499->1500, 1515->1516, 1520->1521, 1523->1524, 1542->exit, 1549->1550, 1563->1571, 1565->1569, 1580->1581, 1590->1592

01:40:45 compose/cli/signals.py               23      0      4      2    93%   36->exit, 43->exit

01:40:45 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

01:40:45 compose/cli/verbose_proxy.py         35     12     10      0    69%   36-39, 42-47, 50-60

01:40:45 compose/config/__init__.py           13      0      0      0   100%

01:40:45 compose/config/config.py            826     30    388     18    95%   266, 277, 508, 621-622, 714, 757, 812-830, 952-953, 959, 979, 982, 1335, 1366, 1412, 265->266, 276->277, 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

01:40:45 compose/config/environment.py       100      7     34      4    92%   41, 104-107, 120, 127, 40->41, 103->104, 119->120, 126->127

01:40:45 compose/config/errors.py             25      2      0      0    92%   36-40

01:40:45 compose/config/interpolation.py     148      7     62      4    94%   66, 148, 196, 222, 227-229, 121->exit, 146->148, 195->196, 221->222

01:40:45 compose/config/serialize.py          97      1     50      2    98%   76, 75->76, 82->85

01:40:45 compose/config/sort_services.py      44      1     18      1    97%   57, 56->57

01:40:45 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

01:40:45 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

01:40:45 compose/const.py                     36      0      0      0   100%

01:40:45 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

01:40:45 compose/errors.py                    17      1      0      0    94%   12

01:40:45 compose/network.py                  190     19     92      5    87%   184, 186-200, 206, 224, 226, 183->184, 185->186, 205->206, 223->224, 225->226

01:40:45 compose/parallel.py                 199      2     56      1    99%   187, 326, 325->326

01:40:45 compose/progress_stream.py           79      8     40      9    86%   40, 71, 74, 80, 85, 90-91, 116, 39->40, 42->46, 53->57, 70->71, 73->74, 79->80, 84->85, 89->90, 112->116

01:40:45 compose/project.py                  424     29    170     16    92%   60, 156, 212-213, 254-255, 364-365, 378-381, 434, 485, 489, 615, 621, 624-627, 752-753, 759-762, 777, 782-785, 788, 809, 57->60, 152->156, 331->333, 362->364, 377->378, 433->434, 484->485, 488->489, 614->615, 620->621, 623->624, 671->exit, 755->762, 776->777, 781->782, 787->788

01:40:45 compose/service.py                  854     48    380     24    94%   271-272, 293, 366-369, 417-422, 428-430, 470-471, 485, 488, 506, 573, 618-619, 727, 946-947, 967-968, 1069, 1115, 1176, 1218, 1240-1255, 1295, 1334-1338, 1526, 1530, 1686, 216->exit, 269->271, 292->293, 427->428, 469->470, 484->485, 487->488, 505->506, 563->573, 722->727, 945->946, 966->967, 1068->1069, 1114->1115, 1175->1176, 1217->1218, 1294->1295, 1331->1334, 1525->1526, 1529->1530, 1578->exit, 1586->1585, 1623->1620, 1685->1686

01:40:45 compose/state.py                      0      0      0      0   100%

01:40:45 compose/timeparse.py                 22      0      4      0   100%

01:40:45 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

01:40:45 compose/version.py                    6      0      0      0   100%

01:40:45 compose/volume.py                   126      4     44      3    95%   150, 200, 211-212, 141->150, 199->200, 209->211

01:40:45 -----------------------------------------------------------------------------

01:40:45 TOTAL                              5553    433   2224    202    91%

01:40:45 Coverage HTML written to dir coverage-html

01:40:45 

01:40:45 =========================== short test summary info ============================

01:40:45 XFAIL tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_rt

01:40:45   not supported by kernel

01:40:45 XFAIL tests/integration/service_test.py::ServiceTest::test_create_container_with_storage_opt

01:40:45   Not supported on most drivers

01:40:45 SKIP [1] /code/tests/integration/testcases.py:167: This daemon does not support the 'nvidia'' runtime

01:40:45 SKIP [1] tests/integration/service_test.py:148: cpu_percent is not supported for Linux

01:40:45 SKIP [1] tests/unit/cli/errors_test.py:70: Needs pywin32

01:40:45 SKIP [1] tests/unit/cli/errors_test.py:90: Needs pywin32

01:40:45 SKIP [1] tests/unit/cli/command_test.py:39: windows separator

01:40:45 SKIP [1] tests/acceptance/cli_test.py:2403: race condition between up and logs

01:40:45 SKIP [1] tests/unit/cli/errors_test.py:80: Needs pywin32

01:40:45 SKIP [1] tests/integration/service_test.py:1635: Broken on 1.11.0 - 17.03.0

01:40:45 SKIP [1] tests/acceptance/cli_test.py:2376: race condition between up and logs

01:40:45 SKIP [1] tests/acceptance/cli_test.py:2424: race condition between up and logs

01:40:45 SKIP [1] tests/unit/config/config_test.py:3777: windows paths

01:40:45 

01:40:45 ======= 1122 passed, 11 skipped, 2 xfailed, 3 xpassed in 787.57 seconds ========

01:40:45 ___________________________________ summary ____________________________________

01:40:45   py27: commands succeeded

01:40:45   congratulations :)

01:40:45 + on_exit
01:40:45 + [[ 0 != \0 ]]
01:40:45 + docker rm -vf compose-dind-19.03.2-rc1-jenkins-compose-PR-6850-2
01:40:45 compose-dind-19.03.2-rc1-jenkins-compose-PR-6850-2
[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // withDockerRegistry
[Pipeline] }
[Pipeline] // node
[Pipeline] }
Terminated
01:40:46 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root_always_recreate_deps PASSED [ 36%]

01:40:47 tests/integration/service_test.py::ServiceTest::test_start_container_with_external_links PASSED [ 34%]

01:40:48 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root_no_recreate PASSED [ 36%]

01:40:49 tests/integration/service_test.py::ServiceTest::test_start_normal_container_does_not_create_links_to_its_own_service PASSED [ 34%]

01:40:50 tests/integration/service_test.py::ServiceTest::test_start_one_off_container_creates_links_to_its_own_service PASSED [ 34%]

01:40:51 tests/integration/service_test.py::ServiceTest::test_stop_signal PASSED  [ 34%]

01:40:51 tests/integration/state_test.py::ProjectWithDependenciesTest::test_service_recreated_when_dependency_created PASSED [ 36%]

01:40:52 tests/integration/service_test.py::ServiceTest::test_tmpfs PASSED        [ 34%]

01:40:52 tests/integration/service_test.py::ServiceTest::test_userns_mode_host PASSED [ 34%]

01:40:53 tests/integration/service_test.py::ServiceTest::test_userns_mode_none_defined PASSED [ 34%]

01:40:53 tests/integration/service_test.py::ServiceTest::test_with_high_enough_api_version_we_get_default_network_mode PASSED [ 34%]

01:40:53 tests/integration/service_test.py::ServiceTest::test_working_dir_param PASSED [ 35%]

01:40:54 tests/integration/service_test.py::ConfigHashTest::test_config_hash_sticks_around PASSED [ 35%]

01:40:55 tests/integration/service_test.py::ConfigHashTest::test_config_hash_with_custom_labels PASSED [ 35%]

01:40:55 tests/integration/service_test.py::ConfigHashTest::test_no_config_hash_when_one_off PASSED [ 35%]

01:40:55 tests/integration/service_test.py::ConfigHashTest::test_no_config_hash_when_overriding_options PASSED [ 35%]

Terminated
01:40:57 tests/integration/state_test.py::BasicProjectTest::test_all_change PASSED [ 35%]

01:40:58 tests/integration/state_test.py::ProjectWithDependenciesTest::test_service_removed_while_down PASSED [ 36%]

01:40:58 tests/integration/state_test.py::BasicProjectTest::test_no_change PASSED [ 35%]

01:40:59 tests/integration/state_test.py::ProjectWithDependenciesTest::test_up PASSED [ 36%]

01:41:00 tests/integration/state_test.py::BasicProjectTest::test_partial_change PASSED [ 35%]

01:41:03 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_leaf PASSED [ 36%]

01:41:03 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_leaf PASSED [ 35%]

01:41:06 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_middle PASSED [ 36%]

01:41:07 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_middle PASSED [ 35%]

01:41:11 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_middle_always_recreate_deps PASSED [ 36%]

01:41:12 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_middle_always_recreate_deps PASSED [ 35%]

01:41:15 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root PASSED [ 36%]

01:41:16 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root PASSED [ 36%]

01:41:22 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root_always_recreate_deps PASSED [ 36%]

01:41:24 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root_always_recreate_deps PASSED [ 36%]

01:41:24 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root_no_recreate PASSED [ 36%]

01:41:24 tests/integration/state_test.py::ProjectWithDependenciesTest::test_change_root_no_recreate PASSED [ 36%]

01:41:27 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_dependency_added PASSED [ 37%]

01:41:28 tests/integration/state_test.py::ProjectWithDependenciesTest::test_service_recreated_when_dependency_created PASSED [ 36%]

01:41:32 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_dependency_removed PASSED [ 37%]

01:41:35 tests/integration/state_test.py::ProjectWithDependenciesTest::test_service_removed_while_down PASSED [ 36%]

01:41:36 tests/integration/state_test.py::ProjectWithDependenciesTest::test_up PASSED [ 36%]

01:41:39 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_service_removed_while_down PASSED [ 37%]

01:41:41 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_leaf PASSED [ 36%]

01:41:43 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_service_removed_while_up PASSED [ 37%]

01:41:44 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_up PASSED [ 37%]

01:41:45 tests/integration/state_test.py::ServiceStateTest::test_image_changed_to_build PASSED [ 37%]

01:41:45 tests/integration/state_test.py::ServiceStateTest::test_trigger_create PASSED [ 37%]

01:41:46 tests/integration/state_test.py::ServiceStateTest::test_trigger_noop PASSED [ 37%]

01:41:46 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_middle PASSED [ 36%]

01:41:48 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_build <- tests/integration/testcases.py PASSED [ 37%]

01:41:48 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_config_change PASSED [ 37%]

01:41:49 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_image_change PASSED [ 37%]

01:41:49 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_nonexistent_image_tag PASSED [ 38%]

01:41:50 tests/integration/state_test.py::ServiceStateTest::test_trigger_start PASSED [ 38%]

01:41:50 tests/integration/volume_test.py::VolumeTest::test_create_volume PASSED  [ 38%]

01:41:50 tests/integration/volume_test.py::VolumeTest::test_create_volume_custom_name PASSED [ 38%]

01:41:50 tests/integration/volume_test.py::VolumeTest::test_exists <- tests/integration/testcases.py PASSED [ 38%]

01:41:50 tests/integration/volume_test.py::VolumeTest::test_exists_external <- tests/integration/testcases.py PASSED [ 38%]

01:41:50 tests/integration/volume_test.py::VolumeTest::test_exists_external_aliased <- tests/integration/testcases.py PASSED [ 38%]

01:41:50 tests/integration/volume_test.py::VolumeTest::test_external_aliased_volume <- tests/integration/testcases.py PASSED [ 38%]

01:41:50 tests/integration/volume_test.py::VolumeTest::test_external_volume <- tests/integration/testcases.py PASSED [ 38%]

01:41:50 tests/integration/volume_test.py::VolumeTest::test_inspect_volume <- tests/integration/testcases.py PASSED [ 38%]

01:41:50 tests/integration/volume_test.py::VolumeTest::test_recreate_existing_volume PASSED [ 38%]

01:41:50 tests/integration/volume_test.py::VolumeTest::test_remove_volume <- tests/integration/testcases.py PASSED [ 39%]

01:41:50 tests/integration/volume_test.py::VolumeTest::test_volume_default_labels <- tests/integration/testcases.py PASSED [ 39%]

01:41:50 tests/unit/bundle_test.py::test_get_image_digest_exists PASSED           [ 39%]

01:41:51 tests/unit/bundle_test.py::test_get_image_digest_image_uses_digest PASSED [ 39%]

01:41:51 tests/unit/bundle_test.py::test_get_image_digest_from_repository PASSED  [ 39%]

01:41:51 tests/unit/bundle_test.py::test_get_image_digest_no_image PASSED         [ 39%]

01:41:52 tests/unit/bundle_test.py::test_push_image_with_saved_digest PASSED      [ 39%]

01:41:52 tests/unit/bundle_test.py::test_push_image PASSED                        [ 39%]

01:41:52 tests/unit/bundle_test.py::test_to_bundle PASSED                         [ 39%]

01:41:52 tests/unit/bundle_test.py::test_convert_service_to_bundle PASSED         [ 39%]

01:41:52 tests/unit/bundle_test.py::test_set_command_and_args_none PASSED         [ 39%]

01:41:52 tests/unit/bundle_test.py::test_set_command_and_args_from_command PASSED [ 39%]

01:41:52 tests/unit/bundle_test.py::test_set_command_and_args_from_entrypoint PASSED [ 40%]

01:41:52 tests/unit/bundle_test.py::test_set_command_and_args_from_both PASSED    [ 40%]

01:41:52 tests/unit/bundle_test.py::test_make_service_networks_default PASSED     [ 40%]

01:41:52 tests/unit/bundle_test.py::test_make_service_networks PASSED             [ 40%]

01:41:52 tests/unit/bundle_test.py::test_make_port_specs PASSED                   [ 40%]

01:41:52 tests/unit/bundle_test.py::test_make_port_spec_with_protocol PASSED      [ 40%]

01:41:52 tests/unit/bundle_test.py::test_make_port_spec_default_protocol PASSED   [ 40%]

01:41:52 tests/unit/cli_test.py::CLITestCase::test_command_help PASSED            [ 40%]

01:41:52 tests/unit/cli_test.py::CLITestCase::test_command_help_nonexistent PASSED [ 40%]

01:41:52 tests/unit/cli_test.py::CLITestCase::test_command_manual_and_service_ports_together PASSED [ 40%]

01:41:52 tests/unit/cli_test.py::CLITestCase::test_default_project_name PASSED    [ 40%]

01:41:52 tests/unit/cli_test.py::CLITestCase::test_get_project PASSED             [ 41%]

01:41:52 tests/unit/cli_test.py::CLITestCase::test_project_name_from_environment_new_var PASSED [ 41%]

01:41:52 tests/unit/cli_test.py::CLITestCase::test_project_name_with_empty_environment_var PASSED [ 41%]

01:41:52 tests/unit/cli_test.py::CLITestCase::test_project_name_with_environment_file PASSED [ 41%]

01:41:52 tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_base_dir PASSED [ 41%]

01:41:52 tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_project_name PASSED [ 41%]

01:41:52 tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_uppercase_base_dir PASSED [ 41%]

01:41:52 tests/unit/cli_test.py::CLITestCase::test_run_interactive_passes_logs_false PASSED [ 41%]

01:41:53 tests/unit/cli_test.py::CLITestCase::test_run_service_with_restart_always PASSED [ 41%]

01:41:53 tests/unit/container_test.py::ContainerTest::test_environment PASSED     [ 41%]

01:41:53 tests/unit/container_test.py::ContainerTest::test_from_ps PASSED         [ 41%]

01:41:53 tests/unit/container_test.py::ContainerTest::test_from_ps_prefixed PASSED [ 42%]

01:41:53 tests/unit/container_test.py::ContainerTest::test_get PASSED             [ 42%]

01:41:53 tests/unit/container_test.py::ContainerTest::test_get_local_port PASSED  [ 42%]

01:41:53 tests/unit/container_test.py::ContainerTest::test_has_api_logs PASSED    [ 42%]

01:41:53 tests/unit/container_test.py::ContainerTest::test_human_readable_ports_none PASSED [ 42%]

01:41:53 tests/unit/container_test.py::ContainerTest::test_human_readable_ports_public_and_private PASSED [ 42%]

01:41:53 tests/unit/container_test.py::ContainerTest::test_human_readable_states_healthy PASSED [ 42%]

01:41:53 tests/unit/container_test.py::ContainerTest::test_human_readable_states_no_health PASSED [ 42%]

01:41:53 tests/unit/container_test.py::ContainerTest::test_human_readable_states_starting PASSED [ 42%]

01:41:53 tests/unit/container_test.py::ContainerTest::test_inspect_if_not_inspected PASSED [ 42%]

01:41:53 tests/unit/container_test.py::ContainerTest::test_name PASSED            [ 42%]

01:41:53 tests/unit/container_test.py::ContainerTest::test_name_without_project PASSED [ 42%]

01:41:53 tests/unit/container_test.py::ContainerTest::test_name_without_project_custom_container_name PASSED [ 43%]

01:41:53 tests/unit/container_test.py::ContainerTest::test_name_without_project_one_off PASSED [ 43%]

01:41:53 tests/unit/container_test.py::ContainerTest::test_number PASSED          [ 43%]

01:41:53 tests/unit/container_test.py::ContainerTest::test_short_id PASSED        [ 43%]

01:41:53 tests/unit/container_test.py::GetContainerNameTestCase::test_get_container_name PASSED [ 43%]

01:41:53 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_driver_mismatch PASSED [ 43%]

01:41:53 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_null_remote PASSED [ 43%]

01:41:53 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_null_remote_ipam_options PASSED [ 43%]

01:41:53 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_options_mismatch PASSED [ 43%]

01:41:53 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_success PASSED [ 43%]

01:41:53 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_whitelist PASSED [ 43%]

01:41:53 tests/unit/network_test.py::NetworkTest::test_check_remote_network_labels_mismatch PASSED [ 44%]

01:41:53 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute PASSED  [ 44%]

01:41:53 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_deps PASSED [ 44%]

01:41:53 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_global_limit PASSED [ 44%]

01:41:53 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_limit PASSED [ 44%]

01:41:53 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_upstream_errors PASSED [ 44%]

01:41:53 tests/unit/parallel_test.py::test_parallel_execute_alignment PASSED      [ 44%]

01:41:53 tests/unit/parallel_test.py::test_parallel_execute_ansi PASSED           [ 44%]

01:41:53 tests/unit/parallel_test.py::test_parallel_execute_noansi PASSED         [ 44%]

01:41:53 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_get_digest_from_pull PASSED [ 44%]

01:41:53 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_get_digest_from_push PASSED [ 44%]

01:41:53 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_mismatched_encoding_stream_write PASSED [ 44%]

01:41:53 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output PASSED [ 45%]

01:41:53 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_div_zero PASSED [ 45%]

01:41:53 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_no_progress_event_no_tty PASSED [ 45%]

01:41:53 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_null_total PASSED [ 45%]

01:41:53 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_progress_event_no_tty PASSED [ 45%]

01:41:53 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_progress_event_tty PASSED [ 45%]

01:41:53 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_middle_always_recreate_deps PASSED [ 36%]

01:41:53 tests/unit/project_test.py::ProjectTest::test_avoid_multiple_push PASSED [ 45%]

01:41:53 tests/unit/project_test.py::ProjectTest::test_build_container_operation_with_timeout_func_does_not_mutate_options_with_timeout PASSED [ 45%]

01:41:54 tests/unit/project_test.py::ProjectTest::test_container_without_name PASSED [ 45%]

01:41:54 tests/unit/project_test.py::ProjectTest::test_down_with_no_resources PASSED [ 45%]

01:41:54 tests/unit/project_test.py::ProjectTest::test_error_parallel_pull PASSED [ 45%]

01:41:54 tests/unit/project_test.py::ProjectTest::test_events PASSED              [ 46%]

01:41:55 tests/unit/project_test.py::ProjectTest::test_events_legacy PASSED       [ 46%]

01:41:55 tests/unit/project_test.py::ProjectTest::test_from_config_v1 PASSED      [ 46%]

01:41:55 tests/unit/project_test.py::ProjectTest::test_from_config_v2 PASSED      [ 46%]

01:41:55 tests/unit/project_test.py::ProjectTest::test_get_service PASSED         [ 46%]

01:41:56 tests/unit/project_test.py::ProjectTest::test_get_services_removes_duplicates_following_links PASSED [ 46%]

01:41:56 tests/unit/project_test.py::ProjectTest::test_get_services_returns_all_services_without_args PASSED [ 46%]

01:41:56 tests/unit/project_test.py::ProjectTest::test_get_services_returns_listed_services_with_args PASSED [ 46%]

01:41:56 tests/unit/project_test.py::ProjectTest::test_get_services_with_include_links PASSED [ 46%]

01:41:57 tests/unit/project_test.py::ProjectTest::test_net_unset PASSED           [ 46%]

01:41:57 tests/unit/project_test.py::ProjectTest::test_no_such_service_unicode PASSED [ 46%]

01:41:57 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root PASSED [ 36%]

01:41:57 tests/unit/project_test.py::ProjectTest::test_no_warning_in_normal_mode PASSED [ 47%]

01:41:57 tests/unit/project_test.py::ProjectTest::test_no_warning_on_stop PASSED  [ 47%]

01:41:58 tests/unit/project_test.py::ProjectTest::test_no_warning_with_no_swarm_info PASSED [ 47%]

01:41:58 tests/unit/project_test.py::ProjectTest::test_project_platform_value PASSED [ 47%]

01:41:58 tests/unit/project_test.py::ProjectTest::test_use_net_from_container PASSED [ 47%]

01:41:58 tests/unit/project_test.py::ProjectTest::test_use_net_from_service PASSED [ 47%]

01:41:59 tests/unit/project_test.py::ProjectTest::test_use_volumes_from_container PASSED [ 47%]

01:41:59 tests/unit/project_test.py::ProjectTest::test_use_volumes_from_service_container PASSED [ 47%]

01:41:59 tests/unit/project_test.py::ProjectTest::test_use_volumes_from_service_no_container PASSED [ 47%]

01:41:59 tests/unit/project_test.py::ProjectTest::test_uses_default_network_false PASSED [ 47%]

01:42:00 tests/unit/project_test.py::ProjectTest::test_uses_default_network_true PASSED [ 47%]

01:42:00 tests/unit/service_test.py::ServiceTest::test_build_does_not_pull PASSED [ 47%]

01:42:00 tests/unit/service_test.py::ServiceTest::test_build_isolation_from_build_override_service_config PASSED [ 48%]

01:42:00 tests/unit/service_test.py::ServiceTest::test_build_service_with_proxy_config PASSED [ 48%]

01:42:01 tests/unit/service_test.py::ServiceTest::test_build_volume_options_duplicate_binds PASSED [ 48%]

01:42:01 tests/unit/service_test.py::ServiceTest::test_build_with_default_platform PASSED [ 48%]

01:42:01 tests/unit/service_test.py::ServiceTest::test_build_with_isolation_from_service_config PASSED [ 48%]

01:42:01 tests/unit/service_test.py::ServiceTest::test_build_with_override_build_args PASSED [ 48%]

01:42:02 tests/unit/service_test.py::ServiceTest::test_build_with_platform PASSED [ 48%]

01:42:02 tests/unit/service_test.py::ServiceTest::test_cgroup_parent PASSED       [ 48%]

01:42:02 tests/unit/service_test.py::ServiceTest::test_config_dict PASSED         [ 48%]

01:42:02 tests/unit/service_test.py::ServiceTest::test_config_dict_with_network_mode_from_container PASSED [ 48%]

01:42:03 tests/unit/service_test.py::ServiceTest::test_config_hash_matches_label PASSED [ 48%]

01:42:03 tests/unit/service_test.py::ServiceTest::test_container_without_name PASSED [ 49%]

01:42:03 tests/unit/service_test.py::ServiceTest::test_containers PASSED          [ 49%]

01:42:03 tests/unit/service_test.py::ServiceTest::test_containers_with_containers PASSED [ 49%]

01:42:03 tests/unit/service_test.py::ServiceTest::test_create_container PASSED    [ 49%]

01:42:04 tests/unit/service_test.py::ServiceTest::test_create_when_removed_containers_are_listed PASSED [ 49%]

01:42:04 tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_force_build PASSED [ 49%]

01:42:04 tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_no_build PASSED [ 49%]

01:42:04 tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_no_build_but_needs_build PASSED [ 49%]

01:42:05 tests/unit/service_test.py::ServiceTest::test_get_container PASSED       [ 49%]

01:42:05 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_does_not_mutate_options PASSED [ 49%]

01:42:05 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_no_affinity_without_binds PASSED [ 49%]

01:42:06 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_sets_affinity_with_binds PASSED [ 50%]

01:42:06 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_with_name_option PASSED [ 50%]

01:42:06 tests/unit/service_test.py::ServiceTest::test_get_container_not_found PASSED [ 50%]

01:42:06 tests/unit/service_test.py::ServiceTest::test_get_create_options_with_proxy_config PASSED [ 50%]

01:42:07 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_container PASSED [ 50%]

01:42:07 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_container_read_only PASSED [ 50%]

01:42:07 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_container_exists PASSED [ 50%]

01:42:07 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root_always_recreate_deps PASSED [ 36%]

01:42:08 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_container_exists_with_flags PASSED [ 50%]

01:42:08 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_no_container PASSED [ 50%]

01:42:08 tests/unit/service_test.py::ServiceTest::test_image_name_default PASSED  [ 50%]

01:42:09 tests/unit/service_test.py::ServiceTest::test_image_name_from_config PASSED [ 50%]

01:42:09 tests/unit/service_test.py::ServiceTest::test_log_opt PASSED             [ 50%]

01:42:09 tests/unit/service_test.py::ServiceTest::test_mem_reservation PASSED     [ 51%]

01:42:09 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_change_root_no_recreate PASSED [ 36%]

01:42:09 tests/unit/service_test.py::ServiceTest::test_memory_swap_limit PASSED   [ 51%]

01:42:10 tests/unit/service_test.py::ServiceTest::test_no_default_hostname_when_not_using_networking PASSED [ 51%]

01:42:10 tests/unit/service_test.py::ServiceTest::test_only_log_warning_when_host_ports_clash PASSED [ 51%]

01:42:10 tests/unit/service_test.py::ServiceTest::test_parse_proxy_config PASSED  [ 51%]

01:42:10 tests/unit/service_test.py::ServiceTest::test_parse_proxy_config_per_host PASSED [ 51%]

01:42:11 tests/unit/service_test.py::ServiceTest::test_parse_repository_tag PASSED [ 51%]

01:42:11 tests/unit/service_test.py::ServiceTest::test_pull_image PASSED          [ 51%]

01:42:11 tests/unit/service_test.py::ServiceTest::test_pull_image_digest PASSED   [ 51%]

01:42:11 tests/unit/service_test.py::ServiceTest::test_pull_image_no_tag PASSED   [ 51%]

01:42:12 tests/unit/service_test.py::ServiceTest::test_pull_image_with_default_platform PASSED [ 51%]

01:42:12 tests/unit/service_test.py::ServiceTest::test_pull_image_with_platform PASSED [ 52%]

01:42:12 tests/unit/service_test.py::ServiceTest::test_pull_image_with_platform_unsupported_api PASSED [ 52%]

01:42:12 tests/unit/service_test.py::ServiceTest::test_recreate_container PASSED  [ 52%]

01:42:13 tests/unit/service_test.py::ServiceTest::test_recreate_container_with_timeout PASSED [ 52%]

01:42:13 tests/unit/service_test.py::ServiceTest::test_remove_image_all_does_remove PASSED [ 52%]

01:42:13 tests/unit/service_test.py::ServiceTest::test_remove_image_local_with_image_name_doesnt_remove PASSED [ 52%]

01:42:13 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_dependency_added PASSED [ 37%]

01:42:13 tests/unit/service_test.py::ServiceTest::test_remove_image_local_without_image_name_does_remove PASSED [ 52%]

01:42:14 tests/unit/service_test.py::ServiceTest::test_remove_image_none PASSED   [ 52%]

01:42:14 tests/unit/service_test.py::ServiceTest::test_remove_image_with_error PASSED [ 52%]

01:42:14 tests/unit/service_test.py::ServiceTest::test_remove_non_existing_image PASSED [ 52%]

01:42:14 tests/unit/service_test.py::ServiceTest::test_self_reference_external_link PASSED [ 52%]

01:42:15 tests/unit/service_test.py::ServiceTest::test_service_ignore_default_platform_with_unsupported_api PASSED [ 52%]

01:42:15 tests/unit/service_test.py::ServiceTest::test_service_platform_precedence PASSED [ 53%]

01:42:15 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_container_port PASSED [ 53%]

01:42:15 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_container_port_range PASSED [ 53%]

01:42:16 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_and_port PASSED [ 53%]

01:42:16 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_and_port_range PASSED [ 53%]

01:42:16 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_no_port PASSED [ 53%]

01:42:17 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_no_port_range PASSED [ 53%]

01:42:17 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_port PASSED [ 53%]

01:42:17 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_port_range PASSED [ 53%]

01:42:17 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_no_ports PASSED [ 53%]

01:42:17 tests/unit/service_test.py::ServiceTest::test_split_domainname_both PASSED [ 53%]

01:42:18 tests/unit/service_test.py::ServiceTest::test_split_domainname_fqdn PASSED [ 54%]

01:42:18 tests/unit/service_test.py::ServiceTest::test_split_domainname_none PASSED [ 54%]

01:42:18 tests/unit/service_test.py::ServiceTest::test_split_domainname_weird PASSED [ 54%]

01:42:18 tests/unit/service_test.py::ServiceTest::test_stop_grace_period PASSED   [ 54%]

01:42:19 tests/unit/service_test.py::ServiceTest::test_volumes_order_is_preserved PASSED [ 54%]

01:42:19 tests/unit/service_test.py::TestServiceNetwork::test_connect_container_to_networks_short_aliase_exists PASSED [ 54%]

01:42:19 tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_dict PASSED [ 54%]

01:42:19 tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_integers_and_dicts PASSED [ 54%]

01:42:19 tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_ints PASSED [ 54%]

01:42:19 tests/unit/service_test.py::NetTestCase::test_network_mode PASSED        [ 54%]

01:42:19 tests/unit/service_test.py::NetTestCase::test_network_mode_container PASSED [ 54%]

01:42:20 tests/unit/service_test.py::NetTestCase::test_network_mode_service PASSED [ 55%]

01:42:20 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_dependency_removed PASSED [ 37%]

01:42:20 tests/unit/service_test.py::NetTestCase::test_network_mode_service_no_containers PASSED [ 55%]

01:42:20 tests/unit/service_test.py::ServicePortsTest::test_formatted_ports PASSED [ 55%]

01:42:20 tests/unit/service_test.py::ServiceVolumesTest::test_build_volume_binding PASSED [ 55%]

01:42:20 tests/unit/service_test.py::ServiceVolumesTest::test_create_with_special_volume_mode PASSED [ 55%]

01:42:21 tests/unit/service_test.py::ServiceVolumesTest::test_get_container_create_options_with_different_host_path_in_container_json PASSED [ 55%]

01:42:21 tests/unit/service_test.py::ServiceVolumesTest::test_get_container_data_volumes PASSED [ 55%]

01:42:21 tests/unit/service_test.py::ServiceVolumesTest::test_merge_volume_bindings PASSED [ 55%]

01:42:21 tests/unit/service_test.py::ServiceVolumesTest::test_mount_same_host_path_to_two_volumes PASSED [ 55%]

01:42:22 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_no_warning_with_container_only_option PASSED [ 55%]

01:42:22 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_no_warning_with_same_path PASSED [ 55%]

01:42:22 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_volume_no_warning_when_no_container_volumes PASSED [ 55%]

01:42:22 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_volume_when_masked PASSED [ 56%]

01:42:23 tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes PASSED [ 56%]

01:42:23 tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes_abspath PASSED [ 56%]

01:42:23 tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes_no_target PASSED [ 56%]

01:42:23 tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_unix_path PASSED [ 56%]

01:42:23 tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_url_no_prefix PASSED [ 56%]

01:42:23 tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_windows_path PASSED [ 56%]

01:42:23 tests/unit/split_buffer_test.py::SplitBufferTest::test_chunked_line PASSED [ 56%]

01:42:23 tests/unit/split_buffer_test.py::SplitBufferTest::test_multiple_line_chunk PASSED [ 56%]

01:42:23 tests/unit/split_buffer_test.py::SplitBufferTest::test_no_end_separator PASSED [ 56%]

01:42:23 tests/unit/split_buffer_test.py::SplitBufferTest::test_preserves_unicode_sequences_within_lines PASSED [ 56%]

01:42:23 tests/unit/split_buffer_test.py::SplitBufferTest::test_single_line_chunks PASSED [ 57%]

01:42:23 tests/unit/timeparse_test.py::test_milli PASSED                          [ 57%]

01:42:23 tests/unit/timeparse_test.py::test_milli_float PASSED                    [ 57%]

01:42:23 tests/unit/timeparse_test.py::test_second_milli PASSED                   [ 57%]

01:42:23 tests/unit/timeparse_test.py::test_second_milli_micro PASSED             [ 57%]

01:42:23 tests/unit/timeparse_test.py::test_second PASSED                         [ 57%]

01:42:23 tests/unit/timeparse_test.py::test_second_as_float PASSED                [ 57%]

01:42:23 tests/unit/timeparse_test.py::test_minute PASSED                         [ 57%]

01:42:23 tests/unit/timeparse_test.py::test_hour_minute PASSED                    [ 57%]

01:42:23 tests/unit/timeparse_test.py::test_minute_as_float PASSED                [ 57%]

01:42:23 tests/unit/timeparse_test.py::test_hour_minute_second PASSED             [ 57%]

01:42:23 tests/unit/timeparse_test.py::test_invalid_with_space PASSED             [ 57%]

01:42:23 tests/unit/timeparse_test.py::test_invalid_with_comma PASSED             [ 58%]

01:42:23 tests/unit/timeparse_test.py::test_invalid_with_empty_string PASSED      [ 58%]

01:42:23 tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_no_object PASSED [ 58%]

01:42:23 tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_with_object PASSED [ 58%]

01:42:23 tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_leading_whitespace PASSED [ 58%]

01:42:23 tests/unit/utils_test.py::TestStreamAsText::test_stream_with_non_utf_unicode_character PASSED [ 58%]

01:42:23 tests/unit/utils_test.py::TestStreamAsText::test_stream_with_utf_character PASSED [ 58%]

01:42:23 tests/unit/utils_test.py::TestJsonStream::test_with_falsy_entries PASSED [ 58%]

01:42:23 tests/unit/utils_test.py::TestJsonStream::test_with_leading_whitespace PASSED [ 58%]

01:42:23 tests/unit/utils_test.py::TestParseBytes::test_parse_bytes PASSED        [ 58%]

01:42:23 tests/unit/utils_test.py::TestMoreItertools::test_unique_everseen PASSED [ 58%]

01:42:23 tests/unit/volume_test.py::TestVolume::test_remove_local_volume PASSED   [ 59%]

01:42:24 tests/unit/volume_test.py::TestVolume::test_remove_external_volume PASSED [ 59%]

01:42:24 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_path_from_options PASSED [ 59%]

01:42:24 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_single_path_from_env PASSED [ 59%]

01:42:24 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env PASSED [ 59%]

01:42:24 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env_windows SKIPPED [ 59%]

01:42:24 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env_custom_separator PASSED [ 59%]

01:42:24 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_no_path PASSED [ 59%]

01:42:24 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_unicode_path_from_options PASSED [ 59%]

01:42:24 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_unicode_path_from_env PASSED [ 59%]

01:42:24 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_custom_timeout_error PASSED [ 59%]

01:42:24 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_docker_client_no_home PASSED [ 60%]

01:42:24 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_docker_client_with_custom_timeout PASSED [ 60%]

01:42:24 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_user_agent PASSED [ 60%]

01:42:24 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_assert_hostname_explicit_skip PASSED [ 60%]

01:42:24 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_simple_tls PASSED [ 60%]

01:42:24 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_ca_cert PASSED [ 60%]

01:42:24 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_ca_cert_explicit PASSED [ 60%]

01:42:24 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca PASSED [ 60%]

01:42:24 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca_explicit PASSED [ 60%]

01:42:24 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca_quoted_paths PASSED [ 60%]

01:42:24 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_cert PASSED [ 60%]

01:42:24 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_cert_explicit PASSED [ 60%]

01:42:24 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_missing_key PASSED [ 61%]

01:42:24 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_flags_override_environment PASSED [ 61%]

01:42:24 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_mixed_environment_and_flags PASSED [ 61%]

01:42:24 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_simple_with_tls_version PASSED [ 61%]

01:42:24 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_default_cert_path PASSED [ 61%]

01:42:24 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_env_falsy_value PASSED [ 61%]

01:42:24 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_flag_no_override PASSED [ 61%]

01:42:24 tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_default PASSED [ 61%]

01:42:24 tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_upgrade PASSED [ 61%]

01:42:24 tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_unavailable PASSED [ 61%]

01:42:24 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_generic_connection_error PASSED [ 61%]

01:42:24 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_mismatch PASSED [ 62%]

01:42:24 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_mismatch_unicode_explanation PASSED [ 62%]

01:42:24 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_other PASSED [ 62%]

01:42:24 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_other_unicode_explanation PASSED [ 62%]

01:42:24 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_no_data SKIPPED [ 62%]

01:42:24 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_misc SKIPPED [ 62%]

01:42:24 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_encoding_issue SKIPPED [ 62%]

01:42:24 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_error PASSED [ 62%]

01:42:24 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_info PASSED [ 62%]

01:42:24 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_error PASSED [ 62%]

01:42:24 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_info PASSED [ 62%]

01:42:24 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_warn PASSED [ 63%]

01:42:24 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_warn PASSED [ 63%]

01:42:24 tests/unit/cli/log_printer_test.py::TestLogPresenter::test_monochrome PASSED [ 63%]

01:42:24 tests/unit/cli/log_printer_test.py::TestLogPresenter::test_polychrome PASSED [ 63%]

01:42:24 tests/unit/cli/log_printer_test.py::test_wait_on_exit PASSED             [ 63%]

01:42:24 tests/unit/cli/log_printer_test.py::test_wait_on_exit_raises PASSED      [ 63%]

01:42:24 tests/unit/cli/log_printer_test.py::test_build_no_log_generator PASSED   [ 63%]

01:42:24 tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_no_log_stream PASSED [ 63%]

01:42:24 tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_with_log_stream PASSED [ 63%]

01:42:24 tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_unicode PASSED [ 63%]

01:42:24 tests/unit/cli/log_printer_test.py::TestWatchEvents::test_stop_event PASSED [ 63%]

01:42:24 tests/unit/cli/log_printer_test.py::TestWatchEvents::test_start_event PASSED [ 63%]

01:42:24 tests/unit/cli/log_printer_test.py::TestWatchEvents::test_other_event PASSED [ 64%]

01:42:24 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_an_exception PASSED [ 64%]

01:42:24 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_stop_without_cascade_stop PASSED [ 64%]

01:42:24 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_stop_with_cascade_stop PASSED [ 64%]

01:42:24 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_none_when_timeout_is_hit PASSED [ 64%]

01:42:24 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_filter_containers_to_service_names PASSED [ 64%]

01:42:24 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_filter_containers_to_service_names_all PASSED [ 64%]

01:42:25 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_warning_in_swarm_mode PASSED [ 64%]

01:42:25 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_build_one_off_container_options PASSED [ 64%]

01:42:25 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_get_docker_start_call PASSED [ 64%]

01:42:25 tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_tty_verbose PASSED [ 64%]

01:42:25 tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_tty_not_verbose PASSED [ 65%]

01:42:25 tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_not_a_tty PASSED [ 65%]

01:42:25 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_invalid_opts PASSED [ 65%]

01:42:25 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_always PASSED [ 65%]

01:42:25 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_never PASSED [ 65%]

01:42:25 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_changed PASSED [ 65%]

01:42:25 tests/unit/cli/main_test.py::TestCallDocker::test_simple_no_options PASSED [ 65%]

01:42:25 tests/unit/cli/main_test.py::TestCallDocker::test_simple_tls_option PASSED [ 65%]

01:42:25 tests/unit/cli/main_test.py::TestCallDocker::test_advanced_tls_options PASSED [ 65%]

01:42:25 tests/unit/cli/main_test.py::TestCallDocker::test_with_host_option PASSED [ 65%]

01:42:25 tests/unit/cli/main_test.py::TestCallDocker::test_with_http_host PASSED  [ 65%]

01:42:25 tests/unit/cli/main_test.py::TestCallDocker::test_with_host_option_shorthand_equal PASSED [ 65%]

01:42:25 tests/unit/cli/main_test.py::TestCallDocker::test_with_env PASSED        [ 66%]

01:42:25 tests/unit/cli/utils_test.py::UnquotePathTest::test_nested_quotes PASSED [ 66%]

01:42:25 tests/unit/cli/utils_test.py::UnquotePathTest::test_no_quotes PASSED     [ 66%]

01:42:25 tests/unit/cli/utils_test.py::UnquotePathTest::test_simple_quotes PASSED [ 66%]

01:42:25 tests/unit/cli/utils_test.py::UnquotePathTest::test_uneven_quotes PASSED [ 66%]

01:42:25 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_100b PASSED [ 66%]

01:42:25 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_1023b PASSED [ 66%]

01:42:25 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_1kb PASSED [ 66%]

01:42:25 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_units PASSED [ 66%]

01:42:25 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_call PASSED [ 66%]

01:42:25 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return PASSED [ 66%]

01:42:25 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return_no_result PASSED [ 67%]

01:42:25 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return_sequence PASSED [ 67%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_build_args_allow_empty_properties PASSED [ 67%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_build_args_check_zero_preserved PASSED [ 67%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_config_build_configuration PASSED [ 67%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_config_build_configuration_v2 PASSED [ 67%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_config_convertible_label_types PASSED [ 67%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_config_duplicate_cache_from_values_validation_error PASSED [ 67%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_config_duplicate_mount_points PASSED [ 67%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_config_extra_hosts_list_of_dicts_validation_error PASSED [ 67%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_config_extra_hosts_string_raises_validation_error PASSED [ 67%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_config_hint PASSED    [ 68%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error PASSED [ 68%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error_v2 PASSED [ 68%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error_v2_when_no_interpolate PASSED [ 68%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_property_raise_validation_error PASSED [ 68%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_config_invalid_ipam_config PASSED [ 68%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_config_invalid_label_types PASSED [ 68%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_config_invalid_service_name_raise_validation_error PASSED [ 68%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_invalid_keys_validation_error PASSED [ 68%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_required_keys_validation_error PASSED [ 68%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_soft_greater_than_hard_error PASSED [ 68%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_config_valid_environment_dict_key_contains_dashes PASSED [ 68%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_config_valid_ipam_config PASSED [ 69%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_config_valid_service_label_validation PASSED [ 69%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_config_valid_service_names PASSED [ 69%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_depends_on_orders_services PASSED [ 69%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_depends_on_unknown_service_errors PASSED [ 69%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_dns_opt_option PASSED [ 69%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_empty_environment_key_allowed PASSED [ 69%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_external_volume_config PASSED [ 69%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_external_volume_invalid_config PASSED [ 69%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_group_add_option PASSED [ 69%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_build_and_image_specified_v1 PASSED [ 69%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_not_a_dictionary PASSED [ 70%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_not_unique_items PASSED [ 70%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_type_should_be_an_array PASSED [ 70%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_v1 PASSED [ 70%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_v2 PASSED [ 70%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_invalid_list_of_strings_format PASSED [ 70%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_isolation_option PASSED [ 70%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_linked_service_is_undefined PASSED [ 70%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load PASSED           [ 70%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_bind_mount_relative_path PASSED [ 70%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_bind_mount_relative_path_with_tilde PASSED [ 70%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_build_labels_dict PASSED [ 71%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_build_labels_list PASSED [ 71%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_config_custom_resource_names PASSED [ 71%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_config_dockerfile_without_build_raises_error_v1 PASSED [ 71%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_config_invalid_service_names PASSED [ 71%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_config_invalid_service_names_v2 PASSED [ 71%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_config_link_local_ips_network PASSED [ 71%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_config_service_labels PASSED [ 71%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_config_volume_and_network_labels PASSED [ 71%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_configs PASSED   [ 71%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_configs_multi_file PASSED [ 71%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_dockerfile_without_context PASSED [ 71%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_errors_on_uppercase_with_no_image PASSED [ 72%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_invalid_service_definition PASSED [ 72%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_mixed_extends_resolution PASSED [ 72%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_secrets PASSED   [ 72%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_secrets_multi_file PASSED [ 72%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_service_with_name_version PASSED [ 72%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_sorts_in_dependency_order PASSED [ 72%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_when_not_dict PASSED [ 72%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_when_not_dict_v2 PASSED [ 72%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_with_invalid_network_fields PASSED [ 72%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_v2 PASSED        [ 72%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_with_buildargs PASSED [ 73%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_with_empty_build_args PASSED [ 73%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_with_extensions PASSED [ 73%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_with_invalid_field_name PASSED [ 73%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_with_invalid_field_name_v1 PASSED [ 73%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_base PASSED [ 73%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_base_v2 PASSED [ 73%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_override PASSED [ 73%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_override_v2 PASSED [ 73%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_extends_in_override_file PASSED [ 73%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_invalid_override PASSED [ 73%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_mismatched_networks_format PASSED [ 73%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_mismatched_networks_format_inverse_order PASSED [ 74%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v1 PASSED [ 74%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v2 PASSED [ 74%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v3_2 PASSED [ 74%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_yaml_with_bom PASSED [ 74%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_load_yaml_with_yaml_error PASSED [ 74%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_logs_warning_for_boolean_in_environment PASSED [ 74%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_blkio_config PASSED [ 74%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_configs_override PASSED [ 74%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_credential_spec PASSED [ 74%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_depends_on_mixed_syntax PASSED [ 74%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_depends_on_no_override PASSED [ 75%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_deploy PASSED   [ 75%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_deploy_override PASSED [ 75%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_device_cgroup_rules PASSED [ 75%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_different_configs PASSED [ 75%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_different_secrets PASSED [ 75%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_extra_hosts PASSED [ 75%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_config PASSED [ 75%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_override_disables PASSED [ 75%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_override_enables PASSED [ 75%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_isolation PASSED [ 75%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v1 PASSED [ 76%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2 PASSED [ 76%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_base PASSED [ 76%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_base_driver PASSED [ 76%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_drivers PASSED [ 76%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_override PASSED [ 76%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_override_options PASSED [ 76%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_override_driver PASSED [ 76%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_mixed_ports PASSED [ 76%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_pid PASSED      [ 76%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_scale PASSED    [ 76%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_secrets_override PASSED [ 76%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_from_files_with_extends_in_base PASSED [ 77%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_from_files_with_extends_in_override PASSED [ 77%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous PASSED [ 77%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous_2 PASSED [ 77%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous_volumes PASSED [ 77%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_ports_sorting PASSED [ 77%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_merge_storage_opt PASSED [ 77%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_named_volume_config_empty PASSED [ 77%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_named_volume_invalid_type_list PASSED [ 77%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_named_volume_numeric_driver_opt PASSED [ 77%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_networks_invalid_type_list PASSED [ 77%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_normalize_dns_options PASSED [ 78%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_oom_score_adj_option PASSED [ 78%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_runtime_option PASSED [ 78%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_service_volume_invalid_config PASSED [ 78%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_swappiness_option PASSED [ 78%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_tmpfs_option PASSED   [ 78%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_undeclared_volume_v1 PASSED [ 78%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_undeclared_volume_v2 PASSED [ 78%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_unsupported_version PASSED [ 78%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_v1_file_version PASSED [ 78%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_v1_file_with_version_is_invalid PASSED [ 78%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_valid_config_oneof_string_or_list PASSED [ 78%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_valid_config_which_allows_two_type_definitions PASSED [ 79%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_valid_versions PASSED [ 79%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_validate_extra_hosts_invalid PASSED [ 79%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_validate_extra_hosts_invalid_list PASSED [ 79%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_version_1_is_invalid PASSED [ 79%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_volume_invalid_driver_opt PASSED [ 79%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_volume_mode_override PASSED [ 79%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_volumes_long_syntax PASSED [ 79%]

01:42:25 tests/unit/config/config_test.py::ConfigTest::test_wrong_version_type PASSED [ 79%]

01:42:25 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_container PASSED [ 79%]

01:42:25 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_container_v1 PASSED [ 79%]

01:42:25 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_plus_networks_is_invalid PASSED [ 80%]

01:42:25 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service PASSED [ 80%]

01:42:25 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service_nonexistent PASSED [ 80%]

01:42:25 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service_v1 PASSED [ 80%]

01:42:25 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_standard PASSED [ 80%]

01:42:25 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_standard_v1 PASSED [ 80%]

01:42:25 tests/unit/config/config_test.py::PortsTest::test_config_invalid_expose_format_validation PASSED [ 80%]

01:42:25 tests/unit/config/config_test.py::PortsTest::test_config_invalid_expose_type_validation PASSED [ 80%]

01:42:25 tests/unit/config/config_test.py::PortsTest::test_config_invalid_ports_format_validation PASSED [ 80%]

01:42:25 tests/unit/config/config_test.py::PortsTest::test_config_invalid_ports_type_validation PASSED [ 80%]

01:42:25 tests/unit/config/config_test.py::PortsTest::test_config_non_unique_expose_validation PASSED [ 80%]

01:42:25 tests/unit/config/config_test.py::PortsTest::test_config_non_unique_ports_validation PASSED [ 81%]

01:42:25 tests/unit/config/config_test.py::PortsTest::test_config_valid_expose_format_validation PASSED [ 81%]

01:42:26 tests/unit/config/config_test.py::PortsTest::test_config_valid_ports_format_validation PASSED [ 81%]

01:42:26 tests/unit/config/config_test.py::SubnetTest::test_config_invalid_subnet_format_validation PASSED [ 81%]

01:42:26 tests/unit/config/config_test.py::SubnetTest::test_config_invalid_subnet_type_validation PASSED [ 81%]

01:42:26 tests/unit/config/config_test.py::SubnetTest::test_config_valid_subnet_format_validation PASSED [ 81%]

01:42:26 tests/unit/config/config_test.py::InterpolationTest::test_compatibility_mode_load PASSED [ 81%]

01:42:26 tests/unit/config/config_test.py::InterpolationTest::test_compatibility_mode_warnings PASSED [ 81%]

01:42:26 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_file PASSED [ 81%]

01:42:26 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_variable PASSED [ 81%]

01:42:26 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_variable_with_defaults PASSED [ 81%]

01:42:26 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_options_environment_file PASSED [ 81%]

01:42:26 tests/unit/config/config_test.py::InterpolationTest::test_interpolation_configs_section PASSED [ 82%]

01:42:26 tests/unit/config/config_test.py::InterpolationTest::test_interpolation_secrets_section PASSED [ 82%]

01:42:26 tests/unit/config/config_test.py::InterpolationTest::test_invalid_interpolation PASSED [ 82%]

01:42:26 tests/unit/config/config_test.py::InterpolationTest::test_unset_variable_produces_warning PASSED [ 82%]

01:42:26 tests/unit/config/config_test.py::VolumeConfigTest::test_absolute_posix_path_does_not_expand PASSED [ 82%]

01:42:26 tests/unit/config/config_test.py::VolumeConfigTest::test_absolute_windows_path_does_not_expand PASSED [ 82%]

01:42:26 tests/unit/config/config_test.py::VolumeConfigTest::test_home_directory_with_driver_does_not_expand PASSED [ 82%]

01:42:26 tests/unit/config/config_test.py::VolumeConfigTest::test_name_does_not_expand PASSED [ 82%]

01:42:26 tests/unit/config/config_test.py::VolumeConfigTest::test_no_binding PASSED [ 82%]

01:42:26 tests/unit/config/config_test.py::VolumeConfigTest::test_relative_path_does_expand_posix PASSED [ 82%]

01:42:26 tests/unit/config/config_test.py::VolumeConfigTest::test_relative_path_does_expand_windows SKIPPED [ 82%]

01:42:26 tests/unit/config/config_test.py::VolumeConfigTest::test_volume_binding_with_environment_variable PASSED [ 83%]

01:42:26 tests/unit/config/config_test.py::VolumeConfigTest::test_volume_binding_with_home PASSED [ 83%]

01:42:26 tests/unit/config/config_test.py::VolumeConfigTest::test_volume_path_with_non_ascii_directory PASSED [ 83%]

01:42:26 tests/unit/config/config_test.py::VolumeConfigTest::test_volumes_order_is_preserved PASSED [ 83%]

01:42:26 tests/unit/config/config_test.py::MergeVolumesTest::test_add_explicit_path PASSED [ 83%]

01:42:26 tests/unit/config/config_test.py::MergeVolumesTest::test_empty PASSED    [ 83%]

01:42:26 tests/unit/config/config_test.py::MergeVolumesTest::test_no_base PASSED  [ 83%]

01:42:26 tests/unit/config/config_test.py::MergeVolumesTest::test_no_override PASSED [ 83%]

01:42:26 tests/unit/config/config_test.py::MergeVolumesTest::test_override_explicit_path PASSED [ 83%]

01:42:26 tests/unit/config/config_test.py::MergeVolumesTest::test_remove_explicit_path PASSED [ 83%]

01:42:26 tests/unit/config/config_test.py::MergeDevicesTest::test_add_explicit_path PASSED [ 83%]

01:42:26 tests/unit/config/config_test.py::MergeDevicesTest::test_empty PASSED    [ 84%]

01:42:26 tests/unit/config/config_test.py::MergeDevicesTest::test_no_base PASSED  [ 84%]

01:42:26 tests/unit/config/config_test.py::MergeDevicesTest::test_no_override PASSED [ 84%]

01:42:26 tests/unit/config/config_test.py::MergeDevicesTest::test_override_explicit_path PASSED [ 84%]

01:42:26 tests/unit/config/config_test.py::MergeDevicesTest::test_remove_explicit_path PASSED [ 84%]

01:42:26 tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_no_override PASSED [ 84%]

01:42:26 tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_override_with_other PASSED [ 84%]

01:42:26 tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_override_with_same PASSED [ 84%]

01:42:26 tests/unit/config/config_test.py::MergePortsTest::test_add_item PASSED   [ 84%]

01:42:26 tests/unit/config/config_test.py::MergePortsTest::test_duplicate_port_mappings PASSED [ 84%]

01:42:26 tests/unit/config/config_test.py::MergePortsTest::test_empty PASSED      [ 84%]

01:42:26 tests/unit/config/config_test.py::MergePortsTest::test_no_base PASSED    [ 84%]

01:42:26 tests/unit/config/config_test.py::MergePortsTest::test_no_override PASSED [ 85%]

01:42:26 tests/unit/config/config_test.py::MergeNetworksTest::test_add_item PASSED [ 85%]

01:42:26 tests/unit/config/config_test.py::MergeNetworksTest::test_all_properties PASSED [ 85%]

01:42:26 tests/unit/config/config_test.py::MergeNetworksTest::test_empty PASSED   [ 85%]

01:42:26 tests/unit/config/config_test.py::MergeNetworksTest::test_network_has_none_value PASSED [ 85%]

01:42:26 tests/unit/config/config_test.py::MergeNetworksTest::test_no_base PASSED [ 85%]

01:42:26 tests/unit/config/config_test.py::MergeNetworksTest::test_no_network_name_overrides PASSED [ 85%]

01:42:26 tests/unit/config/config_test.py::MergeNetworksTest::test_no_network_overrides PASSED [ 85%]

01:42:26 tests/unit/config/config_test.py::MergeNetworksTest::test_no_override PASSED [ 85%]

01:42:26 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_add_list PASSED [ 85%]

01:42:26 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_add_string PASSED [ 85%]

01:42:26 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_no_base PASSED [ 86%]

01:42:26 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_no_override PASSED [ 86%]

01:42:26 tests/unit/config/config_test.py::MergeLabelsTest::test_add_explicit_value PASSED [ 86%]

01:42:26 tests/unit/config/config_test.py::MergeLabelsTest::test_empty PASSED     [ 86%]

01:42:26 tests/unit/config/config_test.py::MergeLabelsTest::test_no_base PASSED   [ 86%]

01:42:26 tests/unit/config/config_test.py::MergeLabelsTest::test_no_override PASSED [ 86%]

01:42:26 tests/unit/config/config_test.py::MergeLabelsTest::test_override_explicit_value PASSED [ 86%]

01:42:26 tests/unit/config/config_test.py::MergeLabelsTest::test_remove_explicit_value PASSED [ 86%]

01:42:26 tests/unit/config/config_test.py::MergeBuildTest::test_empty_base PASSED [ 86%]

01:42:26 tests/unit/config/config_test.py::MergeBuildTest::test_empty_override PASSED [ 86%]

01:42:26 tests/unit/config/config_test.py::MergeBuildTest::test_full PASSED       [ 86%]

01:42:26 tests/unit/config/config_test.py::MemoryOptionsTest::test_memswap_can_be_a_string PASSED [ 86%]

01:42:26 tests/unit/config/config_test.py::MemoryOptionsTest::test_validation_fails_with_just_memswap_limit PASSED [ 87%]

01:42:26 tests/unit/config/config_test.py::MemoryOptionsTest::test_validation_with_correct_memswap_values PASSED [ 87%]

01:42:26 tests/unit/config/config_test.py::EnvTest::test_environment_overrides_env_file PASSED [ 87%]

01:42:26 tests/unit/config/config_test.py::EnvTest::test_parse_environment_as_dict PASSED [ 87%]

01:42:26 tests/unit/config/config_test.py::EnvTest::test_parse_environment_as_list PASSED [ 87%]

01:42:26 tests/unit/config/config_test.py::EnvTest::test_parse_environment_empty PASSED [ 87%]

01:42:26 tests/unit/config/config_test.py::EnvTest::test_parse_environment_invalid PASSED [ 87%]

01:42:26 tests/unit/config/config_test.py::EnvTest::test_resolve_build_args PASSED [ 87%]

01:42:26 tests/unit/config/config_test.py::EnvTest::test_resolve_environment PASSED [ 87%]

01:42:26 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_from_env_file PASSED [ 87%]

01:42:26 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_from_env_file_with_empty_values PASSED [ 87%]

01:42:26 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_nonexistent_file PASSED [ 88%]

01:42:26 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_with_multiple_env_files PASSED [ 88%]

01:42:26 tests/unit/config/config_test.py::EnvTest::test_resolve_path PASSED      [ 88%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_circular PASSED      [ 88%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_invalid_config PASSED [ 88%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_valid_config PASSED [ 88%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_verbose_and_shorthand_way PASSED [ 88%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_extends PASSED       [ 88%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_extends_file_defaults_to_self PASSED [ 88%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_empty_dictionary PASSED [ 88%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_invalid_key PASSED [ 88%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_missing_service_key PASSED [ 89%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_no_file_key_no_filename_set PASSED [ 89%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_sub_property_key PASSED [ 89%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_valid_config PASSED [ 89%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_defined_version_passes PASSED [ 89%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_depends_on PASSED [ 89%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_environment_and_env_files PASSED [ 89%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_healthcheck PASSED [ 89%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_mixed_versions_is_error PASSED [ 89%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_ports PASSED [ 89%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_security_opt PASSED [ 89%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_invalid_links_in_extended_service PASSED [ 89%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_invalid_net_in_extended_service PASSED [ 90%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_invalid_volumes_from_in_extended_service PASSED [ 90%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_load_config_runs_interpolation_in_extended_service PASSED [ 90%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_load_throws_error_when_base_service_does_not_exist PASSED [ 90%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_merging_env_labels_ulimits PASSED [ 90%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_nested PASSED        [ 90%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_parent_build_path_dne PASSED [ 90%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_partial_service_config_in_extends_is_still_valid PASSED [ 90%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_self_referencing_file PASSED [ 90%]

01:42:26 tests/unit/config/config_test.py::ExtendsTest::test_volume_path PASSED   [ 90%]

01:42:26 tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_absolute PASSED [ 90%]

01:42:26 tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_normal PASSED [ 91%]

01:42:26 tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_with_tilde PASSED [ 91%]

01:42:26 tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_root_mount PASSED [ 91%]

01:42:26 tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_windows_path PASSED [ 91%]

01:42:26 tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_windows_path_in_container PASSED [ 91%]

01:42:26 tests/unit/config/config_test.py::BuildPathTest::test_absolute_path PASSED [ 91%]

01:42:26 tests/unit/config/config_test.py::BuildPathTest::test_from_file PASSED   [ 91%]

01:42:26 tests/unit/config/config_test.py::BuildPathTest::test_from_file_override_dir PASSED [ 91%]

01:42:26 tests/unit/config/config_test.py::BuildPathTest::test_invalid_url_in_build_path PASSED [ 91%]

01:42:26 tests/unit/config/config_test.py::BuildPathTest::test_nonexistent_path PASSED [ 91%]

01:42:26 tests/unit/config/config_test.py::BuildPathTest::test_relative_path PASSED [ 91%]

01:42:26 tests/unit/config/config_test.py::BuildPathTest::test_valid_url_in_build_path PASSED [ 92%]

01:42:26 tests/unit/config/config_test.py::HealthcheckTest::test_disable PASSED   [ 92%]

01:42:26 tests/unit/config/config_test.py::HealthcheckTest::test_disable_with_other_config_is_invalid PASSED [ 92%]

01:42:26 tests/unit/config/config_test.py::HealthcheckTest::test_healthcheck PASSED [ 92%]

01:42:26 tests/unit/config/config_test.py::HealthcheckTest::test_healthcheck_with_invalid_test PASSED [ 92%]

01:42:26 tests/unit/config/config_test.py::GetDefaultConfigFilesTestCase::test_get_config_path_default_file_in_basedir PASSED [ 92%]

01:42:26 tests/unit/config/config_test.py::GetDefaultConfigFilesTestCase::test_get_config_path_default_file_in_parent_dir PASSED [ 92%]

01:42:26 tests/unit/config/config_test.py::SerializeTest::test_denormalize_depends_on_v2_1 PASSED [ 92%]

01:42:26 tests/unit/config/config_test.py::SerializeTest::test_denormalize_depends_on_v3 PASSED [ 92%]

01:42:26 tests/unit/config/config_test.py::SerializeTest::test_denormalize_healthcheck PASSED [ 92%]

01:42:26 tests/unit/config/config_test.py::SerializeTest::test_denormalize_image_has_digest PASSED [ 92%]

01:42:26 tests/unit/config/config_test.py::SerializeTest::test_denormalize_image_no_digest PASSED [ 92%]

01:42:26 tests/unit/config/config_test.py::SerializeTest::test_serialize_bool_string PASSED [ 93%]

01:42:26 tests/unit/config/config_test.py::SerializeTest::test_serialize_configs PASSED [ 93%]

01:42:26 tests/unit/config/config_test.py::SerializeTest::test_serialize_escape_dollar_sign PASSED [ 93%]

01:42:26 tests/unit/config/config_test.py::SerializeTest::test_serialize_escape_dont_interpolate PASSED [ 93%]

01:42:26 tests/unit/config/config_test.py::SerializeTest::test_serialize_external_false PASSED [ 93%]

01:42:26 tests/unit/config/config_test.py::SerializeTest::test_serialize_ports PASSED [ 93%]

01:42:26 tests/unit/config/config_test.py::SerializeTest::test_serialize_ports_with_ext_ip PASSED [ 93%]

01:42:26 tests/unit/config/config_test.py::SerializeTest::test_serialize_secrets PASSED [ 93%]

01:42:26 tests/unit/config/config_test.py::SerializeTest::test_serialize_time PASSED [ 93%]

01:42:26 tests/unit/config/config_test.py::SerializeTest::test_serialize_unicode_values PASSED [ 93%]

01:42:26 tests/unit/config/environment_test.py::EnvironmentTest::test_env_vars_from_file_bom PASSED [ 93%]

01:42:26 tests/unit/config/environment_test.py::EnvironmentTest::test_env_vars_from_file_whitespace PASSED [ 94%]

01:42:26 tests/unit/config/environment_test.py::EnvironmentTest::test_get_boolean PASSED [ 94%]

01:42:26 tests/unit/config/environment_test.py::EnvironmentTest::test_get_simple PASSED [ 94%]

01:42:26 tests/unit/config/environment_test.py::EnvironmentTest::test_get_undefined PASSED [ 94%]

01:42:26 tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_services PASSED [ 94%]

01:42:26 tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_volumes PASSED [ 94%]

01:42:26 tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_secrets PASSED [ 94%]

01:42:26 tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_v2 PASSED [ 94%]

01:42:26 tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_v3 PASSED [ 94%]

01:42:26 tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_invalid PASSED [ 94%]

01:42:26 tests/unit/config/interpolation_test.py::test_interpolate_environment_network_convert_types PASSED [ 94%]

01:42:26 tests/unit/config/interpolation_test.py::test_interpolate_environment_external_resource_convert_types PASSED [ 94%]

01:42:26 tests/unit/config/interpolation_test.py::test_interpolate_service_name_uses_dot PASSED [ 95%]

01:42:26 tests/unit/config/interpolation_test.py::test_escaped_interpolation PASSED [ 95%]

01:42:26 tests/unit/config/interpolation_test.py::test_invalid_interpolation PASSED [ 95%]

01:42:26 tests/unit/config/interpolation_test.py::test_interpolate_missing_no_default PASSED [ 95%]

01:42:26 tests/unit/config/interpolation_test.py::test_interpolate_with_value PASSED [ 95%]

01:42:26 tests/unit/config/interpolation_test.py::test_interpolate_missing_with_default PASSED [ 95%]

01:42:26 tests/unit/config/interpolation_test.py::test_interpolate_with_empty_and_default_value PASSED [ 95%]

01:42:26 tests/unit/config/interpolation_test.py::test_interpolate_mandatory_values PASSED [ 95%]

01:42:26 tests/unit/config/interpolation_test.py::test_interpolate_mandatory_no_err_msg PASSED [ 95%]

01:42:26 tests/unit/config/interpolation_test.py::test_interpolate_mixed_separators PASSED [ 95%]

01:42:26 tests/unit/config/interpolation_test.py::test_unbraced_separators PASSED [ 95%]

01:42:26 tests/unit/config/interpolation_test.py::test_interpolate_unicode_values PASSED [ 96%]

01:42:26 tests/unit/config/interpolation_test.py::test_interpolate_no_fallthrough PASSED [ 96%]

01:42:26 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_1 PASSED [ 96%]

01:42:26 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_2 PASSED [ 96%]

01:42:26 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_3 PASSED [ 96%]

01:42:26 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_4 PASSED [ 96%]

01:42:26 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_5 PASSED [ 96%]

01:42:26 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_6 PASSED [ 96%]

01:42:26 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_7 PASSED [ 96%]

01:42:26 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports PASSED [ 96%]

01:42:26 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports_2 PASSED [ 96%]

01:42:26 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports_3 PASSED [ 97%]

01:42:26 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_self_imports PASSED [ 97%]

01:42:26 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_depends_on_self PASSED [ 97%]

01:42:26 tests/unit/config/types_test.py::test_parse_extra_hosts_list PASSED      [ 97%]

01:42:26 tests/unit/config/types_test.py::test_parse_extra_hosts_dict PASSED      [ 97%]

01:42:26 tests/unit/config/types_test.py::TestServicePort::test_parse_dict PASSED [ 97%]

01:42:26 tests/unit/config/types_test.py::TestServicePort::test_parse_simple_target_port PASSED [ 97%]

01:42:26 tests/unit/config/types_test.py::TestServicePort::test_parse_complete_port_definition PASSED [ 97%]

01:42:26 tests/unit/config/types_test.py::TestServicePort::test_parse_ext_ip_no_published_port PASSED [ 97%]

01:42:26 tests/unit/config/types_test.py::TestServicePort::test_repr_published_port_0 PASSED [ 97%]

01:42:26 tests/unit/config/types_test.py::TestServicePort::test_parse_port_range PASSED [ 97%]

01:42:26 tests/unit/config/types_test.py::TestServicePort::test_parse_port_publish_range PASSED [ 97%]

01:42:26 tests/unit/config/types_test.py::TestServicePort::test_parse_invalid_port PASSED [ 98%]

01:42:26 tests/unit/config/types_test.py::TestServicePort::test_parse_invalid_publish_range PASSED [ 98%]

01:42:26 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_only_one_path PASSED [ 98%]

01:42:26 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_internal_and_external PASSED [ 98%]

01:42:26 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_with_mode PASSED [ 98%]

01:42:26 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_too_many_parts PASSED [ 98%]

01:42:26 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_absolute_path_normalized PASSED [ 98%]

01:42:26 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_absolute_path_native PASSED [ 98%]

01:42:26 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_internal_path_normalized PASSED [ 98%]

01:42:26 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_internal_path_native PASSED [ 98%]

01:42:26 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_just_drives_normalized PASSED [ 98%]

01:42:26 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_just_drives_native PASSED [ 99%]

01:42:26 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_mixed_notations_normalized PASSED [ 99%]

01:42:26 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_mixed_notations_native PASSED [ 99%]

01:42:26 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_from_service PASSED [ 99%]

01:42:26 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_from_container PASSED [ 99%]

01:42:26 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_invalid PASSED [ 99%]

01:42:26 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_service PASSED [ 99%]

01:42:26 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_service_with_mode PASSED [ 99%]

01:42:26 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_container PASSED [ 99%]

01:42:26 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_container_with_mode PASSED [ 99%]

01:42:26 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_invalid_type PASSED [ 99%]

01:42:28 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_service_removed_while_down PASSED [ 37%]

01:42:30 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_invalid PASSED [100%]

01:42:30 

01:42:30 ---------- coverage: platform linux2, python 2.7.13-final-0 ----------

01:42:30 Name                              Stmts   Miss Branch BrPart  Cover   Missing

01:42:30 -----------------------------------------------------------------------------

01:42:30 compose/__init__.py                   3      0      0      0   100%

01:42:30 compose/__main__.py                   4      4      0      0     0%   1-6

01:42:30 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

01:42:30 compose/cli/__init__.py               0      0      0      0   100%

01:42:30 compose/cli/colors.py                23      2     10      2    88%   37-38, 36->37, 48->exit

01:42:30 compose/cli/command.py               93     14     26      4    82%   71-81, 88, 125-130, 174, 70->71, 87->88, 124->125, 171->174

01:42:30 compose/cli/docker_client.py         75      5     24      2    93%   24, 98-99, 107, 123, 106->107, 122->123

01:42:30 compose/cli/docopt_command.py        38      4      8      2    87%   13-14, 29, 35, 28->29, 34->35

01:42:30 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

01:42:30 compose/cli/formatter.py             34      2      8      1    93%   17-18, 15->17

01:42:30 compose/cli/log_printer.py          144     14     50      6    89%   76, 103, 110-115, 162-164, 173, 226-229, 233-234, 253, 43->exit, 75->76, 98->103, 171->173, 225->226, 232->233

01:42:30 compose/cli/main.py                 695     90    292     40    84%   83-84, 86-87, 168, 328, 360-362, 445, 505, 509, 514-515, 525-554, 566, 584-586, 657-658, 696-697, 715, 736-737, 749, 772, 790, 837, 1069, 1078, 1104-1113, 1153-1156, 1164-1168, 1170-1175, 1198, 1220-1249, 1256-1257, 1259-1261, 1276, 1282, 1466, 1484, 1500, 1504-1505, 1516, 1521, 1524, 1550, 1569-1571, 1581, 1592, 60->63, 82->83, 85->86, 167->168, 327->328, 359->360, 444->445, 504->505, 508->509, 519->525, 563->566, 583->584, 655->657, 714->715, 735->736, 748->749, 771->772, 827->837, 829->exit, 1068->1069, 1077->1078, 1163->1164, 1169->1170, 1197->1198, 1255->1256, 1258->1259, 1275->1276, 1281->1282, 1465->1466, 1483->1484, 1499->1500, 1515->1516, 1520->1521, 1523->1524, 1542->exit, 1549->1550, 1563->1571, 1565->1569, 1580->1581, 1590->1592

01:42:30 compose/cli/signals.py               23      0      4      2    93%   36->exit, 43->exit

01:42:30 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

01:42:30 compose/cli/verbose_proxy.py         35     12     10      0    69%   36-39, 42-47, 50-60

01:42:30 compose/config/__init__.py           13      0      0      0   100%

01:42:30 compose/config/config.py            826     30    388     18    95%   266, 277, 508, 621-622, 714, 757, 812-830, 952-953, 959, 979, 982, 1335, 1366, 1412, 265->266, 276->277, 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

01:42:30 compose/config/environment.py       100      7     34      4    92%   41, 104-107, 120, 127, 40->41, 103->104, 119->120, 126->127

01:42:30 compose/config/errors.py             25      2      0      0    92%   36-40

01:42:30 compose/config/interpolation.py     148      7     62      4    94%   66, 148, 196, 222, 227-229, 121->exit, 146->148, 195->196, 221->222

01:42:30 compose/config/serialize.py          97      1     50      2    98%   76, 75->76, 82->85

01:42:30 compose/config/sort_services.py      44      1     18      1    97%   57, 56->57

01:42:30 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

01:42:30 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

01:42:30 compose/const.py                     36      0      0      0   100%

01:42:30 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

01:42:30 compose/errors.py                    17      1      0      0    94%   12

01:42:30 compose/network.py                  190     19     92      5    87%   184, 186-200, 206, 224, 226, 183->184, 185->186, 205->206, 223->224, 225->226

01:42:30 compose/parallel.py                 199      2     56      1    99%   187, 326, 325->326

01:42:30 compose/progress_stream.py           79      8     40      9    86%   40, 71, 74, 80, 85, 90-91, 116, 39->40, 42->46, 53->57, 70->71, 73->74, 79->80, 84->85, 89->90, 112->116

01:42:30 compose/project.py                  424     29    170     16    92%   60, 156, 212-213, 254-255, 364-365, 378-381, 434, 485, 489, 615, 621, 624-627, 752-753, 759-762, 777, 782-785, 788, 809, 57->60, 152->156, 331->333, 362->364, 377->378, 433->434, 484->485, 488->489, 614->615, 620->621, 623->624, 671->exit, 755->762, 776->777, 781->782, 787->788

01:42:30 compose/service.py                  854     48    380     24    94%   271-272, 293, 366-369, 417-422, 428-430, 470-471, 485, 488, 506, 573, 618-619, 727, 946-947, 967-968, 1069, 1115, 1176, 1218, 1240-1255, 1295, 1334-1338, 1526, 1530, 1686, 216->exit, 269->271, 292->293, 427->428, 469->470, 484->485, 487->488, 505->506, 563->573, 722->727, 945->946, 966->967, 1068->1069, 1114->1115, 1175->1176, 1217->1218, 1294->1295, 1331->1334, 1525->1526, 1529->1530, 1578->exit, 1586->1585, 1623->1620, 1685->1686

01:42:30 compose/state.py                      0      0      0      0   100%

01:42:30 compose/timeparse.py                 22      0      4      0   100%

01:42:30 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

01:42:30 compose/version.py                    6      0      0      0   100%

01:42:30 compose/volume.py                   126      4     44      3    95%   150, 200, 211-212, 141->150, 199->200, 209->211

01:42:30 -----------------------------------------------------------------------------

01:42:30 TOTAL                              5553    433   2224    202    91%

01:42:30 Coverage HTML written to dir coverage-html

01:42:30 

01:42:30 =========================== short test summary info ============================

01:42:30 XFAIL tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_rt

01:42:30   not supported by kernel

01:42:30 XFAIL tests/integration/service_test.py::ServiceTest::test_create_container_with_storage_opt

01:42:30   Not supported on most drivers

01:42:30 SKIP [1] tests/unit/cli/errors_test.py:70: Needs pywin32

01:42:30 SKIP [1] tests/acceptance/cli_test.py:2403: race condition between up and logs

01:42:30 SKIP [1] tests/unit/cli/command_test.py:39: windows separator

01:42:30 SKIP [1] tests/unit/cli/errors_test.py:80: Needs pywin32

01:42:30 SKIP [1] tests/integration/service_test.py:148: cpu_percent is not supported for Linux

01:42:30 SKIP [1] tests/acceptance/cli_test.py:2376: race condition between up and logs

01:42:30 SKIP [1] tests/integration/service_test.py:1635: Broken on 1.11.0 - 17.03.0

01:42:30 SKIP [1] /code/tests/integration/testcases.py:167: This daemon does not support the 'nvidia'' runtime

01:42:30 SKIP [1] tests/unit/cli/errors_test.py:90: Needs pywin32

01:42:30 SKIP [1] tests/unit/config/config_test.py:3777: windows paths

01:42:30 SKIP [1] tests/acceptance/cli_test.py:2424: race condition between up and logs

01:42:30 

01:42:30 ======= 1122 passed, 11 skipped, 2 xfailed, 3 xpassed in 771.19 seconds ========

01:42:30 ___________________________________ summary ____________________________________

01:42:30   py27: commands succeeded

01:42:30   congratulations :)

01:42:30 + on_exit
01:42:30 + [[ 0 != \0 ]]
01:42:30 + docker rm -vf compose-dind-18.09.9-rc1-jenkins-compose-PR-6850-2
01:42:31 compose-dind-18.09.9-rc1-jenkins-compose-PR-6850-2
[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // withDockerRegistry
[Pipeline] }
[Pipeline] // node
[Pipeline] }
01:42:33 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_service_removed_while_up PASSED [ 37%]

01:42:36 tests/integration/state_test.py::ProjectWithDependsOnDependenciesTest::test_up PASSED [ 37%]

01:42:36 tests/integration/state_test.py::ServiceStateTest::test_image_changed_to_build PASSED [ 37%]

01:42:36 tests/integration/state_test.py::ServiceStateTest::test_trigger_create PASSED [ 37%]

01:42:37 tests/integration/state_test.py::ServiceStateTest::test_trigger_noop PASSED [ 37%]

Terminated
01:42:39 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_build PASSED [ 37%]

01:42:39 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_config_change PASSED [ 37%]

01:42:40 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_image_change PASSED [ 37%]

01:42:40 tests/integration/state_test.py::ServiceStateTest::test_trigger_recreate_with_nonexistent_image_tag PASSED [ 38%]

01:42:41 tests/integration/state_test.py::ServiceStateTest::test_trigger_start PASSED [ 38%]

01:42:41 tests/integration/volume_test.py::VolumeTest::test_create_volume PASSED  [ 38%]

01:42:41 tests/integration/volume_test.py::VolumeTest::test_create_volume_custom_name PASSED [ 38%]

01:42:41 tests/integration/volume_test.py::VolumeTest::test_exists PASSED         [ 38%]

01:42:41 tests/integration/volume_test.py::VolumeTest::test_exists_external PASSED [ 38%]

01:42:41 tests/integration/volume_test.py::VolumeTest::test_exists_external_aliased PASSED [ 38%]

01:42:41 tests/integration/volume_test.py::VolumeTest::test_external_aliased_volume PASSED [ 38%]

01:42:41 tests/integration/volume_test.py::VolumeTest::test_external_volume PASSED [ 38%]

01:42:41 tests/integration/volume_test.py::VolumeTest::test_inspect_volume PASSED [ 38%]

01:42:41 tests/integration/volume_test.py::VolumeTest::test_recreate_existing_volume PASSED [ 38%]

01:42:41 tests/integration/volume_test.py::VolumeTest::test_remove_volume PASSED  [ 39%]

01:42:41 tests/integration/volume_test.py::VolumeTest::test_volume_default_labels PASSED [ 39%]

01:42:41 tests/unit/bundle_test.py::test_get_image_digest_exists PASSED           [ 39%]

01:42:42 tests/unit/bundle_test.py::test_get_image_digest_image_uses_digest PASSED [ 39%]

01:42:42 tests/unit/bundle_test.py::test_get_image_digest_from_repository PASSED  [ 39%]

01:42:42 tests/unit/bundle_test.py::test_get_image_digest_no_image PASSED         [ 39%]

01:42:42 tests/unit/bundle_test.py::test_push_image_with_saved_digest PASSED      [ 39%]

01:42:43 tests/unit/bundle_test.py::test_push_image PASSED                        [ 39%]

01:42:43 tests/unit/bundle_test.py::test_to_bundle PASSED                         [ 39%]

01:42:43 tests/unit/bundle_test.py::test_convert_service_to_bundle PASSED         [ 39%]

01:42:43 tests/unit/bundle_test.py::test_set_command_and_args_none PASSED         [ 39%]

01:42:43 tests/unit/bundle_test.py::test_set_command_and_args_from_command PASSED [ 39%]

01:42:43 tests/unit/bundle_test.py::test_set_command_and_args_from_entrypoint PASSED [ 40%]

01:42:43 tests/unit/bundle_test.py::test_set_command_and_args_from_both PASSED    [ 40%]

01:42:43 tests/unit/bundle_test.py::test_make_service_networks_default PASSED     [ 40%]

01:42:43 tests/unit/bundle_test.py::test_make_service_networks PASSED             [ 40%]

01:42:43 tests/unit/bundle_test.py::test_make_port_specs PASSED                   [ 40%]

01:42:43 tests/unit/bundle_test.py::test_make_port_spec_with_protocol PASSED      [ 40%]

01:42:43 tests/unit/bundle_test.py::test_make_port_spec_default_protocol PASSED   [ 40%]

01:42:43 tests/unit/cli_test.py::CLITestCase::test_command_help PASSED            [ 40%]

01:42:43 tests/unit/cli_test.py::CLITestCase::test_command_help_nonexistent PASSED [ 40%]

01:42:43 tests/unit/cli_test.py::CLITestCase::test_command_manual_and_service_ports_together PASSED [ 40%]

01:42:43 tests/unit/cli_test.py::CLITestCase::test_default_project_name PASSED    [ 40%]

01:42:43 tests/unit/cli_test.py::CLITestCase::test_get_project PASSED             [ 41%]

01:42:43 tests/unit/cli_test.py::CLITestCase::test_project_name_from_environment_new_var PASSED [ 41%]

01:42:43 tests/unit/cli_test.py::CLITestCase::test_project_name_with_empty_environment_var PASSED [ 41%]

01:42:43 tests/unit/cli_test.py::CLITestCase::test_project_name_with_environment_file PASSED [ 41%]

01:42:43 tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_base_dir PASSED [ 41%]

01:42:43 tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_project_name PASSED [ 41%]

01:42:43 tests/unit/cli_test.py::CLITestCase::test_project_name_with_explicit_uppercase_base_dir PASSED [ 41%]

01:42:43 tests/unit/cli_test.py::CLITestCase::test_run_interactive_passes_logs_false PASSED [ 41%]

01:42:43 tests/unit/cli_test.py::CLITestCase::test_run_service_with_restart_always PASSED [ 41%]

01:42:43 tests/unit/container_test.py::ContainerTest::test_environment PASSED     [ 41%]

01:42:43 tests/unit/container_test.py::ContainerTest::test_from_ps PASSED         [ 41%]

01:42:43 tests/unit/container_test.py::ContainerTest::test_from_ps_prefixed PASSED [ 42%]

01:42:43 tests/unit/container_test.py::ContainerTest::test_get PASSED             [ 42%]

01:42:43 tests/unit/container_test.py::ContainerTest::test_get_local_port PASSED  [ 42%]

01:42:43 tests/unit/container_test.py::ContainerTest::test_has_api_logs PASSED    [ 42%]

01:42:43 tests/unit/container_test.py::ContainerTest::test_human_readable_ports_none PASSED [ 42%]

01:42:43 tests/unit/container_test.py::ContainerTest::test_human_readable_ports_public_and_private PASSED [ 42%]

01:42:43 tests/unit/container_test.py::ContainerTest::test_human_readable_states_healthy PASSED [ 42%]

01:42:43 tests/unit/container_test.py::ContainerTest::test_human_readable_states_no_health PASSED [ 42%]

01:42:43 tests/unit/container_test.py::ContainerTest::test_human_readable_states_starting PASSED [ 42%]

01:42:43 tests/unit/container_test.py::ContainerTest::test_inspect_if_not_inspected PASSED [ 42%]

01:42:43 tests/unit/container_test.py::ContainerTest::test_name PASSED            [ 42%]

01:42:43 tests/unit/container_test.py::ContainerTest::test_name_without_project PASSED [ 42%]

01:42:43 tests/unit/container_test.py::ContainerTest::test_name_without_project_custom_container_name PASSED [ 43%]

01:42:43 tests/unit/container_test.py::ContainerTest::test_name_without_project_one_off PASSED [ 43%]

01:42:43 tests/unit/container_test.py::ContainerTest::test_number PASSED          [ 43%]

01:42:43 tests/unit/container_test.py::ContainerTest::test_short_id PASSED        [ 43%]

01:42:43 tests/unit/container_test.py::GetContainerNameTestCase::test_get_container_name PASSED [ 43%]

01:42:43 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_driver_mismatch PASSED [ 43%]

01:42:43 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_null_remote PASSED [ 43%]

01:42:43 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_null_remote_ipam_options PASSED [ 43%]

01:42:43 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_options_mismatch PASSED [ 43%]

01:42:43 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_success PASSED [ 43%]

01:42:43 tests/unit/network_test.py::NetworkTest::test_check_remote_network_config_whitelist PASSED [ 43%]

01:42:43 tests/unit/network_test.py::NetworkTest::test_check_remote_network_labels_mismatch PASSED [ 44%]

01:42:43 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute PASSED  [ 44%]

01:42:43 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_deps PASSED [ 44%]

01:42:43 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_global_limit PASSED [ 44%]

01:42:43 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_limit PASSED [ 44%]

01:42:43 tests/unit/parallel_test.py::ParallelTest::test_parallel_execute_with_upstream_errors PASSED [ 44%]

01:42:43 tests/unit/parallel_test.py::test_parallel_execute_alignment PASSED      [ 44%]

01:42:43 tests/unit/parallel_test.py::test_parallel_execute_ansi PASSED           [ 44%]

01:42:43 tests/unit/parallel_test.py::test_parallel_execute_noansi PASSED         [ 44%]

01:42:43 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_get_digest_from_pull PASSED [ 44%]

01:42:43 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_get_digest_from_push PASSED [ 44%]

01:42:43 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_mismatched_encoding_stream_write PASSED [ 44%]

01:42:43 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output PASSED [ 45%]

01:42:43 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_div_zero PASSED [ 45%]

01:42:43 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_no_progress_event_no_tty PASSED [ 45%]

01:42:43 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_null_total PASSED [ 45%]

01:42:43 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_progress_event_no_tty PASSED [ 45%]

01:42:43 tests/unit/progress_stream_test.py::ProgressStreamTestCase::test_stream_output_progress_event_tty PASSED [ 45%]

01:42:44 tests/unit/project_test.py::ProjectTest::test_avoid_multiple_push PASSED [ 45%]

01:42:44 tests/unit/project_test.py::ProjectTest::test_build_container_operation_with_timeout_func_does_not_mutate_options_with_timeout PASSED [ 45%]

01:42:44 tests/unit/project_test.py::ProjectTest::test_container_without_name PASSED [ 45%]

01:42:44 tests/unit/project_test.py::ProjectTest::test_down_with_no_resources PASSED [ 45%]

01:42:44 tests/unit/project_test.py::ProjectTest::test_error_parallel_pull PASSED [ 45%]

01:42:45 tests/unit/project_test.py::ProjectTest::test_events PASSED              [ 46%]

01:42:45 tests/unit/project_test.py::ProjectTest::test_events_legacy PASSED       [ 46%]

01:42:45 tests/unit/project_test.py::ProjectTest::test_from_config_v1 PASSED      [ 46%]

01:42:45 tests/unit/project_test.py::ProjectTest::test_from_config_v2 PASSED      [ 46%]

01:42:45 tests/unit/project_test.py::ProjectTest::test_get_service PASSED         [ 46%]

01:42:45 tests/unit/project_test.py::ProjectTest::test_get_services_removes_duplicates_following_links PASSED [ 46%]

01:42:46 tests/unit/project_test.py::ProjectTest::test_get_services_returns_all_services_without_args PASSED [ 46%]

01:42:46 tests/unit/project_test.py::ProjectTest::test_get_services_returns_listed_services_with_args PASSED [ 46%]

01:42:46 tests/unit/project_test.py::ProjectTest::test_get_services_with_include_links PASSED [ 46%]

01:42:46 tests/unit/project_test.py::ProjectTest::test_net_unset PASSED           [ 46%]

01:42:46 tests/unit/project_test.py::ProjectTest::test_no_such_service_unicode PASSED [ 46%]

01:42:46 tests/unit/project_test.py::ProjectTest::test_no_warning_in_normal_mode PASSED [ 47%]

01:42:47 tests/unit/project_test.py::ProjectTest::test_no_warning_on_stop PASSED  [ 47%]

01:42:47 tests/unit/project_test.py::ProjectTest::test_no_warning_with_no_swarm_info PASSED [ 47%]

01:42:47 tests/unit/project_test.py::ProjectTest::test_project_platform_value PASSED [ 47%]

01:42:47 tests/unit/project_test.py::ProjectTest::test_use_net_from_container PASSED [ 47%]

01:42:47 tests/unit/project_test.py::ProjectTest::test_use_net_from_service PASSED [ 47%]

01:42:47 tests/unit/project_test.py::ProjectTest::test_use_volumes_from_container PASSED [ 47%]

01:42:48 tests/unit/project_test.py::ProjectTest::test_use_volumes_from_service_container PASSED [ 47%]

01:42:48 tests/unit/project_test.py::ProjectTest::test_use_volumes_from_service_no_container PASSED [ 47%]

01:42:48 tests/unit/project_test.py::ProjectTest::test_uses_default_network_false PASSED [ 47%]

01:42:48 tests/unit/project_test.py::ProjectTest::test_uses_default_network_true PASSED [ 47%]

01:42:48 tests/unit/service_test.py::ServiceTest::test_build_does_not_pull PASSED [ 47%]

01:42:48 tests/unit/service_test.py::ServiceTest::test_build_isolation_from_build_override_service_config PASSED [ 48%]

01:42:49 tests/unit/service_test.py::ServiceTest::test_build_service_with_proxy_config PASSED [ 48%]

01:42:49 tests/unit/service_test.py::ServiceTest::test_build_volume_options_duplicate_binds PASSED [ 48%]

01:42:49 tests/unit/service_test.py::ServiceTest::test_build_with_default_platform PASSED [ 48%]

01:42:49 tests/unit/service_test.py::ServiceTest::test_build_with_isolation_from_service_config PASSED [ 48%]

01:42:49 tests/unit/service_test.py::ServiceTest::test_build_with_override_build_args PASSED [ 48%]

01:42:49 tests/unit/service_test.py::ServiceTest::test_build_with_platform PASSED [ 48%]

01:42:50 tests/unit/service_test.py::ServiceTest::test_cgroup_parent PASSED       [ 48%]

01:42:50 tests/unit/service_test.py::ServiceTest::test_config_dict PASSED         [ 48%]

01:42:50 tests/unit/service_test.py::ServiceTest::test_config_dict_with_network_mode_from_container PASSED [ 48%]

01:42:50 tests/unit/service_test.py::ServiceTest::test_config_hash_matches_label PASSED [ 48%]

01:42:51 tests/unit/service_test.py::ServiceTest::test_container_without_name PASSED [ 49%]

01:42:51 tests/unit/service_test.py::ServiceTest::test_containers PASSED          [ 49%]

01:42:51 tests/unit/service_test.py::ServiceTest::test_containers_with_containers PASSED [ 49%]

01:42:51 tests/unit/service_test.py::ServiceTest::test_create_container PASSED    [ 49%]

01:42:51 tests/unit/service_test.py::ServiceTest::test_create_when_removed_containers_are_listed PASSED [ 49%]

01:42:51 tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_force_build PASSED [ 49%]

01:42:52 tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_no_build PASSED [ 49%]

01:42:52 tests/unit/service_test.py::ServiceTest::test_ensure_image_exists_no_build_but_needs_build PASSED [ 49%]

01:42:52 tests/unit/service_test.py::ServiceTest::test_get_container PASSED       [ 49%]

01:42:52 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_does_not_mutate_options PASSED [ 49%]

01:42:52 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_no_affinity_without_binds PASSED [ 49%]

01:42:52 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_sets_affinity_with_binds PASSED [ 50%]

01:42:53 tests/unit/service_test.py::ServiceTest::test_get_container_create_options_with_name_option PASSED [ 50%]

01:42:53 tests/unit/service_test.py::ServiceTest::test_get_container_not_found PASSED [ 50%]

01:42:53 tests/unit/service_test.py::ServiceTest::test_get_create_options_with_proxy_config PASSED [ 50%]

01:42:53 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_container PASSED [ 50%]

01:42:53 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_container_read_only PASSED [ 50%]

01:42:54 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_container_exists PASSED [ 50%]

01:42:54 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_container_exists_with_flags PASSED [ 50%]

01:42:54 tests/unit/service_test.py::ServiceTest::test_get_volumes_from_service_no_container PASSED [ 50%]

01:42:54 tests/unit/service_test.py::ServiceTest::test_image_name_default PASSED  [ 50%]

01:42:55 tests/unit/service_test.py::ServiceTest::test_image_name_from_config PASSED [ 50%]

01:42:55 tests/unit/service_test.py::ServiceTest::test_log_opt PASSED             [ 50%]

01:42:55 tests/unit/service_test.py::ServiceTest::test_mem_reservation PASSED     [ 51%]

01:42:55 tests/unit/service_test.py::ServiceTest::test_memory_swap_limit PASSED   [ 51%]

01:42:55 tests/unit/service_test.py::ServiceTest::test_no_default_hostname_when_not_using_networking PASSED [ 51%]

01:42:55 tests/unit/service_test.py::ServiceTest::test_only_log_warning_when_host_ports_clash PASSED [ 51%]

01:42:56 tests/unit/service_test.py::ServiceTest::test_parse_proxy_config PASSED  [ 51%]

01:42:56 tests/unit/service_test.py::ServiceTest::test_parse_proxy_config_per_host PASSED [ 51%]

01:42:56 tests/unit/service_test.py::ServiceTest::test_parse_repository_tag PASSED [ 51%]

01:42:56 tests/unit/service_test.py::ServiceTest::test_pull_image PASSED          [ 51%]

01:42:56 tests/unit/service_test.py::ServiceTest::test_pull_image_digest PASSED   [ 51%]

01:42:56 tests/unit/service_test.py::ServiceTest::test_pull_image_no_tag PASSED   [ 51%]

01:42:57 tests/unit/service_test.py::ServiceTest::test_pull_image_with_default_platform PASSED [ 51%]

01:42:57 tests/unit/service_test.py::ServiceTest::test_pull_image_with_platform PASSED [ 52%]

01:42:57 tests/unit/service_test.py::ServiceTest::test_pull_image_with_platform_unsupported_api PASSED [ 52%]

01:42:57 tests/unit/service_test.py::ServiceTest::test_recreate_container PASSED  [ 52%]

01:42:57 tests/unit/service_test.py::ServiceTest::test_recreate_container_with_timeout PASSED [ 52%]

01:42:58 tests/unit/service_test.py::ServiceTest::test_remove_image_all_does_remove PASSED [ 52%]

01:42:58 tests/unit/service_test.py::ServiceTest::test_remove_image_local_with_image_name_doesnt_remove PASSED [ 52%]

01:42:58 tests/unit/service_test.py::ServiceTest::test_remove_image_local_without_image_name_does_remove PASSED [ 52%]

01:42:58 tests/unit/service_test.py::ServiceTest::test_remove_image_none PASSED   [ 52%]

01:42:58 tests/unit/service_test.py::ServiceTest::test_remove_image_with_error PASSED [ 52%]

01:42:58 tests/unit/service_test.py::ServiceTest::test_remove_non_existing_image PASSED [ 52%]

01:42:59 tests/unit/service_test.py::ServiceTest::test_self_reference_external_link PASSED [ 52%]

01:42:59 tests/unit/service_test.py::ServiceTest::test_service_ignore_default_platform_with_unsupported_api PASSED [ 52%]

01:42:59 tests/unit/service_test.py::ServiceTest::test_service_platform_precedence PASSED [ 53%]

01:42:59 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_container_port PASSED [ 53%]

01:42:59 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_container_port_range PASSED [ 53%]

01:43:00 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_and_port PASSED [ 53%]

01:43:00 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_and_port_range PASSED [ 53%]

01:43:00 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_no_port PASSED [ 53%]

01:43:00 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_ip_no_port_range PASSED [ 53%]

01:43:00 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_port PASSED [ 53%]

01:43:01 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_host_port_range PASSED [ 53%]

01:43:01 tests/unit/service_test.py::ServiceTest::test_specifies_host_port_with_no_ports PASSED [ 53%]

01:43:01 tests/unit/service_test.py::ServiceTest::test_split_domainname_both PASSED [ 53%]

01:43:01 tests/unit/service_test.py::ServiceTest::test_split_domainname_fqdn PASSED [ 54%]

01:43:01 tests/unit/service_test.py::ServiceTest::test_split_domainname_none PASSED [ 54%]

01:43:01 tests/unit/service_test.py::ServiceTest::test_split_domainname_weird PASSED [ 54%]

01:43:02 tests/unit/service_test.py::ServiceTest::test_stop_grace_period PASSED   [ 54%]

01:43:02 tests/unit/service_test.py::ServiceTest::test_volumes_order_is_preserved PASSED [ 54%]

01:43:02 tests/unit/service_test.py::TestServiceNetwork::test_connect_container_to_networks_short_aliase_exists PASSED [ 54%]

01:43:02 tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_dict PASSED [ 54%]

01:43:02 tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_integers_and_dicts PASSED [ 54%]

01:43:02 tests/unit/service_test.py::BuildUlimitsTestCase::test_build_ulimits_with_ints PASSED [ 54%]

01:43:02 tests/unit/service_test.py::NetTestCase::test_network_mode PASSED        [ 54%]

01:43:02 tests/unit/service_test.py::NetTestCase::test_network_mode_container PASSED [ 54%]

01:43:02 tests/unit/service_test.py::NetTestCase::test_network_mode_service PASSED [ 55%]

01:43:03 tests/unit/service_test.py::NetTestCase::test_network_mode_service_no_containers PASSED [ 55%]

01:43:03 tests/unit/service_test.py::ServicePortsTest::test_formatted_ports PASSED [ 55%]

01:43:03 tests/unit/service_test.py::ServiceVolumesTest::test_build_volume_binding PASSED [ 55%]

01:43:03 tests/unit/service_test.py::ServiceVolumesTest::test_create_with_special_volume_mode PASSED [ 55%]

01:43:03 tests/unit/service_test.py::ServiceVolumesTest::test_get_container_create_options_with_different_host_path_in_container_json PASSED [ 55%]

01:43:03 tests/unit/service_test.py::ServiceVolumesTest::test_get_container_data_volumes PASSED [ 55%]

01:43:03 tests/unit/service_test.py::ServiceVolumesTest::test_merge_volume_bindings PASSED [ 55%]

01:43:04 tests/unit/service_test.py::ServiceVolumesTest::test_mount_same_host_path_to_two_volumes PASSED [ 55%]

01:43:04 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_no_warning_with_container_only_option PASSED [ 55%]

01:43:04 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_no_warning_with_same_path PASSED [ 55%]

01:43:04 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_volume_no_warning_when_no_container_volumes PASSED [ 55%]

01:43:04 tests/unit/service_test.py::ServiceVolumesTest::test_warn_on_masked_volume_when_masked PASSED [ 56%]

01:43:04 tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes PASSED [ 56%]

01:43:05 tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes_abspath PASSED [ 56%]

01:43:05 tests/unit/service_test.py::ServiceSecretTest::test_get_secret_volumes_no_target PASSED [ 56%]

01:43:05 tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_unix_path PASSED [ 56%]

01:43:05 tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_url_no_prefix PASSED [ 56%]

01:43:05 tests/unit/service_test.py::RewriteBuildPathTest::test_rewrite_windows_path PASSED [ 56%]

01:43:05 tests/unit/split_buffer_test.py::SplitBufferTest::test_chunked_line PASSED [ 56%]

01:43:05 tests/unit/split_buffer_test.py::SplitBufferTest::test_multiple_line_chunk PASSED [ 56%]

01:43:05 tests/unit/split_buffer_test.py::SplitBufferTest::test_no_end_separator PASSED [ 56%]

01:43:05 tests/unit/split_buffer_test.py::SplitBufferTest::test_preserves_unicode_sequences_within_lines PASSED [ 56%]

01:43:05 tests/unit/split_buffer_test.py::SplitBufferTest::test_single_line_chunks PASSED [ 57%]

01:43:05 tests/unit/timeparse_test.py::test_milli PASSED                          [ 57%]

01:43:05 tests/unit/timeparse_test.py::test_milli_float PASSED                    [ 57%]

01:43:05 tests/unit/timeparse_test.py::test_second_milli PASSED                   [ 57%]

01:43:05 tests/unit/timeparse_test.py::test_second_milli_micro PASSED             [ 57%]

01:43:05 tests/unit/timeparse_test.py::test_second PASSED                         [ 57%]

01:43:05 tests/unit/timeparse_test.py::test_second_as_float PASSED                [ 57%]

01:43:05 tests/unit/timeparse_test.py::test_minute PASSED                         [ 57%]

01:43:05 tests/unit/timeparse_test.py::test_hour_minute PASSED                    [ 57%]

01:43:05 tests/unit/timeparse_test.py::test_minute_as_float PASSED                [ 57%]

01:43:05 tests/unit/timeparse_test.py::test_hour_minute_second PASSED             [ 57%]

01:43:05 tests/unit/timeparse_test.py::test_invalid_with_space PASSED             [ 57%]

01:43:05 tests/unit/timeparse_test.py::test_invalid_with_comma PASSED             [ 58%]

01:43:05 tests/unit/timeparse_test.py::test_invalid_with_empty_string PASSED      [ 58%]

01:43:05 tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_no_object PASSED [ 58%]

01:43:05 tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_with_object PASSED [ 58%]

01:43:05 tests/unit/utils_test.py::TestJsonSplitter::test_json_splitter_leading_whitespace PASSED [ 58%]

01:43:05 tests/unit/utils_test.py::TestStreamAsText::test_stream_with_non_utf_unicode_character PASSED [ 58%]

01:43:05 tests/unit/utils_test.py::TestStreamAsText::test_stream_with_utf_character PASSED [ 58%]

01:43:05 tests/unit/utils_test.py::TestJsonStream::test_with_falsy_entries PASSED [ 58%]

01:43:05 tests/unit/utils_test.py::TestJsonStream::test_with_leading_whitespace PASSED [ 58%]

01:43:05 tests/unit/utils_test.py::TestParseBytes::test_parse_bytes PASSED        [ 58%]

01:43:05 tests/unit/utils_test.py::TestMoreItertools::test_unique_everseen PASSED [ 58%]

01:43:05 tests/unit/volume_test.py::TestVolume::test_remove_local_volume PASSED   [ 59%]

01:43:05 tests/unit/volume_test.py::TestVolume::test_remove_external_volume PASSED [ 59%]

01:43:05 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_path_from_options PASSED [ 59%]

01:43:05 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_single_path_from_env PASSED [ 59%]

01:43:05 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env PASSED [ 59%]

01:43:05 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env_windows SKIPPED [ 59%]

01:43:05 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_multiple_path_from_env_custom_separator PASSED [ 59%]

01:43:05 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_no_path PASSED [ 59%]

01:43:05 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_unicode_path_from_options PASSED [ 59%]

01:43:05 tests/unit/cli/command_test.py::TestGetConfigPathFromOptions::test_unicode_path_from_env SKIPPED [ 59%]

01:43:05 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_custom_timeout_error PASSED [ 59%]

01:43:05 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_docker_client_no_home PASSED [ 60%]

01:43:05 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_docker_client_with_custom_timeout PASSED [ 60%]

01:43:05 tests/unit/cli/docker_client_test.py::DockerClientTestCase::test_user_agent PASSED [ 60%]

01:43:05 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_assert_hostname_explicit_skip PASSED [ 60%]

01:43:05 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_simple_tls PASSED [ 60%]

01:43:05 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_ca_cert PASSED [ 60%]

01:43:05 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_ca_cert_explicit PASSED [ 60%]

01:43:05 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca PASSED [ 60%]

01:43:05 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca_explicit PASSED [ 60%]

01:43:05 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_and_ca_quoted_paths PASSED [ 60%]

01:43:05 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_cert PASSED [ 60%]

01:43:05 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_cert_explicit PASSED [ 60%]

01:43:05 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_client_missing_key PASSED [ 61%]

01:43:05 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_flags_override_environment PASSED [ 61%]

01:43:05 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_mixed_environment_and_flags PASSED [ 61%]

01:43:05 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_simple_with_tls_version PASSED [ 61%]

01:43:05 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_default_cert_path PASSED [ 61%]

01:43:05 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_env_falsy_value PASSED [ 61%]

01:43:05 tests/unit/cli/docker_client_test.py::TLSConfigTestCase::test_tls_verify_flag_no_override PASSED [ 61%]

01:43:05 tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_default PASSED [ 61%]

01:43:05 tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_upgrade PASSED [ 61%]

01:43:05 tests/unit/cli/docker_client_test.py::TestGetTlsVersion::test_get_tls_version_unavailable PASSED [ 61%]

01:43:05 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_generic_connection_error PASSED [ 61%]

01:43:05 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_mismatch PASSED [ 62%]

01:43:05 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_mismatch_unicode_explanation PASSED [ 62%]

01:43:05 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_other PASSED [ 62%]

01:43:05 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_api_error_version_other_unicode_explanation PASSED [ 62%]

01:43:05 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_no_data SKIPPED [ 62%]

01:43:05 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_misc SKIPPED [ 62%]

01:43:05 tests/unit/cli/errors_test.py::TestHandleConnectionErrors::test_windows_pipe_error_encoding_issue SKIPPED [ 62%]

01:43:05 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_error PASSED [ 62%]

01:43:05 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_info PASSED [ 62%]

01:43:05 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_error PASSED [ 62%]

01:43:05 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_info PASSED [ 62%]

01:43:05 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_unicode_warn PASSED [ 63%]

01:43:05 tests/unit/cli/formatter_test.py::ConsoleWarningFormatterTestCase::test_format_warn PASSED [ 63%]

01:43:05 tests/unit/cli/log_printer_test.py::TestLogPresenter::test_monochrome PASSED [ 63%]

01:43:05 tests/unit/cli/log_printer_test.py::TestLogPresenter::test_polychrome PASSED [ 63%]

01:43:05 tests/unit/cli/log_printer_test.py::test_wait_on_exit PASSED             [ 63%]

01:43:05 tests/unit/cli/log_printer_test.py::test_wait_on_exit_raises PASSED      [ 63%]

01:43:05 tests/unit/cli/log_printer_test.py::test_build_no_log_generator PASSED   [ 63%]

01:43:05 tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_no_log_stream PASSED [ 63%]

01:43:05 tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_with_log_stream PASSED [ 63%]

01:43:05 tests/unit/cli/log_printer_test.py::TestBuildLogGenerator::test_unicode PASSED [ 63%]

01:43:05 tests/unit/cli/log_printer_test.py::TestWatchEvents::test_stop_event PASSED [ 63%]

01:43:05 tests/unit/cli/log_printer_test.py::TestWatchEvents::test_start_event PASSED [ 63%]

01:43:05 tests/unit/cli/log_printer_test.py::TestWatchEvents::test_other_event PASSED [ 64%]

01:43:05 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_an_exception PASSED [ 64%]

01:43:05 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_stop_without_cascade_stop PASSED [ 64%]

01:43:05 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_stop_with_cascade_stop PASSED [ 64%]

01:43:05 tests/unit/cli/log_printer_test.py::TestConsumeQueue::test_item_is_none_when_timeout_is_hit PASSED [ 64%]

01:43:06 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_filter_containers_to_service_names PASSED [ 64%]

01:43:06 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_filter_containers_to_service_names_all PASSED [ 64%]

01:43:06 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_warning_in_swarm_mode PASSED [ 64%]

01:43:06 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_build_one_off_container_options PASSED [ 64%]

01:43:06 tests/unit/cli/main_test.py::TestCLIMainTestCase::test_get_docker_start_call PASSED [ 64%]

01:43:06 tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_tty_verbose PASSED [ 64%]

01:43:06 tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_tty_not_verbose PASSED [ 65%]

01:43:06 tests/unit/cli/main_test.py::TestSetupConsoleHandlerTestCase::test_with_not_a_tty PASSED [ 65%]

01:43:06 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_invalid_opts PASSED [ 65%]

01:43:06 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_always PASSED [ 65%]

01:43:06 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_never PASSED [ 65%]

01:43:06 tests/unit/cli/main_test.py::TestConvergeStrategyFromOptsTestCase::test_changed PASSED [ 65%]

01:43:06 tests/unit/cli/main_test.py::TestCallDocker::test_simple_no_options PASSED [ 65%]

01:43:06 tests/unit/cli/main_test.py::TestCallDocker::test_simple_tls_option PASSED [ 65%]

01:43:06 tests/unit/cli/main_test.py::TestCallDocker::test_advanced_tls_options PASSED [ 65%]

01:43:06 tests/unit/cli/main_test.py::TestCallDocker::test_with_host_option PASSED [ 65%]

01:43:06 tests/unit/cli/main_test.py::TestCallDocker::test_with_http_host PASSED  [ 65%]

01:43:06 tests/unit/cli/main_test.py::TestCallDocker::test_with_host_option_shorthand_equal PASSED [ 65%]

01:43:06 tests/unit/cli/main_test.py::TestCallDocker::test_with_env PASSED        [ 66%]

01:43:06 tests/unit/cli/utils_test.py::UnquotePathTest::test_nested_quotes PASSED [ 66%]

01:43:06 tests/unit/cli/utils_test.py::UnquotePathTest::test_no_quotes PASSED     [ 66%]

01:43:06 tests/unit/cli/utils_test.py::UnquotePathTest::test_simple_quotes PASSED [ 66%]

01:43:06 tests/unit/cli/utils_test.py::UnquotePathTest::test_uneven_quotes PASSED [ 66%]

01:43:06 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_100b PASSED [ 66%]

01:43:06 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_1023b PASSED [ 66%]

01:43:06 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_1kb PASSED [ 66%]

01:43:06 tests/unit/cli/utils_test.py::HumanReadableFileSizeTest::test_units PASSED [ 66%]

01:43:06 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_call PASSED [ 66%]

01:43:06 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return PASSED [ 66%]

01:43:06 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return_no_result PASSED [ 67%]

01:43:06 tests/unit/cli/verbose_proxy_test.py::VerboseProxyTestCase::test_format_return_sequence PASSED [ 67%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_build_args_allow_empty_properties PASSED [ 67%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_build_args_check_zero_preserved PASSED [ 67%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_config_build_configuration PASSED [ 67%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_config_build_configuration_v2 PASSED [ 67%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_config_convertible_label_types PASSED [ 67%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_config_duplicate_cache_from_values_validation_error PASSED [ 67%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_config_duplicate_mount_points PASSED [ 67%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_config_extra_hosts_list_of_dicts_validation_error PASSED [ 67%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_config_extra_hosts_string_raises_validation_error PASSED [ 67%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_config_hint PASSED    [ 68%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error PASSED [ 68%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error_v2 PASSED [ 68%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_name_raise_validation_error_v2_when_no_interpolate PASSED [ 68%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_config_integer_service_property_raise_validation_error PASSED [ 68%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_config_invalid_ipam_config PASSED [ 68%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_config_invalid_label_types PASSED [ 68%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_config_invalid_service_name_raise_validation_error PASSED [ 68%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_invalid_keys_validation_error PASSED [ 68%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_required_keys_validation_error PASSED [ 68%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_config_ulimits_soft_greater_than_hard_error PASSED [ 68%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_config_valid_environment_dict_key_contains_dashes PASSED [ 68%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_config_valid_ipam_config PASSED [ 69%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_config_valid_service_label_validation PASSED [ 69%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_config_valid_service_names PASSED [ 69%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_depends_on_orders_services PASSED [ 69%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_depends_on_unknown_service_errors PASSED [ 69%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_dns_opt_option PASSED [ 69%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_empty_environment_key_allowed PASSED [ 69%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_external_volume_config PASSED [ 69%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_external_volume_invalid_config PASSED [ 69%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_group_add_option PASSED [ 69%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_build_and_image_specified_v1 PASSED [ 69%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_not_a_dictionary PASSED [ 70%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_not_unique_items PASSED [ 70%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_type_should_be_an_array PASSED [ 70%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_v1 PASSED [ 70%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_invalid_config_v2 PASSED [ 70%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_invalid_list_of_strings_format PASSED [ 70%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_isolation_option PASSED [ 70%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_linked_service_is_undefined PASSED [ 70%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_load PASSED           [ 70%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_load_bind_mount_relative_path PASSED [ 70%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_load_bind_mount_relative_path_with_tilde PASSED [ 70%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_load_build_labels_dict PASSED [ 71%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_load_build_labels_list PASSED [ 71%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_load_config_custom_resource_names PASSED [ 71%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_load_config_dockerfile_without_build_raises_error_v1 PASSED [ 71%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_load_config_invalid_service_names PASSED [ 71%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_load_config_invalid_service_names_v2 PASSED [ 71%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_load_config_link_local_ips_network PASSED [ 71%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_load_config_service_labels PASSED [ 71%]

01:43:06 tests/unit/config/config_test.py::ConfigTest::test_load_config_volume_and_network_labels PASSED [ 71%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_configs PASSED   [ 71%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_configs_multi_file PASSED [ 71%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_dockerfile_without_context PASSED [ 71%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_errors_on_uppercase_with_no_image PASSED [ 72%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_invalid_service_definition PASSED [ 72%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_mixed_extends_resolution PASSED [ 72%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_secrets PASSED   [ 72%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_secrets_multi_file PASSED [ 72%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_service_with_name_version PASSED [ 72%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_sorts_in_dependency_order PASSED [ 72%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_when_not_dict PASSED [ 72%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_when_not_dict_v2 PASSED [ 72%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_throws_error_with_invalid_network_fields PASSED [ 72%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_v2 PASSED        [ 72%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_with_buildargs PASSED [ 73%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_with_empty_build_args PASSED [ 73%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_with_extensions PASSED [ 73%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_with_invalid_field_name PASSED [ 73%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_with_invalid_field_name_v1 PASSED [ 73%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_base PASSED [ 73%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_base_v2 PASSED [ 73%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_override PASSED [ 73%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_empty_override_v2 PASSED [ 73%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_extends_in_override_file PASSED [ 73%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_and_invalid_override PASSED [ 73%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_mismatched_networks_format PASSED [ 73%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_mismatched_networks_format_inverse_order PASSED [ 74%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v1 PASSED [ 74%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v2 PASSED [ 74%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_with_multiple_files_v3_2 PASSED [ 74%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_yaml_with_bom PASSED [ 74%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_load_yaml_with_yaml_error PASSED [ 74%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_logs_warning_for_boolean_in_environment PASSED [ 74%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_blkio_config PASSED [ 74%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_configs_override PASSED [ 74%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_credential_spec PASSED [ 74%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_depends_on_mixed_syntax PASSED [ 74%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_depends_on_no_override PASSED [ 75%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_deploy PASSED   [ 75%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_deploy_override PASSED [ 75%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_device_cgroup_rules PASSED [ 75%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_different_configs PASSED [ 75%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_different_secrets PASSED [ 75%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_extra_hosts PASSED [ 75%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_config PASSED [ 75%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_override_disables PASSED [ 75%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_healthcheck_override_enables PASSED [ 75%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_isolation PASSED [ 75%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v1 PASSED [ 76%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2 PASSED [ 76%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_base PASSED [ 76%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_base_driver PASSED [ 76%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_drivers PASSED [ 76%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_override PASSED [ 76%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_no_override_options PASSED [ 76%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_logging_v2_override_driver PASSED [ 76%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_mixed_ports PASSED [ 76%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_pid PASSED      [ 76%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_scale PASSED    [ 76%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_secrets_override PASSED [ 76%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_from_files_with_extends_in_base PASSED [ 77%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_from_files_with_extends_in_override PASSED [ 77%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous PASSED [ 77%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous_2 PASSED [ 77%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_heterogeneous_volumes PASSED [ 77%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_service_dicts_ports_sorting PASSED [ 77%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_merge_storage_opt PASSED [ 77%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_named_volume_config_empty PASSED [ 77%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_named_volume_invalid_type_list PASSED [ 77%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_named_volume_numeric_driver_opt PASSED [ 77%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_networks_invalid_type_list PASSED [ 77%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_normalize_dns_options PASSED [ 78%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_oom_score_adj_option PASSED [ 78%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_runtime_option PASSED [ 78%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_service_volume_invalid_config PASSED [ 78%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_swappiness_option PASSED [ 78%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_tmpfs_option PASSED   [ 78%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_undeclared_volume_v1 PASSED [ 78%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_undeclared_volume_v2 PASSED [ 78%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_unsupported_version PASSED [ 78%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_v1_file_version PASSED [ 78%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_v1_file_with_version_is_invalid PASSED [ 78%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_valid_config_oneof_string_or_list PASSED [ 78%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_valid_config_which_allows_two_type_definitions PASSED [ 79%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_valid_versions PASSED [ 79%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_validate_extra_hosts_invalid PASSED [ 79%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_validate_extra_hosts_invalid_list PASSED [ 79%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_version_1_is_invalid PASSED [ 79%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_volume_invalid_driver_opt PASSED [ 79%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_volume_mode_override PASSED [ 79%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_volumes_long_syntax PASSED [ 79%]

01:43:07 tests/unit/config/config_test.py::ConfigTest::test_wrong_version_type PASSED [ 79%]

01:43:07 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_container PASSED [ 79%]

01:43:07 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_container_v1 PASSED [ 79%]

01:43:07 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_plus_networks_is_invalid PASSED [ 80%]

01:43:07 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service PASSED [ 80%]

01:43:07 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service_nonexistent PASSED [ 80%]

01:43:07 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_service_v1 PASSED [ 80%]

01:43:07 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_standard PASSED [ 80%]

01:43:07 tests/unit/config/config_test.py::NetworkModeTest::test_network_mode_standard_v1 PASSED [ 80%]

01:43:07 tests/unit/config/config_test.py::PortsTest::test_config_invalid_expose_format_validation PASSED [ 80%]

01:43:07 tests/unit/config/config_test.py::PortsTest::test_config_invalid_expose_type_validation PASSED [ 80%]

01:43:07 tests/unit/config/config_test.py::PortsTest::test_config_invalid_ports_format_validation PASSED [ 80%]

01:43:07 tests/unit/config/config_test.py::PortsTest::test_config_invalid_ports_type_validation PASSED [ 80%]

01:43:07 tests/unit/config/config_test.py::PortsTest::test_config_non_unique_expose_validation PASSED [ 80%]

01:43:07 tests/unit/config/config_test.py::PortsTest::test_config_non_unique_ports_validation PASSED [ 81%]

01:43:07 tests/unit/config/config_test.py::PortsTest::test_config_valid_expose_format_validation PASSED [ 81%]

01:43:07 tests/unit/config/config_test.py::PortsTest::test_config_valid_ports_format_validation PASSED [ 81%]

01:43:07 tests/unit/config/config_test.py::SubnetTest::test_config_invalid_subnet_format_validation PASSED [ 81%]

01:43:07 tests/unit/config/config_test.py::SubnetTest::test_config_invalid_subnet_type_validation PASSED [ 81%]

01:43:07 tests/unit/config/config_test.py::SubnetTest::test_config_valid_subnet_format_validation PASSED [ 81%]

01:43:07 tests/unit/config/config_test.py::InterpolationTest::test_compatibility_mode_load PASSED [ 81%]

01:43:07 tests/unit/config/config_test.py::InterpolationTest::test_compatibility_mode_warnings PASSED [ 81%]

01:43:07 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_file PASSED [ 81%]

01:43:07 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_variable PASSED [ 81%]

01:43:07 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_environment_variable_with_defaults PASSED [ 81%]

01:43:07 tests/unit/config/config_test.py::InterpolationTest::test_config_file_with_options_environment_file PASSED [ 81%]

01:43:07 tests/unit/config/config_test.py::InterpolationTest::test_interpolation_configs_section PASSED [ 82%]

01:43:07 tests/unit/config/config_test.py::InterpolationTest::test_interpolation_secrets_section PASSED [ 82%]

01:43:07 tests/unit/config/config_test.py::InterpolationTest::test_invalid_interpolation PASSED [ 82%]

01:43:07 tests/unit/config/config_test.py::InterpolationTest::test_unset_variable_produces_warning PASSED [ 82%]

01:43:07 tests/unit/config/config_test.py::VolumeConfigTest::test_absolute_posix_path_does_not_expand PASSED [ 82%]

01:43:07 tests/unit/config/config_test.py::VolumeConfigTest::test_absolute_windows_path_does_not_expand PASSED [ 82%]

01:43:07 tests/unit/config/config_test.py::VolumeConfigTest::test_home_directory_with_driver_does_not_expand PASSED [ 82%]

01:43:07 tests/unit/config/config_test.py::VolumeConfigTest::test_name_does_not_expand PASSED [ 82%]

01:43:07 tests/unit/config/config_test.py::VolumeConfigTest::test_no_binding PASSED [ 82%]

01:43:07 tests/unit/config/config_test.py::VolumeConfigTest::test_relative_path_does_expand_posix PASSED [ 82%]

01:43:07 tests/unit/config/config_test.py::VolumeConfigTest::test_relative_path_does_expand_windows SKIPPED [ 82%]

01:43:07 tests/unit/config/config_test.py::VolumeConfigTest::test_volume_binding_with_environment_variable PASSED [ 83%]

01:43:07 tests/unit/config/config_test.py::VolumeConfigTest::test_volume_binding_with_home PASSED [ 83%]

01:43:07 tests/unit/config/config_test.py::VolumeConfigTest::test_volume_path_with_non_ascii_directory PASSED [ 83%]

01:43:07 tests/unit/config/config_test.py::VolumeConfigTest::test_volumes_order_is_preserved PASSED [ 83%]

01:43:07 tests/unit/config/config_test.py::MergeVolumesTest::test_add_explicit_path PASSED [ 83%]

01:43:07 tests/unit/config/config_test.py::MergeVolumesTest::test_empty PASSED    [ 83%]

01:43:07 tests/unit/config/config_test.py::MergeVolumesTest::test_no_base PASSED  [ 83%]

01:43:07 tests/unit/config/config_test.py::MergeVolumesTest::test_no_override PASSED [ 83%]

01:43:07 tests/unit/config/config_test.py::MergeVolumesTest::test_override_explicit_path PASSED [ 83%]

01:43:07 tests/unit/config/config_test.py::MergeVolumesTest::test_remove_explicit_path PASSED [ 83%]

01:43:07 tests/unit/config/config_test.py::MergeDevicesTest::test_add_explicit_path PASSED [ 83%]

01:43:07 tests/unit/config/config_test.py::MergeDevicesTest::test_empty PASSED    [ 84%]

01:43:07 tests/unit/config/config_test.py::MergeDevicesTest::test_no_base PASSED  [ 84%]

01:43:07 tests/unit/config/config_test.py::MergeDevicesTest::test_no_override PASSED [ 84%]

01:43:07 tests/unit/config/config_test.py::MergeDevicesTest::test_override_explicit_path PASSED [ 84%]

01:43:07 tests/unit/config/config_test.py::MergeDevicesTest::test_remove_explicit_path PASSED [ 84%]

01:43:07 tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_no_override PASSED [ 84%]

01:43:07 tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_override_with_other PASSED [ 84%]

01:43:07 tests/unit/config/config_test.py::BuildOrImageMergeTest::test_merge_build_or_image_override_with_same PASSED [ 84%]

01:43:07 tests/unit/config/config_test.py::MergePortsTest::test_add_item PASSED   [ 84%]

01:43:07 tests/unit/config/config_test.py::MergePortsTest::test_duplicate_port_mappings PASSED [ 84%]

01:43:07 tests/unit/config/config_test.py::MergePortsTest::test_empty PASSED      [ 84%]

01:43:07 tests/unit/config/config_test.py::MergePortsTest::test_no_base PASSED    [ 84%]

01:43:07 tests/unit/config/config_test.py::MergePortsTest::test_no_override PASSED [ 85%]

01:43:07 tests/unit/config/config_test.py::MergeNetworksTest::test_add_item PASSED [ 85%]

01:43:07 tests/unit/config/config_test.py::MergeNetworksTest::test_all_properties PASSED [ 85%]

01:43:07 tests/unit/config/config_test.py::MergeNetworksTest::test_empty PASSED   [ 85%]

01:43:07 tests/unit/config/config_test.py::MergeNetworksTest::test_network_has_none_value PASSED [ 85%]

01:43:07 tests/unit/config/config_test.py::MergeNetworksTest::test_no_base PASSED [ 85%]

01:43:07 tests/unit/config/config_test.py::MergeNetworksTest::test_no_network_name_overrides PASSED [ 85%]

01:43:07 tests/unit/config/config_test.py::MergeNetworksTest::test_no_network_overrides PASSED [ 85%]

01:43:07 tests/unit/config/config_test.py::MergeNetworksTest::test_no_override PASSED [ 85%]

01:43:07 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_add_list PASSED [ 85%]

01:43:07 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_add_string PASSED [ 85%]

01:43:07 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_no_base PASSED [ 86%]

01:43:07 tests/unit/config/config_test.py::MergeStringsOrListsTest::test_no_override PASSED [ 86%]

01:43:07 tests/unit/config/config_test.py::MergeLabelsTest::test_add_explicit_value PASSED [ 86%]

01:43:07 tests/unit/config/config_test.py::MergeLabelsTest::test_empty PASSED     [ 86%]

01:43:07 tests/unit/config/config_test.py::MergeLabelsTest::test_no_base PASSED   [ 86%]

01:43:07 tests/unit/config/config_test.py::MergeLabelsTest::test_no_override PASSED [ 86%]

01:43:07 tests/unit/config/config_test.py::MergeLabelsTest::test_override_explicit_value PASSED [ 86%]

01:43:07 tests/unit/config/config_test.py::MergeLabelsTest::test_remove_explicit_value PASSED [ 86%]

01:43:07 tests/unit/config/config_test.py::MergeBuildTest::test_empty_base PASSED [ 86%]

01:43:07 tests/unit/config/config_test.py::MergeBuildTest::test_empty_override PASSED [ 86%]

01:43:07 tests/unit/config/config_test.py::MergeBuildTest::test_full PASSED       [ 86%]

01:43:07 tests/unit/config/config_test.py::MemoryOptionsTest::test_memswap_can_be_a_string PASSED [ 86%]

01:43:07 tests/unit/config/config_test.py::MemoryOptionsTest::test_validation_fails_with_just_memswap_limit PASSED [ 87%]

01:43:07 tests/unit/config/config_test.py::MemoryOptionsTest::test_validation_with_correct_memswap_values PASSED [ 87%]

01:43:07 tests/unit/config/config_test.py::EnvTest::test_environment_overrides_env_file PASSED [ 87%]

01:43:07 tests/unit/config/config_test.py::EnvTest::test_parse_environment_as_dict PASSED [ 87%]

01:43:07 tests/unit/config/config_test.py::EnvTest::test_parse_environment_as_list PASSED [ 87%]

01:43:07 tests/unit/config/config_test.py::EnvTest::test_parse_environment_empty PASSED [ 87%]

01:43:07 tests/unit/config/config_test.py::EnvTest::test_parse_environment_invalid PASSED [ 87%]

01:43:07 tests/unit/config/config_test.py::EnvTest::test_resolve_build_args PASSED [ 87%]

01:43:07 tests/unit/config/config_test.py::EnvTest::test_resolve_environment PASSED [ 87%]

01:43:07 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_from_env_file PASSED [ 87%]

01:43:07 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_from_env_file_with_empty_values PASSED [ 87%]

01:43:07 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_nonexistent_file PASSED [ 88%]

01:43:07 tests/unit/config/config_test.py::EnvTest::test_resolve_environment_with_multiple_env_files PASSED [ 88%]

01:43:07 tests/unit/config/config_test.py::EnvTest::test_resolve_path PASSED      [ 88%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_circular PASSED      [ 88%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_invalid_config PASSED [ 88%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_valid_config PASSED [ 88%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_extended_service_with_verbose_and_shorthand_way PASSED [ 88%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_extends PASSED       [ 88%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_extends_file_defaults_to_self PASSED [ 88%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_empty_dictionary PASSED [ 88%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_invalid_key PASSED [ 88%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_missing_service_key PASSED [ 89%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_no_file_key_no_filename_set PASSED [ 89%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_sub_property_key PASSED [ 89%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_extends_validation_valid_config PASSED [ 89%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_defined_version_passes PASSED [ 89%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_depends_on PASSED [ 89%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_environment_and_env_files PASSED [ 89%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_healthcheck PASSED [ 89%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_mixed_versions_is_error PASSED [ 89%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_ports PASSED [ 89%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_extends_with_security_opt PASSED [ 89%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_invalid_links_in_extended_service PASSED [ 89%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_invalid_net_in_extended_service PASSED [ 90%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_invalid_volumes_from_in_extended_service PASSED [ 90%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_load_config_runs_interpolation_in_extended_service PASSED [ 90%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_load_throws_error_when_base_service_does_not_exist PASSED [ 90%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_merging_env_labels_ulimits PASSED [ 90%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_nested PASSED        [ 90%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_parent_build_path_dne PASSED [ 90%]

01:43:07 tests/unit/config/config_test.py::ExtendsTest::test_partial_service_config_in_extends_is_still_valid PASSED [ 90%]

01:43:08 tests/unit/config/config_test.py::ExtendsTest::test_self_referencing_file PASSED [ 90%]

01:43:08 tests/unit/config/config_test.py::ExtendsTest::test_volume_path PASSED   [ 90%]

01:43:08 tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_absolute PASSED [ 90%]

01:43:08 tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_normal PASSED [ 91%]

01:43:08 tests/unit/config/config_test.py::ExpandPathTest::test_expand_path_with_tilde PASSED [ 91%]

01:43:08 tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_root_mount PASSED [ 91%]

01:43:08 tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_windows_path PASSED [ 91%]

01:43:08 tests/unit/config/config_test.py::VolumePathTest::test_split_path_mapping_with_windows_path_in_container PASSED [ 91%]

01:43:08 tests/unit/config/config_test.py::BuildPathTest::test_absolute_path PASSED [ 91%]

01:43:08 tests/unit/config/config_test.py::BuildPathTest::test_from_file PASSED   [ 91%]

01:43:08 tests/unit/config/config_test.py::BuildPathTest::test_from_file_override_dir PASSED [ 91%]

01:43:08 tests/unit/config/config_test.py::BuildPathTest::test_invalid_url_in_build_path PASSED [ 91%]

01:43:08 tests/unit/config/config_test.py::BuildPathTest::test_nonexistent_path PASSED [ 91%]

01:43:08 tests/unit/config/config_test.py::BuildPathTest::test_relative_path PASSED [ 91%]

01:43:08 tests/unit/config/config_test.py::BuildPathTest::test_valid_url_in_build_path PASSED [ 92%]

01:43:08 tests/unit/config/config_test.py::HealthcheckTest::test_disable PASSED   [ 92%]

01:43:08 tests/unit/config/config_test.py::HealthcheckTest::test_disable_with_other_config_is_invalid PASSED [ 92%]

01:43:08 tests/unit/config/config_test.py::HealthcheckTest::test_healthcheck PASSED [ 92%]

01:43:08 tests/unit/config/config_test.py::HealthcheckTest::test_healthcheck_with_invalid_test PASSED [ 92%]

01:43:08 tests/unit/config/config_test.py::GetDefaultConfigFilesTestCase::test_get_config_path_default_file_in_basedir PASSED [ 92%]

01:43:08 tests/unit/config/config_test.py::GetDefaultConfigFilesTestCase::test_get_config_path_default_file_in_parent_dir PASSED [ 92%]

01:43:08 tests/unit/config/config_test.py::SerializeTest::test_denormalize_depends_on_v2_1 PASSED [ 92%]

01:43:08 tests/unit/config/config_test.py::SerializeTest::test_denormalize_depends_on_v3 PASSED [ 92%]

01:43:08 tests/unit/config/config_test.py::SerializeTest::test_denormalize_healthcheck PASSED [ 92%]

01:43:08 tests/unit/config/config_test.py::SerializeTest::test_denormalize_image_has_digest PASSED [ 92%]

01:43:08 tests/unit/config/config_test.py::SerializeTest::test_denormalize_image_no_digest PASSED [ 92%]

01:43:08 tests/unit/config/config_test.py::SerializeTest::test_serialize_bool_string PASSED [ 93%]

01:43:08 tests/unit/config/config_test.py::SerializeTest::test_serialize_configs PASSED [ 93%]

01:43:08 tests/unit/config/config_test.py::SerializeTest::test_serialize_escape_dollar_sign PASSED [ 93%]

01:43:08 tests/unit/config/config_test.py::SerializeTest::test_serialize_escape_dont_interpolate PASSED [ 93%]

01:43:08 tests/unit/config/config_test.py::SerializeTest::test_serialize_external_false PASSED [ 93%]

01:43:08 tests/unit/config/config_test.py::SerializeTest::test_serialize_ports PASSED [ 93%]

01:43:08 tests/unit/config/config_test.py::SerializeTest::test_serialize_ports_with_ext_ip PASSED [ 93%]

01:43:08 tests/unit/config/config_test.py::SerializeTest::test_serialize_secrets PASSED [ 93%]

01:43:08 tests/unit/config/config_test.py::SerializeTest::test_serialize_time PASSED [ 93%]

01:43:08 tests/unit/config/config_test.py::SerializeTest::test_serialize_unicode_values PASSED [ 93%]

01:43:08 tests/unit/config/environment_test.py::EnvironmentTest::test_env_vars_from_file_bom PASSED [ 93%]

01:43:08 tests/unit/config/environment_test.py::EnvironmentTest::test_env_vars_from_file_whitespace PASSED [ 94%]

01:43:08 tests/unit/config/environment_test.py::EnvironmentTest::test_get_boolean PASSED [ 94%]

01:43:08 tests/unit/config/environment_test.py::EnvironmentTest::test_get_simple PASSED [ 94%]

01:43:08 tests/unit/config/environment_test.py::EnvironmentTest::test_get_undefined PASSED [ 94%]

01:43:08 tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_services PASSED [ 94%]

01:43:08 tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_volumes PASSED [ 94%]

01:43:08 tests/unit/config/interpolation_test.py::test_interpolate_environment_variables_in_secrets PASSED [ 94%]

01:43:08 tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_v2 PASSED [ 94%]

01:43:08 tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_v3 PASSED [ 94%]

01:43:08 tests/unit/config/interpolation_test.py::test_interpolate_environment_services_convert_types_invalid PASSED [ 94%]

01:43:08 tests/unit/config/interpolation_test.py::test_interpolate_environment_network_convert_types PASSED [ 94%]

01:43:08 tests/unit/config/interpolation_test.py::test_interpolate_environment_external_resource_convert_types PASSED [ 94%]

01:43:08 tests/unit/config/interpolation_test.py::test_interpolate_service_name_uses_dot PASSED [ 95%]

01:43:08 tests/unit/config/interpolation_test.py::test_escaped_interpolation PASSED [ 95%]

01:43:08 tests/unit/config/interpolation_test.py::test_invalid_interpolation PASSED [ 95%]

01:43:08 tests/unit/config/interpolation_test.py::test_interpolate_missing_no_default PASSED [ 95%]

01:43:08 tests/unit/config/interpolation_test.py::test_interpolate_with_value PASSED [ 95%]

01:43:08 tests/unit/config/interpolation_test.py::test_interpolate_missing_with_default PASSED [ 95%]

01:43:08 tests/unit/config/interpolation_test.py::test_interpolate_with_empty_and_default_value PASSED [ 95%]

01:43:08 tests/unit/config/interpolation_test.py::test_interpolate_mandatory_values PASSED [ 95%]

01:43:08 tests/unit/config/interpolation_test.py::test_interpolate_mandatory_no_err_msg PASSED [ 95%]

01:43:08 tests/unit/config/interpolation_test.py::test_interpolate_mixed_separators PASSED [ 95%]

01:43:08 tests/unit/config/interpolation_test.py::test_unbraced_separators PASSED [ 95%]

01:43:08 tests/unit/config/interpolation_test.py::test_interpolate_unicode_values PASSED [ 96%]

01:43:08 tests/unit/config/interpolation_test.py::test_interpolate_no_fallthrough PASSED [ 96%]

01:43:08 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_1 PASSED [ 96%]

01:43:08 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_2 PASSED [ 96%]

01:43:08 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_3 PASSED [ 96%]

01:43:08 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_4 PASSED [ 96%]

01:43:08 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_5 PASSED [ 96%]

01:43:08 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_6 PASSED [ 96%]

01:43:08 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_7 PASSED [ 96%]

01:43:08 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports PASSED [ 96%]

01:43:08 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports_2 PASSED [ 96%]

01:43:08 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_circular_imports_3 PASSED [ 97%]

01:43:08 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_self_imports PASSED [ 97%]

01:43:08 tests/unit/config/sort_services_test.py::TestSortService::test_sort_service_dicts_depends_on_self PASSED [ 97%]

01:43:08 tests/unit/config/types_test.py::test_parse_extra_hosts_list PASSED      [ 97%]

01:43:08 tests/unit/config/types_test.py::test_parse_extra_hosts_dict PASSED      [ 97%]

01:43:08 tests/unit/config/types_test.py::TestServicePort::test_parse_dict PASSED [ 97%]

01:43:08 tests/unit/config/types_test.py::TestServicePort::test_parse_simple_target_port PASSED [ 97%]

01:43:08 tests/unit/config/types_test.py::TestServicePort::test_parse_complete_port_definition PASSED [ 97%]

01:43:08 tests/unit/config/types_test.py::TestServicePort::test_parse_ext_ip_no_published_port PASSED [ 97%]

01:43:08 tests/unit/config/types_test.py::TestServicePort::test_repr_published_port_0 PASSED [ 97%]

01:43:08 tests/unit/config/types_test.py::TestServicePort::test_parse_port_range PASSED [ 97%]

01:43:08 tests/unit/config/types_test.py::TestServicePort::test_parse_port_publish_range PASSED [ 97%]

01:43:08 tests/unit/config/types_test.py::TestServicePort::test_parse_invalid_port PASSED [ 98%]

01:43:08 tests/unit/config/types_test.py::TestServicePort::test_parse_invalid_publish_range PASSED [ 98%]

01:43:08 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_only_one_path PASSED [ 98%]

01:43:08 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_internal_and_external PASSED [ 98%]

01:43:08 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_with_mode PASSED [ 98%]

01:43:08 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_spec_too_many_parts PASSED [ 98%]

01:43:08 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_absolute_path_normalized PASSED [ 98%]

01:43:08 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_absolute_path_native PASSED [ 98%]

01:43:08 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_internal_path_normalized PASSED [ 98%]

01:43:08 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_internal_path_native PASSED [ 98%]

01:43:08 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_just_drives_normalized PASSED [ 98%]

01:43:08 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_just_drives_native PASSED [ 99%]

01:43:08 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_mixed_notations_normalized PASSED [ 99%]

01:43:08 tests/unit/config/types_test.py::TestVolumeSpec::test_parse_volume_windows_mixed_notations_native PASSED [ 99%]

01:43:08 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_from_service PASSED [ 99%]

01:43:08 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_from_container PASSED [ 99%]

01:43:08 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v1_invalid PASSED [ 99%]

01:43:08 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_service PASSED [ 99%]

01:43:08 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_service_with_mode PASSED [ 99%]

01:43:08 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_container PASSED [ 99%]

01:43:08 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_from_container_with_mode PASSED [ 99%]

01:43:08 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_invalid_type PASSED [ 99%]

01:43:11 tests/unit/config/types_test.py::TestVolumesFromSpec::test_parse_v2_invalid PASSED [100%]

01:43:11 

01:43:11 ----------- coverage: platform linux, python 3.7.4-final-0 -----------

01:43:11 Name                              Stmts   Miss Branch BrPart  Cover   Missing

01:43:11 -----------------------------------------------------------------------------

01:43:11 compose/__init__.py                   3      0      0      0   100%

01:43:11 compose/__main__.py                   4      4      0      0     0%   1-6

01:43:11 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

01:43:11 compose/cli/__init__.py               0      0      0      0   100%

01:43:11 compose/cli/colors.py                23      2     10      2    88%   37-38, 36->37, 48->exit

01:43:11 compose/cli/command.py               93     14     28      4    82%   71-81, 88, 125-130, 174, 70->71, 87->88, 124->125, 171->174

01:43:11 compose/cli/docker_client.py         75      5     24      2    93%   24, 98-99, 107, 123, 106->107, 122->123

01:43:11 compose/cli/docopt_command.py        38      4      8      2    87%   13-14, 29, 35, 28->29, 34->35

01:43:11 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

01:43:11 compose/cli/formatter.py             34      2     10      1    93%   17-18, 15->17

01:43:11 compose/cli/log_printer.py          144     14     52      6    89%   76, 103, 110-115, 162-164, 173, 226-229, 233-234, 253, 43->exit, 75->76, 98->103, 171->173, 225->226, 232->233

01:43:11 compose/cli/main.py                 695     90    307     40    85%   83-84, 86-87, 168, 328, 360-362, 445, 505, 509, 514-515, 525-554, 566, 584-586, 657-658, 696-697, 715, 736-737, 749, 772, 790, 837, 1069, 1078, 1104-1113, 1153-1156, 1164-1168, 1170-1175, 1198, 1220-1249, 1256-1257, 1259-1261, 1276, 1282, 1466, 1484, 1500, 1504-1505, 1516, 1521, 1524, 1550, 1569-1571, 1581, 1592, 60->63, 82->83, 85->86, 167->168, 327->328, 359->360, 444->445, 504->505, 508->509, 519->525, 563->566, 583->584, 655->657, 714->715, 735->736, 748->749, 771->772, 827->837, 829->exit, 1068->1069, 1077->1078, 1163->1164, 1169->1170, 1197->1198, 1255->1256, 1258->1259, 1275->1276, 1281->1282, 1465->1466, 1483->1484, 1499->1500, 1515->1516, 1520->1521, 1523->1524, 1542->exit, 1549->1550, 1563->1571, 1565->1569, 1580->1581, 1590->1592

01:43:11 compose/cli/signals.py               23      0      4      2    93%   36->exit, 43->exit

01:43:11 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

01:43:11 compose/cli/verbose_proxy.py         35     12     10      0    69%   36-39, 42-47, 50-60

01:43:11 compose/config/__init__.py           13      0      0      0   100%

01:43:11 compose/config/config.py            826     30    428     18    95%   266, 277, 508, 621-622, 714, 757, 812-830, 952-953, 959, 979, 982, 1335, 1366, 1412, 265->266, 276->277, 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

01:43:11 compose/config/environment.py       100      8     34      5    90%   21, 41, 104-107, 120, 127, 20->21, 40->41, 103->104, 119->120, 126->127

01:43:11 compose/config/errors.py             25      2      2      0    85%   36-40

01:43:11 compose/config/interpolation.py     148      6     64      3    95%   66, 148, 222, 227-229, 121->exit, 146->148, 221->222

01:43:11 compose/config/serialize.py          97      2     58      3    97%   31, 76, 30->31, 75->76, 82->85

01:43:11 compose/config/sort_services.py      44      1     24      1    97%   57, 56->57

01:43:11 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

01:43:11 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

01:43:11 compose/const.py                     36      0      0      0   100%

01:43:11 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

01:43:11 compose/errors.py                    17      1      0      0    94%   12

01:43:11 compose/network.py                  190     19     95      5    87%   184, 186-200, 206, 224, 226, 183->184, 185->186, 205->206, 223->224, 225->226

01:43:11 compose/parallel.py                 199      2     58      1    99%   187, 326, 325->326

01:43:11 compose/progress_stream.py           79      8     40      9    86%   40, 71, 74, 80, 85, 90-91, 116, 39->40, 42->46, 53->57, 70->71, 73->74, 79->80, 84->85, 89->90, 112->116

01:43:11 compose/project.py                  424     29    201     16    92%   60, 156, 212-213, 254-255, 364-365, 378-381, 434, 485, 489, 615, 621, 624-627, 752-753, 759-762, 777, 782-785, 788, 809, 57->60, 152->156, 331->333, 362->364, 377->378, 433->434, 484->485, 488->489, 614->615, 620->621, 623->624, 671->exit, 755->762, 776->777, 781->782, 787->788

01:43:11 compose/service.py                  854     50    433     26    93%   271-272, 293, 366-369, 417-422, 428-430, 470-471, 485, 488, 506, 573, 618-619, 727, 946-947, 967-968, 1069, 1115, 1176, 1218, 1240-1255, 1295, 1334-1338, 1526, 1530, 1646, 1686, 1698, 216->exit, 269->271, 292->293, 427->428, 469->470, 484->485, 487->488, 505->506, 563->573, 722->727, 945->946, 966->967, 1068->1069, 1114->1115, 1175->1176, 1217->1218, 1294->1295, 1331->1334, 1525->1526, 1529->1530, 1578->exit, 1586->1585, 1623->1620, 1645->1646, 1685->1686, 1697->1698

01:43:11 compose/state.py                      0      0      0      0   100%

01:43:11 compose/timeparse.py                 22      0      4      0   100%

01:43:11 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

01:43:11 compose/version.py                    6      0      0      0   100%

01:43:11 compose/volume.py                   126      4     44      3    95%   150, 200, 211-212, 141->150, 199->200, 209->211

01:43:11 -----------------------------------------------------------------------------

01:43:11 TOTAL                              5553    436   2401    205    91%

01:43:11 Coverage HTML written to dir coverage-html

01:43:11 

01:43:11 =========================== short test summary info ============================

01:43:11 XFAIL tests/integration/service_test.py::ServiceTest::test_create_container_with_cpu_rt

01:43:11   not supported by kernel

01:43:11 XFAIL tests/integration/service_test.py::ServiceTest::test_create_container_with_storage_opt

01:43:11   Not supported on most drivers

01:43:11 SKIP [1] tests/acceptance/cli_test.py:2424: race condition between up and logs

01:43:11 SKIP [1] tests/acceptance/cli_test.py:2376: race condition between up and logs

01:43:11 SKIP [1] tests/acceptance/cli_test.py:2403: race condition between up and logs

01:43:11 SKIP [1] /code/tests/integration/testcases.py:167: This daemon does not support the 'nvidia'' runtime

01:43:11 SKIP [1] tests/integration/service_test.py:148: cpu_percent is not supported for Linux

01:43:11 SKIP [1] tests/integration/service_test.py:1635: Broken on 1.11.0 - 17.03.0

01:43:11 SKIP [1] tests/unit/cli/command_test.py:39: windows separator

01:43:11 SKIP [1] tests/unit/cli/command_test.py:69: Env values in Python 3 are already Unicode

01:43:11 SKIP [1] tests/unit/cli/errors_test.py:70: Needs pywin32

01:43:11 SKIP [1] tests/unit/cli/errors_test.py:80: Needs pywin32

01:43:11 SKIP [1] tests/unit/cli/errors_test.py:90: Needs pywin32

01:43:11 SKIP [1] tests/unit/config/config_test.py:3777: windows paths

01:43:11 

01:43:11 ======= 1121 passed, 12 skipped, 2 xfailed, 3 xpassed in 825.94 seconds ========

01:43:11 ___________________________________ summary ____________________________________

01:43:11   py37: commands succeeded

01:43:11   congratulations :)

01:43:11 + on_exit
01:43:11 + [[ 0 != \0 ]]
01:43:11 + docker rm -vf compose-dind-18.09.9-rc1-jenkins-compose-PR-6850-2
01:43:12 compose-dind-18.09.9-rc1-jenkins-compose-PR-6850-2
[Pipeline] }
[Pipeline] // stage
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // wrap
[Pipeline] }
[Pipeline] // withDockerRegistry
[Pipeline] }
[Pipeline] // node
[Pipeline] }
[Pipeline] // parallel
[Pipeline] End of Pipeline

GitHub has been notified of this commit’s build result

Finished: SUCCESS