source: Jenkinsfile @ 40b1df9

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

Jenkins now builds using gcc-4.9, gcc-5, gcc-6

  • Property mode set to 100644
File size: 4.9 KB
RevLine 
[c9d651d]1
[29f4fe62]2//===========================================================================================================
3// Main compilation routine
4//===========================================================================================================
5//Compilation script is done here but environnement set-up and error handling is done in main loop
[371fd1b]6def cfa_build() {
[77f347d]7        build_stage 'Checkout'
[992c26d]8                def install_dir = pwd tmp: true
[77f347d]9                //checkout the source code and clean the repo
10                checkout scm
[01b8088d]11                sh 'git clean -fdqx'
12                sh 'git reset --hard'
[23a14d86]13
[77f347d]14        build_stage 'Build'
[7aebc62]15
[77f347d]16                //Configure the conpilation (Output is not relevant)
17                //Use the current directory as the installation target so nothing
18                //escapes the sandbox
19                //Also specify the compiler by hand
[8f6b229]20                sh "./configure CXX=${currentCC.cpp_cc} --with-backend-compiler=${currentCC.cfa_backend_cc} --prefix=${install_dir} > /dev/null"
[fde808df]21
[77f347d]22                //Compile the project
23                sh 'make -j 8 install'
[fde808df]24
[77f347d]25        build_stage 'Test'
[fde808df]26
[29f4fe62]27                //Run the tests from the example directory
[77f347d]28                dir ('src/examples') {
29                        sh './runTests.sh'
30                }
[fde808df]31
[77f347d]32        build_stage 'Cleanup'
[7359098]33
[86f641b]34                //do a maintainer-clean to make sure we need to remake from scratch
35                sh 'make maintainer-clean > /dev/null'
[77f347d]36}
[7359098]37
[29f4fe62]38//===========================================================================================================
39// Helper classes/variables/routines to make the status and stage name easier to use
40//===========================================================================================================
[e730560]41//Description of a compiler (Must be serializable since pipelines are persistent)
42class CC_Desc implements Serializable {
[8f6b229]43        public String cc_name
44        public String cpp_cc
45        public String cfa_backend_cc
[f25bcb6]46
47        CC_Desc(String cc_name, String cpp_cc, String cfa_backend_cc) {
48                this.cc_name = cc_name
49                this.cpp_cc = cpp_cc
50                this.cfa_backend_cc = cfa_backend_cc
51        }
[992c26d]52}
53
[29f4fe62]54//Global Variables defining the compiler and at which point in the build we are
[aec9a67]55// These variables are used but can't be declared before hand because of wierd scripting rules
56// @Field String currentCC
57// @Field String status_prefix
[fde808df]58
[29f4fe62]59//Wrapper to sync stage name and status name
[77f347d]60def build_stage(String name) {
[8f6b229]61        def stage_name = "${currentCC.cc_name} ${name}".trim()
[77f347d]62        stage stage_name
[fde808df]63
[77f347d]64                status_prefix = stage_name
65}
[fde808df]66
[29f4fe62]67//===========================================================================================================
68// Main loop of the compilation
69//===========================================================================================================
[77f347d]70node ('master'){
[fde808df]71
[77f347d]72        def err = null
73        def log_needed = false
74        currentBuild.result = "SUCCESS"
75
76        try {
[0207e71]77                //Prevent the build from exceeding 30 minutes
78                timeout(30) {
[40b1df9]79
[37bf576]80                        //Wrap build to add timestamp to command line
81                        wrap([$class: 'TimestamperBuildWrapper']) {
[29f4fe62]82
83                                //Compile using gcc-4.9
[f979c4a]84                                currentCC = new CC_Desc('gcc-4.9', 'g++-4.9', 'gcc-4.9')
[371fd1b]85                                cfa_build()
[29f4fe62]86
[40b1df9]87                                //Compile using gcc-5
88                                currentCC = new CC_Desc('gcc-5', 'g++-5', 'gcc-5')
89                                cfa_build()
90
91                                //Compile using gcc-4.9
92                                currentCC = new CC_Desc('gcc-6', 'g++-6', 'gcc-6')
93                                cfa_build()
94
[37bf576]95                        }
[0207e71]96                }
[fde808df]97
[f43a200]98        }
99
[29f4fe62]100        //If an exception is caught we need to change the status and remember to
101        //attach the build log to the email
[fde808df]102        catch (Exception caughtError) {
[29f4fe62]103                //rethrow error later
[fde808df]104                err = caughtError
[29f4fe62]105
106                //An error has occured, the build log is relevent
[b287f67]107                log_needed = true
[29f4fe62]108
109                //Store the result of the build log
[992c26d]110                currentBuild.result = "${status_prefix} FAILURE".trim()
[fde808df]111        }
112
113        finally {
114                //Send email with final results
115                email(currentBuild.result, log_needed)
116
117                /* Must re-throw exception to propagate error */
118                if (err) {
119                        throw err
120                }
[d3d0069]121        }
[7aebc62]122}
[f2b977a]123
[29f4fe62]124//===========================================================================================================
125//Routine responsible of sending the email notification once the build is completed
126//===========================================================================================================
[19ad15b]127def email(String status, boolean log) {
[e8a22a7]128        //Since tokenizer doesn't work, figure stuff out from the environnement variables and command line
129        //Configurations for email format
130        def project_name = (env.JOB_NAME =~ /(.+)\/.+/)[0][1].toLowerCase()
131
[992c26d]132        def email_subject = "[${project_name} git][BUILD# ${env.BUILD_NUMBER} - ${status}] - branch ${env.BRANCH_NAME}"
[848fb00]133        def email_body = """This is an automated email from the Jenkins build machine. It was
134generated because of a git hooks/post-receive script following
135a ref change was pushed to the repository containing
136the project "UNNAMED PROJECT".
[e8a22a7]137
[848fb00]138The branch ${env.BRANCH_NAME} has been updated.
[e8a22a7]139
[848fb00]140Check console output at ${env.BUILD_URL} to view the results."""
[e8a22a7]141
[a6b7480]142        // def config = new File('/u/cforall/software/cfa/cfa-cc/config').text
143        // def email_to = (config =~ /mailinglist ?= ?(.+)/)[0][1]
144        def email_to = "pabuhr@uwaterloo.ca, rschlunt@uwaterloo.ca, a3moss@uwaterloo.ca, tdelisle@uwaterloo.ca, brice.dobry@huawei.com"
[e8a22a7]145
146        //send email notification
[1e34653]147        emailext body: email_body, subject: email_subject, to: email_to, attachLog: log
[e8a22a7]148}
Note: See TracBrowser for help on using the repository browser.