GitHub action to check if pull requests have their corresponding issues linked, in order to enforce traceability.
See action.yml.
Configure a workflow to run a job on these pull_request
or pull_request_target
events.
If you enable the comments
option (enabled by default) we recommend to listen on pull_request_target
event.
pull_request_target
event has write permission to the target repository allowing external forks to create comments.
name: Check linked issues
on:
pull_request_target:
types: [opened, edited, reopened, synchronize]
jobs:
check_pull_requests:
runs-on: ubuntu-latest
name: Check linked issues
permissions:
issues: write
steps:
- uses: nearform-actions/github-action-check-linked-issues@v1
id: check-linked-issues
with:
exclude-branches: "release/**, dependabot/**"
# OPTIONAL: Use the output from the `check-linked-issues` step
- name: Get the output
run: echo "How many linked issues? ${{ steps.check-linked-issues.outputs.linked_issues_count }}"
When the action cannot find any linked issues it will fail explaining the reason.
By default, when the job fails it adds a new comment on Pull Request, but you can also write your custom comment setting
custom-body-comment
.
on:
pull_request_target:
types: [opened, edited, reopened, synchronize]
jobs:
check_pull_requests:
runs-on: ubuntu-latest
name: Check linked issues
permissions:
issues: write
steps:
- uses: nearform-actions/github-action-check-linked-issues@v1
id: check-linked-issues
with:
exclude-branches: "release/**, dependabot/**"
custom-body-comment: "Here is a custom comment!"
# OPTIONAL: Use the output from the `check-linked-issues` step
- name: Get the output
run: echo "How many linked issues? ${{ steps.check-linked-issues.outputs.linked_issues_count }}"
To disable comments in your Pull Request, you just need to set comment
to false.
on:
pull_request_target:
types: [opened, edited, reopened, synchronize]
jobs:
check_pull_requests:
runs-on: ubuntu-latest
name: Check linked issues
permissions:
issues: write
steps:
- uses: nearform-actions/github-action-check-linked-issues@v1
id: check-linked-issues
with:
exclude-branches: "release/**, dependabot/**"
comment: false
# OPTIONAL: Use the output from the `check-linked-issues` step
- name: Get the output
run: echo "How many linked issues? ${{ steps.check-linked-issues.outputs.linked_issues_count }}"
Currently you must link issues from the pull request description.
See the docs for more information about the supported syntax.
When you manually link up issues from the sidebar on the github.com UI, the workflow doesn't trigger. On the other hand, if you link up issues from your commits, then the PR doesn't get linked on your Projects board.
This is a GitHub limitation. This table shows what happens:
Linked from: | Workflow triggered? | Query works? | Appears on Projects? |
---|---|---|---|
Sidebar UI | ❌ | ✅ | ✅ |
Commit message | ✅ | ❌ | ❌ |
PR description | ✅ | ✅ | ✅ |
Please DO NOT link issues manually from the sidebar, neither from commit messages.
You can also reference issues outside of the repository on which the workflow is running. This works only if the repository containing the issue is public
. Issues in private repositories are not accessible by this action.