Merge "Add Common.checkRemoteBinary func"
diff --git a/src/com/mirantis/mk/Common.groovy b/src/com/mirantis/mk/Common.groovy
index 33d4831..6e90c7a 100644
--- a/src/com/mirantis/mk/Common.groovy
+++ b/src/com/mirantis/mk/Common.groovy
@@ -188,20 +188,20 @@
}
}
-def getColorizedString(msg, color){
- def colorMap = [
- 'red' : '\u001B[31m',
- 'black' : '\u001B[30m',
- 'green' : '\u001B[32m',
- 'yellow': '\u001B[33m',
- 'blue' : '\u001B[34m',
- 'purple': '\u001B[35m',
- 'cyan' : '\u001B[36m',
- 'white' : '\u001B[37m',
- 'reset' : '\u001B[0m'
- ]
+def getColorizedString(msg, color) {
+ def colorMap = [
+ 'red' : '\u001B[31m',
+ 'black' : '\u001B[30m',
+ 'green' : '\u001B[32m',
+ 'yellow': '\u001B[33m',
+ 'blue' : '\u001B[34m',
+ 'purple': '\u001B[35m',
+ 'cyan' : '\u001B[36m',
+ 'white' : '\u001B[37m',
+ 'reset' : '\u001B[0m'
+ ]
- return "${colorMap[color]}${msg}${colorMap.reset}"
+ return "${colorMap[color]}${msg}${colorMap.reset}"
}
/**
@@ -638,7 +638,7 @@
""",
returnStatus: true
)
- if (grep_status == 1){
+ if (grep_status == 1) {
common.warningMsg("Grep regexp ${grepOpts} removed all diff!")
diff_status = 0
}
@@ -717,86 +717,110 @@
}
/**
-* Return colored string of specific stage in stageMap
-*
-* @param stageMap LinkedHashMap object.
-* @param stageName The name of current stage we are going to execute.
-* @param color Text color
-**/
-def getColoredStageView(stageMap, stageName, color){
- def stage = stageMap[stageName]
- def banner = []
- def currentStageIndex = new ArrayList<String>(stageMap.keySet()).indexOf(stageName)
- def numberOfStages = stageMap.keySet().size() - 1
+ * Return colored string of specific stage in stageMap
+ *
+ * @param stageMap LinkedHashMap object.
+ * @param stageName The name of current stage we are going to execute.
+ * @param color Text color
+ * */
+def getColoredStageView(stageMap, stageName, color) {
+ def stage = stageMap[stageName]
+ def banner = []
+ def currentStageIndex = new ArrayList<String>(stageMap.keySet()).indexOf(stageName)
+ def numberOfStages = stageMap.keySet().size() - 1
- banner.add(getColorizedString(
- "=========== Stage ${currentStageIndex}/${numberOfStages}: ${stageName} ===========", color))
- for (stage_item in stage.keySet()){
banner.add(getColorizedString(
- "${stage_item}: ${stage[stage_item]}", color))
- }
- banner.add('\n')
-
- return banner
-}
-
-/**
-* Pring stageMap to console with specified color
-*
-* @param stageMap LinkedHashMap object with stages information.
-* @param currentStage The name of current stage we are going to execute.
-*
-**/
-def printCurrentStage(stageMap, currentStage){
- print getColoredStageView(stageMap, currentStage, "cyan").join('\n')
-}
-
-/**
-* Pring stageMap to console with specified color
-*
-* @param stageMap LinkedHashMap object.
-* @param baseColor Text color (default white)
-**/
-def printStageMap(stageMap, baseColor="white"){
- def banner = []
- def index = 0
- for (stage_name in stageMap.keySet()){
- banner.addAll(getColoredStageView(stageMap, stage_name, baseColor))
- }
- print banner.join('\n')
-}
-
-/**
-* Wrap provided code in stage, and do interactive retires if needed.
-*
-* @param stageMap LinkedHashMap object with stages information.
-* @param currentStage The name of current stage we are going to execute.
-* @param target Target host to execute stage on.
-* @param interactive Boolean flag to specify if interaction with user is enabled.
-* @param body Command to be in stage block.
-**/
-def stageWrapper(stageMap, currentStage, target, interactive=true, Closure body) {
- def common = new com.mirantis.mk.Common()
- def banner = []
-
- printCurrentStage(stageMap, currentStage)
-
- stage(currentStage){
- input message: getColorizedString("We are going to execute stage \'${currentStage}\' on the following target ${target}.\nPlease review stage information above.", "yellow")
- try {
- return body.call()
- stageMap[currentStage]['Status'] = "SUCCESS"
- } catch (Exception err) {
- def msg = "Stage ${currentStage} failed with the following exception:\n${err}"
- print getColorizedString(msg, "yellow")
- common.errorMsg(err)
- if (interactive){
- input message: getColorizedString("Please make sure problem is fixed to proceed with retry. Ready to proceed?", "yellow")
- stageMap[currentStage]['Status'] = "RETRYING"
- stageWrapper(stageMap, currentStage, target, interactive, body)
- } else {
- error(msg)
- }
+ "=========== Stage ${currentStageIndex}/${numberOfStages}: ${stageName} ===========", color))
+ for (stage_item in stage.keySet()) {
+ banner.add(getColorizedString(
+ "${stage_item}: ${stage[stage_item]}", color))
}
- }
+ banner.add('\n')
+
+ return banner
+}
+
+/**
+ * Pring stageMap to console with specified color
+ *
+ * @param stageMap LinkedHashMap object with stages information.
+ * @param currentStage The name of current stage we are going to execute.
+ *
+ * */
+def printCurrentStage(stageMap, currentStage) {
+ print getColoredStageView(stageMap, currentStage, "cyan").join('\n')
+}
+
+/**
+ * Pring stageMap to console with specified color
+ *
+ * @param stageMap LinkedHashMap object.
+ * @param baseColor Text color (default white)
+ * */
+def printStageMap(stageMap, baseColor = "white") {
+ def banner = []
+ def index = 0
+ for (stage_name in stageMap.keySet()) {
+ banner.addAll(getColoredStageView(stageMap, stage_name, baseColor))
+ }
+ print banner.join('\n')
+}
+
+/**
+ * Wrap provided code in stage, and do interactive retires if needed.
+ *
+ * @param stageMap LinkedHashMap object with stages information.
+ * @param currentStage The name of current stage we are going to execute.
+ * @param target Target host to execute stage on.
+ * @param interactive Boolean flag to specify if interaction with user is enabled.
+ * @param body Command to be in stage block.
+ * */
+def stageWrapper(stageMap, currentStage, target, interactive = true, Closure body) {
+ def common = new com.mirantis.mk.Common()
+ def banner = []
+
+ printCurrentStage(stageMap, currentStage)
+
+ stage(currentStage) {
+ input message: getColorizedString("We are going to execute stage \'${currentStage}\' on the following target ${target}.\nPlease review stage information above.", "yellow")
+ try {
+ return body.call()
+ stageMap[currentStage]['Status'] = "SUCCESS"
+ } catch (Exception err) {
+ def msg = "Stage ${currentStage} failed with the following exception:\n${err}"
+ print getColorizedString(msg, "yellow")
+ common.errorMsg(err)
+ if (interactive) {
+ input message: getColorizedString("Please make sure problem is fixed to proceed with retry. Ready to proceed?", "yellow")
+ stageMap[currentStage]['Status'] = "RETRYING"
+ stageWrapper(stageMap, currentStage, target, interactive, body)
+ } else {
+ error(msg)
+ }
+ }
+ }
+}
+
+/**
+ * Ugly transition solution for internal tests.
+ * 1) Check input => transform to static result, based on runtime and input
+ * 2) Check remote-binary repo for exact resource
+ */
+
+def checkRemoteBinary(LinkedHashMap config, List extraScmExtensions = []) {
+ def common = new com.mirantis.mk.Common()
+ res = [:]
+ res['MirrorRoot'] = config.get('globalMirrorRoot', env["BIN_MIRROR_ROOT"] ? env["BIN_MIRROR_ROOT"] : "http://mirror.mirantis.com/")
+ // Reclass-like format's. To make life eazy!
+ res['apt_mk_version'] = config.get('apt_mk_version', env["BIN_APT_MK_VERSION"] ? env["BIN_APT_MK_VERSION"] : 'nightly')
+ res['linux_system_repo_url'] = config.get('linux_system_repo_url', env["BIN_linux_system_repo_url"] ? env["BIN_linux_system_repo_url"] : "${res['MirrorRoot']}/${res['apt_mk_version']}/")
+
+ if (config.get('verify', true)) {
+ MirrorRootStatus = sh(script: "wget --auth-no-challenge --spider ${res['linux_system_repo_url']} 2>/dev/null", returnStatus: true)
+ if (MirrorRootStatus != '0') {
+ common.warningMsg("Resource: ${res['linux_system_repo_url']} not exist")
+ res['linux_system_repo_url'] = false
+ }
+ }
+ return res
}