-
-
Notifications
You must be signed in to change notification settings - Fork 7
63 lines (51 loc) · 2 KB
/
pr-issue-check.yml
File metadata and controls
63 lines (51 loc) · 2 KB
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
name: PR Issue Check
on:
pull_request:
types: [opened, edited]
permissions:
contents: read
pull-requests: write
jobs:
check-issue-link:
name: Check for linked issues
runs-on: ubuntu-latest
steps:
- name: Check PR body for issue references
uses: actions/github-script@ed597411d8f924073f98dfc5c65a23a2325f34cd # v8
with:
script: |
const prBody = context.payload.pull_request.body || '';
// Patterns for issue references
const patterns = [
/(?:closes|fixes|resolves)\s+#\d+/gi,
/(?:closes|fixes|resolves)\s+[\w-]+\/[\w-]+#\d+/gi,
/#\d+/g
];
const hasIssueRef = patterns.some(pattern => pattern.test(prBody));
if (!hasIssueRef) {
// Check if we already commented
const comments = await github.rest.issues.listComments({
owner: context.repo.owner,
repo: context.repo.repo,
issue_number: context.payload.pull_request.number
});
const botComment = comments.data.find(c =>
c.user.type === 'Bot' &&
c.body.includes('<!-- pr-issue-check -->')
);
if (!botComment) {
await github.rest.issues.createComment({
owner: context.repo.owner,
repo: context.repo.repo,
issue_number: context.payload.pull_request.number,
body: `<!-- pr-issue-check -->
### Issue Linking Reminder
This PR doesn't appear to have a linked issue. Consider linking to:
- **This repo**: \`Closes #123\`
- **ralph-ideas**: \`Closes multivmlabs/ralph-ideas#123\`
Using \`Closes\`, \`Fixes\`, or \`Resolves\` will auto-close the issue when this PR is merged.
---
*If this PR doesn't need an issue, you can ignore this message.*`
});
}
}