mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2024-11-21 08:31:27 -05:00
Remove commit status running and warning to align GitHub (#25839)
Fix #25776. Close #25826. In the discussion of #25776, @wolfogre's suggestion was to remove the commit status of `running` and `warning` to keep it consistent with github. references: - https://docs.github.com/en/rest/commits/statuses?apiVersion=2022-11-28#about-commit-statuses ## ⚠️ BREAKING ⚠️ So the commit status of Gitea will be consistent with GitHub, only `pending`, `success`, `error` and `failure`, while `warning` and `running` are not supported anymore. --------- Co-authored-by: Jason Song <i@wolfogre.com>
This commit is contained in:
parent
d57e55cd47
commit
840830b655
9 changed files with 45 additions and 44 deletions
|
@ -31,10 +31,6 @@ func TestGetCommitStatuses(t *testing.T) {
|
||||||
assert.Equal(t, structs.CommitStatusPending, statuses[0].State)
|
assert.Equal(t, structs.CommitStatusPending, statuses[0].State)
|
||||||
assert.Equal(t, "https://try.gitea.io/api/v1/repos/user2/repo1/statuses/1234123412341234123412341234123412341234", statuses[0].APIURL(db.DefaultContext))
|
assert.Equal(t, "https://try.gitea.io/api/v1/repos/user2/repo1/statuses/1234123412341234123412341234123412341234", statuses[0].APIURL(db.DefaultContext))
|
||||||
|
|
||||||
assert.Equal(t, "cov/awesomeness", statuses[1].Context)
|
|
||||||
assert.Equal(t, structs.CommitStatusWarning, statuses[1].State)
|
|
||||||
assert.Equal(t, "https://try.gitea.io/api/v1/repos/user2/repo1/statuses/1234123412341234123412341234123412341234", statuses[1].APIURL(db.DefaultContext))
|
|
||||||
|
|
||||||
assert.Equal(t, "cov/awesomeness", statuses[2].Context)
|
assert.Equal(t, "cov/awesomeness", statuses[2].Context)
|
||||||
assert.Equal(t, structs.CommitStatusSuccess, statuses[2].State)
|
assert.Equal(t, structs.CommitStatusSuccess, statuses[2].State)
|
||||||
assert.Equal(t, "https://try.gitea.io/api/v1/repos/user2/repo1/statuses/1234123412341234123412341234123412341234", statuses[2].APIURL(db.DefaultContext))
|
assert.Equal(t, "https://try.gitea.io/api/v1/repos/user2/repo1/statuses/1234123412341234123412341234123412341234", statuses[2].APIURL(db.DefaultContext))
|
||||||
|
|
|
@ -513,6 +513,8 @@ var migrations = []Migration{
|
||||||
NewMigration("Add branch table", v1_21.AddBranchTable),
|
NewMigration("Add branch table", v1_21.AddBranchTable),
|
||||||
// v265 -> v266
|
// v265 -> v266
|
||||||
NewMigration("Alter Actions Artifact table", v1_21.AlterActionArtifactTable),
|
NewMigration("Alter Actions Artifact table", v1_21.AlterActionArtifactTable),
|
||||||
|
// v266 -> v267
|
||||||
|
NewMigration("Reduce commit status", v1_21.ReduceCommitStatus),
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetCurrentDBVersion returns the current db version
|
// GetCurrentDBVersion returns the current db version
|
||||||
|
|
26
models/migrations/v1_21/v266.go
Normal file
26
models/migrations/v1_21/v266.go
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
// Copyright 2023 The Gitea Authors. All rights reserved.
|
||||||
|
// SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
|
package v1_21 //nolint
|
||||||
|
|
||||||
|
import (
|
||||||
|
"xorm.io/xorm"
|
||||||
|
)
|
||||||
|
|
||||||
|
func ReduceCommitStatus(x *xorm.Engine) error {
|
||||||
|
sess := x.NewSession()
|
||||||
|
defer sess.Close()
|
||||||
|
|
||||||
|
if err := sess.Begin(); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if _, err := sess.Exec(`UPDATE commit_status SET state='pending' WHERE state='running'`); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if _, err := sess.Exec(`UPDATE commit_status SET state='failure' WHERE state='warning'`); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return sess.Commit()
|
||||||
|
}
|
|
@ -16,26 +16,17 @@ const (
|
||||||
CommitStatusError CommitStatusState = "error"
|
CommitStatusError CommitStatusState = "error"
|
||||||
// CommitStatusFailure is for when the CommitStatus is Failure
|
// CommitStatusFailure is for when the CommitStatus is Failure
|
||||||
CommitStatusFailure CommitStatusState = "failure"
|
CommitStatusFailure CommitStatusState = "failure"
|
||||||
// CommitStatusWarning is for when the CommitStatus is Warning
|
|
||||||
CommitStatusWarning CommitStatusState = "warning"
|
|
||||||
// CommitStatusRunning is for when the CommitStatus is Running
|
|
||||||
CommitStatusRunning CommitStatusState = "running"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
// NoBetterThan returns true if this State is no better than the given State
|
// NoBetterThan returns true if this State is no better than the given State
|
||||||
func (css CommitStatusState) NoBetterThan(css2 CommitStatusState) bool {
|
func (css CommitStatusState) NoBetterThan(css2 CommitStatusState) bool {
|
||||||
switch css {
|
commitStatusPriorities := map[CommitStatusState]int{
|
||||||
case CommitStatusError:
|
CommitStatusError: 0,
|
||||||
return true
|
CommitStatusFailure: 1,
|
||||||
case CommitStatusFailure:
|
CommitStatusPending: 2,
|
||||||
return css2 != CommitStatusError
|
CommitStatusSuccess: 3,
|
||||||
case CommitStatusWarning:
|
|
||||||
return css2 != CommitStatusError && css2 != CommitStatusFailure
|
|
||||||
case CommitStatusPending:
|
|
||||||
return css2 != CommitStatusError && css2 != CommitStatusFailure && css2 != CommitStatusWarning
|
|
||||||
default:
|
|
||||||
return css2 != CommitStatusError && css2 != CommitStatusFailure && css2 != CommitStatusWarning && css2 != CommitStatusPending
|
|
||||||
}
|
}
|
||||||
|
return commitStatusPriorities[css] <= commitStatusPriorities[css2]
|
||||||
}
|
}
|
||||||
|
|
||||||
// IsPending represents if commit status state is pending
|
// IsPending represents if commit status state is pending
|
||||||
|
@ -57,8 +48,3 @@ func (css CommitStatusState) IsError() bool {
|
||||||
func (css CommitStatusState) IsFailure() bool {
|
func (css CommitStatusState) IsFailure() bool {
|
||||||
return css == CommitStatusFailure
|
return css == CommitStatusFailure
|
||||||
}
|
}
|
||||||
|
|
||||||
// IsWarning represents if commit status state is warning
|
|
||||||
func (css CommitStatusState) IsWarning() bool {
|
|
||||||
return css == CommitStatusWarning
|
|
||||||
}
|
|
||||||
|
|
|
@ -137,14 +137,10 @@ func toCommitStatus(status actions_model.Status) api.CommitStatusState {
|
||||||
switch status {
|
switch status {
|
||||||
case actions_model.StatusSuccess, actions_model.StatusSkipped:
|
case actions_model.StatusSuccess, actions_model.StatusSkipped:
|
||||||
return api.CommitStatusSuccess
|
return api.CommitStatusSuccess
|
||||||
case actions_model.StatusFailure:
|
case actions_model.StatusFailure, actions_model.StatusCancelled:
|
||||||
return api.CommitStatusFailure
|
return api.CommitStatusFailure
|
||||||
case actions_model.StatusCancelled:
|
case actions_model.StatusWaiting, actions_model.StatusBlocked, actions_model.StatusRunning:
|
||||||
return api.CommitStatusWarning
|
|
||||||
case actions_model.StatusWaiting, actions_model.StatusBlocked:
|
|
||||||
return api.CommitStatusPending
|
return api.CommitStatusPending
|
||||||
case actions_model.StatusRunning:
|
|
||||||
return api.CommitStatusRunning
|
|
||||||
default:
|
default:
|
||||||
return api.CommitStatusError
|
return api.CommitStatusError
|
||||||
}
|
}
|
||||||
|
|
|
@ -52,6 +52,14 @@ func ToCombinedStatus(ctx context.Context, statuses []*git_model.CommitStatus, r
|
||||||
retStatus.State = status.State
|
retStatus.State = status.State
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
// According to https://docs.github.com/en/rest/commits/statuses?apiVersion=2022-11-28#get-the-combined-status-for-a-specific-reference
|
||||||
|
// > Additionally, a combined state is returned. The state is one of:
|
||||||
|
// > failure if any of the contexts report as error or failure
|
||||||
|
// > pending if there are no statuses or a context is pending
|
||||||
|
// > success if the latest status for all contexts is success
|
||||||
|
if retStatus.State.IsError() {
|
||||||
|
retStatus.State = api.CommitStatusFailure
|
||||||
|
}
|
||||||
|
|
||||||
return retStatus
|
return retStatus
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
{{if or (eq .State "pending") (eq .State "running")}}
|
{{if eq .State "pending"}}
|
||||||
{{svg "octicon-dot-fill" 18 "commit-status icon text yellow"}}
|
{{svg "octicon-dot-fill" 18 "commit-status icon text yellow"}}
|
||||||
{{end}}
|
{{end}}
|
||||||
{{if eq .State "success"}}
|
{{if eq .State "success"}}
|
||||||
|
@ -10,6 +10,3 @@
|
||||||
{{if eq .State "failure"}}
|
{{if eq .State "failure"}}
|
||||||
{{svg "octicon-x" 18 "commit-status icon text red"}}
|
{{svg "octicon-x" 18 "commit-status icon text red"}}
|
||||||
{{end}}
|
{{end}}
|
||||||
{{if eq .State "warning"}}
|
|
||||||
{{svg "gitea-exclamation" 18 "commit-status icon text yellow"}}
|
|
||||||
{{end}}
|
|
||||||
|
|
|
@ -52,7 +52,6 @@ func TestPullCreate_CommitStatus(t *testing.T) {
|
||||||
api.CommitStatusPending,
|
api.CommitStatusPending,
|
||||||
api.CommitStatusError,
|
api.CommitStatusError,
|
||||||
api.CommitStatusFailure,
|
api.CommitStatusFailure,
|
||||||
api.CommitStatusWarning,
|
|
||||||
api.CommitStatusSuccess,
|
api.CommitStatusSuccess,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -61,7 +60,6 @@ func TestPullCreate_CommitStatus(t *testing.T) {
|
||||||
api.CommitStatusSuccess: "octicon-check",
|
api.CommitStatusSuccess: "octicon-check",
|
||||||
api.CommitStatusError: "gitea-exclamation",
|
api.CommitStatusError: "gitea-exclamation",
|
||||||
api.CommitStatusFailure: "octicon-x",
|
api.CommitStatusFailure: "octicon-x",
|
||||||
api.CommitStatusWarning: "gitea-exclamation",
|
|
||||||
}
|
}
|
||||||
|
|
||||||
testCtx := NewAPITestContext(t, "user1", "repo1", auth_model.AccessTokenScopeWriteRepository)
|
testCtx := NewAPITestContext(t, "user1", "repo1", auth_model.AccessTokenScopeWriteRepository)
|
||||||
|
|
|
@ -125,14 +125,6 @@ func TestRepoCommitsWithStatusFailure(t *testing.T) {
|
||||||
doTestRepoCommitWithStatus(t, "failure", "octicon-x", "red")
|
doTestRepoCommitWithStatus(t, "failure", "octicon-x", "red")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestRepoCommitsWithStatusWarning(t *testing.T) {
|
|
||||||
doTestRepoCommitWithStatus(t, "warning", "gitea-exclamation", "yellow")
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestRepoCommitsWithStatusRunning(t *testing.T) {
|
|
||||||
doTestRepoCommitWithStatus(t, "running", "octicon-dot-fill", "yellow")
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestRepoCommitsStatusParallel(t *testing.T) {
|
func TestRepoCommitsStatusParallel(t *testing.T) {
|
||||||
defer tests.PrepareTestEnv(t)()
|
defer tests.PrepareTestEnv(t)()
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue