Add publish jobs for CircleCI releases

This commit is contained in:
John Kleinschmidt 2018-09-27 10:58:57 -04:00 committed by Samuel Attard
parent cba749e305
commit 3643ce5f85
2 changed files with 130 additions and 112 deletions

View file

@ -25,6 +25,9 @@ env-testing-build: &env-testing-build
env-release-build: &env-release-build env-release-build: &env-release-build
GN_CONFIG: //electron/build/args/release.gn GN_CONFIG: //electron/build/args/release.gn
NOTIFY_SLACK: true NOTIFY_SLACK: true
env-publish-build: &env-publish-build
GN_CONFIG: //electron/build/args/release.gn
ELECTRON_RELEASE: 1 ELECTRON_RELEASE: 1
env-browsertests: &env-browsertests env-browsertests: &env-browsertests
@ -44,11 +47,13 @@ env-arm: &env-arm
GCLIENT_EXTRA_ARGS: '--custom-var=checkout_arm=True' GCLIENT_EXTRA_ARGS: '--custom-var=checkout_arm=True'
GN_EXTRA_ARGS: 'target_cpu = "arm"' GN_EXTRA_ARGS: 'target_cpu = "arm"'
MKSNAPSHOT_TOOLCHAIN: //build/toolchain/linux:clang_arm MKSNAPSHOT_TOOLCHAIN: //build/toolchain/linux:clang_arm
BUILD_NATIVE_MKSNAPSHOT: 1
env-arm64: &env-arm64 env-arm64: &env-arm64
GCLIENT_EXTRA_ARGS: '--custom-var=checkout_arm64=True' GCLIENT_EXTRA_ARGS: '--custom-var=checkout_arm64=True'
GN_EXTRA_ARGS: 'target_cpu = "arm64" fatal_linker_warnings = false enable_linux_installer = false' GN_EXTRA_ARGS: 'target_cpu = "arm64" fatal_linker_warnings = false enable_linux_installer = false'
MKSNAPSHOT_TOOLCHAIN: //build/toolchain/linux:clang_arm64 MKSNAPSHOT_TOOLCHAIN: //build/toolchain/linux:clang_arm64
BUILD_NATIVE_MKSNAPSHOT: 1
env-mas: &env-mas env-mas: &env-mas
GN_EXTRA_ARGS: 'is_mas_build = true' GN_EXTRA_ARGS: 'is_mas_build = true'
@ -110,9 +115,11 @@ step-setup-env-for-build: &step-setup-env-for-build
# To find `gn` executable. # To find `gn` executable.
echo 'export CHROMIUM_BUILDTOOLS_PATH="'"$PWD"'/src/buildtools"' >> $BASH_ENV echo 'export CHROMIUM_BUILDTOOLS_PATH="'"$PWD"'/src/buildtools"' >> $BASH_ENV
if [ "$ELECTRON_RELEASE" != "1" ]; then
# https://github.com/mozilla/sccache # https://github.com/mozilla/sccache
SCCACHE_PATH="$PWD/src/electron/external_binaries/sccache" SCCACHE_PATH="$PWD/src/electron/external_binaries/sccache"
echo 'export SCCACHE_PATH="'"$SCCACHE_PATH"'"' >> $BASH_ENV echo 'export SCCACHE_PATH="'"$SCCACHE_PATH"'"' >> $BASH_ENV
fi
step-install-nodejs-on-mac: &step-install-nodejs-on-mac step-install-nodejs-on-mac: &step-install-nodejs-on-mac
run: run:
@ -128,7 +135,11 @@ step-electron-gn-gen: &step-electron-gn-gen
name: Electron GN gen name: Electron GN gen
command: | command: |
cd src cd src
if [ "$ELECTRON_RELEASE" == "1" ]; then
gn gen out/Default --args='import("'$GN_CONFIG'")'" $GN_EXTRA_ARGS"
else
gn gen out/Default --args='import("'$GN_CONFIG'") cc_wrapper="'"$SCCACHE_PATH"'"'" $GN_EXTRA_ARGS" gn gen out/Default --args='import("'$GN_CONFIG'") cc_wrapper="'"$SCCACHE_PATH"'"'" $GN_EXTRA_ARGS"
fi
step-electron-build: &step-electron-build step-electron-build: &step-electron-build
run: run:
@ -179,10 +190,6 @@ step-persist-data-for-tests: &step-persist-data-for-tests
# Build artifacts # Build artifacts
- src/out/Default/dist.zip - src/out/Default/dist.zip
- src/out/Default/gen/node_headers - src/out/Default/gen/node_headers
- src/out/Default/chromedriver.zip
- src/out/Default/dsym.zip
- src/out/Default/symbols.zip
- src/out/Default/mksnapshot.zip
step-electron-dist-unzip: &step-electron-dist-unzip step-electron-dist-unzip: &step-electron-dist-unzip
run: run:
@ -198,7 +205,11 @@ step-ffmpeg-gn-gen: &step-ffmpeg-gn-gen
name: ffmpeg GN gen name: ffmpeg GN gen
command: | command: |
cd src cd src
if [ "$ELECTRON_RELEASE" == "1" ]; then
gn gen out/ffmpeg --args='import("//electron/build/args/ffmpeg.gn")'" $GN_EXTRA_ARGS"
else
gn gen out/ffmpeg --args='import("//electron/build/args/ffmpeg.gn") cc_wrapper="'"$SCCACHE_PATH"'"'" $GN_EXTRA_ARGS" gn gen out/ffmpeg --args='import("//electron/build/args/ffmpeg.gn") cc_wrapper="'"$SCCACHE_PATH"'"'" $GN_EXTRA_ARGS"
fi
step-ffmpeg-build: &step-ffmpeg-build step-ffmpeg-build: &step-ffmpeg-build
run: run:
@ -214,6 +225,11 @@ step-verify-ffmpeg: &step-verify-ffmpeg
cd src cd src
python electron/script/verify-ffmpeg.py --source-root "$PWD" --build-dir out/Default --ffmpeg-path out/ffmpeg python electron/script/verify-ffmpeg.py --source-root "$PWD" --build-dir out/Default --ffmpeg-path out/ffmpeg
step-ffmpeg-store: &step-ffmpeg-store
- store_artifacts:
path: src/out/ffmpeg/ffmpeg.zip
destination: ffmpeg.zip
step-setup-linux-for-headless-testing: &step-setup-linux-for-headless-testing step-setup-linux-for-headless-testing: &step-setup-linux-for-headless-testing
run: run:
name: Setup for headless testing name: Setup for headless testing
@ -240,18 +256,47 @@ step-mksnapshot-store: &step-mksnapshot-store
path: src/out/Default/mksnapshot.zip path: src/out/Default/mksnapshot.zip
destination: mksnapshot.zip destination: mksnapshot.zip
step-maybe-generate-breakpad_symbols: &step-maybe-generate-breakpad_symbols step-generate-breakpad_symbols: &step-generate-breakpad_symbols
run: run:
name: Generate breakpad symbols name: Generate breakpad symbols
command: | command: |
if [ "$ELECTRON_RELEASE" == "1" ]; then
cd src cd src
# Build needed dump_syms executable # Build needed dump_syms executable
ninja -C out/Default third_party/breakpad:dump_syms ninja -C out/Default third_party/breakpad:dump_syms
electron/script/dump-symbols.py -d "$PWD/out/Default/electron.breakpad.syms" electron/script/dump-symbols.py -d "$PWD/out/Default/electron.breakpad.syms"
electron/script/zip-symbols.py electron/script/zip-symbols.py
step-native-mksnapshot-gn-gen: &step-native-mksnapshot-gn-gen
run:
name: native mksnapshot GN gen (if needed)
command: |
if [ "$BUILD_NATIVE_MKSNAPSHOT" == "1" ]; then
cd src
if [ "$ELECTRON_RELEASE" == "1" ]; then
gn gen out/native_mksnapshot --args='import("//electron/build/args/native_mksnapshot.gn") v8_snapshot_toolchain="'"$MKSNAPSHOT_TOOLCHAIN"'"'" $GN_EXTRA_ARGS"
else
gn gen out/native_mksnapshot --args='import("//electron/build/args/native_mksnapshot.gn") cc_wrapper="'"$SCCACHE_PATH"'" v8_snapshot_toolchain="'"$MKSNAPSHOT_TOOLCHAIN"'"'" $GN_EXTRA_ARGS"
fi
else
echo 'skipping native mksnapshot GN gen for non arm build'
fi fi
step-native-mksnapshot-build: &step-native-mksnapshot-build
run:
name: native mksnapshot (arm/arm64) build
command: |
if [ "$BUILD_NATIVE_MKSNAPSHOT" == "1" ]; then
cd src
ninja -C out/native_mksnapshot electron:electron_mksnapshot_zip
cp out/native_mksnapshot/mksnapshot.zip out/native_mksnapshot/native_mksnapshot.zip
else
echo 'skipping native mksnapshot build for non arm build'
fi
step-native-mksnapshot-store: &step-native-mksnapshot-store
store_artifacts:
path: src/out/native_mksnapshot/native_mksnapshot.zip
destination: native_mksnapshot.zip
# Lists of steps. # Lists of steps.
steps-checkout: &steps-checkout steps-checkout: &steps-checkout
@ -315,7 +360,6 @@ steps-electron-build-for-tests: &steps-electron-build-for-tests
- *step-electron-build - *step-electron-build
- *step-electron-dist-build - *step-electron-dist-build
- *step-electron-dist-store - *step-electron-dist-store
- *step-maybe-generate-breakpad_symbols
# mksnapshot # mksnapshot
- *step-mksnapshot-build - *step-mksnapshot-build
@ -336,31 +380,47 @@ steps-electron-build-for-tests: &steps-electron-build-for-tests
- *step-maybe-notify-slack-failure - *step-maybe-notify-slack-failure
- *step-maybe-notify-slack-success - *step-maybe-notify-slack-success
steps-electron-build-for-publish: &steps-electron-build-for-publish
steps:
- *step-checkout-electron
- *step-depot-tools-get
- *step-depot-tools-add-to-path
- *step-gclient-sync
- *step-setup-env-for-build
# Electron app
- *step-electron-gn-gen
- *step-electron-build
- *step-electron-dist-build
- *step-electron-dist-store
- *step-generate-breakpad_symbols
# mksnapshot
- *step-mksnapshot-build
- *step-mksnapshot-store
# native_mksnapshot
- *step-native-mksnapshot-gn-gen
- *step-native-mksnapshot-build
- *step-native-mksnapshot-store
# chromedriver
- *step-electron-chromedriver-build
- *step-electron-chromedriver-store
# Node.js headers
- *step-nodejs-headers-build
steps-native-mksnapshot-build: &steps-native-mksnapshot-build steps-native-mksnapshot-build: &steps-native-mksnapshot-build
steps: steps:
- attach_workspace: - attach_workspace:
at: . at: .
- *step-depot-tools-add-to-path - *step-depot-tools-add-to-path
- *step-setup-env-for-build - *step-setup-env-for-build
- *step-native-mksnapshot-gn-gen
- run: - *step-native-mksnapshot-build
name: native mksnapshot GN gen - *step-native-mksnapshot-store
command: |
cd src
gn gen out/native_mksnapshot --args='import("//electron/build/args/native_mksnapshot.gn") cc_wrapper="'"$SCCACHE_PATH"'" v8_snapshot_toolchain="'"$MKSNAPSHOT_TOOLCHAIN"'"'" $GN_EXTRA_ARGS"
- run:
name: native mksnapshot (arm/arm64) build
command: |
cd src
ninja -C out/native_mksnapshot electron:electron_mksnapshot_zip
cp out/native_mksnapshot/mksnapshot.zip out/native_mksnapshot/native_mksnapshot.zip
- store_artifacts:
path: src/out/native_mksnapshot/native_mksnapshot.zip
destination: native_mksnapshot.zip
- persist_to_workspace:
root: .
paths:
- src/out/Default/mksnapshot.zip
steps-ffmpeg-build: &steps-ffmpeg-build steps-ffmpeg-build: &steps-ffmpeg-build
steps: steps:
@ -371,10 +431,8 @@ steps-ffmpeg-build: &steps-ffmpeg-build
- *step-ffmpeg-gn-gen - *step-ffmpeg-gn-gen
- *step-ffmpeg-build - *step-ffmpeg-build
- *step-ffmpeg-store
- store_artifacts:
path: src/out/ffmpeg/libffmpeg.so
destination: libffmpeg.so
- persist_to_workspace: - persist_to_workspace:
root: . root: .
paths: paths:
@ -486,9 +544,7 @@ steps-build-mac: &steps-build-mac
# ffmpeg # ffmpeg
- *step-ffmpeg-gn-gen - *step-ffmpeg-gn-gen
- *step-ffmpeg-build - *step-ffmpeg-build
- store_artifacts: - *step-ffmpeg-store
path: src/out/ffmpeg/libffmpeg.dylib
destination: libffmpeg.dylib
# It would be better to verify ffmpeg as a part of a test job, # It would be better to verify ffmpeg as a part of a test job,
# but it requires `gn` to run, and it's complicated # but it requires `gn` to run, and it's complicated
@ -557,6 +613,12 @@ jobs:
<<: *env-release-build <<: *env-release-build
<<: *steps-electron-build-for-tests <<: *steps-electron-build-for-tests
linux-x64-publish:
<<: *machine-linux-2xlarge
environment:
<<: *env-publish-build
<<: *steps-electron-build-for-publish
linux-ia32-debug: linux-ia32-debug:
<<: *machine-linux-2xlarge <<: *machine-linux-2xlarge
environment: environment:
@ -584,6 +646,13 @@ jobs:
<<: *env-release-build <<: *env-release-build
<<: *steps-electron-build-for-tests <<: *steps-electron-build-for-tests
linux-ia32-publish:
<<: *machine-linux-2xlarge
environment:
<<: *env-ia32
<<: *env-publish-build
<<: *steps-electron-build-for-publish
linux-arm-debug: linux-arm-debug:
<<: *machine-linux-2xlarge <<: *machine-linux-2xlarge
environment: environment:
@ -611,6 +680,13 @@ jobs:
<<: *env-release-build <<: *env-release-build
<<: *steps-electron-build-for-tests <<: *steps-electron-build-for-tests
linux-arm-publish:
<<: *machine-linux-2xlarge
environment:
<<: *env-arm
<<: *env-publish-build
<<: *steps-electron-build-for-publish
linux-arm-mksnapshot: linux-arm-mksnapshot:
<<: *machine-linux-medium <<: *machine-linux-medium
environment: environment:
@ -644,6 +720,13 @@ jobs:
<<: *env-release-build <<: *env-release-build
<<: *steps-electron-build-for-tests <<: *steps-electron-build-for-tests
linux-arm64-publish:
<<: *machine-linux-2xlarge
environment:
<<: *env-arm64
<<: *env-publish-build
<<: *steps-electron-build-for-publish
linux-arm64-mksnapshot: linux-arm64-mksnapshot:
<<: *machine-linux-medium <<: *machine-linux-medium
environment: environment:
@ -786,64 +869,6 @@ workflows:
requires: requires:
- linux-arm64-checkout - linux-arm64-checkout
release-linux:
jobs:
- linux-checkout
- linux-arm-checkout
- linux-arm64-checkout
- linux-x64-release:
requires:
- linux-checkout
- linux-x64-ffmpeg:
requires:
- linux-checkout
- linux-x64-publish:
requires:
- linux-x64-release
- linux-x64-ffmpeg
- linux-ia32-release:
requires:
- linux-checkout
- linux-ia32-ffmpeg:
requires:
- linux-checkout
- linux-ia32-publish:
requires:
- linux-ia32-release
- linux-ia32-ffmpeg
- linux-arm-release:
requires:
- linux-arm-checkout
- linux-arm-ffmpeg:
requires:
- linux-arm-checkout
- linux-arm-mksnapshot:
requires:
- linux-arm-checkout
- linux-arm-publish:
requires:
- linux-arm-release
- linux-arm-ffmpeg
- linux-arm-mksnapshot
- linux-arm64-release:
requires:
- linux-arm64-checkout
- linux-arm64-ffmpeg:
requires:
- linux-arm64-checkout
- linux-arm64-mksnapshot:
requires:
- linux-arm64-checkout
- linux-arm64-publish:
requires:
- linux-arm64-release
- linux-arm64-ffmpeg
- linux-arm64-mksnapshot
build-mac-fork-prs: build-mac-fork-prs:
jobs: jobs:
- osx-testing: - osx-testing:

