blob: bd19b0218f7065e5916b1a3e1fe0e962ec12233c [file] [log] [blame]
Richard Felkl37ee1e32017-12-11 10:01:39 +01001/**
2 *
Richard Felkl56082e92017-12-20 23:39:53 +01003 * Promote MCP
Richard Felkl37ee1e32017-12-11 10:01:39 +01004 *
5 * Expected parameters:
Richard Felkl56082e92017-12-20 23:39:53 +01006 * SOURCE_REVISION
7 * TARGET_REVISION
Richard Felkl37ee1e32017-12-11 10:01:39 +01008 * RELEASE_APTLY
Richard Felkl56082e92017-12-20 23:39:53 +01009 * RELEASE_DEB_MIRRORS
Richard Felkl37ee1e32017-12-11 10:01:39 +010010 * RELEASE_DOCKER
11 * RELEASE_GIT
12 * APTLY_URL
13 * APTLY_STORAGES
14 * DOCKER_CREDENTIALS
15 * DOCKER_URL
16 * DOCKER_IMAGES
17 * GIT_CREDENTIALS
18 * GIT_REPO_LIST
azvyagintsev87781882018-08-30 18:45:22 +030019 * VCP_IMAGE_LIST - list of images
azvyagintsev759734c2018-10-03 13:57:54 +030020 * SYNC_VCP_IMAGE_TO_S3 - boolean
azvyagintsev87781882018-08-30 18:45:22 +030021 * RELEASE_VCP_IMAGES - boolean
Richard Felklc8c5a5a2018-04-19 17:06:30 +020022 * EMAIL_NOTIFY
23 * NOTIFY_RECIPIENTS
azvyagintsev4696d662018-11-23 19:48:09 +020024 *
azvyagintsev87781882018-08-30 18:45:22 +030025 */
Richard Felkl37ee1e32017-12-11 10:01:39 +010026
Richard Felkl55175f52017-12-20 14:53:41 +010027common = new com.mirantis.mk.Common()
azvyagintsev759734c2018-10-03 13:57:54 +030028
azvyagintsev79778662018-11-23 18:07:16 +020029syncVcpImagesToS3 = env.SYNC_VCP_IMAGE_TO_S3 ?: false
30emailNotify = env.EMAIL_NOTIFY ?: false
Richard Felkl37ee1e32017-12-11 10:01:39 +010031
azvyagintsev87781882018-08-30 18:45:22 +030032def triggerAptlyPromoteJob(aptlyUrl, components, diffOnly, dumpPublish, packages, recreate, source, storages, target) {
33 build job: "aptly-promote-all-testing-stable", parameters: [
34 [$class: 'StringParameterValue', name: 'APTLY_URL', value: aptlyUrl],
35 [$class: 'StringParameterValue', name: 'COMPONENTS', value: components],
36 [$class: 'BooleanParameterValue', name: 'DIFF_ONLY', value: diffOnly],
37 [$class: 'BooleanParameterValue', name: 'DUMP_PUBLISH', value: dumpPublish],
38 [$class: 'StringParameterValue', name: 'PACKAGES', value: packages],
39 [$class: 'BooleanParameterValue', name: 'RECREATE', value: recreate],
40 [$class: 'StringParameterValue', name: 'SOURCE', value: source],
41 [$class: 'StringParameterValue', name: 'STORAGES', value: storages],
42 [$class: 'StringParameterValue', name: 'TARGET', value: target],
43 ]
Richard Felkl37ee1e32017-12-11 10:01:39 +010044}
45
azvyagintsevd162b912018-07-26 10:52:14 +020046def triggerDockerMirrorJob(dockerCredentials, dockerRegistryUrl, targetTag, imageList, sourceImageTag) {
azvyagintsev87781882018-08-30 18:45:22 +030047 build job: "docker-images-mirror", parameters: [
48 [$class: 'StringParameterValue', name: 'TARGET_REGISTRY_CREDENTIALS_ID', value: dockerCredentials],
49 [$class: 'StringParameterValue', name: 'REGISTRY_URL', value: dockerRegistryUrl],
50 [$class: 'StringParameterValue', name: 'IMAGE_TAG', value: targetTag],
azvyagintsevf7c65fa2018-10-02 14:59:09 +030051 [$class: 'TextParameterValue', name: 'IMAGE_LIST', value: imageList],
azvyagintsev87781882018-08-30 18:45:22 +030052 [$class: 'StringParameterValue', name: 'SOURCE_IMAGE_TAG', value: sourceImageTag],
53 ]
Richard Felkl37ee1e32017-12-11 10:01:39 +010054}
55
Richard Felkl56082e92017-12-20 23:39:53 +010056def triggerMirrorRepoJob(snapshotId, snapshotName) {
azvyagintsev87781882018-08-30 18:45:22 +030057 build job: "mirror-snapshot-name-all", parameters: [
58 [$class: 'StringParameterValue', name: 'SNAPSHOT_NAME', value: snapshotName],
59 [$class: 'StringParameterValue', name: 'SNAPSHOT_ID', value: snapshotId],
60 ]
Richard Felkl56082e92017-12-20 23:39:53 +010061}
62
Alexander Evseeve704ca92018-09-11 11:30:55 +020063def triggerEbfRepoJob(snapshotId, snapshotName) {
64 build job: "ebf-snapshot-name-all", parameters: [
65 [$class: 'StringParameterValue', name: 'SNAPSHOT_NAME', value: snapshotName],
66 [$class: 'StringParameterValue', name: 'SNAPSHOT_ID', value: snapshotId],
67 ]
68}
69
azvyagintsev3280a0c2018-07-31 08:44:43 +020070def triggerGitTagJob(gitRepoList, gitCredentials, tag, sourceTag) {
Alexander Evseev85649372018-10-08 18:06:49 +020071 // There is no `nightly` and `testing` build-IDs` in release process
72 // for git repos
azvyagintsev4696d662018-11-23 19:48:09 +020073 if (sourceTag in ['nightly', 'testing']) sourceTag = 'master'
azvyagintsev21308d02018-08-30 17:49:33 +030074 build job: "tag-git-repos-all", parameters: [
azvyagintsevf7c65fa2018-10-02 14:59:09 +030075 [$class: 'TextParameterValue', name: 'GIT_REPO_LIST', value: gitRepoList],
azvyagintsev87781882018-08-30 18:45:22 +030076 [$class: 'StringParameterValue', name: 'GIT_CREDENTIALS', value: gitCredentials],
77 [$class: 'StringParameterValue', name: 'TAG', value: tag],
78 [$class: 'StringParameterValue', name: 'SOURCE_TAG', value: sourceTag],
79 ]
80}
81
82def triggerPromoteVCPJob(VcpImageList, tag, sourceTag) {
83 build job: "promote-vcp-images-all", parameters: [
azvyagintsevf7c65fa2018-10-02 14:59:09 +030084 [$class: 'TextParameterValue', name: 'VCP_IMAGE_LIST', value: VcpImageList],
azvyagintsev87781882018-08-30 18:45:22 +030085 [$class: 'StringParameterValue', name: 'TAG', value: tag],
azvyagintsevff65d402018-10-02 18:37:42 +030086 [$class: 'StringParameterValue', name: 'SOURCE_TAG', value: sourceTag],
87 [$class: 'BooleanParameterValue', name: 'FORCE_OVERWRITE', value: true],
azvyagintsev87781882018-08-30 18:45:22 +030088 ]
Richard Felkl37ee1e32017-12-11 10:01:39 +010089}
Richard Felklc8c5a5a2018-04-19 17:06:30 +020090
Sergey Otpuschennikovb0c4db72018-12-19 19:12:54 +040091def triggerPkgPromoteJob(PkgRepoList, PromoteFrom, PromoteTo) {
92 def repos = PkgRepoList.trim().tokenize()
93 def RepoName, RepoDist, PackagesToPromote
94 for (repo in repos) {
95 if(repo.startsWith('#')){
96 common.warningMsg("Skipping repo ${repo}")
97 continue
98 }
99 if(repo.trim().indexOf(' ') == -1){
100 throw new IllegalArgumentException("Wrong format of repository and commit input")
101 }
102 repoArray = repo.trim().tokenize(' ')
103 RepoName = repoArray[0]
104 RepoDist = repoArray[1]
105 PackagesToPromote = repoArray[2]
106 build job: "pkg-promote", parameters: [
107 [$class: 'ChoiceParameterValue', name: 'repoName', value: RepoName],
108 [$class: 'ChoiceParameterValue', name: 'repoDist', value: RepoDist],
109 [$class: 'ChoiceParameterValue', name: 'promoteFrom', value: PromoteFrom],
110 [$class: 'ChoiceParameterValue', name: 'promoteTo', value: PromoteTo],
111 [$class: 'TextParameterValue', name: 'packagesToPromote', value: PackagesToPromote],
112 ]
113 }
114}
115
azvyagintsev79778662018-11-23 18:07:16 +0200116def triggerSyncVCPJob(VcpImageList, targetTag) {
117 // Operation must be synced with triggerPromoteVCPJob procedure!
118 def images = VcpImageList.trim().tokenize()
119 TargetVcpImageList = ''
120 for (image in images) {
121 if (image.startsWith('#')) {
122 common.warningMsg("Skipping image ${image}")
123 continue
124 }
125 common.infoMsg("Replacing SUBS_SOURCE_VCP_IMAGE_TAG => ${targetTag}")
azvyagintsev4696d662018-11-23 19:48:09 +0200126 TargetVcpImageList += image.replace('SUBS_SOURCE_VCP_IMAGE_TAG', targetTag) + '\n' +
127 image.replace('SUBS_SOURCE_VCP_IMAGE_TAG', targetTag).trim() + '.md5' + '\n'
128
azvyagintsev79778662018-11-23 18:07:16 +0200129 }
Kirill Mashchenkoe866b302018-11-23 21:08:15 +0400130 build job: "upload_images_to_s3", parameters: [
azvyagintsev4696d662018-11-23 19:48:09 +0200131 [$class: 'TextParameterValue', name: 'FILENAMES',
132 value : TargetVcpImageList]
azvyagintsev759734c2018-10-03 13:57:54 +0300133 ]
134}
135
Jakub Josefa63f9862018-01-11 17:58:38 +0100136timeout(time: 12, unit: 'HOURS') {
azvyagintsev87781882018-08-30 18:45:22 +0300137 node() {
138 try {
139 stage("Promote") {
140 if (RELEASE_APTLY.toBoolean()) {
141 common.infoMsg("Promoting Aptly")
142 triggerAptlyPromoteJob(APTLY_URL, 'all', false, true, 'all', false, "(.*)/${SOURCE_REVISION}", APTLY_STORAGES, "{0}/${TARGET_REVISION}")
143 }
Richard Felkl56082e92017-12-20 23:39:53 +0100144
Sergey Otpuschennikovb0c4db72018-12-19 19:12:54 +0400145 if (PKG_PROMOTE.toBoolean() && SOURCE_REVISION == 'testing') {
146 common.infoMsg("Promoting Extra and Ceph packages")
147 triggerPkgPromoteJob(PKG_REPO_LIST, SOURCE_REVISION, TARGET_REVISION)
148 }
149
azvyagintsev87781882018-08-30 18:45:22 +0300150 if (RELEASE_DEB_MIRRORS.toBoolean()) {
151 common.infoMsg("Promoting Debmirrors")
152 triggerMirrorRepoJob(SOURCE_REVISION, TARGET_REVISION)
153 }
Richard Felkl56082e92017-12-20 23:39:53 +0100154
Alexander Evseeve704ca92018-09-11 11:30:55 +0200155 if (RELEASE_EBF_MIRRORS.toBoolean()) {
156 common.infoMsg("Promoting Emergency Bug Fix Debmirrors")
157 triggerEbfRepoJob(SOURCE_REVISION, TARGET_REVISION)
158 }
159
azvyagintsev87781882018-08-30 18:45:22 +0300160 if (RELEASE_DOCKER.toBoolean()) {
161 common.infoMsg("Promoting Docker images")
162 triggerDockerMirrorJob(DOCKER_CREDENTIALS, DOCKER_URL, TARGET_REVISION, DOCKER_IMAGES, SOURCE_REVISION)
163 }
Richard Felkl56082e92017-12-20 23:39:53 +0100164
azvyagintsev87781882018-08-30 18:45:22 +0300165 if (RELEASE_GIT.toBoolean()) {
166 common.infoMsg("Promoting Git repositories")
167 triggerGitTagJob(GIT_REPO_LIST, GIT_CREDENTIALS, TARGET_REVISION, SOURCE_REVISION)
Richard Felklc8c5a5a2018-04-19 17:06:30 +0200168
azvyagintsev87781882018-08-30 18:45:22 +0300169 }
170 if (RELEASE_VCP_IMAGES.toBoolean()) {
171 common.infoMsg("Promoting VCP images")
172 triggerPromoteVCPJob(VCP_IMAGE_LIST, TARGET_REVISION, SOURCE_REVISION)
173
174 }
azvyagintsev79778662018-11-23 18:07:16 +0200175 if (syncVcpImagesToS3.toBoolean()) {
Alexander Evseev1edde6b2018-10-30 15:22:44 +0300176 common.infoMsg("Syncing VCP images from internal: http://images.mcp.mirantis.net/ to s3: images.mirantis.com")
azvyagintsev79778662018-11-23 18:07:16 +0200177 triggerSyncVCPJob(VCP_IMAGE_LIST, TARGET_REVISION)
azvyagintsev759734c2018-10-03 13:57:54 +0300178 }
179 if (emailNotify) {
180 notify_text = "MCP Promotion ${env.SOURCE_REVISION} => ${env.TARGET_REVISION} has been done"
azvyagintsev87781882018-08-30 18:45:22 +0300181 emailext(to: NOTIFY_RECIPIENTS,
azvyagintsev759734c2018-10-03 13:57:54 +0300182 body: notify_text,
azvyagintsev87781882018-08-30 18:45:22 +0300183 subject: "MCP Promotion has been done")
184 }
185 }
186 } catch (Throwable e) {
Jakub Josefa63f9862018-01-11 17:58:38 +0100187 // If there was an error or exception thrown, the build failed
188 currentBuild.result = "FAILURE"
189 throw e
Richard Felkl37ee1e32017-12-11 10:01:39 +0100190 }
azvyagintsev87781882018-08-30 18:45:22 +0300191 }
192}