|
@@ -1,29 +1,32 @@
|
|
|
#!groovy
|
|
|
|
|
|
-def image
|
|
|
-
|
|
|
-def buildImage = { ->
|
|
|
+def buildImage = { String baseImage ->
|
|
|
+ def image
|
|
|
wrappedNode(label: "ubuntu && !zfs", cleanWorkspace: true) {
|
|
|
- stage("build image") {
|
|
|
+ stage("build image for \"${baseImage}\"") {
|
|
|
checkout(scm)
|
|
|
- def imageName = "dockerbuildbot/compose:${gitCommit()}"
|
|
|
+ def imageName = "dockerbuildbot/compose:${baseImage}-${gitCommit()}"
|
|
|
image = docker.image(imageName)
|
|
|
try {
|
|
|
image.pull()
|
|
|
} catch (Exception exc) {
|
|
|
- image = docker.build(imageName, ".")
|
|
|
- image.push()
|
|
|
+ sh "docker build -t ${imageName} --target build --build-arg BUILD_PLATFORM=${baseImage} ."
|
|
|
+ sh "docker push ${imageName}"
|
|
|
+ echo "${imageName}"
|
|
|
+ return imageName
|
|
|
}
|
|
|
}
|
|
|
}
|
|
|
+ echo "image.id: ${image.id}"
|
|
|
+ return image.id
|
|
|
}
|
|
|
|
|
|
-def get_versions = { int number ->
|
|
|
+def get_versions = { String imageId, int number ->
|
|
|
def docker_versions
|
|
|
wrappedNode(label: "ubuntu && !zfs") {
|
|
|
def result = sh(script: """docker run --rm \\
|
|
|
--entrypoint=/code/.tox/py27/bin/python \\
|
|
|
- ${image.id} \\
|
|
|
+ ${imageId} \\
|
|
|
/code/script/test/versions.py -n ${number} docker/docker-ce recent
|
|
|
""", returnStdout: true
|
|
|
)
|
|
@@ -35,6 +38,8 @@ def get_versions = { int number ->
|
|
|
def runTests = { Map settings ->
|
|
|
def dockerVersions = settings.get("dockerVersions", null)
|
|
|
def pythonVersions = settings.get("pythonVersions", null)
|
|
|
+ def baseImage = settings.get("baseImage", null)
|
|
|
+ def imageName = settings.get("image", null)
|
|
|
|
|
|
if (!pythonVersions) {
|
|
|
throw new Exception("Need Python versions to test. e.g.: `runTests(pythonVersions: 'py27,py37')`")
|
|
@@ -45,7 +50,7 @@ def runTests = { Map settings ->
|
|
|
|
|
|
{ ->
|
|
|
wrappedNode(label: "ubuntu && !zfs", cleanWorkspace: true) {
|
|
|
- stage("test python=${pythonVersions} / docker=${dockerVersions}") {
|
|
|
+ stage("test python=${pythonVersions} / docker=${dockerVersions} / baseImage=${baseImage}") {
|
|
|
checkout(scm)
|
|
|
def storageDriver = sh(script: 'docker info | awk -F \': \' \'$1 == "Storage Driver" { print $2; exit }\'', returnStdout: true).trim()
|
|
|
echo "Using local system's storage driver: ${storageDriver}"
|
|
@@ -55,13 +60,13 @@ def runTests = { Map settings ->
|
|
|
--privileged \\
|
|
|
--volume="\$(pwd)/.git:/code/.git" \\
|
|
|
--volume="/var/run/docker.sock:/var/run/docker.sock" \\
|
|
|
- -e "TAG=${image.id}" \\
|
|
|
+ -e "TAG=${imageName}" \\
|
|
|
-e "STORAGE_DRIVER=${storageDriver}" \\
|
|
|
-e "DOCKER_VERSIONS=${dockerVersions}" \\
|
|
|
-e "BUILD_NUMBER=\$BUILD_TAG" \\
|
|
|
-e "PY_TEST_VERSIONS=${pythonVersions}" \\
|
|
|
--entrypoint="script/test/ci" \\
|
|
|
- ${image.id} \\
|
|
|
+ ${imageName} \\
|
|
|
--verbose
|
|
|
"""
|
|
|
}
|
|
@@ -69,15 +74,16 @@ def runTests = { Map settings ->
|
|
|
}
|
|
|
}
|
|
|
|
|
|
-buildImage()
|
|
|
-
|
|
|
def testMatrix = [failFast: true]
|
|
|
-def docker_versions = get_versions(2)
|
|
|
-
|
|
|
-for (int i = 0; i < docker_versions.length; i++) {
|
|
|
- def dockerVersion = docker_versions[i]
|
|
|
- testMatrix["${dockerVersion}_py27"] = runTests([dockerVersions: dockerVersion, pythonVersions: "py27"])
|
|
|
- testMatrix["${dockerVersion}_py37"] = runTests([dockerVersions: dockerVersion, pythonVersions: "py37"])
|
|
|
+def baseImages = ['alpine', 'debian']
|
|
|
+def pythonVersions = ['py27', 'py37']
|
|
|
+baseImages.each { baseImage ->
|
|
|
+ def imageName = buildImage(baseImage)
|
|
|
+ get_versions(imageName, 2).each { dockerVersion ->
|
|
|
+ pythonVersions.each { pyVersion ->
|
|
|
+ testMatrix["${baseImage}_${dockerVersion}_${pyVersion}"] = runTests([baseImage: baseImage, image: imageName, dockerVersions: dockerVersion, pythonVersions: pyVersion])
|
|
|
+ }
|
|
|
+ }
|
|
|
}
|
|
|
|
|
|
parallel(testMatrix)
|