blob: 394ca98dfd5f3ddd18ef8900c9216c61abfd455a [file] [log] [blame]
Jiri Broulikbdfa2fb2017-07-17 16:26:12 +02001/**
2 * Update packages on given nodes
3 *
4 * Expected parameters:
5 * SALT_MASTER_CREDENTIALS Credentials to the Salt API.
6 * SALT_MASTER_URL Full Salt API address [https://10.10.10.1:8000].
7 * TARGET_SERVERS Salt compound target to match nodes to be updated [*, G@osfamily:debian].
8 * TARGET_SUBSET_TEST Number of nodes to list package updates, empty string means all targetted nodes.
9 * TARGET_SUBSET_LIVE Number of selected nodes to live apply selected package update.
10 *
11**/
12
13def common = new com.mirantis.mk.Common()
14def salt = new com.mirantis.mk.Salt()
chnyda625f4b42017-10-11 14:10:31 +020015def python = new com.mirantis.mk.Python()
Jiri Broulikbdfa2fb2017-07-17 16:26:12 +020016
chnyda625f4b42017-10-11 14:10:31 +020017def pepperEnv = "pepperEnv"
Jiri Broulikbdfa2fb2017-07-17 16:26:12 +020018def targetTestSubset
19def targetLiveSubset
20def targetLiveAll
21def minions
22def result
23def args
24def command
25def commandKwargs
26def probe = 1
27
28node() {
29 try {
30
chnyda625f4b42017-10-11 14:10:31 +020031 stage('Setup virtualenv for Pepper') {
32 python.setupPepperVirtualenv(venvPepper, SALT_MASTER_URL, SALT_MASTER_CREDENTIALS)
Jiri Broulikbdfa2fb2017-07-17 16:26:12 +020033 }
34
35 stage('List target servers') {
chnyda625f4b42017-10-11 14:10:31 +020036 minions = salt.getMinions(pepperEnv, TARGET_SERVERS)
Jiri Broulikbdfa2fb2017-07-17 16:26:12 +020037
38 if (minions.isEmpty()) {
39 throw new Exception("No minion was targeted")
40 }
41
42 if (TARGET_SUBSET_TEST != "") {
43 targetTestSubset = minions.subList(0, Integer.valueOf(TARGET_SUBSET_TEST)).join(' or ')
44 } else {
45 targetTestSubset = minions.join(' or ')
46 }
47 targetLiveSubset = minions.subList(0, Integer.valueOf(TARGET_SUBSET_LIVE)).join(' or ')
48 targetTestSubsetProbe = minions.subList(0, probe).join(' or ')
49 targetLiveSubsetProbe = minions.subList(0, probe).join(' or ')
50
51 targetLiveAll = minions.join(' or ')
52 common.infoMsg("Found nodes: ${targetLiveAll}")
53 common.infoMsg("Selected test nodes: ${targetTestSubset}")
54 common.infoMsg("Selected sample nodes: ${targetLiveSubset}")
55 }
56
57
58 stage("Add new repos on test nodes") {
chnyda625f4b42017-10-11 14:10:31 +020059 salt.enforceState(pepperEnv, targetTestSubset, 'linux.system.repo')
Jiri Broulikbdfa2fb2017-07-17 16:26:12 +020060 }
61
62 stage("List package upgrades") {
chnyda625f4b42017-10-11 14:10:31 +020063 salt.runSaltProcessStep(pepperEnv, targetTestSubset, 'pkg.list_upgrades', [], null, true)
Jiri Broulikbdfa2fb2017-07-17 16:26:12 +020064 }
65
66 stage('Confirm upgrade on sample nodes') {
67 input message: "Please verify the list of packages that you want to be upgraded. Do you want to continue with upgrade?"
68 }
69
70 stage("Add new repos on sample nodes") {
chnyda625f4b42017-10-11 14:10:31 +020071 salt.enforceState(pepperEnv, targetLiveSubset, 'linux.system.repo')
Jiri Broulikbdfa2fb2017-07-17 16:26:12 +020072 }
73
74 args = "apt-get -y -s -o Dpkg::Options::=\"--force-confdef\" -o Dpkg::Options::=\"--force-confold\" dist-upgrade"
75
76 stage('Test upgrade on sample') {
77 try {
chnyda625f4b42017-10-11 14:10:31 +020078 salt.cmdRun(pepperEnv, targetLiveSubset, args)
Jiri Broulikbdfa2fb2017-07-17 16:26:12 +020079 } catch (Exception er) {
80 print(er)
81 }
82 }
83
84 stage('Confirm upgrade on sample') {
85 input message: "Please verify if there are packages that it wants to downgrade. If so, execute apt-cache policy on them and verify if everything is fine. Do you want to continue with upgrade?"
86 }
87
88 command = "cmd.run"
89 args = 'export DEBIAN_FRONTEND=noninteractive; apt-get -y -q --allow-downgrades -o Dpkg::Options::=\"--force-confdef\" -o Dpkg::Options::=\"--force-confold\" dist-upgrade;'
90
91 stage('Apply package upgrades on sample') {
chnyda625f4b42017-10-11 14:10:31 +020092 out = salt.runSaltCommand(pepperEnv, 'local', ['expression': targetLiveSubset, 'type': 'compound'], command, null, args, commandKwargs)
Jiri Broulikbdfa2fb2017-07-17 16:26:12 +020093 salt.printSaltCommandResult(out)
94 }
95
96 args = "sudo /usr/share/openvswitch/scripts/ovs-ctl start"
97
98 stage('Start ovs on sample nodes') {
chnyda625f4b42017-10-11 14:10:31 +020099 out = salt.runSaltCommand(pepperEnv, 'local', ['expression': targetLiveSubset, 'type': 'compound'], command, null, args, commandKwargs)
Jiri Broulikbdfa2fb2017-07-17 16:26:12 +0200100 salt.printSaltCommandResult(out)
101 }
102 stage("Run Neutron state on sample nodes") {
chnyda625f4b42017-10-11 14:10:31 +0200103 salt.enforceState(pepperEnv, targetLiveSubset, ['neutron'])
Jiri Broulikbdfa2fb2017-07-17 16:26:12 +0200104 }
105
106 stage("Run Highstate on sample nodes") {
107 try {
chnyda625f4b42017-10-11 14:10:31 +0200108 salt.enforceHighstate(pepperEnv, targetLiveSubset)
Jiri Broulikbdfa2fb2017-07-17 16:26:12 +0200109 } catch (Exception er) {
110 common.errorMsg("Highstate was executed on ${targetLiveSubset} but something failed. Please check it and fix it accordingly.")
111 }
112 }
113
114 stage('Confirm upgrade on all targeted nodes') {
115 timeout(time: 2, unit: 'HOURS') {
116 input message: "Verify that the upgraded sample nodes are working correctly. If so, do you want to approve live upgrade on ${targetLiveAll} nodes?"
117 }
118 }
119
120 stage("Add new repos on all targeted nodes") {
chnyda625f4b42017-10-11 14:10:31 +0200121 salt.enforceState(pepperEnv, targetLiveAll, 'linux.system.repo')
Jiri Broulikbdfa2fb2017-07-17 16:26:12 +0200122 }
123
124 args = 'export DEBIAN_FRONTEND=noninteractive; apt-get -y -q --allow-downgrades -o Dpkg::Options::=\"--force-confdef\" -o Dpkg::Options::=\"--force-confold\" dist-upgrade;'
125
126 stage('Apply package upgrades on all targeted nodes') {
chnyda625f4b42017-10-11 14:10:31 +0200127 out = salt.runSaltCommand(pepperEnv, 'local', ['expression': targetLiveAll, 'type': 'compound'], command, null, args, commandKwargs)
Jiri Broulikbdfa2fb2017-07-17 16:26:12 +0200128 salt.printSaltCommandResult(out)
129 }
130
131 args = "sudo /usr/share/openvswitch/scripts/ovs-ctl start"
132
133 stage('Start ovs on all targeted nodes') {
chnyda625f4b42017-10-11 14:10:31 +0200134 out = salt.runSaltCommand(pepperEnv, 'local', ['expression': targetLiveAll, 'type': 'compound'], command, null, args, commandKwargs)
Jiri Broulikbdfa2fb2017-07-17 16:26:12 +0200135 salt.printSaltCommandResult(out)
136 }
137 stage("Run Neutron state on all targeted nodes") {
chnyda625f4b42017-10-11 14:10:31 +0200138 salt.enforceState(pepperEnv, targetLiveAll, ['neutron'])
Jiri Broulikbdfa2fb2017-07-17 16:26:12 +0200139 }
140
141 stage("Run Highstate on all targeted nodes") {
142 try {
chnyda625f4b42017-10-11 14:10:31 +0200143 salt.enforceHighstate(pepperEnv, targetLiveAll)
Jiri Broulikbdfa2fb2017-07-17 16:26:12 +0200144 } catch (Exception er) {
145 common.errorMsg("Highstate was executed ${targetLiveAll} but something failed. Please check it and fix it accordingly.")
146 }
147 }
148
149 } catch (Throwable e) {
150 // If there was an error or exception thrown, the build failed
151 currentBuild.result = "FAILURE"
Jakub Josefd2efd7d2017-08-22 17:49:57 +0200152 currentBuild.description = currentBuild.description ? e.message + " " + currentBuild.description : e.message
Jiri Broulikbdfa2fb2017-07-17 16:26:12 +0200153 throw e
154 }
155}
156