Fixes PR thank you msg. from potentially tagging the PR author twice #10084
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Auto Add Needs Testing Label | |
on: | |
pull_request: | |
types: [opened, reopened, edited] | |
issue_comment: | |
types: [created] | |
pull_request_review: | |
types: [submitted] | |
jobs: | |
auto_label: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Check PR Conditions and Add Label | |
id: check_conditions | |
uses: actions/github-script@v5 | |
with: | |
github-token: ${{ secrets.GITHUB_TOKEN }} | |
script: | | |
const pr = context.payload.pull_request; | |
const comment = context.payload.comment; | |
const review = context.payload.review; | |
if (pr) { | |
const isDraft = pr.draft; | |
const isReadyForTestingComment = comment && comment.body.includes('ready for testing'); | |
const isChangesRequired = review && review.state === 'changes_requested'; | |
if ((isReadyForTestingComment && !isDraft) || (!isDraft && pr.draft_changed)) { | |
await github.issues.addLabels({ | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
issue_number: pr.number, | |
labels: ['needs testing'] | |
}); | |
} | |
if (isChangesRequired) { | |
await github.rest.issues.createComment({ | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
issue_number: pr.number, | |
body: 'Reminder: To add the "needs testing" label, comment "ready for testing" on this PR.' | |
}); | |
if (pr.labels.some(label => label.name === 'needs testing')) { | |
await github.issues.removeLabel({ | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
issue_number: pr.number, | |
name: 'needs testing' | |
}); | |
} | |
} | |
} |