Skip to content

Tag Git snapshot at git-for-windows/git@6ac2e9e007b7715b0f21f3d2c6d97b0ced5902ad #96

Tag Git snapshot at git-for-windows/git@6ac2e9e007b7715b0f21f3d2c6d97b0ced5902ad

Tag Git snapshot at git-for-windows/git@6ac2e9e007b7715b0f21f3d2c6d97b0ced5902ad #96

Workflow file for this run

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 }}