source: Jenkins/FullBuild@ e109716

ADT aaron-thesis arm-eh ast-experimental cleanup-dtors ctor deferred_resn demangler enum forall-pointer-decay jacob/cs343-translation jenkins-sandbox memory new-ast new-ast-unique-expr new-env no_list persistent-indexer pthread-emulation qualifiedEnum resolv-new with_gc
Last change on this file since e109716 was e109716, checked in by Thierry Delisle <tdelisle@…>, 9 years ago

added some debug logs to full build script since errors seem uncaught

  • Property mode set to 100644
File size: 4.3 KB
Line 
1#!groovy
2
3//===========================================================================================================
4// Main compilation routines
5//===========================================================================================================
6
7def trigger_build(String arch) {
8 def result = build job: 'Cforall/master', \
9 parameters: [ \
10 [$class: 'BooleanParameterValue', \
11 name: 'isFullBuild', \
12 value: true], \
13 [$class: 'StringParameterValue', \
14 name: 'buildArchitecture', \
15 value: arch] \
16 ]
17
18 echo(result.result)
19 echo(result.absoluteUrl)
20}
21
22def push_build() {
23 //Don't use the build_stage function which outputs the compiler
24 stage 'Push'
25
26 status_prefix = 'Push'
27
28 def out_dir = pwd tmp: true
29 sh "mkdir -p ${out_dir}"
30
31 //checkout the code to make sure this is a valid git repo
32 checkout scm
33
34 collect_git_info()
35
36 //parse git logs to find what changed
37 sh "git remote > ${out_dir}/GIT_REMOTE"
38 git_remote = readFile("${out_dir}/GIT_REMOTE")
39 remoteDoLangExists = git_remote.contains("DoLang")
40
41 if( !remoteDoLangExists ) {
42 sh 'git remote add DoLang git@gitlab.do-lang.org:internal/cfa-cc.git'
43 }
44
45 //sh "GIT_SSH_COMMAND=\"ssh -v\" git push DoLang ${gitRefNewValue}:master"
46 echo('BUILD NOT PUSH SINCE DO-LANG SERVER WAS DOWN')
47}
48
49//Helper routine to collect information about the git history
50def collect_git_info() {
51
52 //create the temporary output directory in case it doesn't already exist
53 def out_dir = pwd tmp: true
54 sh "mkdir -p ${out_dir}"
55
56 //parse git logs to find what changed
57 dir("../Cforall_Full_Build@script") {
58 sh "git reflog > ${out_dir}/GIT_COMMIT"
59 }
60 git_reflog = readFile("${out_dir}/GIT_COMMIT")
61 gitRefOldValue = (git_reflog =~ /moving from (.+) to (.+)/)[0][1]
62 gitRefNewValue = (git_reflog =~ /moving from (.+) to (.+)/)[0][2]
63}
64
65//===========================================================================================================
66// Main loop of the compilation
67//===========================================================================================================
68
69node ('master') {
70 def err = null
71
72 try {
73 //Prevent the build from exceeding 30 minutes
74 timeout(60) {
75
76 //Wrap build to add timestamp to command line
77 wrap([$class: 'TimestamperBuildWrapper']) {
78
79 stage 'Build'
80
81 results = [null, null]
82
83 parallel (
84 x64: {
85 trigger_build('64-bit')
86 },
87 x32: {
88 trigger_build('32-bit')
89 }
90 )
91
92 //Push latest changes to do-lang repo
93 push_build()
94 }
95 }
96 }
97
98 //If an exception is caught we need to change the status and remember to
99 //attach the build log to the email
100 catch (Exception caughtError) {
101 echo('error caught')
102
103 //rethrow error later
104 err = caughtError
105
106 //Store the result of the build log
107 currentBuild.result = "${status_prefix} FAILURE".trim()
108
109 //Send email to notify the failure
110 promote_email(currentBuild.result)
111 }
112
113 finally {
114 //Must re-throw exception to propagate error
115 if (err) {
116 throw err
117 }
118 }
119}
120//===========================================================================================================
121//Routine responsible of sending the email notification once the build is completed
122//===========================================================================================================
123
124//Email notification on a full build failure
125def promote_email(String status) {
126 echo('notifying users')
127
128 //Since tokenizer doesn't work, figure stuff out from the environnement variables and command line
129 //Configurations for email format
130 def email_subject = "[cforall git][PROMOTE - FAILURE]"
131 def email_body = """This is an automated email from the Jenkins build machine. It was
132generated because of a git hooks/post-receive script following
133a ref change was pushed to the repository containing
134the project "UNNAMED PROJECT".
135
136Check console output at ${env.BUILD_URL} to view the results.
137
138- Status --------------------------------------------------------------
139
140PROMOTE FAILURE - ${status}
141"""
142
143 def email_to = "pabuhr@uwaterloo.ca, rschlunt@uwaterloo.ca, a3moss@uwaterloo.ca, tdelisle@uwaterloo.ca, brice.dobry@huawei.com"
144
145 //send email notification
146 emailext body: email_body, subject: email_subject, to: email_to, attachLog: true
147}
Note: See TracBrowser for help on using the repository browser.