-
Notifications
You must be signed in to change notification settings - Fork 10
104 lines (89 loc) · 3.28 KB
/
pr-validation.yaml
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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
name: "pr-validation"
on:
pull_request:
permissions:
checks: write
contents: read
pull-requests: write
concurrency:
group: ${{ github.workflow }}-${{ github.event.pull_request.number }}
cancel-in-progress: true
jobs:
autolabeler:
runs-on: ubuntu-latest
steps:
- uses: release-drafter/release-drafter@v5
with:
config-name: release-drafter-config.yaml
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
title-checker:
runs-on: ubuntu-latest
steps:
- uses: amannn/action-semantic-pull-request@v5
id: lint_pr_title
with:
types: |
breaking
bug
docs
documentation
enhancement
feat
feature
fix
misc
security
requireScope: false
ignoreLabels: |
skip-changelog
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- uses: marocchino/sticky-pull-request-comment@v2
# 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
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.
Examples for valid PR titles:
feat(ui): Add button component.
fix: Correct typo.
_type(scope): subject._
Adding a scope is optional
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
with:
header: pr-title-lint-error
delete: true
label-checker:
needs: autolabeler
runs-on: ubuntu-latest
steps:
- uses: danielchabr/[email protected]
id: lint_pr_labels
with:
hasSome: breaking,bug,documentation,enhancement,feature,fix,misc,security
githubToken: ${{ secrets.GITHUB_TOKEN }}
- uses: marocchino/sticky-pull-request-comment@v2
# 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_labels.outputs.passed == false)
with:
header: pr-labels-lint-error
message: |
Hey there and thank you for opening this pull request! 👋🏼
The PR needs to have at least one of the following labels: breaking, bug, documentation, enhancement, feature, fix, misc, security.
# Delete a previous comment when the issue has been resolved
- if: ${{ steps.lint_pr_labels.outputs.passed != false }}
uses: marocchino/sticky-pull-request-comment@v2
with:
header: pr-labels-lint-error
delete: true