mirror of
https://github.com/woodpecker-ci/woodpecker.git
synced 2024-12-12 08:23:48 +02:00
4276a04f0c
Completely switch to zerolog (Remove usage of logrus and std logger) Signed-off-by: jolheiser <john.olheiser@gmail.com> Co-authored-by: 6543 <6543@obermui.de>
84 lines
1.4 KiB
Go
84 lines
1.4 KiB
Go
package build
|
|
|
|
import (
|
|
"os"
|
|
"strconv"
|
|
"text/template"
|
|
|
|
"github.com/urfave/cli"
|
|
|
|
"github.com/woodpecker-ci/woodpecker/cli/internal"
|
|
)
|
|
|
|
var buildPsCmd = cli.Command{
|
|
Name: "ps",
|
|
Usage: "show build steps",
|
|
ArgsUsage: "<repo/name> [build]",
|
|
Action: buildPs,
|
|
Flags: []cli.Flag{
|
|
cli.StringFlag{
|
|
Name: "format",
|
|
Usage: "format output",
|
|
Value: tmplBuildPs,
|
|
},
|
|
},
|
|
}
|
|
|
|
func buildPs(c *cli.Context) error {
|
|
repo := c.Args().First()
|
|
|
|
owner, name, err := internal.ParseRepo(repo)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
client, err := internal.NewClient(c)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
buildArg := c.Args().Get(1)
|
|
var number int
|
|
|
|
if buildArg == "last" || len(buildArg) == 0 {
|
|
// Fetch the build number from the last build
|
|
build, err := client.BuildLast(owner, name, "")
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
number = build.Number
|
|
} else {
|
|
number, err = strconv.Atoi(buildArg)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
build, err := client.Build(owner, name, number)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
tmpl, err := template.New("_").Parse(c.String("format") + "\n")
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
for _, proc := range build.Procs {
|
|
for _, child := range proc.Children {
|
|
if err := tmpl.Execute(os.Stdout, child); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
// template for build ps information
|
|
var tmplBuildPs = "\x1b[33mProc #{{ .PID }} \x1b[0m" + `
|
|
Step: {{ .Name }}
|
|
State: {{ .State }}
|
|
`
|