-
Notifications
You must be signed in to change notification settings - Fork 249
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
chore_: enable windows and macos CI build
- Added support for Windows and macOS in CI pipelines - Added missing dependencies for Windows and x86-64-darwin - Resolved macOS SDK version compatibility for darwin-x86_64 The `mkShell` override was necessary to ensure compatibility with the newer macOS SDK (version 11.0) for x86_64. The default SDK (10.12) was causing build failures because of the missing libs and frameworks. OverrideSDK creates a mapping from the default SDK in all package categories to the requested SDK (11.0).
- Loading branch information
1 parent
e611b1e
commit 4552288
Showing
8 changed files
with
176 additions
and
99 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,154 @@ | ||
#!/usr/bin/env groovy | ||
library 'status-jenkins-lib@v1.9.12' | ||
|
||
pipeline { | ||
/* This way we run the same Jenkinsfile on different platforms. */ | ||
agent { label "${params.AGENT_LABEL}" } | ||
|
||
parameters { | ||
string( | ||
name: 'BRANCH', | ||
defaultValue: 'develop', | ||
description: 'Name of branch to build.' | ||
) | ||
string( | ||
name: 'AGENT_LABEL', | ||
description: 'Label for targetted CI slave host.', | ||
defaultValue: params.AGENT_LABEL ?: getAgentLabel(), | ||
) | ||
booleanParam( | ||
name: 'RELEASE', | ||
defaultValue: false, | ||
description: 'Enable to create build for release.', | ||
) | ||
} | ||
|
||
options { | ||
timestamps() | ||
ansiColor('xterm') | ||
/* Prevent Jenkins jobs from running forever */ | ||
timeout(time: 15, unit: 'MINUTES') | ||
disableConcurrentBuilds() | ||
/* manage how many builds we keep */ | ||
buildDiscarder(logRotator( | ||
numToKeepStr: '5', | ||
daysToKeepStr: '30', | ||
artifactNumToKeepStr: '1', | ||
)) | ||
} | ||
|
||
environment { | ||
PLATFORM = getPlatformFromLabel(params.AGENT_LABEL) | ||
TMPDIR = "${WORKSPACE_TMP}" | ||
GOPATH = "${WORKSPACE_TMP}/go" | ||
GOCACHE = "${WORKSPACE_TMP}/gocache" | ||
PATH = "${PATH}:${GOPATH}/bin:/c/Users/jenkins/go/bin" | ||
REPO_SRC = "${GOPATH}/src/github.com/status-im/status-go" | ||
VERSION = sh(script: "./_assets/scripts/version.sh", returnStdout: true) | ||
ARTIFACT = utils.pkgFilename( | ||
name: 'status-go', | ||
type: env.PLATFORM, | ||
version: env.VERSION, | ||
ext: 'zip', | ||
) | ||
/* prevent sharing cache dir across different jobs */ | ||
GO_GENERATE_FAST_DIR = "${env.WORKSPACE_TMP}/go-generate-fast" | ||
} | ||
|
||
stages { | ||
stage('Setup') { | ||
steps { | ||
script { | ||
if (env.PLATFORM != 'windows') { | ||
sh "mkdir -p \$(dirname ${REPO_SRC})" | ||
sh "ln -s ${WORKSPACE} ${REPO_SRC}" | ||
} | ||
} | ||
} | ||
} | ||
|
||
stage('Deps') { | ||
steps { script { | ||
shell('make status-go-deps') | ||
} | ||
} | ||
} | ||
|
||
stage('Generate') { | ||
steps { script { | ||
shell('make generate') | ||
} | ||
} | ||
} | ||
|
||
stage('Build Static Lib') { | ||
steps { | ||
script { | ||
shell('make statusgo-library') | ||
} | ||
} | ||
} | ||
|
||
stage('Build Shared Lib') { | ||
steps { | ||
script { | ||
shell('make statusgo-shared-library') | ||
} | ||
} | ||
} | ||
|
||
stage('Archive') { | ||
steps { | ||
zip zipFile: "${ARTIFACT}", archive: true, dir: 'build/bin' | ||
} | ||
} | ||
|
||
stage('Upload') { | ||
steps { | ||
script { | ||
env.PKG_URL = s5cmd.upload(ARTIFACT) | ||
} | ||
} | ||
} | ||
} // stages | ||
post { | ||
success { script { github.notifyPR(true) } } | ||
failure { script { github.notifyPR(false) } } | ||
cleanup { | ||
cleanWs() | ||
dir("${env.WORKSPACE}@tmp") { cleanWs() } | ||
} | ||
} // post | ||
} // pipeline | ||
|
||
/* This allows us to use one Jenkinsfile and run | ||
* jobs on different platforms based on job name. */ | ||
def getAgentLabel() { | ||
if (params.AGENT_LABEL) { return params.AGENT_LABEL } | ||
/* We extract the name of the job from currentThread because | ||
* before an agent is picket env is not available. */ | ||
def tokens = Thread.currentThread().getName().split('/') | ||
def labels = [] | ||
/* Check if the job path contains any of the valid labels. */ | ||
['linux', 'macos', 'windows', 'x86_64', 'aarch64', 'arm64'].each { | ||
if (tokens.contains(it)) { labels.add(it) } | ||
} | ||
return labels.join(' && ') | ||
} | ||
|
||
/* This function extracts the platform from the AGENT_LABEL */ | ||
def getPlatformFromLabel(label) { | ||
for (platform in ['linux', 'macos', 'windows']) { | ||
if (label.contains(platform)) { | ||
return platform | ||
} | ||
} | ||
} | ||
|
||
def shell(cmd) { | ||
if (env.PLATFORM == 'windows') { | ||
sh "${cmd} SHELL=/bin/sh" | ||
} else { | ||
nix.shell(cmd, pure: false) // Use nix.shell for Linux/macOS | ||
} | ||
} |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
Jenkinsfile.desktop |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
Jenkinsfile.desktop |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
Jenkinsfile.desktop |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters