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: Install cargo-component run: | if ! which cargo-component > /dev/null; then cargo install cargo-component fi - 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: 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 }}.dmg path: target/release/Zed.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/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 }}