azvyagintsev | 4eb89ea | 2018-08-07 17:48:19 +0200 | [diff] [blame] | 1 | package com.mirantis.mk |
azvyagintsev | 5c0313d | 2018-08-13 17:13:35 +0300 | [diff] [blame] | 2 | |
azvyagintsev | 4eb89ea | 2018-08-07 17:48:19 +0200 | [diff] [blame] | 3 | def common = new com.mirantis.mk.Common() |
| 4 | def 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 |
azvyagintsev | 5c0313d | 2018-08-13 17:13:35 +0300 | [diff] [blame] | 9 | * SLAVE_NODE: |
azvyagintsev | 4eb89ea | 2018-08-07 17:48:19 +0200 | [diff] [blame] | 10 | */ |
| 11 | |
azvyagintsev | 2a4ad37 | 2019-02-07 18:43:12 +0200 | [diff] [blame] | 12 | slaveNode = env.SLAVE_NODE ?: 'docker' |
azvyagintsev | 5c0313d | 2018-08-13 17:13:35 +0300 | [diff] [blame] | 13 | |
azvyagintsev | 4eb89ea | 2018-08-07 17:48:19 +0200 | [diff] [blame] | 14 | timeout(time: 1, unit: 'HOURS') { |
azvyagintsev | a381cc3 | 2018-09-11 15:36:23 +0300 | [diff] [blame] | 15 | node(slaveNode) { |
| 16 | stage("RunTest") { |
| 17 | try { |
| 18 | extraVars = readYaml text: EXTRA_VARIABLES_YAML |
| 19 | currentBuild.description = extraVars.modelFile |
Denis Egorenko | 032b8ca | 2018-09-13 17:00:23 +0400 | [diff] [blame] | 20 | 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 = [ |
Denis Egorenko | 926bc7d | 2019-02-19 14:27:34 +0400 | [diff] [blame] | 30 | 'dockerHostname': "cfg01", |
| 31 | 'domain': "${templateContext.default_context.cluster_domain}", |
Denis Egorenko | 032b8ca | 2018-09-13 17:00:23 +0400 | [diff] [blame] | 32 | 'clusterName': templateContext.default_context.cluster_name, |
| 33 | 'reclassEnv': extraVars.testReclassEnv, |
azvyagintsev | 1bcadc4 | 2018-10-05 20:13:15 +0300 | [diff] [blame] | 34 | 'distribRevision': extraVars.DISTRIB_REVISION, |
Denis Egorenko | 032b8ca | 2018-09-13 17:00:23 +0400 | [diff] [blame] | 35 | 'dockerContainerName': extraVars.DockerCName, |
| 36 | 'testContext': extraVars.modelFile |
| 37 | ] |
Denis Egorenko | 086aff1 | 2018-10-18 17:54:59 +0400 | [diff] [blame] | 38 | if (extraVars.useExtraRepos) { |
| 39 | config['extraRepos'] = extraVars.extraRepos ? extraVars.extraRepos : [:] |
| 40 | config['extraRepoMergeStrategy'] = extraVars.extraRepoMergeStrategy ? extraVars.extraRepoMergeStrategy : '' |
| 41 | } |
Denis Egorenko | 032b8ca | 2018-09-13 17:00:23 +0400 | [diff] [blame] | 42 | saltModelTesting.testNode(config) |
azvyagintsev | a381cc3 | 2018-09-11 15:36:23 +0300 | [diff] [blame] | 43 | } catch (Throwable e) { |
| 44 | // If there was an error or exception thrown, the build failed |
| 45 | currentBuild.result = "FAILURE" |
| 46 | currentBuild.description = currentBuild.description ? e.message + " " + currentBuild.description : e.message |
| 47 | throw e |
| 48 | } |
| 49 | } |
azvyagintsev | 4eb89ea | 2018-08-07 17:48:19 +0200 | [diff] [blame] | 50 | } |
azvyagintsev | 5c0313d | 2018-08-13 17:13:35 +0300 | [diff] [blame] | 51 | } |