mirror of https://github.com/asterisk/asterisk
				
				
				
			
			You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							178 lines
						
					
					
						
							5.9 KiB
						
					
					
				
			
		
		
	
	
							178 lines
						
					
					
						
							5.9 KiB
						
					
					
				| /*
 | |
|  * This pipeline is the "template" for the Asterisk Periodic Tests multi-branch
 | |
|  * parent job.  Jenkins will automatically scan the branches in the "asterisk"
 | |
|  * or "Security-asterisk" projects in Gerrit and automatically create a branch-
 | |
|  * specific job for each branch it finds this file in.
 | |
|  *
 | |
|  * This file starts as a declarative pipeline because with a declarative
 | |
|  * pipeline, you can define the trigger in the pipeline file.  This keeps
 | |
|  * everything in one place.  We transition to scripted pipeline later on because
 | |
|  * we need to dynamically determine which docker image we're going to use and
 | |
|  * you can't do that in a declarative pipeline.
 | |
|  */
 | |
| def timeoutTime = 3
 | |
| def timeoutUnits = 'HOURS'
 | |
| if (env.TIMEOUT_DAILIES) {
 | |
| 	def _timeout = env.TIMEOUT_DAILIES.split()
 | |
| 	timeoutTime = _timeout[0].toInteger()
 | |
| 	timeoutUnits = _timeout[1]
 | |
| }
 | |
| 
 | |
