blob: 60477ee6288214471c3d56c9e75efc19ce88cf87 [file] [log] [blame]
chnydad66d6fa2017-06-22 09:34:43 +02001
2/**
3 * Test salt models pipeline
4 * DEFAULT_GIT_REF
5 * DEFAULT_GIT_URL
6 * CREDENTIALS_ID
Jakub Josef107769c2017-08-17 13:38:15 +02007 * CLUSTER_NAME
chnydad66d6fa2017-06-22 09:34:43 +02008 * NODE_TARGET
9 * SYSTEM_GIT_URL
10 * SYSTEM_GIT_REF
Mykyta Karpinc0758f32017-06-23 18:10:24 +030011 * FORMULAS_SOURCE
Jakub Josefe40bbf92018-03-22 15:02:46 +010012 * RECLASS_VERSION
chnydabb6d2a62017-07-31 14:09:16 +020013 * MAX_CPU_PER_JOB
Jakub Josef6e4a09d2017-10-05 16:53:02 +020014 * LEGACY_TEST_MODE
Jakub Josefb1c81632017-10-05 17:19:53 +020015 * RECLASS_IGNORE_CLASS_NOTFOUND
Dmitry Ukovb2aa6db2017-10-23 12:30:31 +040016 * APT_REPOSITORY
17 * APT_REPOSITORY_GPG
chnydad66d6fa2017-06-22 09:34:43 +020018 */
19
20def common = new com.mirantis.mk.Common()
21def gerrit = new com.mirantis.mk.Gerrit()
chnyda4ed3c272017-06-22 14:50:09 +020022def git = new com.mirantis.mk.Git()
chnydac6092a22017-06-22 14:47:10 +020023def ssh = new com.mirantis.mk.Ssh()
chnydad66d6fa2017-06-22 09:34:43 +020024def saltModelTesting = new com.mirantis.mk.SaltModelTesting()
25
26def defaultGitRef = DEFAULT_GIT_REF
27def defaultGitUrl = DEFAULT_GIT_URL
28
29def checkouted = false
chnyda03f3ad42017-09-19 14:41:07 +020030
Vasyl Saienko682043d2018-07-23 16:04:10 +030031def reclassVersion = 'v1.5.4'
Vasyl Saienko772e1232018-07-23 14:42:24 +030032if (common.validInputParam('RECLASS_VERSION')) {
33 reclassVersion = RECLASS_VERSION
34}
35
chnyda03f3ad42017-09-19 14:41:07 +020036throttle(['test-model']) {
Jakub Josefdb3ddd82018-01-23 13:30:47 +010037 timeout(time: 1, unit: 'HOURS') {
Jakub Josef22815b02018-01-30 16:05:26 +010038 node("python&&docker") {
Jakub Josefa63f9862018-01-11 17:58:38 +010039 try{
40 stage("checkout") {
41 if(defaultGitRef != "" && defaultGitUrl != "") {
42 checkouted = gerrit.gerritPatchsetCheckout(defaultGitUrl, defaultGitRef, "HEAD", CREDENTIALS_ID)
43 } else {
44 throw new Exception("Cannot checkout gerrit patchset, DEFAULT_GIT_URL or DEFAULT_GIT_REF is null")
45 }
46 if(checkouted) {
47 if (fileExists('classes/system')) {
48 if (SYSTEM_GIT_URL == "") {
49 ssh.prepareSshAgentKey(CREDENTIALS_ID)
50 dir('classes/system') {
51 remoteUrl = git.getGitRemote()
52 ssh.ensureKnownHosts(remoteUrl)
53 }
54 ssh.agentSh("git submodule init; git submodule sync; git submodule update --recursive")
55 } else {
56 dir('classes/system') {
57 if (!gerrit.gerritPatchsetCheckout(SYSTEM_GIT_URL, SYSTEM_GIT_REF, "HEAD", CREDENTIALS_ID)) {
58 common.errorMsg("Failed to obtain system reclass with url: ${SYSTEM_GIT_URL} and ${SYSTEM_GIT_REF}")
59 }
chnyda03f3ad42017-09-19 14:41:07 +020060 }
chnydad66d6fa2017-06-22 09:34:43 +020061 }
62 }
63 }
64 }
chnydad66d6fa2017-06-22 09:34:43 +020065
Jakub Josefa63f9862018-01-11 17:58:38 +010066 stage("test node") {
67 if (checkouted) {
68 def workspace = common.getWorkspace()
azvyagintsev7c4a3cf2018-07-08 08:43:33 +030069 def testResult = false
Jakub Josefa63f9862018-01-11 17:58:38 +010070 common.infoMsg("Running salt model test for node ${NODE_TARGET} in cluster ${CLUSTER_NAME}")
71 try {
Kirill Mashchenko18071f62018-06-29 12:42:16 +030072 def DockerCName = "${env.JOB_NAME.toLowerCase()}_${env.BUILD_TAG.toLowerCase()}"
azvyagintsev7c4a3cf2018-07-08 08:43:33 +030073 testResult = saltModelTesting.setupAndTestNode(
azvyagintsev1c9801f2018-07-07 23:02:53 +030074 NODE_TARGET,
75 CLUSTER_NAME,
azvyagintsevb8ddb492018-09-12 14:59:45 +030076 '',
azvyagintsev1c9801f2018-07-07 23:02:53 +030077 workspace,
78 FORMULAS_SOURCE,
79 FORMULAS_REVISION,
Vasyl Saienkoc777bb82018-07-23 14:56:01 +030080 reclassVersion,
azvyagintsev1c9801f2018-07-07 23:02:53 +030081 MAX_CPU_PER_JOB.toInteger(),
82 RECLASS_IGNORE_CLASS_NOTFOUND,
83 LEGACY_TEST_MODE,
84 APT_REPOSITORY,
85 APT_REPOSITORY_GPG,
86 DockerCName)
Jakub Josefa63f9862018-01-11 17:58:38 +010087 } catch (Exception e) {
88 if (e.getMessage() == "script returned exit code 124") {
89 common.errorMsg("Impossible to test node due to timeout of salt-master, ABORTING BUILD")
90 currentBuild.result = "ABORTED"
91 } else {
92 throw e
93 }
chnyda3dcf0bd2017-11-30 11:49:24 +010094 }
azvyagintsev7c4a3cf2018-07-08 08:43:33 +030095 if (testResult) {
azvyagintsev1c9801f2018-07-07 23:02:53 +030096 common.infoMsg("Test finished: SUCCESS")
97 } else {
azvyagintsev3ed704f2018-07-09 15:49:27 +030098 error('Test node finished: FAILURE')
99 throw new RuntimeException('Test node stage finished: FAILURE')
azvyagintsev1c9801f2018-07-07 23:02:53 +0300100 }
chnyda3dcf0bd2017-11-30 11:49:24 +0100101 }
chnyda03f3ad42017-09-19 14:41:07 +0200102 }
Jakub Josefa63f9862018-01-11 17:58:38 +0100103 } catch (Throwable e) {
azvyagintsev1c9801f2018-07-07 23:02:53 +0300104 // If there was an error or exception thrown, the build failed
105 currentBuild.result = "FAILURE"
106 currentBuild.description = currentBuild.description ? e.message + " " + currentBuild.description : e.message
107 throw e
chnydad66d6fa2017-06-22 09:34:43 +0200108 }
109 }
chnydad66d6fa2017-06-22 09:34:43 +0200110 }
111}