Use upstream cargo-about #23
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: CI | |
on: | |
push: | |
branches: | |
- main | |
- "v[0-9]+.[0-9]+.x" | |
tags: | |
- "v*" | |
pull_request: | |
branches: | |
- "**" | |
concurrency: | |
# Allow only one workflow per any non-`main` branch. | |
group: ${{ github.workflow }}-${{ github.ref_name }}-${{ github.ref_name == 'main' && github.sha || 'anysha' }} | |
cancel-in-progress: true | |
env: | |
CARGO_TERM_COLOR: always | |
CARGO_INCREMENTAL: 0 | |
RUST_BACKTRACE: 1 | |
jobs: | |
style: | |
name: Check formatting and spelling | |
runs-on: | |
- self-hosted | |
- test | |
steps: | |
- name: Checkout repo | |
uses: actions/checkout@v4 | |
with: | |
clean: false | |
submodules: "recursive" | |
fetch-depth: 0 | |
- name: Remove untracked files | |
run: git clean -df | |
- name: Set up default .cargo/config.toml | |
run: cp ./.cargo/ci-config.toml ~/.cargo/config.toml | |
- name: Check spelling | |
run: | | |
if ! which typos > /dev/null; then | |
cargo install typos-cli | |
fi | |
typos | |
- name: Run style checks | |
uses: ./.github/actions/check_style | |
- name: Check unused dependencies | |
uses: bnjbvr/cargo-machete@main | |
- name: Ensure fresh merge | |
shell: bash -euxo pipefail {0} | |
run: | | |
if [ -z "$GITHUB_BASE_REF" ]; | |
then | |
echo "BUF_BASE_BRANCH=$(git merge-base origin/main HEAD)" >> $GITHUB_ENV | |
else | |
git checkout -B temp | |
git merge -q origin/$GITHUB_BASE_REF -m "merge main into temp" | |
echo "BUF_BASE_BRANCH=$GITHUB_BASE_REF" >> $GITHUB_ENV | |
fi | |
- uses: bufbuild/buf-setup-action@v1 | |
with: | |
version: v1.29.0 | |
- uses: bufbuild/buf-breaking-action@v1 | |
with: | |
input: "crates/rpc/proto/" | |
against: "https://github.com/${GITHUB_REPOSITORY}.git#branch=${BUF_BASE_BRANCH},subdir=crates/rpc/proto/" | |
macos_tests: | |
name: (macOS) Run Clippy and tests | |
runs-on: | |
- self-hosted | |
- test | |
steps: | |
- name: Checkout repo | |
uses: actions/checkout@v4 | |
with: | |
clean: false | |
submodules: "recursive" | |
- name: cargo clippy | |
run: cargo xtask clippy | |
- name: Run tests | |
uses: ./.github/actions/run_tests | |
- name: Build collab | |
run: cargo build -p collab | |
- name: Build other binaries and features | |
run: cargo build --workspace --bins --all-features; cargo check -p gpui --features "macos-blade" | |
# todo(linux): Actually run the tests | |
linux_tests: | |
name: (Linux) Run Clippy and tests | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout repo | |
uses: actions/checkout@v4 | |
with: | |
clean: false | |
submodules: "recursive" | |
- name: Cache dependencies | |
uses: swatinem/rust-cache@v2 | |
with: | |
save-if: ${{ github.ref == 'refs/heads/main' }} | |
- name: configure linux | |
shell: bash -euxo pipefail {0} | |
run: script/linux | |
- name: cargo clippy | |
run: cargo xtask clippy | |
- name: Build Zed | |
run: cargo build -p zed | |
# todo(windows): Actually run the tests | |
windows_tests: | |
name: (Windows) Run Clippy and tests | |
runs-on: windows-latest | |
steps: | |
- name: Checkout repo | |
uses: actions/checkout@v4 | |
with: | |
clean: false | |
submodules: "recursive" | |
- name: Cache dependencies | |
uses: swatinem/rust-cache@v2 | |
with: | |
save-if: ${{ github.ref == 'refs/heads/main' }} | |
- name: cargo clippy | |
run: cargo xtask clippy | |
- name: Build Zed | |
run: cargo build -p zed | |
bundle-mac: | |
name: Create a macOS bundle | |
runs-on: | |
- self-hosted | |
- bundle | |
if: ${{ startsWith(github.ref, 'refs/tags/v') || contains(github.event.pull_request.labels.*.name, 'run-bundling') }} | |
needs: [macos_tests] | |
env: | |
MACOS_CERTIFICATE: ${{ secrets.MACOS_CERTIFICATE }} | |
MACOS_CERTIFICATE_PASSWORD: ${{ secrets.MACOS_CERTIFICATE_PASSWORD }} | |
APPLE_NOTARIZATION_USERNAME: ${{ secrets.APPLE_NOTARIZATION_USERNAME }} | |
APPLE_NOTARIZATION_PASSWORD: ${{ secrets.APPLE_NOTARIZATION_PASSWORD }} | |
ZED_CLIENT_CHECKSUM_SEED: ${{ secrets.ZED_CLIENT_CHECKSUM_SEED }} | |
DIGITALOCEAN_SPACES_ACCESS_KEY: ${{ secrets.DIGITALOCEAN_SPACES_ACCESS_KEY }} | |
DIGITALOCEAN_SPACES_SECRET_KEY: ${{ secrets.DIGITALOCEAN_SPACES_SECRET_KEY }} | |
steps: | |
- name: Install Node | |
uses: actions/setup-node@v4 | |
with: | |
node-version: "18" | |
- name: Checkout repo | |
uses: actions/checkout@v4 | |
with: | |
clean: false | |
submodules: "recursive" | |
- name: Limit target directory size | |
run: script/clear-target-dir-if-larger-than 100 | |
- name: Determine version and release channel | |
if: ${{ startsWith(github.ref, 'refs/tags/v') }} | |
run: | | |
set -eu | |
version=$(script/get-crate-version zed) | |
channel=$(cat crates/zed/RELEASE_CHANNEL) | |
echo "Publishing version: ${version} on release channel ${channel}" | |
echo "RELEASE_CHANNEL=${channel}" >> $GITHUB_ENV | |
expected_tag_name="" | |
case ${channel} in | |
stable) | |
expected_tag_name="v${version}";; | |
preview) | |
expected_tag_name="v${version}-pre";; | |
nightly) | |
expected_tag_name="v${version}-nightly";; | |
*) | |
echo "can't publish a release on channel ${channel}" | |
exit 1;; | |
esac | |
if [[ $GITHUB_REF_NAME != $expected_tag_name ]]; then | |
echo "invalid release tag ${GITHUB_REF_NAME}. expected ${expected_tag_name}" | |
exit 1 | |
fi | |
- name: Generate license file | |
run: script/generate-licenses | |
- name: Create macOS app bundle | |
run: script/bundle-mac | |
- name: Rename single-architecture binaries | |
if: ${{ github.ref == 'refs/heads/main' }} || contains(github.event.pull_request.labels.*.name, 'run-bundling') }} | |
run: | | |
mv target/aarch64-apple-darwin/release/Zed.dmg target/aarch64-apple-darwin/release/Zed-aarch64.dmg | |
mv target/x86_64-apple-darwin/release/Zed.dmg target/x86_64-apple-darwin/release/Zed-x86_64.dmg | |
- name: Upload app bundle (universal) to workflow run if main branch or specific label | |
uses: actions/upload-artifact@v4 | |
if: ${{ github.ref == 'refs/heads/main' }} || contains(github.event.pull_request.labels.*.name, 'run-bundling') }} | |
with: | |
name: Zed_${{ github.event.pull_request.head.sha || github.sha }}.dmg | |
path: target/release/Zed.dmg | |
- name: Upload app bundle (aarch64) to workflow run if main branch or specific label | |
uses: actions/upload-artifact@v4 | |
if: ${{ github.ref == 'refs/heads/main' }} || contains(github.event.pull_request.labels.*.name, 'run-bundling') }} | |
with: | |
name: Zed_${{ github.event.pull_request.head.sha || github.sha }}-aarch64.dmg | |
path: target/aarch64-apple-darwin/release/Zed-aarch64.dmg | |
- name: Upload app bundle (x86_64) to workflow run if main branch or specific label | |
uses: actions/upload-artifact@v4 | |
if: ${{ github.ref == 'refs/heads/main' }} || contains(github.event.pull_request.labels.*.name, 'run-bundling') }} | |
with: | |
name: Zed_${{ github.event.pull_request.head.sha || github.sha }}-x86_64.dmg | |
path: target/x86_64-apple-darwin/release/Zed-x86_64.dmg | |
- uses: softprops/action-gh-release@v1 | |
name: Upload app bundle to release | |
if: ${{ env.RELEASE_CHANNEL == 'preview' || env.RELEASE_CHANNEL == 'stable' }} | |
with: | |
draft: true | |
prerelease: ${{ env.RELEASE_CHANNEL == 'preview' }} | |
files: | | |
target/aarch64-apple-darwin/release/Zed-aarch64.dmg | |
target/x86_64-apple-darwin/release/Zed-x86_64.dmg | |
target/release/Zed.dmg | |
body: "" | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
bundle-deb: | |
name: Create a *.deb Linux bundle | |
runs-on: ubuntu-22.04 # keep the version fixed to avoid libc and dynamic linked library issues | |
if: ${{ startsWith(github.ref, 'refs/tags/v') || contains(github.event.pull_request.labels.*.name, 'run-bundling') }} | |
needs: [linux_tests] | |
env: | |
ZED_CLIENT_CHECKSUM_SEED: ${{ secrets.ZED_CLIENT_CHECKSUM_SEED }} | |
DIGITALOCEAN_SPACES_ACCESS_KEY: ${{ secrets.DIGITALOCEAN_SPACES_ACCESS_KEY }} | |
DIGITALOCEAN_SPACES_SECRET_KEY: ${{ secrets.DIGITALOCEAN_SPACES_SECRET_KEY }} | |
steps: | |
- name: Checkout repo | |
uses: actions/checkout@v4 | |
with: | |
clean: false | |
submodules: "recursive" | |
- name: Cache dependencies | |
uses: swatinem/rust-cache@v2 | |
with: | |
save-if: ${{ github.ref == 'refs/heads/main' }} | |
- name: Configure linux | |
shell: bash -euxo pipefail {0} | |
run: script/linux | |
- name: Determine version and release channel | |
if: ${{ startsWith(github.ref, 'refs/tags/v') }} | |
run: | | |
set -eu | |
version=$(script/get-crate-version zed) | |
channel=$(cat crates/zed/RELEASE_CHANNEL) | |
echo "Publishing version: ${version} on release channel ${channel}" | |
echo "RELEASE_CHANNEL=${channel}" >> $GITHUB_ENV | |
expected_tag_name="" | |
case ${channel} in | |
stable) | |
expected_tag_name="v${version}";; | |
preview) | |
expected_tag_name="v${version}-pre";; | |
nightly) | |
expected_tag_name="v${version}-nightly";; | |
*) | |
echo "can't publish a release on channel ${channel}" | |
exit 1;; | |
esac | |
if [[ $GITHUB_REF_NAME != $expected_tag_name ]]; then | |
echo "invalid release tag ${GITHUB_REF_NAME}. expected ${expected_tag_name}" | |
exit 1 | |
fi | |
# TODO linux : Find a way to add licenses to the final bundle | |
# - name: Generate license file | |
# run: script/generate-licenses | |
- name: Create Linux *.deb bundle | |
run: script/bundle-linux | |
- name: Upload app bundle to workflow run if main branch or specific label | |
uses: actions/upload-artifact@v4 | |
if: ${{ github.ref == 'refs/heads/main' }} || contains(github.event.pull_request.labels.*.name, 'run-bundling') }} | |
with: | |
name: Zed_${{ github.event.pull_request.head.sha || github.sha }}.deb | |
path: target/release/*.deb | |
# TODO linux : make it stable enough to be uploaded as a release | |
# - uses: softprops/action-gh-release@v1 | |
# name: Upload app bundle to release | |
# if: ${{ env.RELEASE_CHANNEL == 'preview' || env.RELEASE_CHANNEL == 'stable' }} | |
# with: | |
# draft: true | |
# prerelease: ${{ env.RELEASE_CHANNEL == 'preview' }} | |
# files: target/release/Zed.dmg | |
# body: "" | |
# env: | |
# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} |