library 'status-react-jenkins@v1.1.1' pipeline { agent { label 'linux' } parameters { string( name: 'BUILD_TYPE', description: 'Specify build type. Values: pr / nightly / release', defaultValue: 'pr', ) } options { timestamps() /* Prevent Jenkins jobs from running forever */ timeout(time: 45, unit: 'MINUTES') /* Limit builds retained */ buildDiscarder(logRotator( numToKeepStr: '10', daysToKeepStr: '20', artifactNumToKeepStr: '10', )) } /** * WARNING: Jenkins ignores PATH changes in Docker * https://issues.jenkins-ci.org/browse/JENKINS-49076 **/ environment { LANG = "en_US.UTF-8" LC_ALL = "en_US.UTF-8" LANGUAGE = "en_US.UTF-8" TARGET = 'windows' NIX_CONF_DIR = "${env.WORKSPACE}/nix" VERBOSE_LEVEL = '3' /* Conan settings */ CONAN_PRINT_RUN_COMMANDS = '1' CONAN_SYSREQUIRES_MODE = 'disabled' CONAN_SYSREQUIRES_SUDO = '0' /* We use EXECUTOR_NUMBER to avoid multiple instances clashing */ YARN_CACHE_FOLDER = "/var/tmp/yarn-${EXECUTOR_NUMBER}" } stages { stage('Prep') { steps { script { btype = utils.getBuildType() print "Running ${btype} build!" jenkins.abortPreviousRunningBuilds() /* Cleanup and Prep */ commonPrep(btype) } } } stage('Parallel Assemble') { parallel { stage('Checks') { stages { stage('Lint') { steps { script { /* We want the build result to be uploaded */ catchError( message: 'Linting check failed!', buildResult: 'FAILURE', stageResult: 'FAILURE' ) { sh 'make lint' } } } } stage('Tests') { steps { script { sh 'make test' } } } } } stage('Build') { stages { stage('JSBundle') { steps { script { desktop.buildJSBundle() } } } stage('Compile') { steps { script { desktop.compile() } } } stage('Bundle') { steps { script { app = desktop.bundleWindows(btype) } } } } } } } stage('Parallel Upload') { parallel { stage('Archive') { steps { archiveArtifacts app } } stage('Upload') { steps { script { env.PKG_URL = s3.uploadArtifact(app) } } } } } stage('Cleanup') { steps { sh 'make watchman-clean' sh 'make clean' } } } post { success { script { github.notifyPR(true) } } failure { script { github.notifyPR(false) } } } }