From 9b06ab4724554f7c91656edb9b36094f10ae76be Mon Sep 17 00:00:00 2001 From: Gauthier Petetin Date: Fri, 24 May 2024 15:55:52 +0200 Subject: [PATCH] ci: skip template check for flaky tests issues (#23857) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit ## **Description** - Flaky test issues do not need to match issues template as their description just includes a link to circleci. Example here: https://github.com/MetaMask/metamask-extension/issues/22702 - By skipping the template check for [issues](https://github.com/MetaMask/metamask-extension/labels/flaky%20tests) labeled with `flaky tests`, we avoid them being automatically labeled with `INVALID-ISSUE-TEMPLATE`. ## **Related issues** - Fixes: None ## **Manual testing steps** 1. Go to this [test repo](https://github.com/gauthierpetetin-test/repo_test) which inlcudes the [same changes](https://github.com/gauthierpetetin-test/repo_test/commit/7446f442a966bef7223047bd8b6b741739e98924) as this PR 2. [Create a new issue](https://github.com/gauthierpetetin-test/repo_test/issues/new?assignees=&labels=&projects=&template=general_issue.yml) with empty description 3. Wait for 30s until the template check Github action is executed 4. Issue shall automatically labeled with `INVALID-ISSUE-TEMPLATE` 5. Label the issue with `flaky tests` label 6. Edit the issue's description (for example by adding a random character in it), to re-trigger the template check Github action 7. Wait for 30s until the template check Github action is executed 8. `INVALID-ISSUE-TEMPLATE` label shall automatically be removed from issue ## **Screenshots/Recordings** - None ## **Pre-merge author checklist** - [x] I’ve followed [MetaMask Coding Standards](https://github.com/MetaMask/metamask-extension/blob/develop/.github/guidelines/CODING_GUIDELINES.md). - [x] I've completed the PR template to the best of my ability - [x] I’ve included tests if applicable - [x] I’ve documented my code using [JSDoc](https://jsdoc.app/) format if applicable - [x] I’ve applied the right labels on the PR (see [labeling guidelines](https://github.com/MetaMask/metamask-extension/blob/develop/.github/guidelines/LABELING_GUIDELINES.md)). Not required for external contributors. ## **Pre-merge reviewer checklist** - [ ] I've manually tested the PR (e.g. pull and build branch, run the app, test code being changed). - [ ] I confirm that this PR addresses all acceptance criteria described in the ticket it closes and includes the necessary testing evidence such as recordings and or screenshots. --- .github/guidelines/LABELING_GUIDELINES.md | 2 +- .../scripts/check-template-and-add-labels.ts | 15 ++++++++++++++ .github/scripts/shared/label.ts | 6 ++++++ .github/scripts/shared/labelable.ts | 20 +++++++++++++++---- 4 files changed, 38 insertions(+), 5 deletions(-) diff --git a/.github/guidelines/LABELING_GUIDELINES.md b/.github/guidelines/LABELING_GUIDELINES.md index dbdd3b2ed9b8..e718e3f1d38b 100644 --- a/.github/guidelines/LABELING_GUIDELINES.md +++ b/.github/guidelines/LABELING_GUIDELINES.md @@ -13,7 +13,7 @@ It's essential to ensure that PRs have the appropriate labels before they are co - **regression-prod-x.y.z**: This label is automatically added to a bug report issue at the time of its creation. The `x.y.z` in the label represents the version in which the bug first appeared. This label is auto-generated by a [GitHub action](../workflows/check-template-and-add-labels.yml), which determines the `x.y.z` value based on the version information provided in the bug report issue form. Manual intervention is only necessary under certain circumstances. For example, if a user submits a bug report and specifies the version they are currently using, but the bug was actually introduced in a prior version, the label would need to be manually updated to accurately reflect the version where the bug originated. ### Optional labels: -- **regression-develop**: This label can manually be added to a bug report issue at the time of its creation if the bug is present on development branch (i.e. `develop`), but is not yet released in production. +- **regression-develop**: This label can manually be added to a bug report issue at the time of its creation if the bug is present on the development branch, i.e., `develop`, but is not yet released in production. - **needs-qa**: If the PR includes a new features, complex testing steps, or large refactors, this label must be added to indicated PR requires a full manual QA prior being merged and added to a release. ### Labels prohibited when PR needs to be merged: diff --git a/.github/scripts/check-template-and-add-labels.ts b/.github/scripts/check-template-and-add-labels.ts index abcc53a3496b..7551ff607851 100644 --- a/.github/scripts/check-template-and-add-labels.ts +++ b/.github/scripts/check-template-and-add-labels.ts @@ -6,6 +6,7 @@ import { retrieveIssue } from './shared/issue'; import { Labelable, LabelableType, + findLabel, addLabelToLabelable, removeLabelFromLabelable, removeLabelFromLabelableIfPresent, @@ -13,6 +14,7 @@ import { import { Label, externalContributorLabel, + flakyTestsLabel, invalidIssueTemplateLabel, invalidPullRequestTemplateLabel, } from './shared/label'; @@ -90,6 +92,19 @@ async function main(): Promise { } if (labelable.type === LabelableType.Issue) { + + // If labelable is a flaky test report, no template is needed (we just add a link to circle.ci in the description), we skip the template checks + const flakyTestsLabelFound = findLabel(labelable, flakyTestsLabel); + if (flakyTestsLabelFound?.id) { + console.log(`Issue ${labelable?.number} was created to report a flaky test. Issue's description doesn't need to match issue template in that case as the issue's description only includes a link redirecting to circle.ci. Skip template checks.`); + await removeLabelFromLabelableIfPresent( + octokit, + labelable, + invalidIssueTemplateLabel, + ); + process.exit(0); // Stop the process and exit with a success status code + } + if (templateType === TemplateType.GeneralIssue) { console.log("Issue matches 'general-issue.yml' template."); await removeLabelFromLabelableIfPresent( diff --git a/.github/scripts/shared/label.ts b/.github/scripts/shared/label.ts index 32097fda66ee..2a0632a263de 100644 --- a/.github/scripts/shared/label.ts +++ b/.github/scripts/shared/label.ts @@ -14,6 +14,12 @@ export const externalContributorLabel: Label = { description: 'Issue or PR created by user outside org', }; +export const flakyTestsLabel: Label = { + name: 'flaky tests', + color: 'BE564E', + description: 'Flaky test report', +}; + export const invalidIssueTemplateLabel: Label = { name: 'INVALID-ISSUE-TEMPLATE', color: 'EDEDED', diff --git a/.github/scripts/shared/labelable.ts b/.github/scripts/shared/labelable.ts index 56a8675190c0..9726297ea714 100644 --- a/.github/scripts/shared/labelable.ts +++ b/.github/scripts/shared/labelable.ts @@ -23,6 +23,20 @@ export interface Labelable { }[]; } +// This function tries to find a label on a labelable object (i.e. a pull request or an issue) if present +export function findLabel( + labelable: Labelable, + labelToFind: Label, +): { + id: string; + name: string; +} | undefined { + // Check if label is present on labelable + return labelable.labels.find( + (label) => label.name === labelToFind.name, + ); +} + // This function adds label to a labelable object (i.e. a pull request or an issue) export async function addLabelToLabelable( octokit: InstanceType, @@ -77,10 +91,8 @@ export async function removeLabelFromLabelableIfPresent( labelable: Labelable, labelToRemove: Label, ): Promise { - // Check if label is present on issue - const labelFound = labelable?.labels?.find( - (label) => label.name === labelToRemove?.name, - ); + // Check if label is present on labelable + const labelFound = findLabel(labelable, labelToRemove); if (labelFound?.id) { // Remove label from labelable