mirror of
https://github.com/go-gitea/gitea
synced 2025-07-04 17:47:19 +00:00
Backport #34815 Fix #34504 Since one required context can match more than one commit statuses, we should not directly compare the lengths of `requiredCommitStatuses` and `requiredContexts`
This commit is contained in:
@ -35,15 +35,16 @@ func MergeRequiredContextsCommitStatus(commitStatuses []*git_model.CommitStatus,
|
||||
}
|
||||
|
||||
for _, gp := range requiredContextsGlob {
|
||||
var targetStatus structs.CommitStatusState
|
||||
var targetStatuses []*git_model.CommitStatus
|
||||
for _, commitStatus := range commitStatuses {
|
||||
if gp.Match(commitStatus.Context) {
|
||||
targetStatus = commitStatus.State
|
||||
targetStatuses = append(targetStatuses, commitStatus)
|
||||
matchedCount++
|
||||
break
|
||||
}
|
||||
}
|
||||
|
||||
targetStatus := git_model.CalcCommitStatus(targetStatuses).State
|
||||
|
||||
// If required rule not match any action, then it is pending
|
||||
if targetStatus == "" {
|
||||
if structs.CommitStatusPending.NoBetterThan(returnedStatus) {
|
||||
|
Reference in New Issue
Block a user