extension_workflow_rollout.yml

  1# Generated from xtask::workflows::extension_workflow_rollout
  2# Rebuild with `cargo xtask workflows`.
  3name: extension_workflow_rollout
  4env:
  5  CARGO_TERM_COLOR: always
  6on:
  7  workflow_dispatch: {}
  8jobs:
  9  fetch_extension_repos:
 10    if: (github.repository_owner == 'zed-industries' || github.repository_owner == 'zed-extensions') && github.ref == 'refs/heads/main'
 11    runs-on: namespace-profile-2x4-ubuntu-2404
 12    steps:
 13    - id: list-repos
 14      name: extension_workflow_rollout::fetch_extension_repos::get_repositories
 15      uses: actions/github-script@v7
 16      with:
 17        script: |
 18          const repos = await github.paginate(github.rest.repos.listForOrg, {
 19              org: 'zed-extensions',
 20              type: 'public',
 21              per_page: 100,
 22          });
 23
 24          const filteredRepos = repos
 25              .filter(repo => !repo.archived)
 26              .map(repo => repo.name);
 27
 28          console.log(`Found ${filteredRepos.length} extension repos`);
 29          return filteredRepos;
 30        result-encoding: json
 31    outputs:
 32      repos: ${{ steps.list-repos.outputs.result }}
 33    timeout-minutes: 5
 34  rollout_workflows_to_extension:
 35    needs:
 36    - fetch_extension_repos
 37    if: needs.fetch_extension_repos.outputs.repos != '[]'
 38    runs-on: namespace-profile-2x4-ubuntu-2404
 39    strategy:
 40      matrix:
 41        repo: ${{ fromJson(needs.fetch_extension_repos.outputs.repos) }}
 42      fail-fast: false
 43      max-parallel: 10
 44    steps:
 45    - id: generate-token
 46      name: extension_bump::generate_token
 47      uses: actions/create-github-app-token@v2
 48      with:
 49        app-id: ${{ secrets.ZED_ZIPPY_APP_ID }}
 50        private-key: ${{ secrets.ZED_ZIPPY_APP_PRIVATE_KEY }}
 51        owner: zed-extensions
 52        repositories: ${{ matrix.repo }}
 53        permission-pull-requests: write
 54        permission-contents: write
 55        permission-workflows: write
 56    - name: checkout_zed_repo
 57      uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683
 58      with:
 59        clean: false
 60        fetch-depth: 0
 61        path: zed
 62    - name: checkout_extension_repo
 63      uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683
 64      with:
 65        clean: false
 66        token: ${{ steps.generate-token.outputs.token }}
 67        path: extension
 68        repository: zed-extensions/${{ matrix.repo }}
 69    - id: prev-tag
 70      name: extension_workflow_rollout::rollout_workflows_to_extension::get_previous_tag_commit
 71      run: |
 72        PREV_COMMIT=$(git rev-parse "extension-workflows^{commit}" 2>/dev/null || echo "")
 73        if [ -z "$PREV_COMMIT" ]; then
 74            echo "::error::No previous rollout tag 'extension-workflows' found. Cannot determine file changes."
 75            exit 1
 76        fi
 77        echo "Found previous rollout at commit: $PREV_COMMIT"
 78        echo "prev_commit=$PREV_COMMIT" >> "$GITHUB_OUTPUT"
 79      working-directory: zed
 80    - id: calc-changes
 81      name: extension_workflow_rollout::rollout_workflows_to_extension::get_removed_files
 82      run: |
 83        if [ "$MATRIX_REPO" = "workflows" ]; then
 84            WORKFLOW_DIR="extensions/workflows"
 85        else
 86            WORKFLOW_DIR="extensions/workflows/shared"
 87        fi
 88
 89        echo "Calculating changes from $PREV_COMMIT to HEAD for $WORKFLOW_DIR"
 90
 91        # Get deleted files (status D) and renamed files (status R - old name needs removal)
 92        # Using -M to detect renames, then extracting files that are gone from their original location
 93        REMOVED_FILES=$(git diff --name-status -M "$PREV_COMMIT" HEAD -- "$WORKFLOW_DIR" | \
 94            awk '/^D/ { print $2 } /^R/ { print $2 }' | \
 95            xargs -I{} basename {} 2>/dev/null | \
 96            tr '\n' ' ' || echo "")
 97
 98        REMOVED_FILES=$(echo "$REMOVED_FILES" | xargs)
 99
