blob: 55ae33b9e8bd1fd95e623faebe1cd513c096ab45 (
plain) (
blame)
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
|
// Jenkinsfile utilities
import bconfig.bconfig
// Clone the source repository and examine the most recent commit message.
// If a '[ci skip]' or '[skip ci]' directive is present, immediately
// terminate the job with a success code.
// If no skip directive is found, stash all the source files for efficient retrieval
// by subsequent nodes.
def scm_checkout() {
skip_job = 0
node("on-master") {
stage("Setup") {
checkout(scm)
// Obtain the last commit message and examine it for skip directives.
logoutput = sh(script:"git log -1 --pretty=%B", returnStdout: true).trim()
if (logoutput.contains("[ci skip]") || logoutput.contains("[skip ci]")) {
skip_job = 1
currentBuild.result = 'SUCCESS'
println("\nBuild skipped due to commit message directive.\n")
// System.exit(0) // WARNING: FATAL to Jenkins
return skip_job
//throw new hudson.AbortException('Guess what!')
//throw new java.io.IOException('Guess what!')
}
sh(script: "ls -al")
stash includes: '**/*', name: 'source_tree'
}
}
return skip_job
}
class TClass implements Serializable {
def var = "varvalue"
}
def concurrent2(configs) {
def tasks = [:]
println("Size of configs = ${configs.size()}")
def myconf = new bconfig()
println("myconf.name = ${myconf.name}")
for (config in configs) {
t = new TClass()
println("concurrent2: build.nodetype = ${config.nodetype}")
println("concurrent2: build.build_mode= ${config.build_mode}")
println("concurrent2: build.build_args= ${config.build_args}")
println("concurrent2: build.env_vars= ${config.env_vars}")
def run_tests = config.run_tests
tasks["${config.nodetype}/${config.build_mode}"] = {
node(config.nodetype) {
//withEnv(config.env_vars) {
println("task: build.nodetype = ${config.nodetype}")
println("task: build.build_mode= ${config.build_mode}")
println("task: build.build_args= ${config.build_args}")
println("task: build.env_vars= ${config.env_vars}")
println("task: config.run_tests = ${config.run_tests}")
println("task: run_tests = ${run_tests}")
def prefix = pwd() + "/_install"
stage("Build (${config.build_mode})") {
unstash "source_tree"
sh(script: "ls -al")
} //end stage
stage("Test (${config.build_mode})") {
//if (config.run_tests) {
if (run_tests) {
println("RUNNING TESTS")
}
}
//} //end withEnv
} // end node
}
} //end for
stage("Matrix") {
parallel(tasks)
}
} //end concurrent2
// Allow deep copying of a config object to another instance.
def copy(config) {
return config.createNewInstance()
}
|