mirror of https://github.com/docker/compose.git
Parallelize Docker versions
Signed-off-by: Joffrey F <joffrey@docker.com>
This commit is contained in:
parent
dce62c81d5
commit
632abe94c0
|
@ -18,12 +18,26 @@ def buildImage = { ->
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
def get_versions = { int number ->
|
||||||
|
def docker_versions
|
||||||
|
wrappedNode(label: "ubuntu && !zfs") {
|
||||||
|
def result = sh(script: """docker run --rm \\
|
||||||
|
--entrypoint=/code/.tox/py27/bin/python \\
|
||||||
|
${image.id} \\
|
||||||
|
/code/script/test/versions.py -n ${number} docker/docker-ce recent
|
||||||
|
""", returnStdout: true
|
||||||
|
)
|
||||||
|
docker_versions = result.split()
|
||||||
|
}
|
||||||
|
return docker_versions
|
||||||
|
}
|
||||||
|
|
||||||
def runTests = { Map settings ->
|
def runTests = { Map settings ->
|
||||||
def dockerVersions = settings.get("dockerVersions", null)
|
def dockerVersions = settings.get("dockerVersions", null)
|
||||||
def pythonVersions = settings.get("pythonVersions", null)
|
def pythonVersions = settings.get("pythonVersions", null)
|
||||||
|
|
||||||
if (!pythonVersions) {
|
if (!pythonVersions) {
|
||||||
throw new Exception("Need Python versions to test. e.g.: `runTests(pythonVersions: 'py27,py34')`")
|
throw new Exception("Need Python versions to test. e.g.: `runTests(pythonVersions: 'py27,py36')`")
|
||||||
}
|
}
|
||||||
if (!dockerVersions) {
|
if (!dockerVersions) {
|
||||||
throw new Exception("Need Docker versions to test. e.g.: `runTests(dockerVersions: 'all')`")
|
throw new Exception("Need Docker versions to test. e.g.: `runTests(dockerVersions: 'all')`")
|
||||||
|
@ -46,7 +60,7 @@ def runTests = { Map settings ->
|
||||||
-e "DOCKER_VERSIONS=${dockerVersions}" \\
|
-e "DOCKER_VERSIONS=${dockerVersions}" \\
|
||||||
-e "BUILD_NUMBER=\$BUILD_TAG" \\
|
-e "BUILD_NUMBER=\$BUILD_TAG" \\
|
||||||
-e "PY_TEST_VERSIONS=${pythonVersions}" \\
|
-e "PY_TEST_VERSIONS=${pythonVersions}" \\
|
||||||
--entrypoint="script/ci" \\
|
--entrypoint="script/test/ci" \\
|
||||||
${image.id} \\
|
${image.id} \\
|
||||||
--verbose
|
--verbose
|
||||||
"""
|
"""
|
||||||
|
@ -56,9 +70,14 @@ def runTests = { Map settings ->
|
||||||
}
|
}
|
||||||
|
|
||||||
buildImage()
|
buildImage()
|
||||||
// TODO: break this out into meaningful "DOCKER_VERSIONS" values instead of all
|
|
||||||
parallel(
|
def testMatrix = [failFast: true]
|
||||||
failFast: true,
|
def docker_versions = get_versions(2)
|
||||||
all_py27: runTests(pythonVersions: "py27", dockerVersions: "all"),
|
|
||||||
all_py36: runTests(pythonVersions: "py36", dockerVersions: "all"),
|
for (int i = 0 ;i < docker_versions.length ; i++) {
|
||||||
)
|
def dockerVersion = docker_versions[i]
|
||||||
|
testMatrix["${dockerVersion}_py27"] = runTests([dockerVersions: dockerVersion, pythonVersions: "py27"])
|
||||||
|
testMatrix["${dockerVersion}_py36"] = runTests([dockerVersions: dockerVersion, pythonVersions: "py36"])
|
||||||
|
}
|
||||||
|
|
||||||
|
parallel(testMatrix)
|
||||||
|
|
|
@ -14,7 +14,7 @@ set -ex
|
||||||
|
|
||||||
docker version
|
docker version
|
||||||
|
|
||||||
export DOCKER_VERSIONS=all
|
export DOCKER_VERSIONS=${DOCKER_VERSIONS:-all}
|
||||||
STORAGE_DRIVER=${STORAGE_DRIVER:-overlay}
|
STORAGE_DRIVER=${STORAGE_DRIVER:-overlay}
|
||||||
export DOCKER_DAEMON_ARGS="--storage-driver=$STORAGE_DRIVER"
|
export DOCKER_DAEMON_ARGS="--storage-driver=$STORAGE_DRIVER"
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue