1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2024-12-31 11:34:15 -05:00

Key CI cache on build profile (#10333)

We are aware that "lint debug ubuntu" and "test debug ubuntu" are sharing
caches - and that it is not ideal. Likely the lint cache will be written
first, and test-debug will have to build extra. However neither are the
bottleneck now.

We proceed on the assumption that we're hitting the 5 GB cache limit on a
single PR, inducing a forever-rolling behavior.

If "test debug ubuntu" becomes the bottleneck in the future we will
revisit.
This commit is contained in:
Ryan Dahl 2021-04-23 12:54:23 -04:00 committed by GitHub
parent 2400ecbe16
commit c5fda85ef0
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -4,7 +4,7 @@ on: [push, pull_request]
jobs: jobs:
build: build:
name: ${{ matrix.kind }} ${{ matrix.os }} name: ${{ matrix.kind }} ${{ matrix.profile }} ${{ matrix.os }}
if: | if: |
github.event_name == 'push' || github.event_name == 'push' ||
!startsWith(github.event.pull_request.head.label, 'denoland:') !startsWith(github.event.pull_request.head.label, 'denoland:')
@ -13,22 +13,29 @@ jobs:
strategy: strategy:
matrix: matrix:
include: include:
# TODO(ry) Rename 'kind' to 'job'?
- os: macos-10.15 - os: macos-10.15
kind: test_release kind: test
profile: release
- os: windows-2019 - os: windows-2019
kind: test_release kind: test
profile: release
- os: ${{ github.repository == 'denoland/deno' && 'ubuntu-latest-xl' || 'ubuntu-latest' }} - os: ${{ github.repository == 'denoland/deno' && 'ubuntu-latest-xl' || 'ubuntu-latest' }}
kind: bench kind: bench
profile: release
- os: ${{ github.repository == 'denoland/deno' && 'ubuntu-latest-xl' || 'ubuntu-latest' }} - os: ${{ github.repository == 'denoland/deno' && 'ubuntu-latest-xl' || 'ubuntu-latest' }}
kind: lint kind: lint
profile: debug
- os: ${{ github.repository == 'denoland/deno' && 'ubuntu-latest-xl' || 'ubuntu-latest' }} - os: ${{ github.repository == 'denoland/deno' && 'ubuntu-latest-xl' || 'ubuntu-latest' }}
kind: test_debug kind: test
profile: debug
# Warning: Do not upgrade test_release to newer version of ubuntu # Warning: Do not upgrade test_release to newer version of ubuntu
# runners. We need to link against older version of glibc in order to # runners. We need to link against older version of glibc in order to
# run on older systems. glibc in 20.04 is not compatible with 18.04. # run on older systems. glibc in 20.04 is not compatible with 18.04.
# See #9484. # See #9484.
- os: ubuntu-18.04 - os: ubuntu-18.04
kind: test_release kind: test
profile: release
# Always run main branch builds to completion. This allows the cache to # Always run main branch builds to completion. This allows the cache to
# stay mostly up-to-date in situations where a single job fails due to # stay mostly up-to-date in situations where a single job fails due to
@ -58,7 +65,8 @@ jobs:
- name: Create source tarballs (release, linux) - name: Create source tarballs (release, linux)
if: | if: |
startsWith(matrix.os, 'ubuntu') && startsWith(matrix.os, 'ubuntu') &&
matrix.kind == 'test_release' && matrix.profile == 'release' &&
matrix.kind == 'test' &&
github.repository == 'denoland/deno' && github.repository == 'denoland/deno' &&
startsWith(github.ref, 'refs/tags/') startsWith(github.ref, 'refs/tags/')
run: | run: |
@ -112,7 +120,8 @@ jobs:
- name: Setup gcloud (unix) - name: Setup gcloud (unix)
if: | if: |
runner.os != 'Windows' && runner.os != 'Windows' &&
matrix.kind == 'test_release' && matrix.profile == 'release' &&
matrix.kind == 'test' &&
github.repository == 'denoland/deno' && github.repository == 'denoland/deno' &&
(github.ref == 'refs/heads/main' || (github.ref == 'refs/heads/main' ||
startsWith(github.ref, 'refs/tags/')) startsWith(github.ref, 'refs/tags/'))
@ -125,7 +134,8 @@ jobs:
- name: Setup gcloud (windows) - name: Setup gcloud (windows)
if: | if: |
runner.os == 'Windows' && runner.os == 'Windows' &&
matrix.kind == 'test_release' && matrix.kind == 'test' &&
matrix.profile == 'release' &&
github.repository == 'denoland/deno' && github.repository == 'denoland/deno' &&
(github.ref == 'refs/heads/main' || (github.ref == 'refs/heads/main' ||
startsWith(github.ref, 'refs/tags/')) startsWith(github.ref, 'refs/tags/'))
@ -139,7 +149,8 @@ jobs:
- name: Configure canary build - name: Configure canary build
if: | if: |
matrix.kind == 'test_release' && matrix.kind == 'test' &&
matrix.profile == 'release' &&
github.repository == 'denoland/deno' && github.repository == 'denoland/deno' &&
github.ref == 'refs/heads/main' github.ref == 'refs/heads/main'
shell: bash shell: bash
@ -179,7 +190,7 @@ jobs:
path: | path: |
./target ./target
key: key:
d-${{ matrix.os }}-${{ matrix.kind }}-${{ hashFiles('Cargo.lock') }}-${{ hashFiles('Cargo.lock') }} a-cargo-target-${{ matrix.os }}-${{ matrix.profile }}-${{ hashFiles('Cargo.lock') }}
- name: Apply and update mtime cache - name: Apply and update mtime cache
uses: ./.github/mtime_cache uses: ./.github/mtime_cache
@ -192,22 +203,22 @@ jobs:
- name: lint.js - name: lint.js
if: matrix.kind == 'lint' if: matrix.kind == 'lint'
# TODO(ry) assert matrix.profile == "debug"
run: deno run --unstable --allow-write --allow-read --allow-run ./tools/lint.js run: deno run --unstable --allow-write --allow-read --allow-run ./tools/lint.js
- name: Build release - name: Build release
if: | if: (matrix.kind == 'test' || matrix.kind == 'bench') && matrix.profile == 'release'
matrix.kind == 'test_release' ||
matrix.kind == 'bench'
run: cargo build --release --locked --all-targets -vv run: cargo build --release --locked --all-targets -vv
- name: Build debug - name: Build debug
if: matrix.kind == 'test_debug' if: (matrix.kind == 'test' || matrix.kind == 'bench') && matrix.profile == 'debug'
run: cargo build --locked --all-targets run: cargo build --locked --all-targets
- name: Pre-release (linux) - name: Pre-release (linux)
if: | if: |
startsWith(matrix.os, 'ubuntu') && startsWith(matrix.os, 'ubuntu') &&
matrix.kind == 'test_release' matrix.kind == 'test' &&
matrix.profile == 'release'
run: | run: |
cd target/release cd target/release
zip -r deno-x86_64-unknown-linux-gnu.zip deno zip -r deno-x86_64-unknown-linux-gnu.zip deno
@ -217,7 +228,8 @@ jobs:
- name: Pre-release (mac) - name: Pre-release (mac)
if: | if: |
startsWith(matrix.os, 'macOS') && startsWith(matrix.os, 'macOS') &&
matrix.kind == 'test_release' matrix.kind == 'test' &&
matrix.profile == 'release'
run: | run: |
cd target/release cd target/release
zip -r deno-x86_64-apple-darwin.zip deno zip -r deno-x86_64-apple-darwin.zip deno
@ -226,7 +238,8 @@ jobs:
- name: Pre-release (windows) - name: Pre-release (windows)
if: | if: |
startsWith(matrix.os, 'windows') && startsWith(matrix.os, 'windows') &&
matrix.kind == 'test_release' matrix.kind == 'test' &&
matrix.profile == 'release'
run: | run: |
Compress-Archive -CompressionLevel Optimal -Force -Path target/release/deno.exe -DestinationPath target/release/deno-x86_64-pc-windows-msvc.zip Compress-Archive -CompressionLevel Optimal -Force -Path target/release/deno.exe -DestinationPath target/release/deno-x86_64-pc-windows-msvc.zip
Compress-Archive -CompressionLevel Optimal -Force -Path target/release/denort.exe -DestinationPath target/release/denort-x86_64-pc-windows-msvc.zip Compress-Archive -CompressionLevel Optimal -Force -Path target/release/denort.exe -DestinationPath target/release/denort-x86_64-pc-windows-msvc.zip
@ -234,7 +247,8 @@ jobs:
- name: Upload canary to dl.deno.land (unix) - name: Upload canary to dl.deno.land (unix)
if: | if: |
runner.os != 'Windows' && runner.os != 'Windows' &&
matrix.kind == 'test_release' && matrix.kind == 'test' &&
matrix.profile == 'release' &&
github.repository == 'denoland/deno' && github.repository == 'denoland/deno' &&
github.ref == 'refs/heads/main' github.ref == 'refs/heads/main'
run: | run: |
@ -245,7 +259,8 @@ jobs:
- name: Upload canary to dl.deno.land (windows) - name: Upload canary to dl.deno.land (windows)
if: | if: |
runner.os == 'Windows' && runner.os == 'Windows' &&
matrix.kind == 'test_release' && matrix.kind == 'test' &&
matrix.profile == 'release' &&
github.repository == 'denoland/deno' && github.repository == 'denoland/deno' &&
github.ref == 'refs/heads/main' github.ref == 'refs/heads/main'
env: env:
@ -257,11 +272,11 @@ jobs:
gsutil cp canary-latest.txt gs://dl.deno.land/canary-latest.txt gsutil cp canary-latest.txt gs://dl.deno.land/canary-latest.txt
- name: Test release - name: Test release
if: matrix.kind == 'test_release' if: matrix.kind == 'test' && matrix.profile == 'release'
run: cargo test --release --locked --all-targets run: cargo test --release --locked --all-targets
- name: Test debug - name: Test debug
if: matrix.kind == 'test_debug' if: matrix.kind == 'test' && matrix.profile == 'debug'
run: | run: |
cargo test --locked --doc cargo test --locked --doc
cargo test --locked --all-targets cargo test --locked --all-targets
@ -277,13 +292,13 @@ jobs:
run: python wpt make-hosts-file | Out-File $env:SystemRoot\System32\drivers\etc\hosts -Encoding ascii -Append run: python wpt make-hosts-file | Out-File $env:SystemRoot\System32\drivers\etc\hosts -Encoding ascii -Append
- name: Run web platform tests (release) - name: Run web platform tests (release)
if: matrix.kind == 'test_release' if: matrix.kind == 'test' && matrix.profile == 'release'
run: | run: |
deno run --unstable --allow-write --allow-read --allow-net --allow-env --allow-run ./tools/wpt.ts setup deno run --unstable --allow-write --allow-read --allow-net --allow-env --allow-run ./tools/wpt.ts setup
deno run --unstable --allow-write --allow-read --allow-net --allow-env --allow-run ./tools/wpt.ts run --quiet --release deno run --unstable --allow-write --allow-read --allow-net --allow-env --allow-run ./tools/wpt.ts run --quiet --release
- name: Run web platform tests (debug) - name: Run web platform tests (debug)
if: matrix.kind == 'test_debug' if: matrix.kind == 'test' && matrix.profile == 'debug'
run: | run: |
deno run --unstable --allow-write --allow-read --allow-net --allow-env --allow-run ./tools/wpt.ts setup deno run --unstable --allow-write --allow-read --allow-net --allow-env --allow-run ./tools/wpt.ts setup
deno run --unstable --allow-write --allow-read --allow-net --allow-env --allow-run ./tools/wpt.ts run --quiet deno run --unstable --allow-write --allow-read --allow-net --allow-env --allow-run ./tools/wpt.ts run --quiet
@ -318,7 +333,8 @@ jobs:
- name: Upload release to dl.deno.land (unix) - name: Upload release to dl.deno.land (unix)
if: | if: |
runner.os != 'Windows' && runner.os != 'Windows' &&
matrix.kind == 'test_release' && matrix.kind == 'test' &&
matrix.profile == 'release' &&
github.repository == 'denoland/deno' && github.repository == 'denoland/deno' &&
startsWith(github.ref, 'refs/tags/') startsWith(github.ref, 'refs/tags/')
run: | run: |
@ -329,7 +345,8 @@ jobs:
- name: Upload release to dl.deno.land (windows) - name: Upload release to dl.deno.land (windows)
if: | if: |
runner.os == 'Windows' && runner.os == 'Windows' &&
matrix.kind == 'test_release' && matrix.kind == 'test' &&
matrix.profile == 'release' &&
github.repository == 'denoland/deno' && github.repository == 'denoland/deno' &&
startsWith(github.ref, 'refs/tags/') startsWith(github.ref, 'refs/tags/')
env: env:
@ -343,7 +360,8 @@ jobs:
- name: Upload release to GitHub - name: Upload release to GitHub
uses: softprops/action-gh-release@v1 uses: softprops/action-gh-release@v1
if: | if: |
matrix.kind == 'test_release' && matrix.kind == 'test' &&
matrix.profile == 'release' &&
github.repository == 'denoland/deno' && github.repository == 'denoland/deno' &&
startsWith(github.ref, 'refs/tags/') startsWith(github.ref, 'refs/tags/')
env: env: