-
Notifications
You must be signed in to change notification settings - Fork 25
/
MultiBranchJob.groovy
89 lines (77 loc) · 2.35 KB
/
MultiBranchJob.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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
package org.centos.contra.jobdsl
class MultiBranchJob {
def job
MultiBranchJob(def job, String name) {
this.job = job.multibranchPipelineJob(name)
}
/**
* Add a gitHub branch source
* @param repoName
* @param owner
* @param credentials - optional
*/
void addGitHub(String repoName, String owner, String credentials = null) {
job.with {
branchSources {
github {
if (credentials) {
scanCredentialsId(credentials)
}
repoOwner(owner)
repository(repoName)
}
}
}
}
/**
* How long to keep orphaned branches around
* @param days
*/
void discardOldBranches(def days = 7) {
job.with {
orphanedItemStrategy {
discardOldItems {
numToKeep(days)
}
}
}
}
/**
* Add property to trigger job on a specific comment
* @param comment
* @return
*/
def addComment(String comment) {
job.with {
configure {
it / sources / 'data' / 'jenkins.branch.BranchSource' << {
strategy(class: 'jenkins.branch.DefaultBranchPropertyStrategy') {
properties(class: 'java.util.Arrays$ArrayList') {
a(class: 'jenkins.branch.BranchProperty-array') {
if (comment == "\\[merge\\]") {
'jenkins.branch.NoTriggerBranchProperty'()
}
'com.adobe.jenkins.github__pr__comment__build.TriggerPRCommentBranchProperty' {
commentBody(comment)
}
}
}
}
}
}
}
}
/**
* Change default Jenkinsfile path/name
* @param pipelineScript
*/
void addScriptPath(String pipelineScript) {
job.with {
configure {
it / factory(class: "org.jenkinsci.plugins.workflow.multibranch.WorkflowBranchProjectFactory") << {
scriptPath(pipelineScript)
}
}
}
}
}