Release tracking #9124
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: Assign Release Conductor | |
on: | |
pull_request: | |
workflow_dispatch: | |
inputs: | |
pull-request: | |
type: number | |
description: Pull Request Number | |
required: true | |
jobs: | |
assign-release-conductor: | |
if: github.head_ref == 'changeset-release/main' | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- uses: actions/setup-node@v4 | |
with: | |
node-version: 20 | |
- run: npm i -g npm@^10.5.1 | |
- run: npm ci | |
- uses: ./.github/actions/pagerduty | |
id: pagerduty | |
with: | |
schedule-id: 'P3IIVC4' | |
token: ${{ secrets.PAGERDUTY_API_KEY_SID }} | |
- run: echo ${{ steps.pagerduty.outputs.user }} is release conductor | |
- name: Add user as assignee and reviewer | |
uses: actions/github-script@v7 | |
env: | |
PR_NUMBER: ${{ github.event.inputs.pull-request || github.event.pull_request.number }} | |
RELEASE_CONDUCTOR: ${{ steps.pagerduty.outputs.user }} | |
PREV_RELEASE_CONDUCTOR: ${{ steps.pagerduty.outputs.previous-schedule-user }} | |
with: | |
script: | | |
const { PR_NUMBER, RELEASE_CONDUCTOR, PREV_RELEASE_CONDUCTOR } = process.env; | |
const { data: pull } = await github.rest.pulls.get({ | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
pull_number: PR_NUMBER, | |
}); | |
// If the previous release conductor was added as an assignee, remove them | |
const hasPreviousAssignee = pull.assignees.find((assignee) => { | |
return assignee.login === PREV_RELEASE_CONDUCTOR; | |
}); | |
if (hasPreviousAssignee) { | |
await github.rest.issues.removeAssignees({ | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
issue_number: PR_NUMBER, | |
assignees: [PREV_RELEASE_CONDUCTOR], | |
}); | |
} | |
// If the previous release conductor was added as a reviewer, remove them | |
const { data: requestedReviewers } = await github.rest.pulls.listRequestedReviewers({ | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
pull_number: PR_NUMBER, | |
}); | |
const hasPreviousReviewer = requestedReviewers.users.find((user) => { | |
return user.login === PREV_RELEASE_CONDUCTOR; | |
}); | |
// Add the current release conductor as an assignee if they are not currently assigned | |
const hasAssignee = pull.assignees.find((assignee) => { | |
return assignee.login === RELEASE_CONDUCTOR; | |
}); | |
if (!hasAssignee) { | |
await github.rest.issues.addAssignees({ | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
issue_number: PR_NUMBER, | |
assignees: [RELEASE_CONDUCTOR] | |
}) | |
} | |
// Request the current release conductor as a reviewer if they are not currently requested | |
const hasReviewer = requestedReviewers.users.find((user) => { | |
return user.login === RELEASE_CONDUCTOR; | |
}); | |
if (!hasReviewer) { | |
await github.rest.pulls.requestReviewers({ | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
pull_number: PR_NUMBER, | |
reviewers: [RELEASE_CONDUCTOR] | |
}) | |
} | |
if (hasPreviousReviewer) { | |
await github.rest.pulls.removeRequestedReviewers({ | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
pull_number: PR_NUMBER, | |
reviewers: [PREV_RELEASE_CONDUCTOR], | |
}); | |
} |