ci: use config version 2.1 on CircleCI (#15665)

This commit is contained in:
Alexey Kuzmin 2018-11-12 20:22:21 +01:00 committed by Jeremy Apthorp
parent b21dbdb20d
commit 0c46a7a4d9

View file

@ -7,20 +7,29 @@
# CircleCI docs on variables:
# https://circleci.com/docs/2.0/env-vars/
version: 2.1
# Build machines configs.
docker-image: &docker-image
docker:
- image: electronbuilds/electron:0.0.9
machine-linux-medium: &machine-linux-medium
executors:
linux-medium:
<<: *docker-image
resource_class: medium
environment:
# Ninja misdetects a number of available CPUs.
NINJA_PARALLEL_JOBS: -j 3 # 2 CPUs + 1
machine-linux-2xlarge: &machine-linux-2xlarge
linux-2xlarge:
<<: *docker-image
resource_class: 2xlarge
environment:
# Ninja misdetects a number of available CPUs.
NINJA_PARALLEL_JOBS: -j 18 # 16 CPUs + 2
machine-mac: &machine-mac
mac:
macos:
xcode: "8.3.3"
@ -169,7 +178,7 @@ step-electron-build: &step-electron-build
name: Electron build
command: |
cd src
ninja -C out/Default electron -j18
ninja -C out/Default electron $NINJA_PARALLEL_JOBS
step-maybe-electron-dist-strip: &step-maybe-electron-dist-strip
run:
@ -185,7 +194,7 @@ step-electron-dist-build: &step-electron-dist-build
name: Build dist.zip
command: |
cd src
ninja -C out/Default electron:electron_dist_zip
ninja -C out/Default electron:electron_dist_zip $NINJA_PARALLEL_JOBS
step-electron-dist-store: &step-electron-dist-store
store_artifacts:
@ -197,11 +206,9 @@ step-electron-chromedriver-build: &step-electron-chromedriver-build
name: Build chromedriver.zip
command: |
cd src
# NOTE(alexeykuzmin): -j3 because chromedriver is currently built
# on a smaller size machine and ninja mis-detects the number of CPUs available.
ninja -C out/Default chrome/test/chromedriver -j3
ninja -C out/Default chrome/test/chromedriver $NINJA_PARALLEL_JOBS
electron/script/strip-binaries.py --target-cpu="$TARGET_ARCH" --file $PWD/out/Default/chromedriver
ninja -C out/Default electron:electron_chromedriver_zip
ninja -C out/Default electron:electron_chromedriver_zip $NINJA_PARALLEL_JOBS
step-electron-chromedriver-store: &step-electron-chromedriver-store
store_artifacts:
@ -213,7 +220,7 @@ step-nodejs-headers-build: &step-nodejs-headers-build
name: Build Node.js headers
command: |
cd src
ninja -C out/Default third_party/electron_node:headers
ninja -C out/Default third_party/electron_node:headers $NINJA_PARALLEL_JOBS
step-nodejs-headers-store: &step-nodejs-headers-store
store_artifacts:
@ -274,9 +281,7 @@ step-ffmpeg-build: &step-ffmpeg-build
name: Non proprietary ffmpeg build
command: |
cd src
# NOTE(jeremy): -j3 because ffmpeg is currently built on a smaller
# machine size and ninja mis-detects the number of CPUs available.
ninja -C out/ffmpeg electron:electron_ffmpeg_zip -j3
ninja -C out/ffmpeg electron:electron_ffmpeg_zip $NINJA_PARALLEL_JOBS
step-verify-ffmpeg: &step-verify-ffmpeg
run:
@ -327,9 +332,7 @@ step-mksnapshot-build: &step-mksnapshot-build
electron/script/strip-binaries.py --file $PWD/out/Default/mksnapshot
fi
fi
# NOTE(jeremy): -j3 because mksnapshot is currently built on a smaller
# machine size and ninja mis-detects the number of CPUs available.
ninja -C out/Default electron:electron_mksnapshot_zip -j3
ninja -C out/Default electron:electron_mksnapshot_zip $NINJA_PARALLEL_JOBS
step-mksnapshot-store: &step-mksnapshot-store
store_artifacts:
@ -342,7 +345,7 @@ step-build-dump-syms: &step-build-dump-syms
command: |
cd src
# Build needed dump_syms executable
ninja -C out/Default third_party/breakpad:dump_syms
ninja -C out/Default third_party/breakpad:dump_syms $NINJA_PARALLEL_JOBS
step-generate-breakpad-symbols: &step-generate-breakpad-symbols
run:
@ -378,9 +381,7 @@ step-maybe-native-mksnapshot-build: &step-maybe-native-mksnapshot-build
command: |
if [ "$BUILD_NATIVE_MKSNAPSHOT" == "1" ]; then
cd src
# NOTE(jeremy): -j3 because mksnapshot is currently built on a smaller
# machine size and ninja mis-detects the number of CPUs available.
ninja -C out/native_mksnapshot electron:electron_mksnapshot_zip -j3
ninja -C out/native_mksnapshot electron:electron_mksnapshot_zip $NINJA_PARALLEL_JOBS
else
echo 'Skipping native mksnapshot build for non arm build'
fi
@ -607,7 +608,7 @@ steps-native-tests: &steps-native-tests
name: Build tests
command: |
cd src
ninja -C out/Default $BUILD_TARGET
ninja -C out/Default $BUILD_TARGET $NINJA_PARALLEL_JOBS
- *step-show-sccache-stats
- *step-setup-linux-for-headless-testing
@ -748,51 +749,50 @@ chromium-upgrade-branches: &chromium-upgrade-branches
/chromium\-upgrade\/[0-9]+/
# List of all jobs.
version: 2
jobs:
# Layer 1: Checkout.
linux-checkout:
<<: *machine-linux-2xlarge
executor: linux-2xlarge
environment:
GCLIENT_EXTRA_ARGS: '--custom-var=checkout_arm=True --custom-var=checkout_arm64=True'
<<: *steps-checkout
linux-checkout-for-native-tests:
<<: *machine-linux-2xlarge
executor: linux-2xlarge
environment:
GCLIENT_EXTRA_ARGS: '--custom-var=checkout_pyyaml=True'
<<: *steps-checkout
linux-checkout-for-native-tests-with-no-patches:
<<: *machine-linux-2xlarge
executor: linux-2xlarge
environment:
GCLIENT_EXTRA_ARGS: '--custom-var=apply_patches=False --custom-var=checkout_pyyaml=True'
<<: *steps-checkout
# Layer 2: Builds.
linux-x64-debug:
<<: *machine-linux-2xlarge
executor: linux-2xlarge
environment:
<<: *env-debug-build
<<: *env-enable-sccache
<<: *steps-electron-build
linux-x64-testing:
<<: *machine-linux-2xlarge
executor: linux-2xlarge
environment:
<<: *env-testing-build
<<: *env-enable-sccache
<<: *steps-electron-build-for-tests
linux-x64-ffmpeg:
<<: *machine-linux-medium
executor: linux-medium
environment:
<<: *env-enable-sccache
<<: *env-send-slack-notifications
<<: *steps-ffmpeg-build
linux-x64-chromedriver:
<<: *machine-linux-medium
executor: linux-medium
environment:
<<: *env-release-build
<<: *env-enable-sccache
@ -800,7 +800,7 @@ jobs:
<<: *steps-chromedriver-build
linux-x64-release:
<<: *machine-linux-2xlarge
executor: linux-2xlarge
environment:
<<: *env-release-build
<<: *env-enable-sccache
@ -808,14 +808,14 @@ jobs:
<<: *steps-electron-build-for-tests
linux-x64-publish:
<<: *machine-linux-2xlarge
executor: linux-2xlarge
environment:
GCLIENT_EXTRA_ARGS: '--custom-var=checkout_boto=True --custom-var=checkout_requests=True'
<<: *env-release-build
<<: *steps-electron-build-for-publish
linux-ia32-debug:
<<: *machine-linux-2xlarge
executor: linux-2xlarge
environment:
<<: *env-ia32
<<: *env-debug-build
@ -823,7 +823,7 @@ jobs:
<<: *steps-electron-build
linux-ia32-testing:
<<: *machine-linux-2xlarge
executor: linux-2xlarge
environment:
<<: *env-ia32
<<: *env-testing-build
@ -831,7 +831,7 @@ jobs:
<<: *steps-electron-build-for-tests
linux-ia32-ffmpeg:
<<: *machine-linux-medium
executor: linux-medium
environment:
<<: *env-ia32
<<: *env-enable-sccache
@ -839,7 +839,7 @@ jobs:
<<: *steps-ffmpeg-build
linux-ia32-chromedriver:
<<: *machine-linux-medium
executor: linux-medium
environment:
<<: *env-ia32
<<: *env-release-build
@ -848,7 +848,7 @@ jobs:
<<: *steps-chromedriver-build
linux-ia32-release:
<<: *machine-linux-2xlarge
executor: linux-2xlarge
environment:
<<: *env-ia32
<<: *env-release-build
@ -857,7 +857,7 @@ jobs:
<<: *steps-electron-build-for-tests
linux-ia32-publish:
<<: *machine-linux-2xlarge
executor: linux-2xlarge
environment:
GCLIENT_EXTRA_ARGS: '--custom-var=checkout_boto=True --custom-var=checkout_requests=True'
<<: *env-ia32
@ -865,7 +865,7 @@ jobs:
<<: *steps-electron-build-for-publish
linux-arm-debug:
<<: *machine-linux-2xlarge
executor: linux-2xlarge
environment:
<<: *env-arm
<<: *env-debug-build
@ -873,7 +873,7 @@ jobs:
<<: *steps-electron-build
linux-arm-testing:
<<: *machine-linux-2xlarge
executor: linux-2xlarge
environment:
<<: *env-arm
<<: *env-testing-build
@ -882,7 +882,7 @@ jobs:
<<: *steps-electron-build-for-tests
linux-arm-ffmpeg:
<<: *machine-linux-medium
executor: linux-medium
environment:
<<: *env-arm
<<: *env-enable-sccache
@ -890,7 +890,7 @@ jobs:
<<: *steps-ffmpeg-build
linux-arm-chromedriver:
<<: *machine-linux-medium
executor: linux-medium
environment:
<<: *env-arm
<<: *env-release-build
@ -899,7 +899,7 @@ jobs:
<<: *steps-chromedriver-build
linux-arm-release:
<<: *machine-linux-2xlarge
executor: linux-2xlarge
environment:
<<: *env-arm
<<: *env-release-build
@ -908,7 +908,7 @@ jobs:
<<: *steps-electron-build-for-tests
linux-arm-publish:
<<: *machine-linux-2xlarge
executor: linux-2xlarge
environment:
<<: *env-arm
<<: *env-release-build
@ -916,7 +916,7 @@ jobs:
<<: *steps-electron-build-for-publish
linux-arm-native-mksnapshot:
<<: *machine-linux-medium
executor: linux-medium
environment:
<<: *env-arm
<<: *env-enable-sccache
@ -924,7 +924,7 @@ jobs:
<<: *steps-native-mksnapshot-build
linux-arm64-debug:
<<: *machine-linux-2xlarge
executor: linux-2xlarge
environment:
<<: *env-arm64
<<: *env-debug-build
@ -932,7 +932,7 @@ jobs:
<<: *steps-electron-build
linux-arm64-testing:
<<: *machine-linux-2xlarge
executor: linux-2xlarge
environment:
<<: *env-arm64
<<: *env-testing-build
@ -941,7 +941,7 @@ jobs:
<<: *steps-electron-build-for-tests
linux-arm64-ffmpeg:
<<: *machine-linux-medium
executor: linux-medium
environment:
<<: *env-arm64
<<: *env-enable-sccache
@ -949,7 +949,7 @@ jobs:
<<: *steps-ffmpeg-build
linux-arm64-chromedriver:
<<: *machine-linux-medium
executor: linux-medium
environment:
<<: *env-arm64
<<: *env-release-build
@ -958,7 +958,7 @@ jobs:
<<: *steps-chromedriver-build
linux-arm64-release:
<<: *machine-linux-2xlarge
executor: linux-2xlarge
environment:
<<: *env-arm64
<<: *env-release-build
@ -967,7 +967,7 @@ jobs:
<<: *steps-electron-build-for-tests
linux-arm64-publish:
<<: *machine-linux-2xlarge
executor: linux-2xlarge
environment:
<<: *env-arm64
<<: *env-release-build
@ -975,7 +975,7 @@ jobs:
<<: *steps-electron-build-for-publish
linux-arm64-native-mksnapshot:
<<: *machine-linux-medium
executor: linux-medium
environment:
<<: *env-arm64
<<: *env-enable-sccache
@ -983,14 +983,14 @@ jobs:
<<: *steps-native-mksnapshot-build
osx-testing:
<<: *machine-mac
executor: mac
environment:
<<: *env-testing-build
<<: *env-enable-sccache
<<: *steps-build-mac
mas-testing:
<<: *machine-mac
executor: mac
environment:
<<: *env-mas
<<: *env-testing-build
@ -999,7 +999,7 @@ jobs:
# Layer 3: Tests.
linux-x64-unittests:
<<: *machine-linux-2xlarge
executor: linux-2xlarge
environment:
<<: *env-unittests
<<: *env-enable-sccache
@ -1007,7 +1007,7 @@ jobs:
<<: *steps-native-tests
linux-x64-disabled-unittests:
<<: *machine-linux-2xlarge
executor: linux-2xlarge
environment:
<<: *env-unittests
<<: *env-enable-sccache
@ -1016,7 +1016,7 @@ jobs:
<<: *steps-native-tests
linux-x64-chromium-unittests:
<<: *machine-linux-2xlarge
executor: linux-2xlarge
environment:
<<: *env-unittests
<<: *env-enable-sccache
@ -1025,7 +1025,7 @@ jobs:
<<: *steps-native-tests
linux-x64-browsertests:
<<: *machine-linux-2xlarge
executor: linux-2xlarge
environment:
<<: *env-browsertests
<<: *env-testing-build
@ -1034,35 +1034,35 @@ jobs:
<<: *steps-native-tests
linux-x64-testing-tests:
<<: *machine-linux-medium
executor: linux-medium
environment:
<<: *env-headless-testing
<<: *env-stack-dumping
<<: *steps-tests
linux-x64-release-tests:
<<: *machine-linux-medium
executor: linux-medium
environment:
<<: *env-headless-testing
<<: *env-send-slack-notifications
<<: *steps-tests
linux-x64-verify-ffmpeg:
<<: *machine-linux-medium
executor: linux-medium
environment:
<<: *env-headless-testing
<<: *env-send-slack-notifications
<<: *steps-verify-ffmpeg
linux-x64-verify-mksnapshot:
<<: *machine-linux-medium
executor: linux-medium
environment:
<<: *env-headless-testing
<<: *env-send-slack-notifications
<<: *steps-verify-mksnapshot
linux-ia32-testing-tests:
<<: *machine-linux-medium
executor: linux-medium
environment:
<<: *env-ia32
<<: *env-headless-testing
@ -1070,7 +1070,7 @@ jobs:
<<: *steps-tests
linux-ia32-release-tests:
<<: *machine-linux-medium
executor: linux-medium
environment:
<<: *env-ia32
<<: *env-headless-testing
@ -1078,7 +1078,7 @@ jobs:
<<: *steps-tests
linux-ia32-verify-ffmpeg:
<<: *machine-linux-medium
executor: linux-medium
environment:
<<: *env-ia32
<<: *env-headless-testing
@ -1086,49 +1086,22 @@ jobs:
<<: *steps-verify-ffmpeg
linux-ia32-verify-mksnapshot:
<<: *machine-linux-medium
executor: linux-medium
environment:
<<: *env-ia32
<<: *env-headless-testing
<<: *env-send-slack-notifications
<<: *steps-verify-mksnapshot
osx-testing-tests:
<<: *machine-mac
environment:
<<: *env-stack-dumping
<<: *steps-tests
mas-testing-tests:
<<: *machine-mac
mac-tests:
executor: mac
environment:
<<: *env-stack-dumping
<<: *steps-tests
# Layer 4: Summary.
linux-x64-release-summary:
<<: *machine-linux-medium
environment:
- *env-send-slack-notifications
steps:
- *step-maybe-notify-slack-success
linux-ia32-release-summary:
<<: *machine-linux-medium
environment:
- *env-send-slack-notifications
steps:
- *step-maybe-notify-slack-success
linux-arm-release-summary:
<<: *machine-linux-medium
environment:
- *env-send-slack-notifications
steps:
- *step-maybe-notify-slack-success
linux-arm64-release-summary:
<<: *machine-linux-medium
linux-release-summary:
executor: linux-medium
environment:
- *env-send-slack-notifications
steps:
@ -1178,14 +1151,16 @@ workflows:
jobs:
- osx-testing:
<<: *filter-only-prs-from-forks
- osx-testing-tests:
- mac-tests:
name: osx-testing-tests
<<: *filter-only-prs-from-forks
requires:
- osx-testing
- mas-testing:
<<: *filter-only-prs-from-forks
- mas-testing-tests:
- mac-tests:
name: mas-testing-tests
<<: *filter-only-prs-from-forks
requires:
- mas-testing
@ -1221,7 +1196,8 @@ workflows:
- linux-x64-chromedriver:
requires:
- linux-checkout
- linux-x64-release-summary:
- linux-release-summary:
name: linux-x64-release-summary
requires:
- linux-x64-release
- linux-x64-release-tests
@ -1248,7 +1224,8 @@ workflows:
- linux-ia32-chromedriver:
requires:
- linux-checkout
- linux-ia32-release-summary:
- linux-release-summary:
name: linux-ia32-release-summary
requires:
- linux-ia32-release
- linux-ia32-release-tests
@ -1268,7 +1245,8 @@ workflows:
- linux-arm-chromedriver:
requires:
- linux-checkout
- linux-arm-release-summary:
- linux-release-summary:
name: linux-arm-release-summary
requires:
- linux-arm-release
- linux-arm-ffmpeg
@ -1287,7 +1265,8 @@ workflows:
- linux-arm64-chromedriver:
requires:
- linux-checkout
- linux-arm64-release-summary:
- linux-release-summary:
name: linux-arm64-release-summary
requires:
- linux-arm64-release
- linux-arm64-ffmpeg