Add commit statuses reports on pull request view (#6845)
* Add commit statuses reports on pull view * Add some translations * improve the UI * fix fmt * fix tests * add a new test git repo to fix tests * fix bug when headRepo or headBranch missing * fix tests * fix tests * fix consistency * fix tests * fix tests * change the test repo * fix tests * fix tests * fix migration * keep db size consistency * fix translation * change commit hash status table unique index * remove unused table * use char instead varchar * make hashCommitStatusContext private * split merge section with status check on pull view ui * fix tests; fix arc-green theme on pull uitokarchuk/v1.17
parent
1e46eedce7
commit
ff85dd3e12
Binary file not shown.
Binary file not shown.
Binary file not shown.
@ -0,0 +1 @@ |
|||||||
|
0abcb056019adb8336cf9db3ad9d9cf80cd4b141 |
@ -0,0 +1,66 @@ |
|||||||
|
// Copyright 2019 The Gitea Authors. All rights reserved.
|
||||||
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
|
package migrations |
||||||
|
|
||||||
|
import ( |
||||||
|
"crypto/sha1" |
||||||
|
"fmt" |
||||||
|
|
||||||
|
"github.com/go-xorm/xorm" |
||||||
|
) |
||||||
|
|
||||||
|
func hashContext(context string) string { |
||||||
|
return fmt.Sprintf("%x", sha1.Sum([]byte(context))) |
||||||
|
} |
||||||
|
|
||||||
|
func addCommitStatusContext(x *xorm.Engine) error { |
||||||
|
type CommitStatus struct { |
||||||
|
ID int64 `xorm:"pk autoincr"` |
||||||
|
ContextHash string `xorm:"char(40) index"` |
||||||
|
Context string `xorm:"TEXT"` |
||||||
|
} |
||||||
|
|
||||||
|
if err := x.Sync2(new(CommitStatus)); err != nil { |
||||||
|
return err |
||||||
|
} |
||||||
|
|
||||||
|
sess := x.NewSession() |
||||||
|
defer sess.Close() |
||||||
|
|
||||||
|
var start = 0 |
||||||
|
for { |
||||||
|
var statuses = make([]*CommitStatus, 0, 100) |
||||||
|
err := sess.OrderBy("id").Limit(100, start).Find(&statuses) |
||||||
|
if err != nil { |
||||||
|
return err |
||||||
|
} |
||||||
|
if len(statuses) == 0 { |
||||||
|
break |
||||||
|
} |
||||||
|
|
||||||
|
if err = sess.Begin(); err != nil { |
||||||
|
return err |
||||||
|
} |
||||||
|
|
||||||
|
for _, status := range statuses { |
||||||
|
status.ContextHash = hashContext(status.Context) |
||||||
|
if _, err := sess.ID(status.ID).Cols("context_hash").Update(status); err != nil { |
||||||
|
return err |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
if err := sess.Commit(); err != nil { |
||||||
|
return err |
||||||
|
} |
||||||
|
|
||||||
|
if len(statuses) < 100 { |
||||||
|
break |
||||||
|
} |
||||||
|
|
||||||
|
start += len(statuses) |
||||||
|
} |
||||||
|
|
||||||
|
return nil |
||||||
|
} |
@ -0,0 +1,39 @@ |
|||||||
|
// Copyright 2019 The Gitea Authors. All rights reserved.
|
||||||
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
|
package repofiles |
||||||
|
|
||||||
|
import ( |
||||||
|
"fmt" |
||||||
|
|
||||||
|
"code.gitea.io/gitea/models" |
||||||
|
"code.gitea.io/gitea/modules/git" |
||||||
|
) |
||||||
|
|
||||||
|
// CreateCommitStatus creates a new CommitStatus given a bunch of parameters
|
||||||
|
// NOTE: All text-values will be trimmed from whitespaces.
|
||||||
|
// Requires: Repo, Creator, SHA
|
||||||
|
func CreateCommitStatus(repo *models.Repository, creator *models.User, sha string, status *models.CommitStatus) error { |
||||||
|
repoPath := repo.RepoPath() |
||||||
|
|
||||||
|
// confirm that commit is exist
|
||||||
|
gitRepo, err := git.OpenRepository(repoPath) |
||||||
|
if err != nil { |
||||||
|
return fmt.Errorf("OpenRepository[%s]: %v", repoPath, err) |
||||||
|
} |
||||||
|
if _, err := gitRepo.GetCommit(sha); err != nil { |
||||||
|
return fmt.Errorf("GetCommit[%s]: %v", sha, err) |
||||||
|
} |
||||||
|
|
||||||
|
if err := models.NewCommitStatus(models.NewCommitStatusOptions{ |
||||||
|
Repo: repo, |
||||||
|
Creator: creator, |
||||||
|
SHA: sha, |
||||||
|
CommitStatus: status, |
||||||
|
}); err != nil { |
||||||
|
return fmt.Errorf("NewCommitStatus[repo_id: %d, user_id: %d, sha: %s]: %v", repo.ID, creator.ID, sha, err) |
||||||
|
} |
||||||
|
|
||||||
|
return nil |
||||||
|
} |
@ -0,0 +1,21 @@ |
|||||||
|
{{if $.LatestCommitStatus}} |
||||||
|
<div class="ui top attached header"> |
||||||
|
{{if eq .LatestCommitStatus.State "pending"}} |
||||||
|
{{$.i18n.Tr "repo.pulls.status_checking"}} |
||||||
|
{{else if eq .LatestCommitStatus.State "success"}} |
||||||
|
{{$.i18n.Tr "repo.pulls.status_checks_success"}} |
||||||
|
{{else if eq .LatestCommitStatus.State "error"}} |
||||||
|
{{$.i18n.Tr "repo.pulls.status_checks_error"}} |
||||||
|
{{else}} |
||||||
|
{{$.i18n.Tr "repo.pulls.status_checking"}} |
||||||
|
{{end}} |
||||||
|
</div> |
||||||
|
|
||||||
|
{{range $.LatestCommitStatuses}} |
||||||
|
<div class="ui attached segment"> |
||||||
|
<span>{{template "repo/commit_status" .}}</span> |
||||||
|
<span class="ui">{{.Context}} <span class="text grey">{{.Description}}</span></span> |
||||||
|
<div class="ui right">{{if .TargetURL}}<a href="{{.TargetURL}}">Details</a>{{end}}</div> |
||||||
|
</div> |
||||||
|
{{end}} |
||||||
|
{{end}} |
Loading…
Reference in new issue