blob: cdc6e1ec160a85d771eff8d8f1b82b27b6866bc4 [file] [log] [blame]
azvyagintsev4eb89ea2018-08-07 17:48:19 +02001package com.mirantis.mk
azvyagintsev5c0313d2018-08-13 17:13:35 +03002
azvyagintsev4eb89ea2018-08-07 17:48:19 +02003def common = new com.mirantis.mk.Common()
4def saltModelTesting = new com.mirantis.mk.SaltModelTesting()
5
6/**
7 * Test CC model wrapper
8 * EXTRA_VARIABLES_YAML: yaml based string, to be directly passed into testCCModel
azvyagintsev5c0313d2018-08-13 17:13:35 +03009 * SLAVE_NODE:
azvyagintsev4eb89ea2018-08-07 17:48:19 +020010 */
11
azvyagintsev5c0313d2018-08-13 17:13:35 +030012slaveNode = env.SLAVE_NODE ?: 'python&&docker'
13
azvyagintsev4eb89ea2018-08-07 17:48:19 +020014timeout(time: 1, unit: 'HOURS') {
azvyagintseva381cc32018-09-11 15:36:23 +030015 node(slaveNode) {
16 stage("RunTest") {
17 try {
18 extraVars = readYaml text: EXTRA_VARIABLES_YAML
19 currentBuild.description = extraVars.modelFile
Denis Egorenko032b8ca2018-09-13 17:00:23 +040020 sh(script: 'find . -mindepth 1 -delete || true', returnStatus: true)
21 sh(script: """
22 wget --progress=dot:mega --auth-no-challenge -O models.tar.gz ${extraVars.MODELS_TARGZ}
23 tar -xzf models.tar.gz
24 """)
25 common.infoMsg("Going to test exactly one context: ${extraVars.modelFile}\n, with params: ${extraVars}")
26
27 def content = readFile(file: extraVars.modelFile)
28 def templateContext = readYaml text: content
29 def config = [
30 'dockerHostname': "cfg01.${templateContext.default_context.cluster_domain}",
31 'clusterName': templateContext.default_context.cluster_name,
32 'reclassEnv': extraVars.testReclassEnv,
azvyagintsev1bcadc42018-10-05 20:13:15 +030033 'distribRevision': extraVars.DISTRIB_REVISION,
Denis Egorenko032b8ca2018-09-13 17:00:23 +040034 'dockerContainerName': extraVars.DockerCName,
35 'testContext': extraVars.modelFile
36 ]
Denis Egorenko086aff12018-10-18 17:54:59 +040037 if (extraVars.useExtraRepos) {
38 config['extraRepos'] = extraVars.extraRepos ? extraVars.extraRepos : [:]
39 config['extraRepoMergeStrategy'] = extraVars.extraRepoMergeStrategy ? extraVars.extraRepoMergeStrategy : ''
40 }
Denis Egorenko032b8ca2018-09-13 17:00:23 +040041 saltModelTesting.testNode(config)
azvyagintseva381cc32018-09-11 15:36:23 +030042 } catch (Throwable e) {
43 // If there was an error or exception thrown, the build failed
44 currentBuild.result = "FAILURE"
45 currentBuild.description = currentBuild.description ? e.message + " " + currentBuild.description : e.message
46 throw e
47 }
48 }
azvyagintsev4eb89ea2018-08-07 17:48:19 +020049 }
azvyagintsev5c0313d2018-08-13 17:13:35 +030050}