Skip to content

Commit 5bf367f

Browse files
silverwinddelvhGiteaBot
authored
Restore warning commit status (#27504)
Partial revert of #25839. This commit status is used by a number of external integrations, so I think we should not remove it (See #25839 (comment)). This is a rare case where an existing migration needed to be alterted to avoid data loss. --------- Co-authored-by: delvh <dev.lh@web.de> Co-authored-by: Giteabot <teabot@gitea.io>
1 parent 0c2a3f4 commit 5bf367f

File tree

8 files changed

+26
-7
lines changed

8 files changed

+26
-7
lines changed

models/git/commit_status_test.go

+4
Original file line numberDiff line numberDiff line change
@@ -31,6 +31,10 @@ func TestGetCommitStatuses(t *testing.T) {
3131
assert.Equal(t, structs.CommitStatusPending, statuses[0].State)
3232
assert.Equal(t, "https://try.gitea.io/api/v1/repos/user2/repo1/statuses/1234123412341234123412341234123412341234", statuses[0].APIURL(db.DefaultContext))
3333

34+
assert.Equal(t, "cov/awesomeness", statuses[1].Context)
35+
assert.Equal(t, structs.CommitStatusWarning, statuses[1].State)
36+
assert.Equal(t, "https://try.gitea.io/api/v1/repos/user2/repo1/statuses/1234123412341234123412341234123412341234", statuses[1].APIURL(db.DefaultContext))
37+
3438
assert.Equal(t, "cov/awesomeness", statuses[2].Context)
3539
assert.Equal(t, structs.CommitStatusSuccess, statuses[2].State)
3640
assert.Equal(t, "https://try.gitea.io/api/v1/repos/user2/repo1/statuses/1234123412341234123412341234123412341234", statuses[2].APIURL(db.DefaultContext))

models/migrations/v1_21/v266.go

-3
Original file line numberDiff line numberDiff line change
@@ -18,9 +18,6 @@ func ReduceCommitStatus(x *xorm.Engine) error {
1818
if _, err := sess.Exec(`UPDATE commit_status SET state='pending' WHERE state='running'`); err != nil {
1919
return err
2020
}
21-
if _, err := sess.Exec(`UPDATE commit_status SET state='failure' WHERE state='warning'`); err != nil {
22-
return err
23-
}
2421

2522
return sess.Commit()
2623
}

modules/structs/commit_status.go

+11-3
Original file line numberDiff line numberDiff line change
@@ -16,13 +16,16 @@ const (
1616
CommitStatusError CommitStatusState = "error"
1717
// CommitStatusFailure is for when the CommitStatus is Failure
1818
CommitStatusFailure CommitStatusState = "failure"
19+
// CommitStatusWarning is for when the CommitStatus is Warning
20+
CommitStatusWarning CommitStatusState = "warning"
1921
)
2022

2123
var commitStatusPriorities = map[CommitStatusState]int{
2224
CommitStatusError: 0,
2325
CommitStatusFailure: 1,
24-
CommitStatusPending: 2,
25-
CommitStatusSuccess: 3,
26+
CommitStatusWarning: 2,
27+
CommitStatusPending: 3,
28+
CommitStatusSuccess: 4,
2629
}
2730

2831
func (css CommitStatusState) String() string {
@@ -32,7 +35,7 @@ func (css CommitStatusState) String() string {
3235
// NoBetterThan returns true if this State is no better than the given State
3336
// This function only handles the states defined in CommitStatusPriorities
3437
func (css CommitStatusState) NoBetterThan(css2 CommitStatusState) bool {
35-
// NoBetterThan only handles the 4 states above
38+
// NoBetterThan only handles the 5 states above
3639
if _, exist := commitStatusPriorities[css]; !exist {
3740
return false
3841
}
@@ -63,3 +66,8 @@ func (css CommitStatusState) IsError() bool {
6366
func (css CommitStatusState) IsFailure() bool {
6467
return css == CommitStatusFailure
6568
}
69+
70+
// IsWarning represents if commit status state is warning
71+
func (css CommitStatusState) IsWarning() bool {
72+
return css == CommitStatusWarning
73+
}

templates/repo/commit_status.tmpl

+3
Original file line numberDiff line numberDiff line change
@@ -11,3 +11,6 @@
1111
{{if eq .State "failure"}}
1212
{{svg "octicon-x" 18 "commit-status icon text red"}}
1313
{{end}}
14+
{{if eq .State "warning"}}
15+
{{svg "gitea-exclamation" 18 "commit-status icon text yellow"}}
16+
{{end}}

templates/repo/issue/view_content/pull.tmpl

+1-1
Original file line numberDiff line numberDiff line change
@@ -13,7 +13,7 @@
1313
{{- else if .IsBlockedByOutdatedBranch}}red
1414
{{- else if .IsBlockedByChangedProtectedFiles}}red
1515
{{- else if and .EnableStatusCheck (or .RequiredStatusCheckState.IsFailure .RequiredStatusCheckState.IsError)}}red
16-
{{- else if and .EnableStatusCheck (or (not $.LatestCommitStatus) .RequiredStatusCheckState.IsPending)}}yellow
16+
{{- else if and .EnableStatusCheck (or (not $.LatestCommitStatus) .RequiredStatusCheckState.IsPending .RequiredStatusCheckState.IsWarning)}}yellow
1717
{{- else if and .AllowMerge .RequireSigned (not .WillSign)}}red
1818
{{- else if .Issue.PullRequest.IsChecking}}yellow
1919
{{- else if .Issue.PullRequest.IsEmpty}}grey

tests/integration/pull_status_test.go

+2
Original file line numberDiff line numberDiff line change
@@ -53,13 +53,15 @@ func TestPullCreate_CommitStatus(t *testing.T) {
5353
api.CommitStatusError,
5454
api.CommitStatusFailure,
5555
api.CommitStatusSuccess,
56+
api.CommitStatusWarning,
5657
}
5758

5859
statesIcons := map[api.CommitStatusState]string{
5960
api.CommitStatusPending: "octicon-dot-fill",
6061
api.CommitStatusSuccess: "octicon-check",
6162
api.CommitStatusError: "gitea-exclamation",
6263
api.CommitStatusFailure: "octicon-x",
64+
api.CommitStatusWarning: "gitea-exclamation",
6365
}
6466

6567
testCtx := NewAPITestContext(t, "user1", "repo1", auth_model.AccessTokenScopeWriteRepository)

tests/integration/repo_commits_test.go

+4
Original file line numberDiff line numberDiff line change
@@ -125,6 +125,10 @@ func TestRepoCommitsWithStatusFailure(t *testing.T) {
125125
doTestRepoCommitWithStatus(t, "failure", "octicon-x", "red")
126126
}
127127

128+
func TestRepoCommitsWithStatusWarning(t *testing.T) {
129+
doTestRepoCommitWithStatus(t, "warning", "gitea-exclamation", "yellow")
130+
}
131+
128132
func TestRepoCommitsStatusParallel(t *testing.T) {
129133
defer tests.PrepareTestEnv(t)()
130134

web_src/js/components/DashboardRepoList.vue

+1
Original file line numberDiff line numberDiff line change
@@ -12,6 +12,7 @@ const commitStatus = {
1212
success: {name: 'octicon-check', color: 'green'},
1313
error: {name: 'gitea-exclamation', color: 'red'},
1414
failure: {name: 'octicon-x', color: 'red'},
15+
warning: {name: 'gitea-exclamation', color: 'yellow'},
1516
};
1617
1718
const sfc = {

0 commit comments

Comments
 (0)