mirror of
https://github.com/Mibew/simple-icons.git
synced 2025-01-19 08:30:35 +03:00
039f4f4a20
* Use PAT to avoid version bump commit problems due to branch protections Following the instructions of stefanzweifel/git-auto-commit-action [1] for pushing to branches with branch protections, this changes the create release workflow to fetch the repo with a PAT (that must belong to an admin for this to work). As a result, when pushing the version bump commit, the required status checks are not required (provided the rules are not applied to admins). --- 1. https://github.com/stefanzweifel/git-auto-commit-action#push-to-protected-branches * Add warning to not add `on: push` to create release workflow * Enforce that create-release isn'ttriggered by push events
57 lines
2.2 KiB
YAML
57 lines
2.2 KiB
YAML
name: Create Release Pull Request
|
|
on:
|
|
# THIS WORKFLOW SHOULD NEVER BE TRIGGERED ON A PUSH EVENT. IF TRIGGERED ON A
|
|
# PUSH EVENT IT MAY CREATE AN ENDLESS STREAM OF 'version bump' COMMITS.
|
|
workflow_dispatch:
|
|
schedule:
|
|
# "At 00:00 on Sunday" (https://crontab.guru/once-a-week)
|
|
- cron: "0 0 * * 0"
|
|
|
|
# This Workflow can be triggered manually through the GitHub UI or API. For the
|
|
# API use the following request:
|
|
# curl -X POST \
|
|
# -H "Authorization: Bearer <token>" \
|
|
# -d '{"ref":"develop"}' \
|
|
# https://api.github.com/repos/simple-icons/simple-icons/actions/workflows/create-release.yml/dispatches
|
|
# Replacing <token> by a personal access token with scope `public_repo`
|
|
|
|
jobs:
|
|
release-pr:
|
|
runs-on: ubuntu-latest
|
|
if: github.event_name != 'push'
|
|
outputs:
|
|
did-create-pr: ${{ steps.release.outputs.did-create-pr }}
|
|
new-version: ${{ steps.release.outputs.new-version }}
|
|
steps:
|
|
- uses: simple-icons/release-action@master
|
|
id: release
|
|
with:
|
|
repo-token: ${{ secrets.GITHUB_TOKEN }}
|
|
version-bump:
|
|
runs-on: ubuntu-latest
|
|
needs: release-pr
|
|
if: |
|
|
github.event_name != 'push' &&
|
|
needs.release-pr.outputs.did-create-pr == 'true'
|
|
steps:
|
|
- name: Checkout
|
|
uses: actions/checkout@v2
|
|
with:
|
|
# Ensure the commit can be pushed regardless of branch protections (must belong to an admin of this repo)
|
|
token: ${{ secrets.RELEASE_TOKEN }}
|
|
# Ensure we are checked out on the develop branch
|
|
ref: develop
|
|
- name: Bump version
|
|
run: node ./scripts/release/bump-version.js "${{ needs.release-pr.outputs.new-version }}"
|
|
- name: Update major version in CDN URLs
|
|
run: node ./scripts/release/update-cdn-urls.js
|
|
- name: Update slugs table
|
|
run: node ./scripts/release/update-slugs-table.js
|
|
- name: Commit version bump
|
|
uses: stefanzweifel/git-auto-commit-action@v4.12.0
|
|
with:
|
|
commit_message: version bump
|
|
commit_user_name: "github-actions[bot]"
|
|
commit_user_email: "github-actions[bot]@users.noreply.github.com"
|
|
commit_author: "github-actions[bot] <github-actions[bot]@users.noreply.github.com>"
|