diff --git a/services/web/Jenkinsfile b/services/web/Jenkinsfile index 721ede90a8..cb8c4c23d0 100644 --- a/services/web/Jenkinsfile +++ b/services/web/Jenkinsfile @@ -1,19 +1,37 @@ String cron_string = BRANCH_NAME == "master" ? "@daily" : "" pipeline { - + agent any - + environment { HOME = "/tmp" + GIT_PROJECT = "web-sharelatex-internal" + JENKINS_WORKFLOW = "web-sharelatex-internal" + TARGET_URL = "${env.JENKINS_URL}blue/organizations/jenkins/${JENKINS_WORKFLOW}/detail/$BRANCH_NAME/$BUILD_NUMBER/pipeline" + GIT_API_URL = "https://api.github.com/repos/sharelatex/${GIT_PROJECT}/statuses/$GIT_COMMIT" } - + triggers { pollSCM('* * * * *') cron(cron_string) } - + stages { + stage('Pre') { + steps { + withCredentials([usernamePassword(credentialsId: 'GITHUB_INTEGRATION', usernameVariable: 'GH_AUTH_USERNAME', passwordVariable: 'GH_AUTH_PASSWORD')]) { + sh "curl $GIT_API_URL \ + --data '{ \ + \"state\" : \"pending\", \ + \"target_url\": \"$TARGET_URL\", \ + \"description\": \"Your build is underway\", \ + \"context\": \"ci/jenkins\" }' \ + -u $GH_AUTH_USERNAME:$GH_AUTH_PASSWORD" + } + } + } + stage('Install modules') { steps { sshagent (credentials: ['GIT_DEPLOY_KEY']) { @@ -21,7 +39,7 @@ pipeline { } } } - + stage('Install') { agent { docker { @@ -66,7 +84,7 @@ pipeline { sh 'make --no-print-directory lint' } } - + stage('Test and Minify') { parallel { stage('Unit Test') { @@ -80,7 +98,7 @@ pipeline { sh 'make --no-print-directory test_unit MOCHA_ARGS="--reporter tap"' } } - + stage('Acceptance Test') { steps { // Spawns its own docker containers @@ -108,7 +126,7 @@ pipeline { sh 'make --no-print-directory test_frontend' } } - + stage('Package') { steps { sh 'rm -rf ./node_modules/grunt*' @@ -117,7 +135,7 @@ pipeline { sh 'tar -czf build.tar.gz --exclude=build.tar.gz --exclude-vcs .' } } - + stage('Publish') { steps { withAWS(credentials:'S3_CI_BUILDS_AWS_KEYS', region:"${S3_REGION_BUILD_ARTEFACTS}") { @@ -127,8 +145,8 @@ pipeline { } } } - - + + stage('Sync OSS') { when { branch 'master' @@ -140,29 +158,50 @@ pipeline { } } } - + post { always { sh 'make clean_ci' } + success { + withCredentials([usernamePassword(credentialsId: 'GITHUB_INTEGRATION', usernameVariable: 'GH_AUTH_USERNAME', passwordVariable: 'GH_AUTH_PASSWORD')]) { + sh "curl $GIT_API_URL \ + --data '{ \ + \"state\" : \"success\", \ + \"target_url\": \"$TARGET_URL\", \ + \"description\": \"Your build succeeded!\", \ + \"context\": \"ci/jenkins\" }' \ + -u $GH_AUTH_USERNAME:$GH_AUTH_PASSWORD" + } + } + failure { - mail(from: "${EMAIL_ALERT_FROM}", - to: "${EMAIL_ALERT_TO}", + mail(from: "${EMAIL_ALERT_FROM}", + to: "${EMAIL_ALERT_TO}", subject: "Jenkins build failed: ${JOB_NAME}:${BUILD_NUMBER}", body: "Build: ${BUILD_URL}") + withCredentials([usernamePassword(credentialsId: 'GITHUB_INTEGRATION', usernameVariable: 'GH_AUTH_USERNAME', passwordVariable: 'GH_AUTH_PASSWORD')]) { + sh "curl $GIT_API_URL \ + --data '{ \ + \"state\" : \"failure\", \ + \"target_url\": \"$TARGET_URL\", \ + \"description\": \"Your build failed\", \ + \"context\": \"ci/jenkins\" }' \ + -u $GH_AUTH_USERNAME:$GH_AUTH_PASSWORD" + } } } - + // The options directive is for configuration that applies to the whole job. options { // Only build one at a time disableConcurrentBuilds() - + // we'd like to make sure remove old builds, so we don't fill up our storage! buildDiscarder(logRotator(numToKeepStr:'50')) - + // And we'd really like to be sure that this build doesn't hang forever, so let's time it out after: timeout(time: 30, unit: 'MINUTES') }