From 6c296f98db9edb9d4fad22cc1ea33926e3ac3a7e Mon Sep 17 00:00:00 2001 From: Oded Ben Ozer Date: Wed, 15 May 2024 10:46:17 +0200 Subject: [PATCH 1/3] Support automaticallyh merging PRs that don't affect target clusters --- docs/installation.md | 4 ++++ internal/pkg/configuration/config.go | 1 + internal/pkg/githubapi/github.go | 9 ++++++++- 3 files changed, 13 insertions(+), 1 deletion(-) diff --git a/docs/installation.md b/docs/installation.md index a6b01b9..eb4deb4 100644 --- a/docs/installation.md +++ b/docs/installation.md @@ -117,6 +117,8 @@ Configuration keys: |`dryRunMode`| if true, the bot will just comment the planned promotion on the merged PR| |`autoApprovePromotionPrs`| if true the bot will auto-approve all promotion PRs, with the assumption the original PR was peer reviewed and is promoted verbatim. Required additional GH token via APPROVER_GITHUB_OAUTH_TOKEN env variable| |`toggleCommitStatus`| Map of strings, allow (non-repo-admin) users to change the [Github commit status](https://docs.github.com/en/rest/commits/statuses) state(from failure to success and back). This can be used to continue promotion of a change that doesn't pass repo checks. the keys are strings commented in the PRs, values are [Github commit status context](https://docs.github.com/en/rest/commits/statuses?apiVersion=2022-11-28#create-a-commit-status) to be overridden| +|`commentArgocdDiffonPR`| Uses ArgoCD API to calculate expected changes to k8s state and comment the resulting "diff" as comment in the PR. Requires ARGOCD_* environment variables, see below. | +|`autoMergeNoDiffPRs`| if true the Telefonistka will **merge** promotion PRs,that are not expected the change target clusters. Requires `commentArgocdDiffonPR` and possibly `autoApprovePromotionPrs`(depending on repo branch protection rules)| Example: @@ -159,6 +161,8 @@ promotionPaths: - "clusters/prod/us-east4/c2" dryRunMode: true autoApprovePromotionPrs: true +commentArgocdDiffonPR: true +autoMergeNoDiffPRs: true toggleCommitStatus: override-terrafrom-pipeline: "github-action-terraform" ``` diff --git a/internal/pkg/configuration/config.go b/internal/pkg/configuration/config.go index 531fe37..ea82282 100644 --- a/internal/pkg/configuration/config.go +++ b/internal/pkg/configuration/config.go @@ -41,6 +41,7 @@ type Config struct { ToggleCommitStatus map[string]string `yaml:"toggleCommitStatus"` WebhookEndpointRegexs []WebhookEndpointRegex `yaml:"webhookEndpointRegexs"` CommentArgocdDiffonPR bool `yaml:"commentArgocdDiffonPR"` + AutoMergeNoDiffPRs bool `yaml:"autoMergeNoDiffPRs"` } func ParseConfigFromYaml(y string) (*Config, error) { diff --git a/internal/pkg/githubapi/github.go b/internal/pkg/githubapi/github.go index 6b61867..9f636b0 100644 --- a/internal/pkg/githubapi/github.go +++ b/internal/pkg/githubapi/github.go @@ -124,7 +124,14 @@ func HandlePREvent(eventPayload *github.PullRequestEvent, ghPrClientDetails GhPr } else { ghPrClientDetails.PrLogger.Debugf("PR %v labeled\n%+v", *eventPayload.PullRequest.Number, prLables) } - // TODO Auto-merge PRs with no changes(optional) + if DoesPrHasLabel(*eventPayload, "promotion") && config.AutoMergeNoDiffPRs { + ghPrClientDetails.PrLogger.Infof("Auto-merging (no diff)PR %d", *eventPayload.PullRequest.Number) + err := MergePr(ghPrClientDetails, eventPayload.PullRequest.Number) + if err != nil { + prHandleError = err + ghPrClientDetails.PrLogger.Errorf("PR auto merge failed: err=%v", err) + } + } } } From 02dbe3b3955cf712554423dc136d10d2009e95af Mon Sep 17 00:00:00 2001 From: Oded Ben Ozer Date: Wed, 15 May 2024 11:38:06 +0200 Subject: [PATCH 2/3] Update docs/installation.md Co-authored-by: Sunil Aggarwal --- docs/installation.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/installation.md b/docs/installation.md index eb4deb4..050eb35 100644 --- a/docs/installation.md +++ b/docs/installation.md @@ -118,7 +118,7 @@ Configuration keys: |`autoApprovePromotionPrs`| if true the bot will auto-approve all promotion PRs, with the assumption the original PR was peer reviewed and is promoted verbatim. Required additional GH token via APPROVER_GITHUB_OAUTH_TOKEN env variable| |`toggleCommitStatus`| Map of strings, allow (non-repo-admin) users to change the [Github commit status](https://docs.github.com/en/rest/commits/statuses) state(from failure to success and back). This can be used to continue promotion of a change that doesn't pass repo checks. the keys are strings commented in the PRs, values are [Github commit status context](https://docs.github.com/en/rest/commits/statuses?apiVersion=2022-11-28#create-a-commit-status) to be overridden| |`commentArgocdDiffonPR`| Uses ArgoCD API to calculate expected changes to k8s state and comment the resulting "diff" as comment in the PR. Requires ARGOCD_* environment variables, see below. | -|`autoMergeNoDiffPRs`| if true the Telefonistka will **merge** promotion PRs,that are not expected the change target clusters. Requires `commentArgocdDiffonPR` and possibly `autoApprovePromotionPrs`(depending on repo branch protection rules)| +|`autoMergeNoDiffPRs`| if true, Telefonistka will **merge** promotion PRs that are not expected to change the target clusters. Requires `commentArgocdDiffonPR` and possibly `autoApprovePromotionPrs`(depending on repo branch protection rules)| Example: From 536b99f40a750ad16710ab5e1d1d61df9c9e5f3b Mon Sep 17 00:00:00 2001 From: Oded Ben Ozer Date: Wed, 15 May 2024 11:38:27 +0200 Subject: [PATCH 3/3] Update internal/pkg/githubapi/github.go Co-authored-by: Sunil Aggarwal --- internal/pkg/githubapi/github.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/internal/pkg/githubapi/github.go b/internal/pkg/githubapi/github.go index 9f636b0..8d91a62 100644 --- a/internal/pkg/githubapi/github.go +++ b/internal/pkg/githubapi/github.go @@ -125,7 +125,7 @@ func HandlePREvent(eventPayload *github.PullRequestEvent, ghPrClientDetails GhPr ghPrClientDetails.PrLogger.Debugf("PR %v labeled\n%+v", *eventPayload.PullRequest.Number, prLables) } if DoesPrHasLabel(*eventPayload, "promotion") && config.AutoMergeNoDiffPRs { - ghPrClientDetails.PrLogger.Infof("Auto-merging (no diff)PR %d", *eventPayload.PullRequest.Number) + ghPrClientDetails.PrLogger.Infof("Auto-merging (no diff) PR %d", *eventPayload.PullRequest.Number) err := MergePr(ghPrClientDetails, eventPayload.PullRequest.Number) if err != nil { prHandleError = err