From f61457d007e1e5f7b0857e49937ef71ad15132d5 Mon Sep 17 00:00:00 2001 From: Nabarun Pal Date: Mon, 15 Nov 2021 17:17:33 +0530 Subject: [PATCH 1/2] krel/promote-images: make an error message more verbose When `krel promote-images` is called without passing a GitHub token, the error message didn't say what env var should be set. This commit adds the same to the error message. Signed-off-by: Nabarun Pal --- cmd/krel/cmd/promote-images.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/cmd/krel/cmd/promote-images.go b/cmd/krel/cmd/promote-images.go index 7197fc2daf2..0b96d019f0f 100644 --- a/cmd/krel/cmd/promote-images.go +++ b/cmd/krel/cmd/promote-images.go @@ -87,7 +87,7 @@ func (o *promoteOptions) Validate() error { // Check that the GitHub token is set token, isSet := os.LookupEnv(github.TokenEnvKey) if !isSet || token == "" { - return errors.New("cannot promote images if GitHub token is not set") + return fmt.Errorf("cannot promote images if GitHub token env var %s is not set", github.TokenEnvKey) } return nil } From f032d32b742ba9eb764e770f1f19d1db51022b58 Mon Sep 17 00:00:00 2001 From: Nabarun Pal Date: Mon, 15 Nov 2021 19:34:31 +0530 Subject: [PATCH 2/2] krel/promote-images: update promotion PR body to have the command This will be helpful to verify the changes, if required to do so. Signed-off-by: Nabarun Pal --- cmd/krel/cmd/promote-images.go | 39 ++++++++++++++++++++++++++++------ 1 file changed, 32 insertions(+), 7 deletions(-) diff --git a/cmd/krel/cmd/promote-images.go b/cmd/krel/cmd/promote-images.go index 0b96d019f0f..630e1fdc4b4 100644 --- a/cmd/krel/cmd/promote-images.go +++ b/cmd/krel/cmd/promote-images.go @@ -38,6 +38,8 @@ const ( k8sioRepo = "k8s.io" k8sioDefaultBranch = "main" promotionBranchSuffix = "-image-promotion" + defaultProject = release.Kubernetes + defaultReviewers = "@kubernetes/release-engineering" ) // promoteCommand is the krel subcommand to promote conainer images @@ -98,7 +100,7 @@ func init() { imagePromoteCommand.PersistentFlags().StringVar( &promoteOpts.project, "project", - release.Kubernetes, + defaultProject, "the name of the project to promote images for", ) @@ -120,7 +122,7 @@ func init() { imagePromoteCommand.PersistentFlags().StringVar( &promoteOpts.reviewers, "reviewers", - "@kubernetes/release-engineering", + defaultReviewers, "the list of GitHub users or teams to assign to the PR", ) @@ -289,16 +291,12 @@ func runPromote(opts *promoteOptions) error { return nil } - prBody := fmt.Sprintf("Image promotion for %s %s\n", opts.project, strings.Join(opts.tags, " / ")) - prBody += "This is an automated PR generated from `krel The Kubernetes Release Toolbox`\n\n" - prBody += fmt.Sprintf("/hold\ncc: %s\n", opts.reviewers) - // Create the Pull Request if mustRun(opts, "Create pull request?") { pr, err := gh.CreatePullRequest( git.DefaultGithubOrg, k8sioRepo, k8sioDefaultBranch, fmt.Sprintf("%s:%s", userForkOrg, branchname), - commitMessage, prBody, + commitMessage, generatePRBody(opts), ) if err != nil { return errors.Wrap(err, "creating the pull request in k/k8s.io") @@ -331,3 +329,30 @@ func mustRun(opts *promoteOptions, question string) bool { } return false } + +// generatePRBody creates the body of the Image Promotion Pull Request +func generatePRBody(opts *promoteOptions) string { + args := fmt.Sprintf("--fork %s", opts.userFork) + if opts.interactiveMode { + args += " --interactive" + } + + if opts.project != defaultProject { + args += " --project" + opts.project + } + + if opts.reviewers != defaultReviewers { + args += " --reviewers" + opts.reviewers + } + + for _, tag := range opts.tags { + args += " --tag " + tag + } + + prBody := fmt.Sprintf("Image promotion for %s %s\n", opts.project, strings.Join(opts.tags, " / ")) + prBody += "This is an automated PR generated from `krel The Kubernetes Release Toolbox`\n" + prBody += fmt.Sprintf("```\nkrel promote-images %s\n```\n\n", args) + prBody += fmt.Sprintf("/hold\ncc: %s\n", opts.reviewers) + + return prBody +}