-
-
Notifications
You must be signed in to change notification settings - Fork 0
72 lines (62 loc) · 2.83 KB
/
semantic-pull-request.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
# https://help.github.com/en/categories/automating-your-workflow-with-github-actions
name: "Semantic Pull Request"
on: # yamllint disable-line rule:truthy
pull_request_target:
types:
- "opened"
- "reopened"
- "edited"
- "synchronize"
merge_group: # yamllint disable-line rule:empty-values
permissions:
contents: "read"
jobs:
semantic-pull-request:
permissions:
pull-requests: "write" # to analyze PRs (amannn/action-semantic-pull-request)
statuses: "write" # to mark status of analyzed PR (amannn/action-semantic-pull-request)
runs-on: "ubuntu-latest"
name: "Semantic Pull Request"
steps:
- name: "Harden Runner"
uses: "step-security/harden-runner@a4aa98b93cab29d9b1101a6143fb8bce00e2eac4" # v2.7.1
with:
egress-policy: "audit"
- name: "Validate PR title"
id: "lint_pr_title"
uses: "amannn/action-semantic-pull-request@0723387faaf9b38adef4775cd42cfd5155ed6017" # v5.5.3
env:
GITHUB_TOKEN: "${{ secrets.GITHUB_TOKEN }}"
with:
types: |
build
chore
ci
docs
feat
fix
perf
infra
refactor
revert
test
- uses: "marocchino/sticky-pull-request-comment@331f8f5b4215f0445d3c07b4967662a32a2d3e31" # v2.9.0
# When the previous steps fail, 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"
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.
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@331f8f5b4215f0445d3c07b4967662a32a2d3e31" # v2.9.0
with:
header: "pr-title-lint-error"
message: |
Thank you for following the naming conventions! 🙏