blob: 8e23e26a093ed258bef9acc6061c88953fbd0ca7 [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
7 * EXTRA_FORMULAS
Jakub Josef107769c2017-08-17 13:38:15 +02008 * CLUSTER_NAME
chnydad66d6fa2017-06-22 09:34:43 +02009 * NODE_TARGET
10 * SYSTEM_GIT_URL
11 * SYSTEM_GIT_REF
Mykyta Karpinc0758f32017-06-23 18:10:24 +030012 * FORMULAS_SOURCE
chnydabb6d2a62017-07-31 14:09:16 +020013 * MAX_CPU_PER_JOB
Jakub Josef6e4a09d2017-10-05 16:53:02 +020014 * LEGACY_TEST_MODE
chnydad66d6fa2017-06-22 09:34:43 +020015 */
16
17def common = new com.mirantis.mk.Common()
18def gerrit = new com.mirantis.mk.Gerrit()
chnyda4ed3c272017-06-22 14:50:09 +020019def git = new com.mirantis.mk.Git()
chnydac6092a22017-06-22 14:47:10 +020020def ssh = new com.mirantis.mk.Ssh()
chnydad66d6fa2017-06-22 09:34:43 +020021def saltModelTesting = new com.mirantis.mk.SaltModelTesting()
22
23def defaultGitRef = DEFAULT_GIT_REF
24def defaultGitUrl = DEFAULT_GIT_URL
25
26def checkouted = false
chnyda03f3ad42017-09-19 14:41:07 +020027
28throttle(['test-model']) {
29 node("python") {
30 try{
31 stage("checkout") {
32 if(defaultGitRef != "" && defaultGitUrl != "") {
33 checkouted = gerrit.gerritPatchsetCheckout(defaultGitUrl, defaultGitRef, "HEAD", CREDENTIALS_ID)
34 } else {
35 throw new Exception("Cannot checkout gerrit patchset, DEFAULT_GIT_URL or DEFAULT_GIT_REF is null")
36 }
37 if(checkouted) {
38 if (fileExists('classes/system')) {
39 if (SYSTEM_GIT_URL == "") {
40 ssh.prepareSshAgentKey(CREDENTIALS_ID)
41 dir('classes/system') {
42 remoteUrl = git.getGitRemote()
43 ssh.ensureKnownHosts(remoteUrl)
44 }
45 ssh.agentSh("git submodule init; git submodule sync; git submodule update --recursive")
46 } else {
47 dir('classes/system') {
48 if (!gerrit.gerritPatchsetCheckout(SYSTEM_GIT_URL, SYSTEM_GIT_REF, "HEAD", CREDENTIALS_ID)) {
49 common.errorMsg("Failed to obtain system reclass with url: ${SYSTEM_GIT_URL} and ${SYSTEM_GIT_REF}")
50 }
chnydad66d6fa2017-06-22 09:34:43 +020051 }
52 }
53 }
54 }
55 }
chnydad66d6fa2017-06-22 09:34:43 +020056
chnyda03f3ad42017-09-19 14:41:07 +020057 stage("test node") {
58 if (checkouted) {
59 def workspace = common.getWorkspace()
Jakub Josef70fd76e2017-09-25 14:48:44 +020060 common.infoMsg("Running salt model test for node ${NODE_TARGET} in cluster ${CLUSTER_NAME}")
Jakub Josef6e4a09d2017-10-05 16:53:02 +020061 saltModelTesting.setupAndTestNode(NODE_TARGET, CLUSTER_NAME, EXTRA_FORMULAS, workspace, FORMULAS_SOURCE, FORMULAS_REVISION, MAX_CPU_PER_JOB.toInteger(), LEGACY_TEST_MODE)
chnyda03f3ad42017-09-19 14:41:07 +020062 }
chnydad66d6fa2017-06-22 09:34:43 +020063 }
chnyda03f3ad42017-09-19 14:41:07 +020064 } catch (Throwable e) {
65 // If there was an error or exception thrown, the build failed
66 currentBuild.result = "FAILURE"
67 currentBuild.description = currentBuild.description ? e.message + " " + currentBuild.description : e.message
68 throw e
chnydad66d6fa2017-06-22 09:34:43 +020069 }
chnydad66d6fa2017-06-22 09:34:43 +020070 }
71}