Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

test: Integrate Git Hub Action Results into Tide #11262

Merged

Conversation

VaniHaripriya
Copy link
Contributor

@VaniHaripriya VaniHaripriya commented Oct 1, 2024

Description of your changes:

  • Introduced a GitHub Action workflow to validate the successful completion of all CI checks.
  • Automatically adds a ci-passed label once all CI checks have passed.
  • Removes the ci-passed label when the pull request is either synchronized or reopened.

PR to update GoogleCloudPlatform/oss-test-infra
GoogleCloudPlatform/oss-test-infra#2392

Checklist:

Copy link

Hi @VaniHaripriya. Thanks for your PR.

I'm waiting for a kubeflow member to verify that this patch is reasonable to test. If it is, they should reply with /ok-to-test on its own line. Until that is done, I will not automatically test new commits in this PR, but the usual testing commands by org members will still work. Regular contributors should join the org to skip this step.

Once the patch is verified, the new status will be reflected by the ok-to-test label.

I understand the commands that are listed here.

Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes/test-infra repository.

@VaniHaripriya VaniHaripriya force-pushed the ghaction-tide-integration branch 4 times, most recently from b63e395 to 1cf98e2 Compare October 1, 2024 18:33
@VaniHaripriya VaniHaripriya marked this pull request as ready for review October 1, 2024 19:02
@VaniHaripriya VaniHaripriya changed the title test: Integrate Git Hub Actions into Tide test: Integrate Git Hub Action Results into Tide Oct 1, 2024
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
steps:
- name: Remove 'ci-passed' Label on PR Synchronize
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

For clarity I would rename this to "Reset ci-passed label status on PR Syncronization" - as it stands it suggests the label should no longer exist after a sync event (even though the very next check is attempting to re-add it)

pull-requests: write

jobs:
remove_ci_passed_label:
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

similar to below, perhaps we should rename this to say reset instead of remove

@VaniHaripriya VaniHaripriya force-pushed the ghaction-tide-integration branch from 64c92ac to d462580 Compare October 1, 2024 19:17
- name: Add 'ci-passed' label
if: success()
run: |
gh pr edit ${{ github.event.pull_request.number }} --add-label "ci-passed" --repo $GITHUB_REPOSITORY
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It seems like the gh pr edit --add-label command requires that the labels you are adding already exist in your repository. It cannot create new labels on the fly; it can only assign existing labels to pull requests. From the GitHub CLI manual for gh pr edit:

--add-label stringArray
    Add labels by name

This makes me think that the command expects the label names provided to match existing labels in the repository.

- name: Reset ci-passed label status on PR Syncronization
run: |
echo "Resetting 'ci-passed' label as new changes have been pushed."
gh pr edit ${{ github.event.pull_request.number }} --remove-label "ci-passed" --repo $GITHUB_REPOSITORY || echo "Label not present"
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@DharmitD That's correct. @HumairAK added the 'ci-passed' label to the repo.

@VaniHaripriya
Copy link
Contributor Author

/rerun-all

@gmfrasca
Copy link
Member

gmfrasca commented Oct 2, 2024

/ok-to-test

(not sure if that label is needed for /rerun-all to work)

@gmfrasca
Copy link
Member

gmfrasca commented Oct 2, 2024

/rerun-all

- name: Check if all CI checks passed
uses: wechuli/allcheckspassed@0b68b3b7d92e595bcbdea0c860d05605720cf479
with:
GITHUB_TOKEN: ${{ env.GITHUB_TOKEN }}
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm not sure this is needed (There is a warning in the GHAction result logs about GITHUB_TOKEN being an unexpected key).

Documentation suggests this either should be under steps[].env, or more likely this is already covered by the job env

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Good catch @gmfrasca will update accordingly..

@VaniHaripriya VaniHaripriya force-pushed the ghaction-tide-integration branch from 4d556b1 to dc64098 Compare October 3, 2024 19:23
@gmfrasca
Copy link
Member

gmfrasca commented Oct 3, 2024

Resource not accessible by integration (addLabelsToLabelable)

sounds like the GITHUB_TOKEN provided doesn't have proper permissions to add the label (likely needs write on pull-requests)

@VaniHaripriya VaniHaripriya force-pushed the ghaction-tide-integration branch 4 times, most recently from cb66d69 to e0859f0 Compare October 3, 2024 23:35
@VaniHaripriya VaniHaripriya force-pushed the ghaction-tide-integration branch 2 times, most recently from 1c36394 to 79a6893 Compare October 4, 2024 16:02
@HumairAK
Copy link
Collaborator

HumairAK commented Oct 4, 2024

the token's permissions are limited when runnin on PRs

https://docs.github.com/en/actions/security-for-github-actions/security-guides/automatic-token-authentication#permissions-for-the-github_token

GraphQL: Resource not accessible by integration (addLabelsToLabelable)

we have to be careful here, if we give this workflow the permission to add labels, users will be able to change the workflow and game their way to a merge by adjusting the checks/labels

you can use workflow_run event to put a workflow in main , and run the label add functionality there, this should have access to ${{ secrets.GITHUB_TOKEN }} because it's running from main branch

@VaniHaripriya VaniHaripriya force-pushed the ghaction-tide-integration branch from dc26665 to 62fac1c Compare October 7, 2024 03:42
@@ -0,0 +1,24 @@
# This workflow adds the 'ci-passed' label to a pull request once the 'CI Check' workflow completes successfully.

name: Labeling Workflow
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The name "Labeling Workflow" and labeling.yml gives the impression that this workflow is intended for any label.
We should probably rename it (and the file) to something like "Add ci-passed label".

@google-oss-prow google-oss-prow bot added size/L and removed size/M labels Oct 9, 2024
@VaniHaripriya VaniHaripriya force-pushed the ghaction-tide-integration branch 2 times, most recently from 005d8f0 to 76d3187 Compare October 10, 2024 03:27
Copy link
Contributor

@hbelmiro hbelmiro left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

/lgtm

Copy link
Contributor

@DharmitD DharmitD left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

/lgtm

@VaniHaripriya VaniHaripriya force-pushed the ghaction-tide-integration branch from 6278cfc to 91328b1 Compare October 10, 2024 16:04
Copy link

[APPROVALNOTIFIER] This PR is APPROVED

This pull-request has been approved by: hbelmiro

The full list of commands accepted by this bot can be found here.

The pull request process is described here

Needs approval from an approver in each of these files:

Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment

@hbelmiro
Copy link
Contributor

/lgtm

@google-oss-prow google-oss-prow bot added the lgtm label Oct 12, 2024
@google-oss-prow google-oss-prow bot merged commit 4ccb047 into kubeflow:master Oct 12, 2024
3 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants