chore(runner): support fetch detail stage data
Signed-off-by: Bo-Yi.Wu <appleboy.tw@gmail.com>
This commit is contained in:
@@ -8,6 +8,7 @@ import (
|
||||
"context"
|
||||
"errors"
|
||||
"fmt"
|
||||
"strconv"
|
||||
|
||||
"code.gitea.io/gitea/core"
|
||||
"code.gitea.io/gitea/models/db"
|
||||
@@ -30,7 +31,7 @@ func init() {
|
||||
// Build represnets bot build task
|
||||
type Build struct {
|
||||
ID int64
|
||||
Title string
|
||||
Name string
|
||||
UUID string `xorm:"CHAR(36)"`
|
||||
Index int64 `xorm:"index unique(repo_index)"`
|
||||
RepoID int64 `xorm:"index unique(repo_index)"`
|
||||
@@ -138,11 +139,20 @@ func UpdateBuild(t *Build, cols ...string) error {
|
||||
type ErrBuildNotExist struct {
|
||||
RepoID int64
|
||||
Index int64
|
||||
ID int64
|
||||
UUID string
|
||||
}
|
||||
|
||||
func (err ErrBuildNotExist) Error() string {
|
||||
return fmt.Sprintf("Bot build [%s] is not exist", err.UUID)
|
||||
uuid := ""
|
||||
if err.UUID != "" {
|
||||
uuid = err.UUID
|
||||
}
|
||||
|
||||
if err.ID != 0 {
|
||||
uuid = strconv.FormatInt(err.ID, 10)
|
||||
}
|
||||
return fmt.Sprintf("build [%s] is not exist", uuid)
|
||||
}
|
||||
|
||||
// GetBuildByUUID gets bot build by uuid
|
||||
@@ -159,6 +169,20 @@ func GetBuildByUUID(buildUUID string) (*Build, error) {
|
||||
return &build, nil
|
||||
}
|
||||
|
||||
func GetBuildByID(id int64) (*Build, error) {
|
||||
var build Build
|
||||
has, err := db.GetEngine(db.DefaultContext).Where("id=?", id).Get(&build)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
} else if !has {
|
||||
return nil, ErrBuildNotExist{
|
||||
ID: id,
|
||||
}
|
||||
}
|
||||
|
||||
return &build, nil
|
||||
}
|
||||
|
||||
// GetCurBuildByID return the build for the bot
|
||||
func GetCurBuildByID(runnerID int64) (*Build, error) {
|
||||
var builds []Build
|
||||
|
||||
@@ -6,6 +6,7 @@ package bots
|
||||
|
||||
import (
|
||||
"context"
|
||||
"fmt"
|
||||
|
||||
"code.gitea.io/gitea/core"
|
||||
"code.gitea.io/gitea/models/db"
|
||||
@@ -29,7 +30,9 @@ type BuildStage struct {
|
||||
Started timeutil.TimeStamp
|
||||
Stopped timeutil.TimeStamp
|
||||
LogToFile bool // read log from database or from storage
|
||||
Version int `xorm:"version"`
|
||||
Created timeutil.TimeStamp `xorm:"created"`
|
||||
Updated timeutil.TimeStamp `xorm:"updated"`
|
||||
}
|
||||
|
||||
func (bj BuildStage) TableName() string {
|
||||
@@ -69,6 +72,34 @@ func FindStages(ctx context.Context, opts FindStageOptions) (BuildStageList, err
|
||||
return rows, sess.Find(&rows)
|
||||
}
|
||||
|
||||
// GetStageByID gets build stage by id
|
||||
func GetStageByID(id int64) (*BuildStage, error) {
|
||||
var build BuildStage
|
||||
has, err := db.GetEngine(db.DefaultContext).Where("id=?", id).Get(&build)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
} else if !has {
|
||||
return nil, ErrBuildStageNotExist{
|
||||
ID: id,
|
||||
}
|
||||
}
|
||||
return &build, nil
|
||||
}
|
||||
|
||||
// ErrBuildNotExist represents an error for bot build not exist
|
||||
type ErrBuildStageNotExist struct {
|
||||
ID int64
|
||||
}
|
||||
|
||||
func (err ErrBuildStageNotExist) Error() string {
|
||||
return fmt.Sprintf("build stage [%d] is not exist", err.ID)
|
||||
}
|
||||
|
||||
// UpdateBuildStage updates build stage
|
||||
func UpdateBuildStage(t *BuildStage, cols ...string) (int64, error) {
|
||||
return db.GetEngine(db.DefaultContext).ID(t.ID).Cols(cols...).Update(t)
|
||||
}
|
||||
|
||||
func GetBuildWorkflows(buildID int64) (map[string]map[string]*BuildStage, error) {
|
||||
jobs := make(map[string]map[string]*BuildStage)
|
||||
err := db.GetEngine(db.DefaultContext).Iterate(new(BuildStage), func(idx int, bean interface{}) error {
|
||||
|
||||
Reference in New Issue
Block a user