#!/usr/bin/env groovy library 'status-jenkins-lib@v1.9.6' /* Options section can't access functions in objects. */ def isPRBuild = utils.isPRBuild() def isNightlyBuild = utils.isNightlyBuild() pipeline { agent { /* Necessary image with Ubuntu 20.04 for older Glibc. */ docker { label 'linux' image 'statusteam/nim-status-client-build:1.4.1-qt5.15.2' /* allows jenkins use cat and mounts '/dev/fuse' for linuxdeployqt */ args '--entrypoint="" --cap-add SYS_ADMIN --security-opt apparmor:unconfined --device /dev/fuse' } } parameters { booleanParam( name: 'RELEASE', description: 'Decides whether release credentials are used.', defaultValue: params.RELEASE ?: false ) booleanParam( name: 'INCLUDE_DEBUG_SYMBOLS', description: 'Decides whether binaries are built with debug symbols.', defaultValue: params.INCLUDE_DEBUG_SYMBOLS ?: false ) choice( name: 'VERBOSE', description: 'Level of verbosity based on nimbus-build-system setup.', choices: ['0', '1', '2'] ) string( name: 'NIMFLAGS', description: 'Extra Nim flags. Examples: --verbosity:2 --passL:"-v" --passC:"-v"', defaultValue: '--colors:off' ) booleanParam( name: 'USE_MOCKED_KEYCARD_LIB', description: 'Decides whether the mocked status-keycard-go library is built.', defaultValue: false ) } options { timestamps() /* Prevent Jenkins jobs from running forever */ timeout(time: 25, unit: 'MINUTES') /* manage how many builds we keep */ buildDiscarder(logRotator( numToKeepStr: '10', daysToKeepStr: '30', artifactNumToKeepStr: '1', )) /* Allows combined build to copy */ copyArtifactPermission('/status-desktop/*') /* Abort old PR builds. */ disableConcurrentBuilds( abortPrevious: isPRBuild ) } environment { PLATFORM = "linux/${getArch()}" /* Improve make performance */ MAKEFLAGS = "-j4 V=${params.VERBOSE}" /* Makefile assumes the compiler folder is included */ QTDIR = "/opt/qt/5.15.2/gcc_64" PATH = "${env.QTDIR}/bin:${env.PATH}" /* Avoid weird bugs caused by stale cache. */ QML_DISABLE_DISK_CACHE = "true" /* Control output the filename */ STATUS_CLIENT_APPIMAGE = "pkg/${utils.pkgFilename(ext: 'AppImage', arch: getArch())}" STATUS_CLIENT_TARBALL = "pkg/${utils.pkgFilename(ext: 'tar.gz', arch: getArch())}" STATUS_BUILD_PROXY_STAGE_NAME = "${utils.isReleaseBuild() ? 'prod' : 'test'}" } stages { stage('Deps') { steps { sh 'make update' sh 'make deps' } } stage('status-go') { steps { sh 'make status-go' } } stage('Package') { steps { script { linux.bundle('tgz-linux') } } } stage('Parallel Upload') { parallel { stage('Upload') { steps { script { env.PKG_URL = s3.uploadArtifact(env.STATUS_CLIENT_TARBALL) jenkins.setBuildDesc(AppImage: env.PKG_URL) } } } stage('Archive') { steps { script { archiveArtifacts("${env.STATUS_CLIENT_TARBALL}*") } } } } } stage('E2E') { when { expression { utils.isPRBuild() } } steps { script { build( job: 'status-desktop/e2e/prs', wait: false, parameters: jenkins.mapToParams([ GIT_REF: env.GIT_COMMIT, BUILD_SOURCE: env.JOB_NAME, ]), ) } } } } post { success { script { github.notifyPR(true) } } failure { script { github.notifyPR(false) } } cleanup { sh './scripts/clean-git.sh' } } } def getArch() { def tokens = Thread.currentThread().getName().split('/') for (def arch in ['x86_64', 'aarch64']) { if (tokens.contains(arch)) { return arch } } }