View file

@ -6,21 +6,15 @@ const buildAppVeyorURL = 'https://windows-ci.electronjs.org/api/builds'
const vstsURL = 'https://github.visualstudio.com/electron/_apis/build' const vstsURL = 'https://github.visualstudio.com/electron/_apis/build'
const appVeyorJobs = { const appVeyorJobs = {
'electron-x64': 'electron-n7wrc', 'electron-x64': 'electron',
'electron-ia32': 'electron-egxcs' 'electron-ia32': 'electron-39ng6'
} }
// TODO: Enable the Build Processing preview to get the ability to trigger workflows
// programatically.
// - https://circleci.com/docs/2.0/build-processing/
// TODO: Update sudowoodo to somehow support monitoring workflows and individual
// builds on legacy brances
const circleCIJobs = [ const circleCIJobs = [
'linux-arm-release', 'linux-arm-publish',
'linux-arm64-release', 'linux-arm64-publish',
'linux-ia32-release', 'linux-ia32-publish',
'linux-x64-release' 'linux-x64-publish'
] ]
const vstsJobs = [ const vstsJobs = [
@ -100,7 +94,6 @@ function buildAppVeyor (targetBranch, options) {
async function callAppVeyor (targetBranch, job, options) { async function callAppVeyor (targetBranch, job, options) {
console.log(`Triggering AppVeyor to run build job: ${job} on branch: ${targetBranch} with release flag.`) console.log(`Triggering AppVeyor to run build job: ${job} on branch: ${targetBranch} with release flag.`)
const environmentVariables = { const environmentVariables = {
GN_CONFIG: 'release',
ELECTRON_RELEASE: 1 ELECTRON_RELEASE: 1
} }