|  | @@ -1,5 +1,9 @@
 | 
	
		
			
				|  |  |  #!groovy
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | +def dockerVersions
 | 
	
		
			
				|  |  | +def baseImages = ['alpine', 'debian']
 | 
	
		
			
				|  |  | +def pythonVersions = ['py27', 'py37']
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  pipeline {
 | 
	
		
			
				|  |  |      agent none
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -17,6 +21,7 @@ pipeline {
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      stages {
 | 
	
		
			
				|  |  |          stage('Build test images') {
 | 
	
		
			
				|  |  | +            // TODO use declarative 1.5.0 `matrix` once available on CI
 | 
	
		
			
				|  |  |              parallel {
 | 
	
		
			
				|  |  |                  stage('alpine') {
 | 
	
		
			
				|  |  |                      agent {
 | 
	
	
		
			
				|  | @@ -36,6 +41,20 @@ pipeline {
 | 
	
		
			
				|  |  |                  }
 | 
	
		
			
				|  |  |              }
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | +        stage('Get Docker versions') {
 | 
	
		
			
				|  |  | +            agent {
 | 
	
		
			
				|  |  | +                label 'ubuntu'
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +            steps {
 | 
	
		
			
				|  |  | +                script {
 | 
	
		
			
				|  |  | +                    dockerVersions = sh(script:"""
 | 
	
		
			
				|  |  | +                    curl https://api.github.com/repos/docker/docker-ce/releases \
 | 
	
		
			
				|  |  | +                        | jq -r -c '.[] | select (.prerelease == false ) | .tag_name | ltrimstr("v")' > /tmp/versions.txt
 | 
	
		
			
				|  |  | +                    for v in \$(cut -f1 -d"." /tmp/versions.txt | uniq | head -2); do grep -m 1 "\$v" /tmp/versions.txt ; done
 | 
	
		
			
				|  |  | +                        """, returnStdout: true)
 | 
	
		
			
				|  |  | +                }
 | 
	
		
			
				|  |  | +            }
 | 
	
		
			
				|  |  | +        }
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -64,33 +83,9 @@ def buildImage(baseImage) {
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -def get_versions(number) {
 | 
	
		
			
				|  |  | -  def docker_versions
 | 
	
		
			
				|  |  | -  wrappedNode(label: "ubuntu && amd64 && !zfs") {
 | 
	
		
			
				|  |  | -    docker_versions = sh(script:"""
 | 
	
		
			
				|  |  | -        curl https://api.github.com/repos/docker/docker-ce/releases \
 | 
	
		
			
				|  |  | -         | jq -r -c '.[] | select (.prerelease == false ) | .tag_name | ltrimstr("v")' > /tmp/versions.txt
 | 
	
		
			
				|  |  | -        for v in \$(cut -f1 -d"." /tmp/versions.txt | uniq | head -${number}); do grep -m 1 "\$v" /tmp/versions.txt ; done
 | 
	
		
			
				|  |  | -    """, returnStdout: true)
 | 
	
		
			
				|  |  | -  }
 | 
	
		
			
				|  |  | -  return docker_versions
 | 
	
		
			
				|  |  | -}
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -def runTests = { Map settings ->
 | 
	
		
			
				|  |  | -  def dockerVersions = settings.get("dockerVersions", null)
 | 
	
		
			
				|  |  | -  def pythonVersions = settings.get("pythonVersions", null)
 | 
	
		
			
				|  |  | -  def baseImage = settings.get("baseImage", null)
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -  if (!pythonVersions) {
 | 
	
		
			
				|  |  | -    throw new Exception("Need Python versions to test. e.g.: `runTests(pythonVersions: 'py37')`")
 | 
	
		
			
				|  |  | -  }
 | 
	
		
			
				|  |  | -  if (!dockerVersions) {
 | 
	
		
			
				|  |  | -    throw new Exception("Need Docker versions to test. e.g.: `runTests(dockerVersions: 'all')`")
 | 
	
		
			
				|  |  | -  }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -  { ->
 | 
	
		
			
				|  |  | +def runTests(dockerVersion, pythonVersion, baseImage) {
 | 
	
		
			
				|  |  |      wrappedNode(label: "ubuntu && amd64 && !zfs", cleanWorkspace: true) {
 | 
	
		
			
				|  |  | -      stage("test python=${pythonVersions} / docker=${dockerVersions} / baseImage=${baseImage}") {
 | 
	
		
			
				|  |  | +      stage("test python=${pythonVersion} / docker=${dockerVersion} / baseImage=${baseImage}") {
 | 
	
		
			
				|  |  |          def scmvar = checkout(scm)
 | 
	
		
			
				|  |  |          def imageName = "dockerbuildbot/compose:${baseImage}-${scmvar.GIT_COMMIT}"
 | 
	
		
			
				|  |  |          def storageDriver = sh(script: 'docker info | awk -F \': \' \'$1 == "Storage Driver" { print $2; exit }\'', returnStdout: true).trim()
 | 
	
	
		
			
				|  | @@ -103,25 +98,25 @@ def runTests = { Map settings ->
 | 
	
		
			
				|  |  |            --volume="/var/run/docker.sock:/var/run/docker.sock" \\
 | 
	
		
			
				|  |  |            -e "TAG=${imageName}" \\
 | 
	
		
			
				|  |  |            -e "STORAGE_DRIVER=${storageDriver}" \\
 | 
	
		
			
				|  |  | -          -e "DOCKER_VERSIONS=${dockerVersions}" \\
 | 
	
		
			
				|  |  | +          -e "DOCKER_VERSIONS=${dockerVersion}" \\
 | 
	
		
			
				|  |  |            -e "BUILD_NUMBER=\$BUILD_TAG" \\
 | 
	
		
			
				|  |  | -          -e "PY_TEST_VERSIONS=${pythonVersions}" \\
 | 
	
		
			
				|  |  | +          -e "PY_TEST_VERSIONS=${pythonVersion}" \\
 | 
	
		
			
				|  |  |            --entrypoint="script/test/ci" \\
 | 
	
		
			
				|  |  |            ${imageName} \\
 | 
	
		
			
				|  |  |            --verbose
 | 
	
		
			
				|  |  |          """
 | 
	
		
			
				|  |  | -      }
 | 
	
		
			
				|  |  | +     }
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  | -  }
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  def testMatrix = [failFast: true]
 | 
	
		
			
				|  |  | -def baseImages = ['alpine', 'debian']
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  baseImages.each { baseImage ->
 | 
	
		
			
				|  |  | -  def imageName = buildImage(baseImage)
 | 
	
		
			
				|  |  | -  get_versions(imageName, 2).eachLine { dockerVersion ->
 | 
	
		
			
				|  |  | -      testMatrix["${baseImage}_${dockerVersion}"] = runTests([baseImage: baseImage, image: imageName, dockerVersions: dockerVersion, pythonVersions: 'py37'])
 | 
	
		
			
				|  |  | +  dockerVersions.eachLine { dockerVersion ->
 | 
	
		
			
				|  |  | +    pythonVersions.each { pythonVersion ->
 | 
	
		
			
				|  |  | +      testMatrix["${baseImage}_${dockerVersion}_${pythonVersion}"] = runTests(dockerVersion, pythonVersion, baseImage)
 | 
	
		
			
				|  |  | +    }
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |  }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -parallel(testMatrix)
 | 
	
		
			
				|  |  | +parallel testMatrix
 |