This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Build & Release | |
on: | |
push: | |
branches: | |
- main | |
jobs: | |
version: | |
outputs: | |
version: ${{ steps.echo.outputs.version }} | |
# version job uses ubuntu 22.04, this way we don't have to install the updated clang while | |
# the build job uses 20.04 for libc compatibility. | |
runs-on: ubuntu-22.04 | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Cache | |
id: cache | |
uses: actions/cache@v3 | |
with: | |
path: ~/bazel-disk-cache | |
key: capnp-cache-${{ runner.os }}-${{ hashFiles('.bazelversion', '.bazelrc', 'WORKSPACE') }} | |
- name: build capnp | |
run: | | |
bazel build --disk_cache=~/bazel-disk-cache --remote_cache=https://bazel:${{ secrets.BAZEL_CACHE_KEY }}@bazel-remote-cache.devprod.cloudflare.dev @capnp-cpp//src/capnp:capnp_tool | |
- id: echo | |
run: | | |
echo "::set-output name=version::1.$(bazel-bin/external/capnp-cpp/src/capnp/capnp_tool eval src/workerd/io/compatibility-date.capnp supportedCompatibilityDate | tr -d '-' | tr -d '"').0" | |
build: | |
strategy: | |
matrix: | |
os: [ubuntu-20.04, macos-latest, windows-2022] | |
include: | |
- os-name: linux | |
os: ubuntu-20.04 | |
- os-name: macOS | |
os: macos-latest | |
- os-name: windows | |
os: windows-2022 | |
runs-on: ${{ matrix.os }} | |
name: build (${{ matrix.os-name }}) | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Cache | |
id: cache | |
uses: actions/cache@v3 | |
with: | |
path: ~/bazel-disk-cache | |
# Use a different cache key than for tests here, otherwise the release cache could end up | |
# being used for test builds, where it provides little benefit. | |
key: bazel-disk-cache-release-${{ runner.os }}-${{ runner.arch }}-${{ hashFiles('.bazelversion', '.bazelrc', 'WORKSPACE') }} | |
- name: Setup Linux | |
if: runner.os == 'Linux' | |
run: | | |
export DEBIAN_FRONTEND=noninteractive | |
wget https://apt.llvm.org/llvm.sh | |
chmod +x llvm.sh | |
sudo ./llvm.sh 14 | |
sudo apt-get install -y libunwind-14 libc++abi1-14 libc++1-14 libc++-14-dev | |
echo "build:linux --action_env=CC=/usr/lib/llvm-14/bin/clang --action_env=CXX=/usr/lib/llvm-14/bin/clang++" >> .bazelrc | |
echo "build:linux --host_action_env=CC=/usr/lib/llvm-14/bin/clang --host_action_env=CXX=/usr/lib/llvm-14/bin/clang++" >> .bazelrc | |
- name: Setup Windows | |
if: runner.os == 'Windows' | |
run: | | |
[System.IO.File]::WriteAllLines((Join-Path -Path $env:USERPROFILE -ChildPath '.bazelrc'), 'startup --output_user_root=C:/tmp') | |
# Work around bazel clang 16 include path bug (https://github.com/bazelbuild/bazel/issues/17863) | |
Move-Item -Path "C:\Program Files\LLVM\lib\clang\16" -Destination "C:\Program Files\LLVM\lib\clang\16.0.6" | |
- name: Bazel build | |
run: | | |
bazelisk build --disk_cache=~/bazel-disk-cache --remote_cache=https://bazel:${{ secrets.BAZEL_CACHE_KEY }}@bazel-remote-cache.devprod.cloudflare.dev -c opt //src/workerd/server:workerd | |
- name: Strip debug symbols | |
if: runner.os != 'Windows' | |
run: | | |
# bazel makes the output directory read-only, fix permissions for binary | |
chmod +w bazel-bin/src/workerd/server/workerd | |
# Strip debug information from the binary, this is acceptable as debug symbols are not | |
# generated for the release configuration. Regular symbols are still included. | |
strip -S bazel-bin/src/workerd/server/workerd | |
- name: Upload binary | |
uses: actions/upload-artifact@v3.1.0 | |
with: | |
name: ${{ runner.os }}-${{ runner.arch }}-binary | |
path: bazel-bin/src/workerd/server/workerd${{ runner.os == 'Windows' && '.exe' || '' }} | |
check-tag: | |
name: Check tag is new | |
outputs: | |
exists: ${{ steps.check_tag.outputs.exists }} | |
needs: [version, build] | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout Repo | |
uses: actions/checkout@v3 | |
with: | |
fetch-depth: 0 | |
- uses: mukunku/tag-exists-action@v1.1.0 | |
id: check_tag | |
with: | |
tag: v${{ needs.version.outputs.version }} | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
tag-and-release: | |
name: Tag & Release | |
outputs: | |
upload_url: ${{ steps.create_release.outputs.upload_url }} | |
needs: [check-tag, version, build] | |
runs-on: ubuntu-latest | |
if: needs.check-tag.outputs.exists != 'true' | |
steps: | |
- run: echo ${{ needs.check-tag.outputs.exists }} | |
- name: Checkout Repo | |
uses: actions/checkout@v3 | |
with: | |
fetch-depth: 0 | |
- run: git tag v${{ needs.version.outputs.version }} && git push origin v${{ needs.version.outputs.version }} | |
- uses: ncipollo/release-action@v1 | |
id: create_release | |
with: | |
generateReleaseNotes: true | |
token: ${{ secrets.GITHUB_TOKEN }} | |
tag: v${{ needs.version.outputs.version }} | |
upload-artifacts: | |
name: Upload Artifacts | |
needs: [tag-and-release] | |
runs-on: ubuntu-latest | |
strategy: | |
matrix: | |
arch: [linux-64, darwin-64, windows-64] | |
include: | |
- arch: linux-64 | |
name: Linux-X64 | |
- arch: darwin-64 | |
name: macOS-X64 | |
- arch: windows-64 | |
name: Windows-X64 | |
steps: | |
- name: Download ${{ matrix.name }} | |
uses: actions/download-artifact@v3.0.0 | |
with: | |
name: ${{ matrix.name }}-binary | |
path: /tmp | |
# Set execute permissions before compressing the binary | |
- if: matrix.arch != 'windows-64' | |
run: chmod +x /tmp/workerd | |
- name: Compress release binary | |
run: | | |
# As of release v1.20230404.0 the Linux x64 binary after debug_strip is 65.8 MB, | |
# 21.0 MB with gzip and 17.3 MB with brotli -9. Use gzip as a widely supported format | |
# which still produces an acceptable compressed size. | |
gzip -9N /tmp/workerd${{ matrix.arch == 'windows-64' && '.exe' || '' }} | |
- run: mv /tmp/workerd${{ matrix.arch == 'windows-64' && '.exe' || '' }}.gz /tmp/workerd-${{ matrix.arch }}.gz | |
# Upload compressed release binaries – one set of artifacts is sufficient with gzip being | |
# widely supported | |
- name: Upload Release Assets | |
id: upload-release-asset | |
uses: actions/upload-release-asset@v1 | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
with: | |
upload_url: ${{ needs.tag-and-release.outputs.upload_url }} | |
asset_path: /tmp/workerd-${{ matrix.arch }}.gz | |
asset_name: workerd-${{ matrix.arch }}.gz | |
asset_content_type: application/gzip |