resources: - repo: self phases: - phase: Build_Electron_via_GN queue: 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: | set -ex gclient config \ --name "src/electron" \ --unmanaged \ --cache-dir "/Users/electron/libcc_cache" \ "https://github.com/electron/electron" mkdir src git clone https://github.com/electron/electron src/electron # TODO: there's a subtle race condition here in that if you push two # commits to $BUILD_SOURCEBRANCH in quick succession, it's possible that # fetching the BUILD_SOURCEBRANCH ref will not actually fetch the # BUILD_SOURCEVERSION commit, and so the checkout will fail. Find a # 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 export SCCACHE_WRAPPER="`pwd`/libchromiumcontent/tools/sccache/aad2120/mac/sccache" "$SCCACHE_WRAPPER" --start-server --azure_container "$(SCCACHE_AZURE_BLOB_CONTAINER)" --azure_connection "$(SCCACHE_AZURE_CONNECTION_STRING)" "$SCCACHE_WRAPPER" -s echo "##vso[task.setvariable variable=SCCACHE_WRAPPER]$SCCACHE_WRAPPER" echo "##vso[task.setvariable variable=CHROMIUM_BUILDTOOLS_PATH]`pwd`/buildtools" gn gen out/Default --args='import("//electron/build/args/testing.gn") cc_wrapper="'"$SCCACHE_WRAPPER"'"' name: GN_gen - bash: | cd src ninja -C out/Default electron:electron_app name: Ninja_build - bash: | "$SCCACHE_WRAPPER" -s "$SCCACHE_WRAPPER" --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 - task: PublishTestResults@2 displayName: Publish Test Results inputs: testResultsFiles: '**/test-*.xml' condition: and(always(), eq(variables['MOCHA_FILE'], 'junit/test-results.xml')) - 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() - 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()