From 53b197bb66765ec76a6450f39810f47427b8eb26 Mon Sep 17 00:00:00 2001 From: Sabrina Ferguson Date: Wed, 12 Jun 2024 14:39:39 -0400 Subject: [PATCH] chore: add pr title check workflow --- .github/workflows/check-pr-title.yaml | 59 +++++++++++++++++++++++++++ 1 file changed, 59 insertions(+) create mode 100644 .github/workflows/check-pr-title.yaml diff --git a/.github/workflows/check-pr-title.yaml b/.github/workflows/check-pr-title.yaml new file mode 100644 index 00000000..92cf1af6 --- /dev/null +++ b/.github/workflows/check-pr-title.yaml @@ -0,0 +1,59 @@ +name: check 📓 + +on: + pull_request_target: + types: + - opened + - edited + - synchronize + +jobs: + main: + name: validate PR title + runs-on: ubuntu-latest + permissions: + pull-requests: write + statuses: write + contents: read + steps: + - uses: amannn/action-semantic-pull-request@v5.5.2 + id: lint_pr_title + env: + GITHUB_TOKEN: ${{ github.token }} + with: + types: | + fix + feat + docs + ci + chore + requireScope: false + wip: true + + - uses: marocchino/sticky-pull-request-comment@v2.9.0 + # When the previous steps fails, the workflow would stop. By adding this + # condition you can continue the execution with the populated error message. + if: always() && (steps.lint_pr_title.outputs.error_message != null) + with: + header: pr-title-lint-error + GITHUB_TOKEN: ${{ github.token }} + message: | + Hey there and thank you for opening this pull request! 👋🏼 + + We require pull request titles to follow the [Conventional Commits specification](https://www.conventionalcommits.org/en/v1.0.0/) and it looks like your proposed title needs to be adjusted. + + If your PR is still a work in progress, please prefix the title with "[WIP]". + + Details: + + ``` + ${{ steps.lint_pr_title.outputs.error_message }} + ``` + + # Delete a previous comment when the issue has been resolved + - if: ${{ steps.lint_pr_title.outputs.error_message == null }} + uses: marocchino/sticky-pull-request-comment@v2.9.0 + with: + header: pr-title-lint-error + GITHUB_TOKEN: ${{ github.token }} + delete: true