source: Jenkins/FullBuild@ 920725d

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 920725d was 920725d, checked in by Thierry Delisle <tdelisle@…>, 9 years ago

Full build now properly collects git information before attempting to push

  • Property mode set to 100644
File size: 4.2 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 push DoLang ${gitRefNewValue}:master"
46}
47
48//Helper routine to collect information about the git history
49def collect_git_info() {
50
51 //create the temporary output directory in case it doesn't already exist
52 def out_dir = pwd tmp: true
53 sh "mkdir -p ${out_dir}"
54
55 //parse git logs to find what changed
56 gitRefName = env.BRANCH_NAME
57 dir("../${gitRefName}@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 try {
71 //Prevent the build from exceeding 30 minutes
72 timeout(60) {
73
74 //Wrap build to add timestamp to command line
75 wrap([$class: 'TimestamperBuildWrapper']) {
76
77 stage 'Build'
78
79 results = [null, null]
80
81 parallel (
82 x64: {
83 trigger_build('64-bit')
84 },
85 x32: {
86 trigger_build('32-bit')
87 }
88 )
89
90 //Push latest changes to do-lang repo
91 push_build()
92 }
93 }
94 }
95
96 //If an exception is caught we need to change the status and remember to
97 //attach the build log to the email
98 catch (Exception caughtError) {
99 //rethrow error later
100 err = caughtError
101
102 //Store the result of the build log
103 currentBuild.result = "${status_prefix} FAILURE".trim()
104
105 //Send email to notify the failure
106 promote_email(currentBuild.result)
107 }
108
109 finally {
110 //Must re-throw exception to propagate error
111 if (err) {
112 throw err
113 }
114 }
115}
116//===========================================================================================================
117//Routine responsible of sending the email notification once the build is completed
118//===========================================================================================================
119
120//Email notification on a full build failure
121def promote_email(String status) {
122 //Since tokenizer doesn't work, figure stuff out from the environnement variables and command line
123 //Configurations for email format
124 def email_subject = "[cforall git][PROMOTE - FAILURE]"
125 def email_body = """This is an automated email from the Jenkins build machine. It was
126generated because of a git hooks/post-receive script following
127a ref change was pushed to the repository containing
128the project "UNNAMED PROJECT".
129
130Check console output at ${env.BUILD_URL} to view the results.
131
132- Status --------------------------------------------------------------
133
134PROMOTE FAILURE - ${status}
135"""
136
137 def email_to = "pabuhr@uwaterloo.ca, rschlunt@uwaterloo.ca, a3moss@uwaterloo.ca, tdelisle@uwaterloo.ca, brice.dobry@huawei.com"
138
139 //send email notification
140 emailext body: email_body, subject: email_subject, to: email_to, attachLog: true
141}
Note: See TracBrowser for help on using the repository browser.