Skip to content

Commit

Permalink
chore(prlint): apply needs-maintainer-review label when PR is assigned
Browse files Browse the repository at this point in the history
PRs can only be assigned by members with write access. If a PR has been
assigned to someone, remove the `needs-community-review` label (since it
implies a maintainer is already working on that PR) and apply
the `needs-maintainer-review` label. In order to facilitate this, the
`pull_request_target` event should also be run when a PR is
assigned/unassigned.
  • Loading branch information
laurelmay committed Oct 31, 2023
1 parent b545448 commit 2634115
Show file tree
Hide file tree
Showing 3 changed files with 31 additions and 5 deletions.
2 changes: 2 additions & 0 deletions .github/workflows/pr-linter.yml
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,8 @@ on:
- opened
- synchronize
- reopened
- assigned
- unassigned
workflow_run:
workflows: [PR Linter Trigger]
types:
Expand Down
16 changes: 11 additions & 5 deletions tools/@aws-cdk/prlint/lint.ts
Original file line number Diff line number Diff line change
Expand Up @@ -365,7 +365,7 @@ export class PullRequestLinter {
* 7. It links to a p2 issue and has an approved community review
*/
private async assessNeedsReview(
pr: Pick<GitHubPr, 'mergeable_state' | 'draft' | 'labels' | 'number'>,
pr: Pick<GitHubPr, 'mergeable_state' | 'draft' | 'labels' | 'number' | 'assignees'>,
): Promise<void> {
const reviews = await this.client.pulls.listReviews(this.prParams);
console.log(JSON.stringify(reviews.data));
Expand Down Expand Up @@ -397,6 +397,10 @@ export class PullRequestLinter {
&& review.state === 'COMMENTED',
);

// NOTE: assignment can only be performed by users with write access to the
// repository.
const isAssigned = pr.assignees?.length ? true : false;

const prLinterFailed = reviews.data.find((review) => review.user?.login === 'aws-cdk-automation' && review.state !== 'DISMISSED') as Review;
const userRequestsExemption = pr.labels.some(label => (label.name === Exemption.REQUEST_EXEMPTION || label.name === Exemption.REQUEST_CLARIFICATION));
console.log('evaluation: ', JSON.stringify({
Expand All @@ -408,6 +412,7 @@ export class PullRequestLinter {
communityRequestedChanges,
communityApproved,
userRequestsExemption,
isAssigned,
}, undefined, 2));

const fixesP1 = pr.labels.some(label => label.name === 'p1');
Expand All @@ -430,10 +435,11 @@ export class PullRequestLinter {
}

// needs-maintainer-review means one of the following
// 1) fixes a p1 bug
// 2) is already community approved
// 3) is authored by a core team member
if (readyForReview && (fixesP1 || communityApproved || pr.labels.some(label => label.name === 'contribution/core'))) {
// 1) is assigned
// 2) fixes a p1 bug
// 3) is already community approved
// 4) is authored by a core team member
if (readyForReview && (isAssigned || fixesP1 || communityApproved || pr.labels.some(label => label.name === 'contribution/core'))) {
this.addLabel('pr/needs-maintainer-review', pr);
this.removeLabel('pr/needs-community-review', pr);
} else if (readyForReview && !fixesP1) {
Expand Down
18 changes: 18 additions & 0 deletions tools/@aws-cdk/prlint/test/lint.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -586,6 +586,24 @@ describe('integration tests required on features', () => {
expect(mockRemoveLabel.mock.calls).toEqual([]);
});

test('needs maintainer review when assigned', async () => {
// GIVEN
const assignee = { login: 'testassignee' }
const testPr = {...pr, assignee};

// WHEN
const prLinter = configureMock(testPr);
await prLinter.validatePullRequestTarget(SHA);

// THEN
expect(mockAddLabel.mock.calls[0][0]).toEqual({
issue_number: 1234,
labels: ['pr/needs-maintainer-review'],
owner: 'aws',
repo: 'aws-cdk'
});
})

test('does not need a review because of request changes', async () => {
// GIVEN
mockListReviews.mockImplementation(() => {
Expand Down

0 comments on commit 2634115

Please sign in to comment.