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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
|
this.build_status_file = "${this.parent_workspace}/propagated_build_status"
node(this.label) {
dir(this.parent_workspace) {
env.PATH = "${this.parent_workspace}/miniconda/bin/:" + "${env.PATH}"
env.PYTHONPATH = ""
// Make the log files a bit more deterministic
env.PYTHONUNBUFFERED = "true"
def time = new Date()
sh "env | sort"
println("\n" +
" Package Build Info Summary:\n" +
"${time}\n" +
"JOB_DEF_GENERATION_TIME: ${JOB_DEF_GENERATION_TIME}\n" +
"this.Nodelabel: ${this.label}\n" +
"env.JOB_BASE_NAME: ${env.JOB_BASE_NAME}\n" +
"env.JOB_NAME: ${env.JOB_NAME}\n" +
"env.BUILD_NUMBER: ${env.BUILD_NUMBER}\n" +
"env.NODE_NAME: ${env.NODE_NAME}\n" +
"env.WORKSPACE: ${env.WORKSPACE}\n" +
"env.JENKINS_HOME: ${env.JENKINS_HOME}\n" +
"parameter build_control_repo: ${this.build_control_repo}\n" +
"parameter build_control_branch: ${this.build_control_branch}\n" +
"parameter build_control_tag: ${this.build_control_tag}\n" +
"parameter parent_workspace: ${this.parent_workspace}\n" +
"parameter py_version: ${this.py_version}\n" +
"parameter numpy_version: ${this.numpy_version}\n" +
"parameter cull_manifest: ${this.cull_manifest}\n" +
"parameter channel_URL: ${this.channel_URL}\n" +
"PATH: ${env.PATH}\n" +
"PYTHONPATH: ${env.PYTHONPATH}\n" +
"PYTHONUNBUFFERED: ${env.PYTHONUNBUFFERED}\n")
def build_status = readFile this.build_status_file
build_status = build_status.trim()
// In the directory common to all package build jobs,
// run conda build --dirty for this package to use any existing work
// directory or source trees already obtained.
dir("conda-recipes") {
cmd = "conda build"
// Use channel URL obtained from manifest in build command if
// manifest has been culled to allow packages being built to
// simply download dependency packages from the publication
// channel as needed, rather than build them as part of the
// package build session that requires them.
def channel_option = "--channel ${this.channel_URL}"
stage("Build") {
if (this.cull_manifest == "false") {
channel_option = ""
}
build_cmd = cmd
args = ["--no-test",
"--no-anaconda-upload",
"--python=${this.py_version}",
"--numpy=${this.numpy_version}",
"--skip-existing",
"--override-channels",
"--channel defaults",
"${channel_option}",
"--dirty"]
for (arg in args) {
build_cmd = "${build_cmd} ${arg}"
}
stat = 999
stat = sh(script: "${build_cmd} ${env.JOB_BASE_NAME}",
returnStatus: true)
if (stat != 0) {
currentBuild.result = "FAILURE"
// Ratchet up the overall build status severity if this
// is the most severe seen so far.
if (build_status != "FAILURE") {
sh "echo ${currentBuild.result} > ${this.build_status_file}"
}
}
}
// Skip test stage if build stage has failed.
if (currentBuild.result != "FAILURE") {
stage("Test") {
build_cmd = cmd
args = ["--test",
"--python=${this.py_version}",
"--numpy=${this.numpy_version}",
"--override-channels",
"--channel defaults",
"${channel_option}"]
for (arg in args) {
build_cmd = "${build_cmd} ${arg}"
}
stat = 999
stat = sh(script: "${build_cmd} ${env.JOB_BASE_NAME}",
returnStatus: true)
if (stat != 0) {
currentBuild.result = "UNSTABLE"
// Ratchet up the overall build status severity if this
// is the most severe seen so far.
if (build_status == "SUCCESS") {
sh "echo ${currentBuild.result} > ${this.build_status_file}"
}
}
}
}
} // end dir
}
} //end node
|