Fixing the issue when status check per rule matches multiple actions (#29631)
Close #29628 rule ``` Test / Build* Test / Build * Test / Build 2* Test / Build 1* ``` ![image](https://github.com/go-gitea/gitea/assets/30816317/19bef0a9-fa97-43c5-887b-dece76064aa8) rule2 ``` Test / Build* Test / Build 1* ``` ![image](https://github.com/go-gitea/gitea/assets/30816317/19bef0a9-fa97-43c5-887b-dece76064aa8) rule3 ``` Test / Build* Test / Build 1* NotExist* ``` ![image](https://github.com/go-gitea/gitea/assets/30816317/f6a5e832-2e1b-4049-915b-45bec5ef070c) --------- Co-authored-by: Zettat123 <zettat123@gmail.com> (cherry picked from commit 7cf7a499be80931ae34588201e9605085898e9b8)
This commit is contained in:
parent
76db6d9e74
commit
ac2e882dbf
2 changed files with 76 additions and 7 deletions
|
@ -36,9 +36,9 @@ func MergeRequiredContextsCommitStatus(commitStatuses []*git_model.CommitStatus,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, commitStatus := range commitStatuses {
|
for _, gp := range requiredContextsGlob {
|
||||||
var targetStatus structs.CommitStatusState
|
var targetStatus structs.CommitStatusState
|
||||||
for _, gp := range requiredContextsGlob {
|
for _, commitStatus := range commitStatuses {
|
||||||
if gp.Match(commitStatus.Context) {
|
if gp.Match(commitStatus.Context) {
|
||||||
targetStatus = commitStatus.State
|
targetStatus = commitStatus.State
|
||||||
matchedCount++
|
matchedCount++
|
||||||
|
@ -46,16 +46,20 @@ func MergeRequiredContextsCommitStatus(commitStatuses []*git_model.CommitStatus,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if targetStatus != "" && targetStatus.NoBetterThan(returnedStatus) {
|
// If required rule not match any action, then it is pending
|
||||||
|
if targetStatus == "" {
|
||||||
|
if structs.CommitStatusPending.NoBetterThan(returnedStatus) {
|
||||||
|
returnedStatus = structs.CommitStatusPending
|
||||||
|
}
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
if targetStatus.NoBetterThan(returnedStatus) {
|
||||||
returnedStatus = targetStatus
|
returnedStatus = targetStatus
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if matchedCount != len(requiredContexts) {
|
|
||||||
return structs.CommitStatusPending
|
|
||||||
}
|
|
||||||
|
|
||||||
if matchedCount == 0 {
|
if matchedCount == 0 {
|
||||||
status := git_model.CalcCommitStatus(commitStatuses)
|
status := git_model.CalcCommitStatus(commitStatuses)
|
||||||
if status != nil {
|
if status != nil {
|
||||||
|
|
65
services/pull/commit_status_test.go
Normal file
65
services/pull/commit_status_test.go
Normal file
|
@ -0,0 +1,65 @@
|
||||||
|
// Copyright 2024 The Gitea Authors.
|
||||||
|
// All rights reserved.
|
||||||
|
// SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
|
package pull
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
git_model "code.gitea.io/gitea/models/git"
|
||||||
|
"code.gitea.io/gitea/modules/structs"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestMergeRequiredContextsCommitStatus(t *testing.T) {
|
||||||
|
testCases := [][]*git_model.CommitStatus{
|
||||||
|
{
|
||||||
|
{Context: "Build 1", State: structs.CommitStatusSuccess},
|
||||||
|
{Context: "Build 2", State: structs.CommitStatusSuccess},
|
||||||
|
{Context: "Build 3", State: structs.CommitStatusSuccess},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
{Context: "Build 1", State: structs.CommitStatusSuccess},
|
||||||
|
{Context: "Build 2", State: structs.CommitStatusSuccess},
|
||||||
|
{Context: "Build 2t", State: structs.CommitStatusPending},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
{Context: "Build 1", State: structs.CommitStatusSuccess},
|
||||||
|
{Context: "Build 2", State: structs.CommitStatusSuccess},
|
||||||
|
{Context: "Build 2t", State: structs.CommitStatusFailure},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
{Context: "Build 1", State: structs.CommitStatusSuccess},
|
||||||
|
{Context: "Build 2", State: structs.CommitStatusSuccess},
|
||||||
|
{Context: "Build 2t", State: structs.CommitStatusSuccess},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
{Context: "Build 1", State: structs.CommitStatusSuccess},
|
||||||
|
{Context: "Build 2", State: structs.CommitStatusSuccess},
|
||||||
|
{Context: "Build 2t", State: structs.CommitStatusSuccess},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
testCasesRequiredContexts := [][]string{
|
||||||
|
{"Build*"},
|
||||||
|
{"Build*", "Build 2t*"},
|
||||||
|
{"Build*", "Build 2t*"},
|
||||||
|
{"Build*", "Build 2t*", "Build 3*"},
|
||||||
|
{"Build*", "Build *", "Build 2t*", "Build 1*"},
|
||||||
|
}
|
||||||
|
|
||||||
|
testCasesExpected := []structs.CommitStatusState{
|
||||||
|
structs.CommitStatusSuccess,
|
||||||
|
structs.CommitStatusPending,
|
||||||
|
structs.CommitStatusFailure,
|
||||||
|
structs.CommitStatusPending,
|
||||||
|
structs.CommitStatusSuccess,
|
||||||
|
}
|
||||||
|
|
||||||
|
for i, commitStatuses := range testCases {
|
||||||
|
if MergeRequiredContextsCommitStatus(commitStatuses, testCasesRequiredContexts[i]) != testCasesExpected[i] {
|
||||||
|
assert.Fail(t, "Test case failed", "Test case %d failed", i+1)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue