| def common = new com.mirantis.mk.Common() |
| def salt = new com.mirantis.mk.Salt() |
| def python = new com.mirantis.mk.Python() |
| def pepperEnv = "pepperEnv" |
| |
| timeout(time: 12, unit: 'HOURS') { |
| node() { |
| stage('Setup virtualenv for Pepper') { |
| python.setupPepperVirtualenv(pepperEnv, SALT_MASTER_URL, SALT_MASTER_CREDENTIALS) |
| } |
| stage('Check backup location') { |
| try{ |
| backupNode = salt.getMinions(pepperEnv, "I@backupninja:client")[0] |
| salt.minionsReachable(pepperEnv, "I@salt:master", backupNode) |
| } |
| catch (Exception e) { |
| common.errorMsg(e.getMessage()) |
| common.errorMsg("Pipeline wasn't able to detect backupninja:client pillar or the minion is not reachable") |
| currentBuild.result = "FAILURE" |
| return |
| } |
| try{ |
| backupServer = salt.getMinions(pepperEnv, "I@backupninja:server")[0] |
| salt.minionsReachable(pepperEnv, "I@salt:master", backupServer) |
| } |
| catch (Exception e) { |
| common.errorMsg(e.getMessage()) |
| common.errorMsg("Pipeline wasn't able to detect backupninja:server pillar or the minion is not reachable") |
| currentBuild.result = "FAILURE" |
| return |
| } |
| } |
| stage ('Prepare for backup') { |
| salt.enforceState(['saltId': pepperEnv, 'target': 'I@backupninja:server', 'state': 'backupninja']) |
| salt.enforceState(['saltId': pepperEnv, 'target': 'I@backupninja:client', 'state': 'backupninja']) |
| } |
| stage('Backup') { |
| output = salt.getReturnValues(salt.cmdRun(pepperEnv, backupNode, "su root -c 'backupninja --now -d'")).readLines()[-2] |
| def outputPattern = java.util.regex.Pattern.compile("\\d+") |
| def outputMatcher = outputPattern.matcher(output) |
| if (outputMatcher.find()) { |
| try{ |
| result = outputMatcher.getAt([0,1,2,3]) |
| } |
| catch (Exception e){ |
| common.errorMsg(e.getMessage()) |
| common.errorMsg("Parsing failed.") |
| currentBuild.result = "FAILURE" |
| return |
| } |
| } |
| if (result[1] == 0 || result == ""){ |
| common.errorMsg("Backup failed.") |
| currentBuild.result = "FAILURE" |
| return |
| } |
| else { |
| common.successMsg("Backup successfully finished " + result[1] + " fatals, " + result[2] + " errors " + result[3] +" warnings") |
| } |
| } |
| } |
| } |