blob: 1254337cafc7f7d0c8e955f5acf8d4f8377eb3f3 [file] [log] [blame]
Zsolt Haraszti2a792f62016-05-12 17:49:02 -07001/*
2 * Copyright 2012 the original author or authors.
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
David K. Bainbridge59bdb542016-07-01 11:07:45 -070016import org.opencord.gradle.rules.*
David K. Bainbridge10b0c112016-05-24 13:17:23 -070017import org.yaml.snakeyaml.Yaml
Zsolt Haraszti2a792f62016-05-12 17:49:02 -070018
David K. Bainbridge59bdb542016-07-01 11:07:45 -070019allprojects {
20 apply plugin: 'base'
21 apply plugin: 'de.gesellix.docker'
22 //apply plugin: 'com.tmiyamon.config'
23
24 docker {
25 // dockerHost = System.env.DOCKER_HOST ?: 'unix:///var/run/docker.sock'
26 // dockerHost = System.env.DOCKER_HOST ?: 'https://192.168.99.100:2376'
27 // certPath = System.getProperty('docker.cert.path') ?: "${System.getProperty('user.home')}/.docker/machine/machines/default"
28 // authConfigPlain = [
29 // "username" : "joe",
30 // "password" : "some-pw-as-needed",
31 // "email" : "joe@acme.com",
32 // "serveraddress" : "https://index.docker.io/v1/"
33 // ]
34 }
35}
36
Zsolt Haraszti2a792f62016-05-12 17:49:02 -070037ext {
38
David K. Bainbridge59bdb542016-07-01 11:07:45 -070039 // Upstream registry to simplify filling out the comps table below
40 upstreamReg = project.hasProperty('upstreamReg') ? project.getProperty('upstreamReg') : 'docker.io'
41
David K. Bainbridge10b0c112016-05-24 13:17:23 -070042 // Deployment target config file (yaml format); this can be overwritten from the command line
43 // using the -PdeployConfig=<file-path> syntax.
44 deployConfig = project.hasProperty('deployConfig') ? project.getProperty('deployConfig') : './config/default.yml'
David K. Bainbridge19b8d272016-05-26 21:20:43 -070045
David K. Bainbridgec4e0fc52016-11-14 12:03:35 -080046 println "Using deployment config: $deployConfig"
47 File configFile = new File(deployConfig)
48 def yaml = new Yaml()
49 config = yaml.load(configFile.newReader())
50
51 // Target registry to be used to publish docker images needed for deployment
52 targetReg = project.hasProperty('targetReg')
53 ? project.getProperty('targetReg')
54 : config.docker && config.docker.registry
55 ? config.docker.registry
Zack Williamsb55e8ef2017-02-01 10:54:36 -070056 : config.headnode.ip
57 ? config.headnode.ip + ":5000"
David K. Bainbridgec9cacd32016-11-15 15:10:06 -080058 : 'localhost:5000'
David K. Bainbridgec4e0fc52016-11-14 12:03:35 -080059
60 // The tag used to tag the docker images push to the target registry
61 targetTag = project.hasProperty('targetTag')
62 ? project.getProperty('targetTag')
63 : config.docker && config.docker.imageVersion
64 ? config.docker.imageVersion
65 : 'candidate'
66
David K. Bainbridge59bdb542016-07-01 11:07:45 -070067 comps = [
68 'consul': [
69 'type': 'image',
70 'upstream': upstreamReg,
71 'name': 'consul',
72 'digest': 'sha256:0dc990ff3c44d5b5395475bcc5ebdae4fc8b67f69e17942a8b9793b3df74d290'
73 ]
74 ]
75}
76
77task fetchUpstreamImages {
78 comps.each { name, spec -> if (spec.type == 'image') { dependsOn "fetch" + name } }
Zsolt Haraszti2a792f62016-05-12 17:49:02 -070079}
80
David K. Bainbridge97ee8052016-06-14 00:52:07 -070081// Switch Configuration Image
82
David K. Bainbridgede0d9262016-09-13 20:12:06 -070083def getBuildTimestamp() {
84 def cal = Calendar.getInstance(TimeZone.getTimeZone("UTC"))
85 def date = cal.getTime()
David K. Bainbridge151e8452016-12-19 23:05:51 -080086 def formattedDate = date.format("yyyy-MM-dd'T'HH:mm:ssZ")
David K. Bainbridgede0d9262016-09-13 20:12:06 -070087 return formattedDate
88}
89
David K. Bainbridge151e8452016-12-19 23:05:51 -080090def getCommitDate = { ->
91 def stdOut = new ByteArrayOutputStream()
92 exec {
93 commandLine "git", "log", "--pretty=format:%cd", "--date=format:%FT%T%z", "-n", "1"
94 standardOutput = stdOut
95 }
96 return stdOut.toString().trim()
97}
98
David K. Bainbridgede0d9262016-09-13 20:12:06 -070099def getCommitHash = { ->
100 def hashStdOut = new ByteArrayOutputStream()
101 exec {
David K. Bainbridge151e8452016-12-19 23:05:51 -0800102 commandLine "git", "log", "--pretty=format:%H", "-n", "1"
David K. Bainbridgede0d9262016-09-13 20:12:06 -0700103 standardOutput = hashStdOut
104 }
105 return hashStdOut.toString().trim()
106}
107
David K. Bainbridged4e3f622017-01-12 14:07:54 -0800108def isModified = { ->
109 def statusOut = new ByteArrayOutputStream()
110 def branchesOut = new ByteArrayOutputStream()
David K. Bainbridgede0d9262016-09-13 20:12:06 -0700111 exec {
David K. Bainbridged4e3f622017-01-12 14:07:54 -0800112 commandLine "bash", "-c", "repo --color=never --no-pager status . | tail -n +2 | wc -l"
113 standardOutput = statusOut
David K. Bainbridgede0d9262016-09-13 20:12:06 -0700114 }
David K. Bainbridged4e3f622017-01-12 14:07:54 -0800115 exec {
116 commandLine "bash", "-c", "repo --color=never --no-pager branches | wc -l"
117 standardOutput = branchesOut
118 }
119 def statusVal = statusOut.toString().trim()
120 def branchesVal = branchesOut.toString().trim()
121
122 return statusVal != "0" || branchesVal != "0"
123}
124
125def getBranchName = { ->
126 def stdout = new ByteArrayOutputStream()
127 exec {
128 commandLine "bash", "-c", "repo --color=never --no-pager info -l -o | grep 'Manifest branch:' | awk '{print \$NF}'"
129 standardOutput = stdout
130 }
131 def val = stdout.toString().trim()
132 if ( isModified() != "0" ) {
133 val += '[modified]'
134 }
135 return val
David K. Bainbridgede0d9262016-09-13 20:12:06 -0700136}
David K. Bainbridge6e23ac82016-12-07 12:55:41 -0800137
David K. Bainbridge97ee8052016-06-14 00:52:07 -0700138task buildSwitchqImage(type: Exec) {
David K. Bainbridge528b3182017-01-23 08:51:59 -0800139 workingDir 'switchq'
David K. Bainbridge0a7cdbb2017-07-14 11:36:13 -0700140 commandLine 'make', "DOCKER_TAG=$targetTag", "DOCKER_REGISTRY=$targetReg", 'build'
David K. Bainbridge97ee8052016-06-14 00:52:07 -0700141}
142
143task publishSwitchqImage(type: Exec) {
David K. Bainbridge0a7cdbb2017-07-14 11:36:13 -0700144 workingDir 'switchq'
145 commandLine 'make', "DOCKER_TAG=$targetTag", "DOCKER_REGISTRY=$targetReg", 'publish'
David K. Bainbridge97ee8052016-06-14 00:52:07 -0700146}
147
David K. Bainbridge97ee8052016-06-14 00:52:07 -0700148// IP Allocator Image
149
David K. Bainbridge8bc905c2016-05-31 14:07:10 -0700150task buildAllocationImage(type: Exec) {
David K. Bainbridge528b3182017-01-23 08:51:59 -0800151 workingDir 'ip-allocator'
David K. Bainbridge0a7cdbb2017-07-14 11:36:13 -0700152 commandLine 'make', "DOCKER_TAG=$targetTag", "DOCKER_REGISTRY=$targetReg", 'build'
David K. Bainbridge8bc905c2016-05-31 14:07:10 -0700153}
154
155task publishAllocationImage(type: Exec) {
David K. Bainbridge0a7cdbb2017-07-14 11:36:13 -0700156 workingDir 'ip-allocator'
157 commandLine 'make', "DOCKER_TAG=$targetTag", "DOCKER_REGISTRY=$targetReg", 'publish'
David K. Bainbridge8bc905c2016-05-31 14:07:10 -0700158}
159
David K. Bainbridge97ee8052016-06-14 00:52:07 -0700160// Provisioner Image
161
David K. Bainbridgef0da8732016-06-01 16:15:37 -0700162task buildProvisionerImage(type: Exec) {
David K. Bainbridge528b3182017-01-23 08:51:59 -0800163 workingDir 'provisioner'
David K. Bainbridge0a7cdbb2017-07-14 11:36:13 -0700164 commandLine 'make', "DOCKER_TAG=$targetTag", "DOCKER_REGISTRY=$targetReg", 'build'
David K. Bainbridgef0da8732016-06-01 16:15:37 -0700165}
166
167task publishProvisionerImage(type: Exec) {
David K. Bainbridge0a7cdbb2017-07-14 11:36:13 -0700168 workingDir 'provisioner'
169 commandLine 'make', "DOCKER_TAG=$targetTag", "DOCKER_REGISTRY=$targetReg", 'publish'
David K. Bainbridgef0da8732016-06-01 16:15:37 -0700170}
171
gunjan5e9bdd1d2016-07-13 14:59:33 -0700172// Config Generator Image
173
174task buildConfigGeneratorImage(type: Exec) {
David K. Bainbridge528b3182017-01-23 08:51:59 -0800175 workingDir 'config-generator'
David K. Bainbridge0a7cdbb2017-07-14 11:36:13 -0700176 commandLine 'make', "DOCKER_TAG=$targetTag", "DOCKER_REGISTRY=$targetReg", 'build'
gunjan5e9bdd1d2016-07-13 14:59:33 -0700177}
178
179task publishConfigGeneratorImage(type: Exec) {
David K. Bainbridge0a7cdbb2017-07-14 11:36:13 -0700180 workingDir 'config-generator'
181 commandLine 'make', "DOCKER_TAG=$targetTag", "DOCKER_REGISTRY=$targetReg", 'publish'
gunjan5e9bdd1d2016-07-13 14:59:33 -0700182}
183
David K. Bainbridge9d1e02d2016-06-22 09:22:16 -0700184// Automation Image
David K. Bainbridge97ee8052016-06-14 00:52:07 -0700185
David K. Bainbridgeb5415042016-05-13 17:06:10 -0700186task buildAutomationImage(type: Exec) {
David K. Bainbridge528b3182017-01-23 08:51:59 -0800187 workingDir 'automation'
David K. Bainbridge0a7cdbb2017-07-14 11:36:13 -0700188 commandLine 'make', "DOCKER_TAG=$targetTag", "DOCKER_REGISTRY=$targetReg", 'build'
Zsolt Haraszti2a792f62016-05-12 17:49:02 -0700189}
190
David K. Bainbridgeb5415042016-05-13 17:06:10 -0700191task publishAutomationImage(type: Exec) {
David K. Bainbridge0a7cdbb2017-07-14 11:36:13 -0700192 workingDir 'automation'
193 commandLine 'make', "DOCKER_TAG=$targetTag", "DOCKER_REGISTRY=$targetReg", 'publish'
David K. Bainbridgeb5415042016-05-13 17:06:10 -0700194}
195
David K. Bainbridge97ee8052016-06-14 00:52:07 -0700196// DHCP Harvester Images
197
David K. Bainbridgeb5415042016-05-13 17:06:10 -0700198task buildHarvesterImage(type: Exec) {
David K. Bainbridge528b3182017-01-23 08:51:59 -0800199 workingDir 'harvester'
David K. Bainbridge0a7cdbb2017-07-14 11:36:13 -0700200 commandLine 'make', "DOCKER_TAG=$targetTag", "DOCKER_REGISTRY=$targetReg", 'build'
David K. Bainbridgeb5415042016-05-13 17:06:10 -0700201}
202
203task publishHarvesterImage(type: Exec) {
David K. Bainbridge0a7cdbb2017-07-14 11:36:13 -0700204 workingDir 'harvester'
205 commandLine 'make', "DOCKER_TAG=$targetTag", "DOCKER_REGISTRY=$targetReg", 'publish'
Zsolt Haraszti2a792f62016-05-12 17:49:02 -0700206}
207
208// ~~~~~~~~~~~~~~~~~~~ Global tasks ~~~~~~~~~~~~~~~~~~~~~~~
209
alshabib462f6252016-08-29 16:15:28 -0700210task updateDocker (type: Exec) {
David K. Bainbridge59bdb542016-07-01 11:07:45 -0700211 commandLine 'sudo', 'utils/enable-remote-docker-registry', "$targetReg"
212}
213
Zsolt Haraszti2a792f62016-05-12 17:49:02 -0700214// To be used to fetch upstream binaries, clone repos, etc.
215task fetch(type: Exec) {
216 // this is where we fetch upstream artifacts that we do not need internet for the build phase"
217 // Placeholdr example:
David K. Bainbridge59bdb542016-07-01 11:07:45 -0700218 dependsOn fetchUpstreamImages
David K. Bainbridgea677d4e2016-09-11 20:01:32 -0700219 commandLine "docker", "pull", "golang:alpine"
220 commandLine "docker", "pull", "python:2.7-alpine"
Zsolt Haraszti2a792f62016-05-12 17:49:02 -0700221}
222
223// To be used to generate all needed binaries that need to be present on the target
224// as docker images in the local docker runner.
225task buildImages {
David K. Bainbridgeb5415042016-05-13 17:06:10 -0700226 dependsOn buildHarvesterImage
David K. Bainbridge9d1e02d2016-06-22 09:22:16 -0700227 dependsOn buildAutomationImage
David K. Bainbridge8bc905c2016-05-31 14:07:10 -0700228 dependsOn buildAllocationImage
David K. Bainbridgef0da8732016-06-01 16:15:37 -0700229 dependsOn buildProvisionerImage
gunjan5e9bdd1d2016-07-13 14:59:33 -0700230 dependsOn buildConfigGeneratorImage
David K. Bainbridge97ee8052016-06-14 00:52:07 -0700231 dependsOn buildSwitchqImage
David K. Bainbridgeb5415042016-05-13 17:06:10 -0700232}
233
Zsolt Haraszti2a792f62016-05-12 17:49:02 -0700234task publish {
alshabib462f6252016-08-29 16:15:28 -0700235 //FIXME: This works because the upstream project primes the nodes before running this.
David K. Bainbridge59bdb542016-07-01 11:07:45 -0700236 comps.each { name, spec -> if (spec.type == 'image') { dependsOn "publish" + name } }
David K. Bainbridgeb5415042016-05-13 17:06:10 -0700237 dependsOn publishHarvesterImage
David K. Bainbridge9d1e02d2016-06-22 09:22:16 -0700238 dependsOn publishAutomationImage
David K. Bainbridge8bc905c2016-05-31 14:07:10 -0700239 dependsOn publishAllocationImage
David K. Bainbridgef0da8732016-06-01 16:15:37 -0700240 dependsOn publishProvisionerImage
gunjan5e9bdd1d2016-07-13 14:59:33 -0700241 dependsOn publishConfigGeneratorImage
David K. Bainbridge97ee8052016-06-14 00:52:07 -0700242 dependsOn publishSwitchqImage
David K. Bainbridgeefa951d2016-05-26 10:54:25 -0700243}
244
David K. Bainbridgeb5415042016-05-13 17:06:10 -0700245// ~~~~~~~~~~~~~~~~~~~ Deployment / Test Tasks ~~~~~~~~~~~~~~~~~~~~~~~
246
David K. Bainbridge10b0c112016-05-24 13:17:23 -0700247List.metaClass.asParam = { prefix, sep ->
248 if (delegate.size() == 0) {
249 ""
250 }
251 String result = "--" + prefix + "="
252 String p = ""
253 delegate.each {
254 result += p + "${it}"
255 p = sep
256 }
257 result
David K. Bainbridgeb5415042016-05-13 17:06:10 -0700258}
259
David K. Bainbridge10b0c112016-05-24 13:17:23 -0700260List.metaClass.p = { value, name ->
261 if (value != null && value != "") {
262 delegate << name + "=" + value
263 } else {
264 delegate
265 }
266}
267
268List.metaClass.p = { spec ->
269 if (spec != null && spec != "") {
270 delegate += spec
271 } else {
272 delegate
273 }
274}
275
alshabib462f6252016-08-29 16:15:28 -0700276task prime (type: Exec) {
David K. Bainbridgef4181702016-06-17 14:44:03 -0700277 executable = "ansible-playbook"
Zack Williams642388d2017-04-12 22:39:15 -0700278 args = ["-i", '../genconfig/cord-inv']
David K. Bainbridgef4181702016-06-17 14:44:03 -0700279
Zack Williamsb55e8ef2017-02-01 10:54:36 -0700280 if ( config.headnode.ansible_user != null && config.headnode.ansible_user != "" ) {
281 args = args << "--user=$config.headnode.ansible_user"
David K. Bainbridgef4181702016-06-17 14:44:03 -0700282 }
283
David K. Bainbridge5ba01a92016-08-16 14:58:31 -0700284 if ( config.debug ) {
285 args = args << "-vvvv"
286 }
287
David K. Bainbridgef4181702016-06-17 14:44:03 -0700288 def extraVars = []
Zack Williamsb55e8ef2017-02-01 10:54:36 -0700289 if (config.common) {
290 extraVars = extraVars.p(config.common.extraVars)
291 .p(config.headnode.ansible_ssh_pass, "ansible_ssh_pass")
292 .p(config.headnode.ansible_become_pass, "ansible_become_pass")
293 .p(config.headnode.ansible_ssh_port, "ansible_ssh_port")
294 .p(config.common.fabric_ip, "fabric_ip")
295 .p(config.common.fabric_range_low, "fabric_range_low")
296 .p(config.common.fabric_range_high, "fabric_range_high")
297 .p(config.common.management_ip, "management_ip")
298 .p(config.common.management_range_low, "management_range_low")
299 .p(config.common.management_range_high, "management_range_high")
300 .p(config.common.management_gw, "management_gw")
301 .p(config.common.management_bc, "management_bc")
302 .p(config.common.management_network, "management_network")
303 .p(config.common.management_iface, "management_iface")
304 .p(config.common.external_ip, "external_ip")
305 .p(config.common.external_gw, "external_gw")
306 .p(config.common.external_bc, "external_bc")
307 .p(config.common.external_network, "external_network")
308 .p(config.common.external_iface, "external_iface")
309 .p(config.common.fabric_iface, "fabric_iface")
310 .p(config.common.domain, "domain")
311 .p(config.common.virtualbox_support, "virtualbox_support")
312 .p(config.common.power_helper_user, "power_helper_user")
313 .p(config.common.power_helper_host, "power_helper_host")
saikrishna edupugantie86ddab2017-07-23 21:04:06 -0700314 .p(config.common.kernel_opts, "kernel_opts")
David K. Bainbridgef4181702016-06-17 14:44:03 -0700315 }
316
David K. Bainbridge8b179042016-11-30 15:38:42 -0800317 if (config.passwords) {
318 extraVars = extraVars.p(config.passwords.compute_node, "password_compute_node")
319 .p(config.passwords.maas_admin, "password_maas_admin")
320 .p(config.passwords.maas_user, "password_maas_user")
321 }
322
David K. Bainbridgef4181702016-06-17 14:44:03 -0700323 if (config.otherServers) {
324 extraVars = extraVars.p(config.otherServers.location, "prov_location")
325 .p(config.otherServers.rolesPath, "prov_role_path")
326 .p(config.otherServers.role, "prov_role")
327 }
328
David K. Bainbridgec4e0fc52016-11-14 12:03:35 -0800329 extraVars = extraVars.p("$targetReg", "deploy_docker_registry")
330 .p("$targetTag", "deploy_docker_tag")
David K. Bainbridgef4181702016-06-17 14:44:03 -0700331
David K. Bainbridge6e23ac82016-12-07 12:55:41 -0800332 // the password set on the compute node is skipped because this is being run against the
333 // head node and we don't want to change the head node password as this node was manualy
David K. Bainbridge8b179042016-11-30 15:38:42 -0800334 // set up.
Zack Williamsb55e8ef2017-02-01 10:54:36 -0700335 def skipTags = [].p(config.common.skipTags).p('set_compute_node_password')
David K. Bainbridgef4181702016-06-17 14:44:03 -0700336
337 args = args.p(skipTags.asParam("skip-tags", ",")).p(extraVars.asParam("extra-vars", " ")) << "prime-node.yml"
338}
339
alshabib462f6252016-08-29 16:15:28 -0700340task deployBase(type: Exec) {
David K. Bainbridge10b0c112016-05-24 13:17:23 -0700341 executable = "ansible-playbook"
Zack Williams642388d2017-04-12 22:39:15 -0700342 args = ["-i", '../genconfig/cord-inv']
David K. Bainbridge10b0c112016-05-24 13:17:23 -0700343
Zack Williamsb55e8ef2017-02-01 10:54:36 -0700344 if ( config.headnode.ansible_user != null && config.headnode.ansible_user != "" ) {
345 args = args << "--user=$config.headnode.ansible_user"
David K. Bainbridge10b0c112016-05-24 13:17:23 -0700346 }
347
David K. Bainbridge5ba01a92016-08-16 14:58:31 -0700348 if ( config.debug ) {
349 args = args << "-vvvv"
350 }
351
David K. Bainbridge10b0c112016-05-24 13:17:23 -0700352 def extraVars = []
Zack Williamsb55e8ef2017-02-01 10:54:36 -0700353 if (config.common) {
354 extraVars = extraVars.p(config.common.extraVars)
355 .p(config.headnode.ansible_ssh_pass, "ansible_ssh_pass")
356 .p(config.headnode.ansible_become_pass, "ansible_become_pass")
357 .p(config.headnode.ansible_ssh_port, "ansible_ssh_port")
358 .p(config.common.fabric_ip, "fabric_ip")
359 .p(config.common.fabric_range_low, "fabric_range_low")
360 .p(config.common.fabric_range_high, "fabric_range_high")
361 .p(config.common.management_ip, "management_ip")
362 .p(config.common.management_range_low, "management_range_low")
363 .p(config.common.management_range_high, "management_range_high")
364 .p(config.common.management_gw, "management_gw")
365 .p(config.common.management_network, "management_network")
366 .p(config.common.management_iface, "management_iface")
367 .p(config.common.external_ip, "external_ip")
368 .p(config.common.external_gw, "external_gw")
369 .p(config.common.external_network, "external_network")
370 .p(config.common.external_iface, "external_iface")
371 .p(config.common.fabric_iface, "fabric_iface")
372 .p(config.common.domain, "domain")
373 .p(config.common.virtualbox_support, "virtualbox_support")
374 .p(config.common.power_helper_user, "power_helper_user")
375 .p(config.common.power_helper_host, "power_helper_host")
saikrishna edupugantie86ddab2017-07-23 21:04:06 -0700376 .p(config.common.kernel_opts, "kernel_opts")
David K. Bainbridge6ea57c12016-06-06 23:29:12 -0700377 }
378
David K. Bainbridge8b179042016-11-30 15:38:42 -0800379 if (config.passwords) {
380 extraVars = extraVars.p(config.passwords.compute_node, "password_compute_node")
381 .p(config.passwords.maas_admin, "password_maas_admin")
382 .p(config.passwords.maas_user, "password_maas_user")
383 }
384
David K. Bainbridge10b0c112016-05-24 13:17:23 -0700385 if (config.otherServers) {
386 extraVars = extraVars.p(config.otherServers.location, "prov_location")
387 .p(config.otherServers.rolesPath, "prov_role_path")
388 .p(config.otherServers.role, "prov_role")
389 }
390
David K. Bainbridgec4e0fc52016-11-14 12:03:35 -0800391 extraVars = extraVars.p("$targetReg", "deploy_docker_registry")
392 .p("$targetTag", "deploy_docker_tag")
David K. Bainbridge97ee8052016-06-14 00:52:07 -0700393
David K. Bainbridge8b179042016-11-30 15:38:42 -0800394 // the password set on the compute node is skipped because this is being run against the
395 // head node and we don't want to change the head node password as this node was manualy
396 // set up.
Zack Williamsb55e8ef2017-02-01 10:54:36 -0700397 def skipTags = [].p(config.common.skipTags).p('set_compute_node_password')
David K. Bainbridge10b0c112016-05-24 13:17:23 -0700398
399 args = args.p(skipTags.asParam("skip-tags", ",")).p(extraVars.asParam("extra-vars", " ")) << "head-node.yml"
David K. Bainbridge10b0c112016-05-24 13:17:23 -0700400}
alshabib462f6252016-08-29 16:15:28 -0700401
402prime.dependsOn {
403 updateDocker
404}
405
406tasks.addRule(new DockerFetchRule(project))
407tasks.addRule(new DockerPublishRule(project, project(':maas').prime))
408tasks.addRule(new DockerTagRule(project))
409
410