2018-09-14 18:56:16 +00:00
|
|
|
jobs:
|
2018-10-09 21:01:35 +00:00
|
|
|
- job: build
|
|
|
|
displayName: Build
|
|
|
|
# Build Electron only if we are NOT going to use artifacts produced by a different build.
|
|
|
|
condition: eq(variables['Custom.UseArtifacts.BuildId'], '')
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 120
|
2018-10-08 20:19:40 +00:00
|
|
|
variables:
|
|
|
|
CI: true
|
2018-07-27 01:09:20 +00:00
|
|
|
steps:
|
2018-10-02 20:21:27 +00:00
|
|
|
|
2018-10-18 15:35:40 +00:00
|
|
|
- bash: |
|
|
|
|
git clean -fdx
|
|
|
|
displayName: Clean unneeded git directories
|
|
|
|
timeoutInMinutes: 2
|
|
|
|
|
2018-10-02 20:21:27 +00:00
|
|
|
- task: CopyFiles@2
|
|
|
|
displayName: 'Copy Files to: src/electron'
|
|
|
|
inputs:
|
|
|
|
TargetFolder: src/electron
|
2018-10-18 15:35:40 +00:00
|
|
|
timeoutInMinutes: 2
|
2018-10-02 20:21:27 +00:00
|
|
|
|
2018-07-27 01:09:20 +00:00
|
|
|
- bash: |
|
2018-09-14 18:56:16 +00:00
|
|
|
export PATH="$PATH:/Users/electron/depot_tools"
|
|
|
|
echo "##vso[task.setvariable variable=PATH]$PATH"
|
2018-08-17 16:20:20 +00:00
|
|
|
export GIT_CACHE_PATH="/Users/electron/libcc_cache"
|
2018-10-05 00:20:25 +00:00
|
|
|
if [ "$ELECTRON_RELEASE" == "1" ]; then
|
|
|
|
GCLIENT_EXTRA_ARGS='--custom-var=checkout_boto=True --custom-var=checkout_requests=True'
|
|
|
|
fi
|
|
|
|
|
2018-08-14 23:23:11 +00:00
|
|
|
set -ex
|
2018-07-27 01:09:20 +00:00
|
|
|
gclient config \
|
|
|
|
--name "src/electron" \
|
|
|
|
--unmanaged \
|
2018-10-05 00:20:25 +00:00
|
|
|
$GCLIENT_EXTRA_ARGS \
|
2018-07-27 01:09:20 +00:00
|
|
|
"https://github.com/electron/electron"
|
|
|
|
gclient sync --with_branch_heads --with_tags
|
2018-09-14 18:56:16 +00:00
|
|
|
cd src
|
|
|
|
export CHROMIUM_BUILDTOOLS_PATH=`pwd`/buildtools
|
|
|
|
echo "##vso[task.setvariable variable=CHROMIUM_BUILDTOOLS_PATH]`pwd`/buildtools"
|
|
|
|
displayName: gclient sync
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 25 # Usually takes about 10-15 minutes.
|
2018-07-27 01:09:20 +00:00
|
|
|
|
|
|
|
- bash: |
|
|
|
|
cd src
|
2018-09-12 11:08:05 +00:00
|
|
|
export SCCACHE_BINARY="`pwd`/electron/external_binaries/sccache"
|
|
|
|
"$SCCACHE_BINARY" --start-server
|
|
|
|
echo "##vso[task.setvariable variable=SCCACHE_BINARY]$SCCACHE_BINARY"
|
2018-09-14 18:56:16 +00:00
|
|
|
"$SCCACHE_BINARY" -s
|
2018-08-20 21:02:52 +00:00
|
|
|
echo "GN gen for: $GN_CONFIG"
|
2018-09-14 18:56:16 +00:00
|
|
|
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'))
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 1 # Shouldn't take more than 10 seconds.
|
2018-09-14 18:56:16 +00:00
|
|
|
|
|
|
|
- bash: |
|
|
|
|
cd src
|
|
|
|
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'))
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 1 # Shouldn't take more than 10 seconds.
|
2018-07-27 01:09:20 +00:00
|
|
|
|
|
|
|
- bash: |
|
|
|
|
cd src
|
|
|
|
ninja -C out/Default electron:electron_app
|
2018-09-14 18:56:16 +00:00
|
|
|
displayName: Ninja build app
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 100 # Can take up to 80 minutes without compiler cache.
|
2018-07-27 01:09:20 +00:00
|
|
|
|
2018-09-20 15:02:47 +00:00
|
|
|
- bash: |
|
|
|
|
cd src
|
|
|
|
ninja -C out/Default third_party/electron_node:headers
|
|
|
|
displayName: Build Node.js headers for testing
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 1 # Usually takes less than 10 seconds.
|
2018-09-20 15:02:47 +00:00
|
|
|
|
2018-09-18 13:48:01 +00:00
|
|
|
- bash: |
|
|
|
|
cd src
|
|
|
|
gn gen out/ffmpeg --args='import("//electron/build/args/ffmpeg.gn") cc_wrapper="'"$SCCACHE_PATH"'"'" $GN_EXTRA_ARGS"
|
2018-09-27 05:38:06 +00:00
|
|
|
ninja -C out/ffmpeg electron:electron_ffmpeg_zip
|
2018-09-18 13:48:01 +00:00
|
|
|
displayName: Non proprietary ffmpeg build
|
2018-09-29 12:05:15 +00:00
|
|
|
condition: and(succeeded(), or(eq(variables['RUN_TESTS'], '1'), eq(variables['ELECTRON_RELEASE'], '1')))
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 2 # Usually takes less than 30 seconds.
|
2018-09-18 13:48:01 +00:00
|
|
|
|
2018-09-26 18:56:05 +00:00
|
|
|
- bash: |
|
|
|
|
cd src
|
|
|
|
# Build needed dump_syms executable
|
|
|
|
ninja -C out/Default third_party/breakpad:dump_syms
|
2018-10-05 23:55:06 +00:00
|
|
|
|
2018-10-07 14:05:20 +00:00
|
|
|
# TODO(alexeykuzmin): Explicitly pass an out folder path to the scripts.
|
2018-10-05 23:55:06 +00:00
|
|
|
export ELECTRON_OUT_DIR=Default
|
2018-10-07 14:05:20 +00:00
|
|
|
|
|
|
|
electron/script/dump-symbols.py -d "$PWD/out/Default/electron.breakpad.syms"
|
2018-09-27 05:38:06 +00:00
|
|
|
electron/script/zip-symbols.py
|
2018-10-07 14:05:20 +00:00
|
|
|
displayName: Collect symbols
|
2018-09-26 18:56:05 +00:00
|
|
|
condition: and(succeeded(), eq(variables['ELECTRON_RELEASE'], '1'))
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 5 # Usually takes less than two.
|
2018-09-26 18:56:05 +00:00
|
|
|
|
2018-07-27 01:09:20 +00:00
|
|
|
- bash: |
|
2018-09-12 11:08:05 +00:00
|
|
|
"$SCCACHE_BINARY" --stop-server
|
2018-09-14 18:56:16 +00:00
|
|
|
displayName: Check sccache stats after build
|
|
|
|
condition: and(succeeded(), ne(variables['ELECTRON_RELEASE'], '1'))
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 1
|
2018-07-27 01:09:20 +00:00
|
|
|
|
2018-10-05 15:06:46 +00:00
|
|
|
- bash: |
|
|
|
|
cd src
|
|
|
|
python electron/script/verify-ffmpeg.py --source-root "$PWD" --build-dir out/Default --ffmpeg-path out/ffmpeg
|
|
|
|
displayName: Verify non proprietary ffmpeg
|
|
|
|
condition: and(succeeded(), eq(variables['RUN_TESTS'], '1'))
|
|
|
|
timeoutInMinutes: 5
|
2018-09-20 15:02:47 +00:00
|
|
|
|
2018-09-21 20:54:24 +00:00
|
|
|
- bash: |
|
|
|
|
cd src
|
|
|
|
ninja -C out/Default electron:electron_dist_zip
|
|
|
|
displayName: Build dist zip
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 2 # Usually takes less than 20 seconds.
|
2018-09-21 20:54:24 +00:00
|
|
|
|
|
|
|
- bash: |
|
|
|
|
cd src
|
|
|
|
ninja -C out/Default electron:electron_chromedriver_zip
|
|
|
|
displayName: Build chromedriver and zip
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 3 # Normally less than one minute.
|
2018-09-21 20:54:24 +00:00
|
|
|
|
2018-09-25 01:48:49 +00:00
|
|
|
- bash: |
|
|
|
|
cd src
|
|
|
|
ninja -C out/Default electron:electron_mksnapshot_zip
|
|
|
|
displayName: Build mksnapshot and zip
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 1 # Normally less than 10 seconds.
|
2018-09-25 01:48:49 +00:00
|
|
|
|
2018-09-29 06:39:22 +00:00
|
|
|
- bash: |
|
|
|
|
cd src/electron
|
|
|
|
npm run create-typescript-definitions
|
|
|
|
displayName: Generate type declarations
|
2018-09-29 08:36:28 +00:00
|
|
|
condition: and(succeeded(), eq(variables['ELECTRON_RELEASE'], '1'))
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 2 # Normally takes about 10-15 seconds.
|
2018-09-29 06:39:22 +00:00
|
|
|
|
2018-09-27 05:38:06 +00:00
|
|
|
- bash: |
|
|
|
|
cd src/electron
|
2018-10-08 20:19:40 +00:00
|
|
|
|
|
|
|
export ELECTRON_OUT_DIR=Default
|
|
|
|
export ELECTRON_S3_BUCKET="$(s3_bucket)"
|
|
|
|
export ELECTRON_S3_ACCESS_KEY="$(s3_access_key)"
|
|
|
|
export ELECTRON_S3_SECRET_KEY="$(s3_secret_key)"
|
|
|
|
export ELECTRON_GITHUB_TOKEN="$(github_token)"
|
|
|
|
|
|
|
|
if [ "$UPLOAD_TO_S3" == "1" ]; then
|
2018-09-27 05:38:06 +00:00
|
|
|
echo 'Uploading Electron release distribution to s3'
|
2018-10-08 20:19:40 +00:00
|
|
|
script/upload.py --upload_to_s3
|
|
|
|
else
|
|
|
|
echo 'Uploading Electron release distribution to Github releases'
|
|
|
|
script/upload.py
|
2018-09-27 05:38:06 +00:00
|
|
|
fi
|
2018-10-08 20:19:40 +00:00
|
|
|
displayName: Upload distribution
|
2018-09-27 05:38:06 +00:00
|
|
|
condition: and(succeeded(), eq(variables['ELECTRON_RELEASE'], '1'))
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 5 # Normally takes about two minutes.
|
2018-09-27 05:38:06 +00:00
|
|
|
|
2018-09-21 20:54:24 +00:00
|
|
|
- task: PublishBuildArtifacts@1
|
|
|
|
displayName: Publish Build Artifacts (application zip)
|
|
|
|
inputs:
|
|
|
|
PathtoPublish: '$(System.DefaultWorkingDirectory)/src/out/Default/dist.zip'
|
|
|
|
ArtifactName: Default
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 2 # The file is relatively big, so it takes about 20 seconds.
|
2018-09-21 20:54:24 +00:00
|
|
|
|
2018-10-09 21:01:35 +00:00
|
|
|
- task: PublishBuildArtifacts@1
|
|
|
|
displayName: Publish Build Artifacts (Node.js headers)
|
|
|
|
inputs:
|
|
|
|
PathtoPublish: '$(System.DefaultWorkingDirectory)/src/out/Default/gen/node_headers.tar.gz'
|
|
|
|
ArtifactName: Default
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 1
|
2018-10-09 21:01:35 +00:00
|
|
|
|
2018-09-21 20:54:24 +00:00
|
|
|
- task: PublishBuildArtifacts@1
|
|
|
|
displayName: Publish Build Artifacts (chromedriver.zip)
|
|
|
|
inputs:
|
|
|
|
PathtoPublish: '$(System.DefaultWorkingDirectory)/src/out/Default/chromedriver.zip'
|
|
|
|
ArtifactName: Default
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 1
|
2018-09-21 20:54:24 +00:00
|
|
|
|
2018-10-09 21:01:35 +00:00
|
|
|
- bash: |
|
|
|
|
echo $BUILD_SOURCEVERSION > revision
|
|
|
|
displayName: Save exact revision
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 1
|
2018-10-09 21:01:35 +00:00
|
|
|
|
|
|
|
- task: PublishBuildArtifacts@1
|
|
|
|
displayName: Publish Build Artifacts (revision)
|
|
|
|
inputs:
|
|
|
|
PathtoPublish: '$(System.DefaultWorkingDirectory)/revision'
|
|
|
|
ArtifactName: Default
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 1
|
2018-10-09 21:01:35 +00:00
|
|
|
|
|
|
|
# Notify about success only if we are supposed to, and we don't have to run tests first.
|
|
|
|
- bash: |
|
|
|
|
export BUILD_URL="${SYSTEM_TEAMFOUNDATIONCOLLECTIONURI}${SYSTEM_TEAMPROJECT}/_build/results?buildId=${BUILD_BUILDID}"
|
|
|
|
export MESSAGE="Build succeeded for *<$BUILD_URL|$BUILD_DEFINITIONNAME>* nightly build from *$BUILD_SOURCEBRANCHNAME*."
|
|
|
|
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)
|
|
|
|
displayName: Post Slack Notification on success
|
|
|
|
condition: and(succeeded(), and(eq(variables['NOTIFY_SLACK'], '1'), ne(variables['RUN_TESTS'], '1')))
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 1
|
2018-10-09 21:01:35 +00:00
|
|
|
|
2018-07-27 01:09:20 +00:00
|
|
|
- bash: |
|
|
|
|
export BUILD_URL="${SYSTEM_TEAMFOUNDATIONCOLLECTIONURI}${SYSTEM_TEAMPROJECT}/_build/results?buildId=${BUILD_BUILDID}"
|
2018-09-25 13:59:39 +00:00
|
|
|
export MESSAGE="Build failed for *<$BUILD_URL|$BUILD_DEFINITIONNAME>* nightly build from *$BUILD_SOURCEBRANCHNAME*."
|
2018-07-27 01:09:20 +00:00
|
|
|
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)
|
2018-09-14 18:56:16 +00:00
|
|
|
displayName: 'Post Slack Notification on Failure'
|
|
|
|
condition: and(failed(), eq(variables['NOTIFY_SLACK'], '1'))
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 1
|
2018-07-27 01:09:20 +00:00
|
|
|
|
2018-10-09 21:01:35 +00:00
|
|
|
- job: run_tests
|
|
|
|
displayName: Run Tests
|
|
|
|
dependsOn: build
|
|
|
|
# Run this job only if we are supposed to run the tests,
|
|
|
|
# and we have an Electron built either in the previous job or in a different job, defined by a user.
|
|
|
|
condition: and(eq(variables['RUN_TESTS'], '1'), or(succeeded(), ne(variables['Custom.UseArtifacts.BuildId'], '')))
|
2018-10-12 22:19:27 +00:00
|
|
|
pool:
|
|
|
|
vmImage: 'macOS-10.13'
|
2018-10-09 21:01:35 +00:00
|
|
|
timeoutInMinutes: 20
|
|
|
|
variables:
|
|
|
|
CI: true
|
|
|
|
steps:
|
|
|
|
|
|
|
|
- task: CopyFiles@2
|
|
|
|
displayName: Copy Electron sources to "src/electron"
|
|
|
|
inputs:
|
|
|
|
TargetFolder: src/electron
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 1
|
2018-10-09 21:01:35 +00:00
|
|
|
|
|
|
|
# Use Electron built in the current job, if a user didn't specify a build id.
|
|
|
|
- task: DownloadBuildArtifacts@0
|
|
|
|
displayName: Download build artifacts from the current build
|
|
|
|
inputs:
|
|
|
|
buildType: 'current'
|
|
|
|
artifactName: Default
|
|
|
|
condition: and(succeeded(), eq(variables['Custom.UseArtifacts.BuildId'], ''))
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 1
|
2018-10-09 21:01:35 +00:00
|
|
|
|
|
|
|
# Use Electron built in a different job.
|
|
|
|
- task: DownloadBuildArtifacts@0
|
|
|
|
displayName: Download build artifacts from a build specified by user
|
|
|
|
inputs:
|
|
|
|
buildType: 'specific'
|
|
|
|
project: $(System.TeamProjectId)
|
|
|
|
pipeline: $(Build.DefinitionName)
|
|
|
|
buildVersionToDownload: 'specific'
|
|
|
|
buildId: $(Custom.UseArtifacts.BuildId)
|
|
|
|
artifactName: Default
|
|
|
|
condition: and(succeeded(), ne(variables['Custom.UseArtifacts.BuildId'], ''))
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 1
|
2018-10-09 21:01:35 +00:00
|
|
|
|
|
|
|
- bash: |
|
|
|
|
TESTS_REVISION=$BUILD_SOURCEVERSION
|
|
|
|
SOURCES_REVISION=`cat ${SYSTEM_ARTIFACTSDIRECTORY}/Default/revision`
|
|
|
|
if [ $TESTS_REVISION != $SOURCES_REVISION ]; then
|
|
|
|
echo "$TESTS_REVISION != $SOURCES_REVISION"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
displayName: Check if revisions of build sources and test sources match
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 1
|
2018-10-09 21:01:35 +00:00
|
|
|
|
|
|
|
- task: ExtractFiles@1
|
|
|
|
displayName: Extract Electron app
|
|
|
|
inputs:
|
|
|
|
archiveFilePatterns: $(System.ArtifactsDirectory)/Default/dist.zip
|
|
|
|
destinationFolder: src/out/Default
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 1
|
2018-10-09 21:01:35 +00:00
|
|
|
|
|
|
|
- task: ExtractFiles@1
|
|
|
|
displayName: Extract Node.js headers
|
|
|
|
inputs:
|
|
|
|
archiveFilePatterns: $(System.ArtifactsDirectory)/Default/node_headers.tar.gz
|
|
|
|
destinationFolder: src/out/Default/gen
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 1
|
2018-10-09 21:01:35 +00:00
|
|
|
|
2018-10-12 22:19:27 +00:00
|
|
|
- task: NodeTool@0
|
|
|
|
displayName: Install Node.js 10.x
|
|
|
|
inputs:
|
|
|
|
versionSpec: '10.x'
|
|
|
|
timeoutInMinutes: 2 # Should take less than a minute.
|
2018-10-09 21:01:35 +00:00
|
|
|
|
|
|
|
- bash: |
|
|
|
|
cd src/electron
|
|
|
|
npm install
|
|
|
|
displayName: Install Node.js modules
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 4 # Should take about 30 seconds.
|
2018-10-09 21:01:35 +00:00
|
|
|
|
|
|
|
- bash: |
|
|
|
|
if pgrep Electron; then
|
|
|
|
killall Electron
|
|
|
|
fi
|
|
|
|
rm -rf ~/Library/Saved\ Application\ State/com.github.electron.savedState
|
|
|
|
rm -rf ~/Library/Application\ Support/Electron
|
|
|
|
displayName: Make sure Electron isn't running from previous tests
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 1
|
2018-10-09 21:01:35 +00:00
|
|
|
|
|
|
|
- bash: |
|
|
|
|
export ELECTRON_OUT_DIR=Default
|
2018-10-10 01:11:16 +00:00
|
|
|
(cd src/electron && npm run test -- --ci)
|
2018-10-09 21:01:35 +00:00
|
|
|
displayName: Run Electron test suite
|
|
|
|
timeoutInMinutes: 10
|
|
|
|
|
|
|
|
- bash: |
|
|
|
|
cd src
|
|
|
|
if [ ! -s "$MOCHA_FILE" ]; then
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
displayName: Check test results existence
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 1
|
2018-10-09 21:01:35 +00:00
|
|
|
|
|
|
|
- task: PublishTestResults@2
|
|
|
|
displayName: Publish Test Results
|
|
|
|
inputs:
|
|
|
|
testResultsFiles: '*.xml'
|
|
|
|
searchFolder: '$(System.DefaultWorkingDirectory)/src/junit/'
|
|
|
|
condition: and(always(), eq(variables['MOCHA_FILE'], 'junit/test-results.xml'))
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 1
|
2018-10-09 21:01:35 +00:00
|
|
|
|
|
|
|
- bash: |
|
|
|
|
export BUILD_URL="${SYSTEM_TEAMFOUNDATIONCOLLECTIONURI}${SYSTEM_TEAMPROJECT}/_build/results?buildId=${BUILD_BUILDID}"
|
|
|
|
export MESSAGE="Build failed for *<$BUILD_URL|$BUILD_DEFINITIONNAME>* nightly build from *$BUILD_SOURCEBRANCHNAME*."
|
|
|
|
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)
|
|
|
|
displayName: Post Slack Notification on failure
|
|
|
|
condition: and(failed(), eq(variables['NOTIFY_SLACK'], '1'))
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 1
|
2018-10-09 21:01:35 +00:00
|
|
|
|
2018-07-27 01:09:20 +00:00
|
|
|
- bash: |
|
|
|
|
export BUILD_URL="${SYSTEM_TEAMFOUNDATIONCOLLECTIONURI}${SYSTEM_TEAMPROJECT}/_build/results?buildId=${BUILD_BUILDID}"
|
2018-09-25 13:59:39 +00:00
|
|
|
export MESSAGE="Build succeeded for *<$BUILD_URL|$BUILD_DEFINITIONNAME>* nightly build from *$BUILD_SOURCEBRANCHNAME*."
|
2018-07-27 01:09:20 +00:00
|
|
|
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)
|
2018-10-09 21:01:35 +00:00
|
|
|
displayName: Post Slack Notification on success
|
2018-09-14 18:56:16 +00:00
|
|
|
condition: and(succeeded(), eq(variables['NOTIFY_SLACK'], '1'))
|
2018-10-10 11:44:07 +00:00
|
|
|
timeoutInMinutes: 1
|