100        echo "Files to remove: $REMOVED_FILES"
101        echo "removed_files=$REMOVED_FILES" >> "$GITHUB_OUTPUT"
102      env:
103        PREV_COMMIT: ${{ steps.prev-tag.outputs.prev_commit }}
104        MATRIX_REPO: ${{ matrix.repo }}
105      working-directory: zed
106    - name: extension_workflow_rollout::rollout_workflows_to_extension::sync_workflow_files
107      run: |
108        mkdir -p extension/.github/workflows
109        cd extension/.github/workflows
110
111        if [ -n "$REMOVED_FILES" ]; then
112            for file in $REMOVED_FILES; do
113                if [ -f "$file" ]; then
114                    rm -f "$file"
115                fi
116            done
117        fi
118
119        cd - > /dev/null
120
121        if [ "$MATRIX_REPO" = "workflows" ]; then
122            cp zed/extensions/workflows/*.yml extension/.github/workflows/
123        else
124            cp zed/extensions/workflows/shared/*.yml extension/.github/workflows/
125        fi
126      env:
127        REMOVED_FILES: ${{ steps.calc-changes.outputs.removed_files }}
128        MATRIX_REPO: ${{ matrix.repo }}
129    - id: short-sha
130      name: extension_workflow_rollout::rollout_workflows_to_extension::get_short_sha
131      run: |
132        echo "sha_short=$(git rev-parse --short=7 HEAD)" >> "$GITHUB_OUTPUT"
133      working-directory: zed
134    - id: create-pr
135      name: extension_workflow_rollout::rollout_workflows_to_extension::create_pull_request
136      uses: peter-evans/create-pull-request@v7
137      with:
138        path: extension
139        title: Update CI workflows to `${{ steps.short-sha.outputs.sha_short }}`
140        body: |
141          This PR updates the CI workflow files from the main Zed repository
142          based on the commit zed-industries/zed@${{ github.sha }}
143        commit-message: Update CI workflows to `${{ steps.short-sha.outputs.sha_short }}`
144        branch: update-workflows
145        committer: zed-zippy[bot] <234243425+zed-zippy[bot]@users.noreply.github.com>
146        author: zed-zippy[bot] <234243425+zed-zippy[bot]@users.noreply.github.com>
147        base: main
148        delete-branch: true
149        token: ${{ steps.generate-token.outputs.token }}
150        sign-commits: true
151    - name: extension_workflow_rollout::rollout_workflows_to_extension::enable_auto_merge
152      run: |
153        if [ -n "$PR_NUMBER" ]; then
154            cd extension
155            gh pr merge "$PR_NUMBER" --auto --squash
156        fi
157      env:
158        GH_TOKEN: ${{ steps.generate-token.outputs.token }}
159        PR_NUMBER: ${{ steps.create-pr.outputs.pull-request-number }}
160    timeout-minutes: 10
161  create_rollout_tag:
162    needs:
163    - rollout_workflows_to_extension
164    runs-on: namespace-profile-2x4-ubuntu-2404
165    steps:
166    - id: generate-token
167      name: extension_bump::generate_token
168      uses: actions/create-github-app-token@v2
169      with:
170        app-id: ${{ secrets.ZED_ZIPPY_APP_ID }}
171        private-key: ${{ secrets.ZED_ZIPPY_APP_PRIVATE_KEY }}
172        permission-contents: write
173    - name: steps::checkout_repo
174      uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683
175      with:
176        clean: false
177        fetch-depth: 0
178        token: ${{ steps.generate-token.outputs.token }}
179    - name: extension_workflow_rollout::create_rollout_tag::configure_git
180      run: |
181        git config user.name "zed-zippy[bot]"
182        git config user.email "234243425+zed-zippy[bot]@users.noreply.github.com"
183    - name: extension_workflow_rollout::create_rollout_tag::update_rollout_tag
184      run: |
185        if git rev-parse "extension-workflows" >/dev/null 2>&1; then
186            git tag -d "extension-workflows"
187            git push origin ":refs/tags/extension-workflows" || true
188        fi
189
190        echo "Creating new tag 'extension-workflows' at $(git rev-parse --short HEAD)"
191        git tag "extension-workflows"
192        git push origin "extension-workflows"
193    timeout-minutes: 1
194defaults:
195  run:
196    shell: bash -euxo pipefail {0}