ci: Move Mac builds to Azure Devops (VSTS) (#14588)
* Add support for multiple mocha reporters Allows us to output to junit file and to console at the same time * Cleanup VSTS file Don't install depot_tools everytime as it is already installed. Only run tests if "RUN_TESTS" environment variable is set Only notify slack if "NOTIFY_SLACK" environment variable is set Don't use sccache for release builds Move CircleCI mac builds to VSTS * Only build mac PRS from forks Don't install depot_tools everytime as it is already installed. Only run tests if "RUN_TESTS" environment variable is set Only notify slack if "NOTIFY_SLACK" environment variable is set Don't use sccache for release builds Move CircleCI mac builds to VSTS Use sccache helper script * rename vsts-gn.yml to vsts.yml Make sure Electron isn't running before starting tests
This commit is contained in:
parent
451b1782ac
commit
838b26ee26
4 changed files with 80 additions and 94 deletions
|
@ -112,8 +112,9 @@ build-steps: &build-steps
|
|||
- run:
|
||||
name: Test
|
||||
environment:
|
||||
MOCHA_REPORTER: mocha-junit-reporter
|
||||
MOCHA_REPORTER: mocha-multi-reporters
|
||||
MOCHA_FILE: junit/test-results.xml
|
||||
MOCHA_MULTI_REPORTERS: mocha-junit-reporter, tap
|
||||
ELECTRON_DISABLE_SECURITY_WARNINGS: 1
|
||||
command: |
|
||||
if [ "$RUN_TESTS" != "false" ]; then
|
||||
|
@ -189,8 +190,9 @@ mac-build-steps: &mac-build-steps
|
|||
- run:
|
||||
name: Test
|
||||
environment:
|
||||
MOCHA_REPORTER: mocha-junit-reporter
|
||||
MOCHA_REPORTER: mocha-multi-reporters
|
||||
MOCHA_FILE: junit/test-results.xml
|
||||
MOCHA_MULTI_REPORTERS: mocha-junit-reporter, tap
|
||||
ELECTRON_DISABLE_SECURITY_WARNINGS: 1
|
||||
command: |
|
||||
if [ "$RUN_TESTS" != "false" ]; then
|
||||
|
@ -338,49 +340,15 @@ jobs:
|
|||
<<: *linux-build-machine
|
||||
<<: *build-steps
|
||||
|
||||
electron-osx-release:
|
||||
environment:
|
||||
GN_CONFIG: //electron/build/args/release.gn
|
||||
RUN_TESTS: true
|
||||
NIGHTLY_BUILD: true
|
||||
<<: *mac-build-machine
|
||||
<<: *mac-build-steps
|
||||
|
||||
electron-osx-testing:
|
||||
environment:
|
||||
GN_CONFIG: //electron/build/args/testing.gn
|
||||
RUN_TESTS: true
|
||||
<<: *mac-build-machine
|
||||
<<: *mac-build-steps
|
||||
|
||||
electron-osx-debug:
|
||||
environment:
|
||||
GN_CONFIG: //electron/build/args/debug.gn
|
||||
RUN_TESTS: false
|
||||
<<: *mac-build-machine
|
||||
<<: *mac-build-steps
|
||||
|
||||
electron-mas-release:
|
||||
environment:
|
||||
GN_CONFIG: //electron/build/args/release.gn
|
||||
RUN_TESTS: true
|
||||
GN_EXTRA_ARGS: 'is_mas_build = true'
|
||||
NIGHTLY_BUILD: true
|
||||
<<: *mac-build-machine
|
||||
<<: *mac-build-steps
|
||||
|
||||
electron-mas-testing:
|
||||
environment:
|
||||
GN_CONFIG: //electron/build/args/testing.gn
|
||||
RUN_TESTS: true
|
||||
GN_EXTRA_ARGS: 'is_mas_build = true'
|
||||
<<: *mac-build-machine
|
||||
<<: *mac-build-steps
|
||||
|
||||
electron-mas-debug:
|
||||
environment:
|
||||
GN_CONFIG: //electron/build/args/debug.gn
|
||||
RUN_TESTS: false
|
||||
GN_EXTRA_ARGS: 'is_mas_build = true'
|
||||
<<: *mac-build-machine
|
||||
<<: *mac-build-steps
|
||||
|
@ -397,12 +365,19 @@ workflows:
|
|||
- electron-linux-arm-testing
|
||||
- electron-linux-arm64-debug
|
||||
- electron-linux-arm64-testing
|
||||
build-mac:
|
||||
|
||||
build-mac-fork-prs:
|
||||
jobs:
|
||||
- electron-mas-debug
|
||||
- electron-mas-testing
|
||||
- electron-osx-debug
|
||||
- electron-osx-testing
|
||||
- electron-mas-testing:
|
||||
filters:
|
||||
branches:
|
||||
# only from forks
|
||||
only: /^pull\/.*$/
|
||||
- electron-osx-testing:
|
||||
filters:
|
||||
branches:
|
||||
# only from forks
|
||||
only: /^pull\/.*$/
|
||||
|
||||
nightly-release-test:
|
||||
triggers:
|
||||
|
@ -417,5 +392,3 @@ workflows:
|
|||
- electron-linux-ia32-release
|
||||
- electron-linux-arm-release
|
||||
- electron-linux-arm64-release
|
||||
- electron-mas-release
|
||||
- electron-osx-release
|
||||
|
|
|
@ -15,6 +15,7 @@
|
|||
"mkdirp": "^0.5.1",
|
||||
"mocha": "^5.2.0",
|
||||
"mocha-junit-reporter": "^1.17.0",
|
||||
"mocha-multi-reporters": "^1.1.7",
|
||||
"multiparty": "^4.1.4",
|
||||
"q": "^1.5.1",
|
||||
"send": "^0.16.2",
|
||||
|
|
|
@ -43,10 +43,16 @@
|
|||
|
||||
const { Coverage } = require('electabul')
|
||||
const Mocha = require('mocha')
|
||||
|
||||
const mocha = new Mocha(process.env.MOCHA_REPORTER
|
||||
? { reporter: process.env.MOCHA_REPORTER }
|
||||
: undefined)
|
||||
const mochaOptions = {}
|
||||
if (process.env.MOCHA_REPORTER) {
|
||||
mochaOptions.reporter = process.env.MOCHA_REPORTER
|
||||
}
|
||||
if (process.env.MOCHA_MULTI_REPORTERS) {
|
||||
mochaOptions.reporterOptions = {
|
||||
reporterEnabled: process.env.MOCHA_MULTI_REPORTERS
|
||||
}
|
||||
}
|
||||
const mocha = new Mocha(mochaOptions)
|
||||
|
||||
if (!process.env.MOCHA_REPORTER) {
|
||||
mocha.ui('bdd').reporter(isCi ? 'tap' : 'html')
|
||||
|
|
|
@ -1,16 +1,10 @@
|
|||
resources:
|
||||
- repo: self
|
||||
phases:
|
||||
- phase: Build_Electron_via_GN
|
||||
queue:
|
||||
jobs:
|
||||
- job: Build_Electron_via_GN
|
||||
timeoutInMinutes: 180
|
||||
steps:
|
||||
- bash: |
|
||||
git clone https://chromium.googlesource.com/chromium/tools/depot_tools.git "${AGENT_BUILDDIRECTORY}/depot_tools"
|
||||
echo "##vso[task.setvariable variable=PATH]$PATH:${AGENT_BUILDDIRECTORY}/depot_tools"
|
||||
name: Setup_depot_tools
|
||||
|
||||
- bash: |
|
||||
export PATH="$PATH:/Users/electron/depot_tools"
|
||||
echo "##vso[task.setvariable variable=PATH]$PATH"
|
||||
export GIT_CACHE_PATH="/Users/electron/libcc_cache"
|
||||
set -ex
|
||||
gclient config \
|
||||
|
@ -26,71 +20,83 @@ phases:
|
|||
# better solution for checking out the commit to be built.
|
||||
(cd src/electron; git fetch origin +"${BUILD_SOURCEBRANCH}"; git checkout "${BUILD_SOURCEVERSION}")
|
||||
gclient sync --with_branch_heads --with_tags
|
||||
name: gclient_sync
|
||||
|
||||
- bash: |
|
||||
cd src
|
||||
export CHROMIUM_BUILDTOOLS_PATH=`pwd`/buildtools
|
||||
echo "##vso[task.setvariable variable=CHROMIUM_BUILDTOOLS_PATH]`pwd`/buildtools"
|
||||
displayName: gclient sync
|
||||
|
||||
- bash: |
|
||||
cd src
|
||||
export SCCACHE_BINARY="`pwd`/electron/external_binaries/sccache"
|
||||
# SCCACHE_AZURE_BLOB_CONTAINER and SCCACHE_AZURE_CONNECTION_STRING are expected to be set.
|
||||
"$SCCACHE_BINARY" --start-server
|
||||
echo "##vso[task.setvariable variable=SCCACHE_BINARY]$SCCACHE_BINARY"
|
||||
echo "##vso[task.setvariable variable=CHROMIUM_BUILDTOOLS_PATH]$CHROMIUM_BUILDTOOLS_PATH"
|
||||
echo "GN gen for: $GN_CONFIG"
|
||||
gn gen out/Default --args='import("'$GN_CONFIG'") cc_wrapper="'"$SCCACHE_BINARY"'"'
|
||||
name: GN_gen
|
||||
|
||||
- bash: |
|
||||
cd src
|
||||
ninja -C out/Default electron:electron_app
|
||||
name: Ninja_build
|
||||
|
||||
- bash: |
|
||||
"$SCCACHE_BINARY" -s
|
||||
"$SCCACHE_BINARY" --stop-server
|
||||
name: Check_sccache_stats
|
||||
|
||||
- bash: |
|
||||
set +e
|
||||
cd src
|
||||
ninja -C out/Default third_party/electron_node:headers
|
||||
export npm_config_nodedir="$PWD/out/Default/gen/node_headers"
|
||||
(cd electron/spec && npm install)
|
||||
./out/Default/Electron.app/Contents/MacOS/Electron electron/spec --ci --enable-logging
|
||||
name: Test
|
||||
echo "GN gen for: $GN_CONFIG"
|
||||
gn gen out/Default --args='import("'$GN_CONFIG'") cc_wrapper="'"$SCCACHE_BINARY"'"'" $GN_EXTRA_ARGS"
|
||||
env:
|
||||
AWS_ACCESS_KEY_ID: $(SCCACHE_AWS_ACCESS_KEY)
|
||||
AWS_SECRET_ACCESS_KEY: $(SCCACHE_AWS_SECRET)
|
||||
displayName: GN gen with sccache
|
||||
condition: and(succeeded(), ne(variables['ELECTRON_RELEASE'], '1'))
|
||||
|
||||
- bash: |
|
||||
cd src
|
||||
ninja -C out/Default electron:electron_dist_zip
|
||||
name: Build_dist_zip
|
||||
echo "GN gen for: $GN_CONFIG"
|
||||
gn gen out/Default --args='import("'$GN_CONFIG'")'" $GN_EXTRA_ARGS"
|
||||
displayName: GN gen without sccache
|
||||
condition: and(succeeded(), eq(variables['ELECTRON_RELEASE'], '1'))
|
||||
|
||||
- bash: |
|
||||
cd src
|
||||
ninja -C out/Default electron:electron_app
|
||||
displayName: Ninja build app
|
||||
|
||||
- bash: |
|
||||
"$SCCACHE_BINARY" --stop-server
|
||||
displayName: Check sccache stats after build
|
||||
condition: and(succeeded(), ne(variables['ELECTRON_RELEASE'], '1'))
|
||||
|
||||
- bash: |
|
||||
set +e
|
||||
cd src
|
||||
# Make sure there aren't any Electron processes left running from previous tests
|
||||
killall Electron
|
||||
ninja -C out/Default third_party/electron_node:headers
|
||||
export ELECTRON_OUT_DIR=Default
|
||||
(cd electron && npm run test -- --ci --enable-logging)
|
||||
displayName: Test
|
||||
condition: and(succeeded(), eq(variables['RUN_TESTS'], '1'))
|
||||
|
||||
- bash: |
|
||||
cd src
|
||||
ninja -C out/Default electron:electron_dist_zip
|
||||
displayName: Build dist zip
|
||||
|
||||
- task: PublishTestResults@2
|
||||
displayName: Publish Test Results
|
||||
inputs:
|
||||
testResultsFiles: '**/test-*.xml'
|
||||
condition: and(always(), eq(variables['MOCHA_FILE'], 'junit/test-results.xml'), ne(variables['ELECTRON_RELEASE'], '1'))
|
||||
testResultsFiles: '*.xml'
|
||||
searchFolder: '$(System.DefaultWorkingDirectory)/src/junit/'
|
||||
condition: and(always(), eq(variables['MOCHA_FILE'], 'junit/test-results.xml'), eq(variables['RUN_TESTS'], '1'))
|
||||
|
||||
- task: PublishBuildArtifacts@1
|
||||
displayName: Publish Build Artifacts
|
||||
inputs:
|
||||
PathtoPublish: '$(Build.SourcesDirectory)/out/Default/dist.zip'
|
||||
PathtoPublish: '$(System.DefaultWorkingDirectory)/src/out/Default/dist.zip'
|
||||
ArtifactName: dist.zip
|
||||
condition: and(succeeded(), eq(variables['ELECTRON_RELEASE'], '1'))
|
||||
|
||||
- bash: |
|
||||
export BUILD_URL="${SYSTEM_TEAMFOUNDATIONCOLLECTIONURI}${SYSTEM_TEAMPROJECT}/_build/results?buildId=${BUILD_BUILDID}"
|
||||
export MESSAGE="Build failed for *<$BUILD_URL|$BUILD_DEFINITIONNAME>* nightly build."
|
||||
curl -g -H "Content-Type: application/json" -X POST \
|
||||
-d "{\"text\": \"$MESSAGE\", \"attachments\": [{\"color\": \"#FC5C3C\",\"title\": \"$BUILD_DEFINITIONNAME nightly build results\",\"title_link\": \"$BUILD_URL\"}]}" $(slack_webhook)
|
||||
name: Post_Slack_Notification_on_Failure
|
||||
condition: failed()
|
||||
displayName: 'Post Slack Notification on Failure'
|
||||
condition: and(failed(), eq(variables['NOTIFY_SLACK'], '1'))
|
||||
|
||||
- bash: |
|
||||
export BUILD_URL="${SYSTEM_TEAMFOUNDATIONCOLLECTIONURI}${SYSTEM_TEAMPROJECT}/_build/results?buildId=${BUILD_BUILDID}"
|
||||
export MESSAGE="Build succeeded for *<$BUILD_URL|$BUILD_DEFINITIONNAME>* nightly build."
|
||||
curl -g -H "Content-Type: application/json" -X POST \
|
||||
-d "{\"text\": \"$MESSAGE\", \"attachments\": [{\"color\": \"good\",\"title\": \"$BUILD_DEFINITIONNAME nightly build results\",\"title_link\": \"$BUILD_URL\"}]}" $(slack_webhook)
|
||||
name: Post_Slack_Notification_on_Success
|
||||
condition: succeeded()
|
||||
displayName: 'Post Slack Notification on Success'
|
||||
condition: and(succeeded(), eq(variables['NOTIFY_SLACK'], '1'))
|
Loading…
Reference in a new issue