| pipeline {
 | |
| 	options {
 | |
| 		ansiColor('gnome-terminal')
 | |
| 		throttle(['asterisk-daily'])
 | |
| 		timestamps()
 | |
| 		timeout(time: timeoutTime, unit: timeoutUnits)
 | |
| 	}
 | |
| 	triggers {
 | |
| 		cron 'H H(0-4) * * *'
 | |
| 	}
 | |
| 
 | |
| 	agent {
 | |
| 		/* All of the stages need to be performed on a docker host */
 | |
| 		label "asterisk-daily"
 | |
| 	}
 | |
| 
 | |
| 	stages {
 | |
| 		stage ("->") {
 | |
| 			steps {
 | |
| 				/* Here's where we switch to scripted pipeline */
 | |
| 				script {
 | |
| 					manager.createSummary("/plugin/workflow-job/images/48x48/pipelinejob.png").appendText("Docker Host: ${NODE_NAME}", false)
 | |
| 
 | |
| 					stage ("Checkout") {
 | |
| 						sh "sudo chown -R jenkins:users ."
 | |
| 						sh "printenv -0 | sort -z | tr '\\0' '\\n'"
 | |
| 						sh "sudo tests/CI/setupJenkinsEnvironment.sh"
 | |
| 					}
 | |
| 
 | |
| 					def images = env.DOCKER_IMAGES.split(' ')
 | |
| 					def r = currentBuild.startTimeInMillis % images.length
 | |
| 					def ri = images[(int)r]
 | |
| 					def randomImage = env.DOCKER_REGISTRY + "/" + ri
 | |
| 					def dockerOptions = "--privileged --ulimit core=0 --ulimit nofile=10240 " +
 | |
| 						" --tmpfs /tmp:exec,size=1G -v /srv/jenkins:/srv/jenkins:rw -v /srv/cache:/srv/cache:rw " +
 | |
| 						" --entrypoint=''"
 | |
| 					def bt = env.BUILD_TAG.replaceAll(/[^a-zA-Z0-9_.-]/, '-')
 | |
| 					def outputdir = "tests/CI/output/Testsuite"
 | |
| 
 | |
| 					manager.createSummary("/plugin/workflow-job/images/48x48/pipelinejob.png").appendText("Docker Image: ${randomImage}", false)
 | |
| 					def img = docker.image(randomImage)
 | |
| 					img.pull()
 | |
| 
 | |
| 					img.inside(dockerOptions + " --name ${bt}-build") {
 | |
| 						stage ("Build") {
 | |
| 							echo 'Building..'
 | |
| 							env.CCACHE_DIR = "/srv/cache/ccache"
 | |
| 							sh "./tests/CI/buildAsterisk.sh --branch-name=${BRANCH_NAME} --output-dir=${outputdir} --cache-dir=/srv/cache"
 | |
| 
 | |
| 							archiveArtifacts allowEmptyArchive: true, defaultExcludes: false, fingerprint: false,
 | |
| 								artifacts: "${outputdir}/*"
 | |
| 						}
 | |
| 						stage ("Docs") {
 | |
| 
 | |
| 							sh "sudo ./tests/CI/installAsterisk.sh --branch-name=${BRANCH_NAME}  --user-group=jenkins:users"
 | |
| 
 | |
| 							def docUrl = env.GIT_URL.replaceAll(/\/[^\/]+$/, "/publish-docs")
 | |
| 							checkout scm: [$class: 'GitSCM',
 | |
| 								branches: [[name: "master"]],
 | |
| 									extensions: [
 | |
| 										[$class: 'RelativeTargetDirectory', relativeTargetDir: "tests/CI/output/publish-docs"],
 | |
| 										[$class: 'CloneOption',
 | |
| 											noTags: true,
 | |
| 											honorRefspec: true,
 | |
| 											shallow: false
 | |
| 										],
 | |
| 									],
 | |
| 									userRemoteConfigs: [[url: docUrl]]
 | |
| 								]
 | |
| 
 | |
| 							sh "./tests/CI/publishAsteriskDocs.sh --user-group=jenkins:users --branch-name=${BRANCH_NAME} --wiki-doc-branch-regex=\"${WIKI_DOC_BRANCH_REGEX}\""
 | |
| 						}
 | |
| 					}
 | |
| 
 | |
| 					def testGroups
 | |
| 					configFileProvider([configFile(fileId: 'asterisk_daily_test_groups', variable: 'DAILY_TEST_GROUPS')]) {
 | |
| 					echo "Retrieved config file from ${env.DAILY_TEST_GROUPS}"
 | |
| 						testGroups = readJSON file: env.DAILY_TEST_GROUPS
 | |
| 					}
 | |
| 
 | |
| 					def parallelTasks = [ : ]
 | |
| 
 | |
| 					for (def testGroup in testGroups) {
 | |
| 						/*
 | |
| 						 * Because each task is a Groovy closure, we need to
 | |
| 						 * keep local references to some variables.
 | |
| 						 */
 | |
| 						def groupName = testGroup.name
 | |
| 						def groupDir = testGroup.dir
 | |
| 						def groupTestcmd = testGroup.testcmd
 | |
| 						def groupRunTestsuiteOptions = testGroup.runTestsuiteOptions
 | |
| 						def testsuiteUrl = env.GIT_URL.replaceAll(/\/[^\/]+$/, "/testsuite")
 | |
| 
 | |
| 						parallelTasks[groupName] = {
 | |
| 							stage (groupName) {
 | |
| 
 | |
| 								img.inside("${dockerOptions} --name ${bt}-${groupName}") {
 | |
| 
 | |
| 									lock("${JOB_NAME}.${NODE_NAME}.installer") {
 | |
| 										sh "sudo ./tests/CI/installAsterisk.sh --uninstall-all --branch-name=${BRANCH_NAME} --user-group=jenkins:users"
 | |
| 									}
 | |
| 
 | |
| 									sh "sudo rm -rf ${groupDir} || : "
 | |
| 
 | |
| 									checkout scm: [$class: 'GitSCM',
 | |
| 										branches: [[name: "${BRANCH_NAME}"]],
 | |
| 											extensions: [
 | |
| 												[$class: 'RelativeTargetDirectory', relativeTargetDir: groupDir],
 | |
| 												[$class: 'CloneOption',
 | |
| 													noTags: true,
 | |
| 													depth: 100,
 | |
| 													honorRefspec: true,
 | |
| 													shallow: true
 | |
| 												],
 | |
| 											],
 | |
| 											userRemoteConfigs: [[url: testsuiteUrl]]
 | |
| 										]
 | |
| 
 | |
| 									sh "sudo tests/CI/runTestsuite.sh ${groupRunTestsuiteOptions} --testsuite-dir='${groupDir}' --testsuite-command='${groupTestcmd}'"
 | |
| 
 | |
| 									archiveArtifacts allowEmptyArchive: true, defaultExcludes: false, fingerprint: true,
 | |
| 										artifacts: "${groupDir}/asterisk-test-suite-report.xml, ${groupDir}/logs/**, ${groupDir}/core*.txt"
 | |
| 
 | |
| 									junit testResults: "${groupDir}/asterisk-test-suite-report.xml",
 | |
| 										healthScaleFactor: 1.0,
 | |
| 										keepLongStdio: true
 | |
| 
 | |
| 									echo "Group result d: ${currentBuild.currentResult}"
 | |
| 								}
 | |
| 								echo "Group result s: ${currentBuild.currentResult}"
 | |
| 							}
 | |
| 						}
 | |
| 					}
 | |
| 					parallel parallelTasks
 | |
| 				}
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| 	post {
 | |
| 		cleanup {
 | |
| 			script {
 | |
| 				if (env.CLEANUP_WS_DAILIES.toBoolean()) {
 | |
| 					cleanWs deleteDirs: true, notFailBuild: false
 | |
| 				}
 | |
| 			}
 | |
| 		}
 | |
| 		success {
 | |
| 			echo "Reporting ${currentBuild.currentResult} Passed"
 | |
| 		}
 | |
| 		failure {
 | |
| 			echo "Reporting ${currentBuild.currentResult}: Failed: Fatal Error"
 | |
| 		}
 | |
| 		unstable {
 | |
| 			echo "Reporting ${currentBuild.currentResult}: Failed: Tests Failed"
 | |
| 		}
 | |
| 	}
 | |
| }
 |