Parallelize Docker versions

Signed-off-by: Joffrey F <joffrey@docker.com>
This commit is contained in:
Joffrey F 2018-02-02 16:24:17 -08:00
parent dce62c81d5
commit 632abe94c0
2 changed files with 28 additions and 9 deletions

35
Jenkinsfile vendored
View File

@ -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)

View File

@ -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"