Tag Git snapshot at git-for-windows/git@ba6e4aaec47e8695bd59117967d9b18b1e477686 #91
  
    
      This file contains hidden or 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: tag-git | |
| run-name: "Tag Git ${{ inputs.snapshot == 'true' && 'snapshot ' || '' }}at ${{ inputs.owner }}/${{ inputs.repo }}@${{ inputs.rev }}" | |
| on: | |
| workflow_dispatch: | |
| inputs: | |
| rev: | |
| description: 'The commit to tag' | |
| required: true | |
| default: main | |
| owner: | |
| description: 'Optionally override from where to fetch the specified rev' | |
| required: true | |
| default: git-for-windows | |
| repo: | |
| description: 'Optionally override from where to fetch the specified rev' | |
| required: true | |
| default: git | |
| snapshot: | |
| description: 'A flag indicating whether this is a snapshot or a full Git for Windows release' | |
| required: true | |
| default: "true" | |
| env: | |
| GPG_OPTIONS: "--batch --yes --no-tty --list-options no-show-photos --verify-options no-show-photos --pinentry-mode loopback" | |
| OWNER: "${{github.event.inputs.owner}}" | |
| REPO: "${{github.event.inputs.repo}}" | |
| REV: "${{github.event.inputs.rev}}" | |
| SNAPSHOT: "${{github.event.inputs.snapshot}}" | |
| CREATE_CHECK_RUN: "true" | |
| NODEJS_VERSION: 16 | |
| jobs: | |
| tag-git: | |
| runs-on: ubuntu-latest | |
| outputs: | |
| tag-name: ${{ steps.generate.outputs.tag-name }} | |
| steps: | |
| - name: 'Determine tip commit' | |
| if: env.REV == 'main' | |
| uses: actions/github-script@v7 | |
| with: | |
| script: | | |
| if (process.env.SNAPSHOT === '') throw new Error(`Non-snapshot build on the 'main' branch is not supported.`) | |
| const { data: ref } = await github.rest.git.getRef({ | |
| owner: process.env.OWNER, | |
| repo: 'git', | |
| ref: 'heads/main', | |
| }) | |
| core.exportVariable('REV', ref.object.sha) | |
| - uses: actions/checkout@v4 | |
| - name: Mirror Check Run to ${{ env.OWNER }}/${{ env.REPO }} | |
| if: env.CREATE_CHECK_RUN != 'false' | |
| uses: ./.github/actions/check-run-action | |
| with: | |
| app-id: ${{ secrets.GH_APP_ID }} | |
| private-key: ${{ secrets.GH_APP_PRIVATE_KEY }} | |
| owner: ${{ env.OWNER }} | |
| repo: ${{ env.REPO }} | |
| rev: ${{ env.REV }} | |
| check-run-name: "tag-git" | |
| title: "Tag Git @${{ env.REV }}" | |
| summary: "Tag Git @${{ env.REV }}" | |
| text: "For details, see [this run](https://github.com/${{ github.repository }}/actions/runs/${{ github.run_id}})." | |
| details-url: "https://github.com/${{ github.repository }}/actions/runs/${{ github.run_id}}" | |
| - name: Configure user | |
| run: | |
| USER_NAME="${{github.actor}}" && | |
| USER_EMAIL="${{github.actor}}@users.noreply.github.com" && | |
| git config --global user.name "$USER_NAME" && | |
| git config --global user.email "$USER_EMAIL" && | |
| echo "PACKAGER=$USER_NAME <$USER_EMAIL>" >> $GITHUB_ENV | |
| - name: Clone build-extra | |
| run: git clone --single-branch -b main https://github.com/git-for-windows/build-extra $RUNNER_TEMP/build-extra | |
| - name: Prepare home directory for GPG signing | |
| if: env.GPGKEY != '' | |
| run: | | |
| echo '${{secrets.PRIVGPGKEY}}' | tr % '\n' | gpg $GPG_OPTIONS --import && | |
| git config --global gpg.program "$RUNNER_TEMP/build-extra/gnupg-with-gpgkey.sh" && | |
| info="$(gpg --list-keys --with-colons "${GPGKEY%% *}" | cut -d : -f 1,10 | sed -n '/^uid/{s|uid:||p;q}')" && | |
| git config --global user.name "${info% <*}" && | |
| git config --global user.email "<${info#*<}" | |
| env: | |
| GPGKEY: ${{secrets.GPGKEY}} | |
| - name: install markdown/w3m (needed to render release notes) | |
| run: sudo apt-get install -y markdown w3m | |
| - uses: actions/setup-node@v4 | |
| with: | |
| node-version: ${{env.NODEJS_VERSION}} | |
| - name: Generate bundle artifacts | |
| id: generate | |
| env: | |
| GPGKEY: ${{secrets.GPGKEY}} | |
| run: | | |
| git clone --bare --filter=blob:none https://github.com/git/git && | |
| git -C git.git fetch --tags --filter=blob:none "https://github.com/$OWNER/$REPO" main:refs/remotes/origin/main "$REV" && | |
| sh -x "$GITHUB_WORKSPACE/update-scripts/tag-git.sh" \ | |
| ${{ env.SNAPSHOT != 'true' && '--no-snapshot-version' || ''}} \ | |
| --git-dir="git.git" \ | |
| --build-extra-dir="$RUNNER_TEMP/build-extra" \ | |
| --artifacts-dir="$GITHUB_WORKSPACE/bundle-artifacts" \ | |
| "$REV" && | |
| echo "tag-name=$(cat bundle-artifacts/next_version)" >>$GITHUB_OUTPUT && | |
| echo "Tag name: \`$(cat bundle-artifacts/next_version)\`" >>$GITHUB_STEP_SUMMARY | |
| - name: update check-run | |
| if: env.CREATE_CHECK_RUN != 'false' | |
| uses: ./.github/actions/check-run-action | |
| with: | |
| app-id: ${{ secrets.GH_APP_ID }} | |
| private-key: ${{ secrets.GH_APP_PRIVATE_KEY }} | |
| title: "Tag Git ${{ steps.generate.outputs.tag-name }} @${{ env.REV }}" | |
| summary: "Tag Git ${{ steps.generate.outputs.tag-name }} @${{ env.REV }}" | |
| append-text: 'Tagged Git ${{ steps.generate.outputs.tag-name }}' | |
| - name: 'Publish Pipeline Artifact: bundle-artifacts' | |
| uses: actions/upload-artifact@v4 | |
| with: | |
| name: bundle-artifacts | |
| path: ${{ github.workspace }}/bundle-artifacts | |
| - name: mark check run as completed | |
| if: env.CREATE_CHECK_RUN != 'false' && always() | |
| uses: ./.github/actions/check-run-action | |
| with: | |
| app-id: ${{ secrets.GH_APP_ID }} | |
| private-key: ${{ secrets.GH_APP_PRIVATE_KEY }} | |
| append-text: "${{ job.status == 'success' && 'Done!' || format('Completed: {0}', job.status) }}." | |
| conclusion: ${{ job.status }} |