blob: 665a170ba192ac87dd58ae3dc05163b17cfe62c1 [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
azvyagintsev79778662018-11-23 18:07:16 +020091def triggerSyncVCPJob(VcpImageList, targetTag) {
92 // Operation must be synced with triggerPromoteVCPJob procedure!
93 def images = VcpImageList.trim().tokenize()
94 TargetVcpImageList = ''
95 for (image in images) {
96 if (image.startsWith('#')) {
97 common.warningMsg("Skipping image ${image}")
98 continue
99 }
100 common.infoMsg("Replacing SUBS_SOURCE_VCP_IMAGE_TAG => ${targetTag}")
azvyagintsev4696d662018-11-23 19:48:09 +0200101 TargetVcpImageList += image.replace('SUBS_SOURCE_VCP_IMAGE_TAG', targetTag) + '\n' +
102 image.replace('SUBS_SOURCE_VCP_IMAGE_TAG', targetTag).trim() + '.md5' + '\n'
103
azvyagintsev79778662018-11-23 18:07:16 +0200104 }
Kirill Mashchenkoe866b302018-11-23 21:08:15 +0400105 build job: "upload_images_to_s3", parameters: [
azvyagintsev4696d662018-11-23 19:48:09 +0200106 [$class: 'TextParameterValue', name: 'FILENAMES',
107 value : TargetVcpImageList]
azvyagintsev759734c2018-10-03 13:57:54 +0300108 ]
109}
110
Jakub Josefa63f9862018-01-11 17:58:38 +0100111timeout(time: 12, unit: 'HOURS') {
azvyagintsev87781882018-08-30 18:45:22 +0300112 node() {
113 try {
114 stage("Promote") {
115 if (RELEASE_APTLY.toBoolean()) {
116 common.infoMsg("Promoting Aptly")
117 triggerAptlyPromoteJob(APTLY_URL, 'all', false, true, 'all', false, "(.*)/${SOURCE_REVISION}", APTLY_STORAGES, "{0}/${TARGET_REVISION}")
118 }
Richard Felkl56082e92017-12-20 23:39:53 +0100119
azvyagintsev87781882018-08-30 18:45:22 +0300120 if (RELEASE_DEB_MIRRORS.toBoolean()) {
121 common.infoMsg("Promoting Debmirrors")
122 triggerMirrorRepoJob(SOURCE_REVISION, TARGET_REVISION)
123 }
Richard Felkl56082e92017-12-20 23:39:53 +0100124
Alexander Evseeve704ca92018-09-11 11:30:55 +0200125 if (RELEASE_EBF_MIRRORS.toBoolean()) {
126 common.infoMsg("Promoting Emergency Bug Fix Debmirrors")
127 triggerEbfRepoJob(SOURCE_REVISION, TARGET_REVISION)
128 }
129
azvyagintsev87781882018-08-30 18:45:22 +0300130 if (RELEASE_DOCKER.toBoolean()) {
131 common.infoMsg("Promoting Docker images")
132 triggerDockerMirrorJob(DOCKER_CREDENTIALS, DOCKER_URL, TARGET_REVISION, DOCKER_IMAGES, SOURCE_REVISION)
133 }
Richard Felkl56082e92017-12-20 23:39:53 +0100134
azvyagintsev87781882018-08-30 18:45:22 +0300135 if (RELEASE_GIT.toBoolean()) {
136 common.infoMsg("Promoting Git repositories")
137 triggerGitTagJob(GIT_REPO_LIST, GIT_CREDENTIALS, TARGET_REVISION, SOURCE_REVISION)
Richard Felklc8c5a5a2018-04-19 17:06:30 +0200138
azvyagintsev87781882018-08-30 18:45:22 +0300139 }
140 if (RELEASE_VCP_IMAGES.toBoolean()) {
141 common.infoMsg("Promoting VCP images")
142 triggerPromoteVCPJob(VCP_IMAGE_LIST, TARGET_REVISION, SOURCE_REVISION)
143
144 }
azvyagintsev79778662018-11-23 18:07:16 +0200145 if (syncVcpImagesToS3.toBoolean()) {
Alexander Evseev1edde6b2018-10-30 15:22:44 +0300146 common.infoMsg("Syncing VCP images from internal: http://images.mcp.mirantis.net/ to s3: images.mirantis.com")
azvyagintsev79778662018-11-23 18:07:16 +0200147 triggerSyncVCPJob(VCP_IMAGE_LIST, TARGET_REVISION)
azvyagintsev759734c2018-10-03 13:57:54 +0300148 }
149 if (emailNotify) {
150 notify_text = "MCP Promotion ${env.SOURCE_REVISION} => ${env.TARGET_REVISION} has been done"
azvyagintsev87781882018-08-30 18:45:22 +0300151 emailext(to: NOTIFY_RECIPIENTS,
azvyagintsev759734c2018-10-03 13:57:54 +0300152 body: notify_text,
azvyagintsev87781882018-08-30 18:45:22 +0300153 subject: "MCP Promotion has been done")
154 }
155 }
156 } catch (Throwable e) {
Jakub Josefa63f9862018-01-11 17:58:38 +0100157 // If there was an error or exception thrown, the build failed
158 currentBuild.result = "FAILURE"
159 throw e
Richard Felkl37ee1e32017-12-11 10:01:39 +0100160 }
azvyagintsev87781882018-08-30 18:45:22 +0300161 }
162}