2019-05-20 21:21:14 +02:00
|
|
|
# FIXME(linux): need to configure core dumps, enable them, and then dump
|
|
|
|
# backtraces on failure from all core dumps:
|
|
|
|
#
|
|
|
|
# - bash: sudo apt install gdb
|
|
|
|
# - bash: sudo sh -c 'echo "/checkout/obj/cores/core.%p.%E" > /proc/sys/kernel/core_pattern'
|
|
|
|
#
|
|
|
|
# Check travis config for `gdb --batch` command to print all crash logs
|
|
|
|
|
|
|
|
steps:
|
|
|
|
- checkout: self
|
|
|
|
fetchDepth: 2
|
|
|
|
|
|
|
|
- bash: printenv | sort
|
|
|
|
displayName: Show environment variables
|
|
|
|
|
|
|
|
- bash: |
|
|
|
|
set -e
|
|
|
|
df -h
|
|
|
|
du . | sort -nr | head -n100
|
|
|
|
displayName: Show disk usage
|
|
|
|
# FIXME: this hasn't been tested, but maybe it works on Windows? Should test!
|
|
|
|
condition: ne(variables['Agent.OS'], 'Windows_NT')
|
|
|
|
|
|
|
|
- template: install-sccache.yml
|
|
|
|
- template: install-clang.yml
|
|
|
|
|
|
|
|
# Install some dependencies needed to build LLDB/Clang, currently only needed
|
|
|
|
# during the `dist` target
|
|
|
|
- bash: |
|
|
|
|
set -e
|
|
|
|
brew update
|
|
|
|
brew install xz
|
|
|
|
brew install swig
|
|
|
|
displayName: Install build dependencies (OSX)
|
|
|
|
condition: and(eq(variables['Agent.OS'], 'Darwin'), eq(variables['RUST_CHECK_TARGET'],'dist'))
|
|
|
|
|
|
|
|
- template: install-windows-build-deps.yml
|
|
|
|
|
|
|
|
# Check out all our submodules, but more quickly than using git by using one of
|
|
|
|
# our custom scripts
|
|
|
|
- bash: |
|
|
|
|
set -e
|
|
|
|
mkdir -p $HOME/rustsrc
|
|
|
|
$BUILD_SOURCESDIRECTORY/src/ci/init_repo.sh . $HOME/rustsrc
|
|
|
|
condition: ne(variables['Agent.OS'], 'Windows_NT')
|
|
|
|
displayName: Check out submodules (Unix)
|
|
|
|
- script: |
|
|
|
|
if not exist D:\cache\rustsrc\NUL mkdir D:\cache\rustsrc
|
|
|
|
sh src/ci/init_repo.sh . /d/cache/rustsrc
|
|
|
|
condition: eq(variables['Agent.OS'], 'Windows_NT')
|
|
|
|
displayName: Check out submodules (Windows)
|
|
|
|
|
|
|
|
# Configure our CI_JOB_NAME variable which log analyzers can use for the main
|
|
|
|
# step to see what's going on.
|
|
|
|
- bash: echo "##vso[task.setvariable variable=CI_JOB_NAME]$SYSTEM_JOBNAME"
|
2019-05-20 21:37:18 +02:00
|
|
|
displayName: Configure Job Name
|
2019-05-20 21:21:14 +02:00
|
|
|
|
|
|
|
# As a quick smoke check on the otherwise very fast mingw-check linux builder
|
|
|
|
# check our own internal scripts.
|
|
|
|
- bash: |
|
|
|
|
set -e
|
|
|
|
git clone --depth=1 https://github.com/rust-lang-nursery/rust-toolstate.git
|
|
|
|
cd rust-toolstate
|
|
|
|
python2.7 "$BUILD_SOURCESDIRECTORY/src/tools/publish_toolstate.py" "$(git rev-parse HEAD)" "$(git log --format=%s -n1 HEAD)" "" ""
|
|
|
|
cd ..
|
|
|
|
rm -rf rust-toolstate
|
|
|
|
condition: and(succeeded(), eq(variables['IMAGE'], 'mingw-check'))
|
|
|
|
displayName: Verify the publish_toolstate script works
|
|
|
|
|
2019-05-20 21:39:25 +02:00
|
|
|
- bash: |
|
|
|
|
set -e
|
|
|
|
if [ "$IMAGE" = ""]; then
|
|
|
|
src/ci/run.sh
|
|
|
|
else
|
|
|
|
src/ci/docker/run.sh $IMAGE
|
|
|
|
fi
|
2019-05-20 21:21:14 +02:00
|
|
|
timeoutInMinutes: 180
|
|
|
|
env:
|
|
|
|
CI: true
|
|
|
|
SRC: .
|
|
|
|
AWS_SECRET_ACCESS_KEY: $(SCCACHE_AWS_SECRET_ACCESS_KEY)
|
|
|
|
displayName: Run build
|
|
|
|
|
|
|
|
- bash: |
|
|
|
|
set -e
|
|
|
|
deploy_dir=rustc-builds
|
|
|
|
if [ "$DEPLOY_ALT" == "1" ]; then
|
|
|
|
deploy_dir=rustc-builds-alt
|
|
|
|
fi
|
|
|
|
aws s3 cp --no-progress --recursive --acl public-read ./deploy s3://$DEPLOY_BUCKET/$deploy_dir
|
|
|
|
env:
|
|
|
|
AWS_SECRET_ACCESS_KEY: $(SCCACHE_AWS_SECRET_ACCESS_KEY)
|
|
|
|
condition: and(succeeded(), or(eq(variables.DEPLOY, '1'), eq(variables.DEPLOY_ALT, '1')))
|
|
|
|
displayName: Upload artifacts
|