forked from cloudbees/jenkins-scripts
-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathupdateJobs-fromTemplateA2TemplateB.groovy
69 lines (64 loc) · 3.68 KB
/
updateJobs-fromTemplateA2TemplateB.groovy
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
/*
Author: Dario Villadiego, Carlos Rodriguez Lopez
Since: July 2017
Description: It finds all the jobs in CJE instance based on "Template_A" and update those to "Template_B". On its way, it migrates Properties from "Template_A" to "Template_B".
Scope: Cloudbees Jenkins Enterprise
*/
import com.cloudbees.hudson.plugins.modeling.ModelList
import com.cloudbees.hudson.plugins.modeling.impl.jobTemplate.InstanceFromJobTemplate
import com.cloudbees.hudson.plugins.modeling.impl.jobTemplate.JobPropertyImpl
// Job Templates - Names
def NEW_JOB_TEMPLATE = 'Job-Template2'
def OLD_JOB_TEMPLATE = 'Job-Template1'
// Job Templates - Property JOB_NAME_PROP. It is the default parameters for jobs templates
def JOB_NAME_PROP = 'name'
// Job Templates - Property - Others:
def NEW_JOB_TEMPLATE_PROP = 'Job-Template2-prop'
def OLD_JOB_TEMPLATE_PROP ='Job-Template1-prop'
def InstanceFromJobTemplate itemIntFJTempl, newIntFJTempl = null
def numberOfJobUpdated = 0
def name2migrate = ''
def repo2migrate = ''
//1. Checking that NEW_JOB_TEMPLATE and OLD_JOB_TEMPLATE are currently included in the instance's Model List
if (ModelList.get().getItem(OLD_JOB_TEMPLATE) != null && ModelList.get().getItem(NEW_JOB_TEMPLATE) != null) {
// 2. Retrieving all the job items from the current Jenkins instance
Jenkins.instance.items.findAll { job ->
itemIntFJTempl = InstanceFromJobTemplate.from(job)
//3. Filtering job items based on templates and from those, the ones with the model name $OLD_JOB_TEMPLATE
if (itemIntFJTempl != null && itemIntFJTempl.model.name == OLD_JOB_TEMPLATE) {
//4. Checking that properties from $OLD_JOB_TEMPLATE exist
if (itemIntFJTempl.getValue(JOB_NAME_PROP)!=null && itemIntFJTempl.getValue(OLD_JOB_TEMPLATE_PROP)!=null){
//5. Getting parameters values from $OLD_JOB_TEMPLATE
name2migrate = itemIntFJTempl.getValue(JOB_NAME_PROP)
repo2migrate = itemIntFJTempl.getValue(OLD_JOB_TEMPLATE_PROP)
//6. Create a new Instance from the Job Template $NEW_JOB_TEMPLATE
newIntFJTempl = new InstanceFromJobTemplate(ModelList.get().getItem(NEW_JOB_TEMPLATE))
//7. Assigning new template (6) to the job item
job.addProperty(new JobPropertyImpl(newIntFJTempl))
//8. Migrating parameters from $OLD_JOB_TEMPLATE to the $NEW_JOB_TEMPLATE instance
// 8.1 Job Templates - Property JOB_NAME_PROP
newIntFJTempl.setValue(JOB_NAME_PROP, name2migrate)
try {
// 8.2 Job Templates - Property - Others
newIntFJTempl.setValue(NEW_JOB_TEMPLATE_PROP, repo2migrate)
//9. Saving the instance (6) in order changes take place
newIntFJTempl.save()
//10. Checking final value
itemIntFJTempl = InstanceFromJobTemplate.from(job)
println "[INFO] Job '${job.name}' change template to '${itemIntFJTempl.model.name}' template\n\n"
numberOfJobUpdated++
}catch (IllegalArgumentException e){
println "[ERROR] Any of the '$NEW_JOB_TEMPLATE' properties are not correct"
}
catch (Exception e){
println "[ERROR] "+ e.toString()
}
} else {
println "[ERROR] Any of the '$OLD_JOB_TEMPLATE' properties are not correct"
}
} // end of step 3
} // end of step 2
println "[INFO] Total number of updated template-based jobs : $numberOfJobUpdated"
} else {
println "[ERROR] The '$OLD_JOB_TEMPLATE' and/or '$NEW_JOB_TEMPLATE' are not included into the Model List"
}