wip
This commit is contained in:
parent
a7d81d6013
commit
68ba45ca9c
@ -125,9 +125,13 @@ func IsPrjGitPRApproved(gitea common.GiteaMaintainershipInterface, giteapr Gitea
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
requiredReviews := slices.Clone(config.Reviewers)
|
||||||
for _, r := range prjPR.reviews {
|
for _, r := range prjPR.reviews {
|
||||||
|
if !r.Stale && r.State == common.ReviewStateApproved && slices.Contains(requiredReviews, r.User.UserName) {
|
||||||
|
idx := slices.Index(requiredReviews, r.User.UserName)
|
||||||
|
requiredReviews = slices.Delete(requiredReviews, idx, idx+1)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return true, nil
|
return len(requiredReviews) == 0, nil
|
||||||
}
|
}
|
||||||
|
@ -179,7 +179,7 @@ func TestReviewApproval(t *testing.T) {
|
|||||||
}{
|
}{
|
||||||
{
|
{
|
||||||
name: "Maintainer not approved",
|
name: "Maintainer not approved",
|
||||||
pr: &models.PullRequest{Body: "", Index: 10, RequestedReviewers: []*models.User{}},
|
pr: &models.PullRequest{Body: "PR: foo/foo#10", Index: 10, RequestedReviewers: []*models.User{}},
|
||||||
reviews: []*models.PullReview{},
|
reviews: []*models.PullReview{},
|
||||||
|
|
||||||
maintainerFile: []byte(`{"foo": ["bingo"]}`),
|
maintainerFile: []byte(`{"foo": ["bingo"]}`),
|
||||||
@ -187,11 +187,11 @@ func TestReviewApproval(t *testing.T) {
|
|||||||
approved: false,
|
approved: false,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "Maintainer approved",
|
name: "Maintainer approved",
|
||||||
pr: &models.PullRequest{Body: "", Index: 10, RequestedReviewers: []*models.User{}},
|
pr: &models.PullRequest{Body: "", Index: 10, RequestedReviewers: []*models.User{}},
|
||||||
reviews: []*models.PullReview{
|
reviews: []*models.PullReview{
|
||||||
&models.PullReview{
|
&models.PullReview{
|
||||||
Body: "wow!",
|
Body: "wow!",
|
||||||
Stale: false,
|
Stale: false,
|
||||||
State: common.ReviewStateApproved,
|
State: common.ReviewStateApproved,
|
||||||
User: &models.User{
|
User: &models.User{
|
||||||
@ -217,8 +217,8 @@ func TestReviewApproval(t *testing.T) {
|
|||||||
mi.EXPECT().FetchMaintainershipFile("foo", common.DefaultGitPrj, "bar").Return(test.maintainerFile, nil)
|
mi.EXPECT().FetchMaintainershipFile("foo", common.DefaultGitPrj, "bar").Return(test.maintainerFile, nil)
|
||||||
|
|
||||||
approved, err := IsPrjGitPRApproved(mi, pri, config, 10)
|
approved, err := IsPrjGitPRApproved(mi, pri, config, 10)
|
||||||
if approved == test.approved {
|
if approved != test.approved {
|
||||||
t.Error("Unexpected approved or err:", err)
|
t.Error("Unexpected approve state:", approved, "vs. expected", test.approved, ", or err:", err)
|
||||||
}
|
}
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Error("Unexpected error", err)
|
t.Error("Unexpected error", err)
|
||||||
|
Loading…
Reference in New Issue
Block a user