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:
parent
2400ecbe16
commit
c5fda85ef0
1 changed files with 44 additions and 26 deletions
70
.github/workflows/ci.yml
vendored
70
.github/workflows/ci.yml
vendored
|
@ -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:
|
||||||
|
|
Loading…
Reference in a new issue