source: Jenkins/FullBuild @ 5ee0482

ADTaaron-thesisarm-ehast-experimentalcleanup-dtorsctordeferred_resndemanglerenumforall-pointer-decayjacob/cs343-translationjenkins-sandboxmemorynew-astnew-ast-unique-exprnew-envno_listpersistent-indexerpthread-emulationqualifiedEnumresolv-newwith_gc
Last change on this file since 5ee0482 was 5ee0482, checked in by Thierry Delisle <tdelisle@…>, 8 years ago

Last fix was incorrect, groovy script has weird syntax...

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