From a0a79dcf4dbb0b251a2e5482624cf481799f8c398522d8ffd0280e2708a39dae Mon Sep 17 00:00:00 2001 From: Adam Majer Date: Mon, 30 Sep 2024 16:19:40 +0200 Subject: [PATCH] pr: add reviewers to PR workflow --- bots-common/config.go | 12 ++++++++++++ workflow-pr/README.md | 6 +++++- workflow-pr/main.go | 9 +++++++-- 3 files changed, 24 insertions(+), 3 deletions(-) diff --git a/bots-common/config.go b/bots-common/config.go index 6c55945..29be0d7 100644 --- a/bots-common/config.go +++ b/bots-common/config.go @@ -22,6 +22,7 @@ import ( "encoding/json" "fmt" "io" + "log" "os" "slices" "strings" @@ -32,6 +33,7 @@ type AutogitConfig struct { Organization string GitProjectName string // Organization/GitProjectName.git is PrjGit Branch string // branch name of PkgGit that aligns with PrjGit submodules + Reviewers []string // only used by `pr` workflow } func ReadWorkflowConfigs(reader io.Reader) ([]*AutogitConfig, error) { @@ -47,7 +49,11 @@ func ReadWorkflowConfigs(reader io.Reader) ([]*AutogitConfig, error) { availableWorkflows := []string{"pr", "direct", "test"} for _, workflow := range config { + pr := false for _, w := range workflow.Workflows { + if w == "pr" { + pr = true + } if !slices.Contains(availableWorkflows, w) { return nil, fmt.Errorf( "Invalid Workflow '%s'. Only available workflows are: %s", @@ -58,6 +64,12 @@ func ReadWorkflowConfigs(reader io.Reader) ([]*AutogitConfig, error) { if len(workflow.GitProjectName) == 0 { workflow.GitProjectName = DefaultGitPrj } + if !pr && len(workflow.Reviewers) > 0 { + log.Println(" Warning: non-PR-only workflows contains Reviewers. These are ignored in Org:", workflow.Organization) + } + if pr && !slices.Contains(workflow.Reviewers, Bot_BuildReview) { + workflow.Reviewers = append(workflow.Reviewers, Bot_BuildReview) + } } return config, nil diff --git a/workflow-pr/README.md b/workflow-pr/README.md index a79870f..25d2e12 100644 --- a/workflow-pr/README.md +++ b/workflow-pr/README.md @@ -27,6 +27,9 @@ JSON * _Organization_: organization that holds all the packages * _Branch_: branch updated in repo's * _GitProjectName_: package in above org, or `org/package` for PrjGit +* _Reviewers_: accounts associated with mandatory reviews for PrjGit. Can trigger additional + review requests for PrjGit or associated PkgGit repos. Only when all reviews are + satisfied, will the PrjGit PR be merged. example: @@ -35,7 +38,8 @@ example: "Workflows": ["pr", "direct"], "Organization": "autogits", "GitProjectName": "HiddenPrj", - "Branch": "hidden" + "Branch": "hidden", + "Reviewers": [] }, ... ] diff --git a/workflow-pr/main.go b/workflow-pr/main.go index d7c690c..b21eb3a 100644 --- a/workflow-pr/main.go +++ b/workflow-pr/main.go @@ -180,7 +180,12 @@ referencing the following pull request: } // request build review - _, err = gitea.RequestReviews(PR, common.Bot_BuildReview) + for _, reviewer := range config.Reviewers { + _, err := gitea.RequestReviews(PR, reviewer) + if err != nil { + return fmt.Errorf("Failed to create reviewer '%s' for request: %s/%s/%d Err: %w", reviewer, PR.Base.Repo.Owner.UserName, PR.Base.Repo.Name, PR.Index, err) + } + } return err } @@ -261,7 +266,7 @@ nextSubmodule: } if DebugMode { - log.Println(" - # of PRs to check:" , len(prs)) + log.Println(" - # of PRs to check:", len(prs)) } for _, pr := range prs {