Skip to content

Allow running cargo-generate workflow on workflow_dispatch anywhe… #14

Allow running cargo-generate workflow on workflow_dispatch anywhe…

Allow running cargo-generate workflow on workflow_dispatch anywhe… #14

# This workflow is used to automatically update the `cargo-generate` branch. If you copied the
# template, you can safely delete this. :)
#
# BE VERY CAREFUL about what this workflow runs, since IT HAS THE ABILITY TO DELETE THE ENTIRE
# REPOSITORY'S CONTENTS. For this reason, stick to pre-installed tools and trusted actions (such as
# those hosted from the `actions` organization.)
name: Update `cargo-generate` branch
on:
# Update `cargo-generate` from `main` every time `main` is updated.
push:
branches: main
# Allow this workflow to be manually triggered.
workflow_dispatch:
# This workflows also has write-access for content and workflow, but it is through
# CARGO_GENERATE_PAT.
permissions:
# We need write permissions to create new issues.
issues: write
jobs:
update:
runs-on: ubuntu-latest
# Only run this job on the source repository, skipping forks, unless it was manually triggered.
if: ${{ github.repository == 'TheBevyFlock/bevy_quickstart' || github.event_name == 'workflow_dispatch' }}
steps:
- name: Checkout repository
uses: actions/checkout@v4
with:
# Fetch entire history, since we need it all to successfully merge.
fetch-depth: 0
# Specify a personal access token, since the default one does not let workflows modify
# the `.github/workflows` folder. This PAT needs write permissions for Contents and
# Workflows. I recommend creating a scoped token that only has access to this repository.
token: ${{ secrets.CARGO_GENERATE_PAT }}
- name: Configure Git user
env:
# From https://github.com/actions/checkout/pull/1707.
NAME: github-actions[bot]
EMAIL: 41898282+github-actions[bot]@users.noreply.github.com
run: |
git config user.name "${NAME}"
git config user.email "${EMAIL}"
- name: Switch to `cargo-generate` branch
run: git checkout cargo-generate
- name: Merge `main` branch into `cargo-generate`
id: merge
# We use `--no-edit` to prevent any editor from being opened, since we can't close it.
run: git merge main --no-edit --verbose
- name: Handle merge conflict
# Only run this if merging failed.
if: ${{ failure() && steps.merge.outcome == 'failure' }}
env:
TITLE: Failed to auto-update `cargo-generate`
BODY: |
There were merge conflicts while trying to update `cargo-generate` from `main`. You can
do it manually by running:
```bash
# Update your local copy of the `main` branch.
git switch main
git pull
# Checkout the `cargo-generate` branch.
git checkout cargo-generate
# Merge changes from `main` to `cargo-generate`. You will have to fix merge conflicts.
git merge main
```
<details>
<summary><code>git status</code></summary>
```
GIT_STATUS_IDENTIFIER
```
</details>
<details>
<summary><code>git diff --diff-filter=U</code></summary>
```diff
GIT_DIFF_IDENTIFIER
```
</details>
_This is an automated message created by `cargo-generate.yaml`._
# This is required to use the `gh` CLI.
GH_TOKEN: ${{ github.token }}
run: |
# Get a list of the IDs of open issues created by this action, then count them using JQ.
OPEN_ISSUES="$(
gh issue list \
--search "is:issue is:open author:app/github-actions in:title ${TITLE}" \
--json id \
--jq '. | length'
)"
# If an issue already exists, do not create another.
if [[ "${OPEN_ISSUES}" -gt 0 ]]; then
echo 'An issue already exists on merge conflicts! Exiting without creating another.'
exit 0
fi
GIT_STATUS="$(git status)"
# Filter the diff to only include files with merge conflicts.
GIT_DIFF="$(git diff --diff-filter=U)"
# Replace `GIT_STATUS_IDENTIFIER` and `GIT_DIFF_IDENTIFIER` with their outputs.
BODY="${BODY/GIT_STATUS_IDENTIFIER/"${GIT_STATUS}"}"
BODY="${BODY/GIT_DIFF_IDENTIFIER/"${GIT_DIFF}"}"
# Create the issue.
gh issue create --title "${TITLE}" --body "${BODY}"
- name: Push changes
# Only run if merging succeeded.
if: ${{ success() && steps.merge.outcome == 'success' }}
run: git push