/
job.go
113 lines (100 loc) · 2.48 KB
/
job.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
package main
import (
"bytes"
"encoding/json"
"fmt"
"io"
"strconv"
"time"
"github.com/hhatto/nanairo"
"github.com/urfave/cli"
)
type JobBuildInfo struct {
Number int `json:"number"`
Result string `json:"result"`
Timestamp int64 `json:"timestamp"`
Duration int `json:"duration"`
}
func getJobInfo(url string, jobName string, dumpFlag bool) ([]JobBuildInfo, error) {
client := NewClient(url)
res, err := client.get(fmt.Sprintf("job/%s/api/json?depth=1", jobName))
if err != nil {
return nil, err
}
defer res.Body.Close()
if dumpFlag == true {
buf := new(bytes.Buffer)
buf.ReadFrom(res.Body)
fmt.Println(buf.String())
return nil, nil
}
var r struct {
JobInfo []JobBuildInfo `json:"builds"`
}
err = json.NewDecoder(io.Reader(res.Body)).Decode(&r)
if err != nil {
return nil, err
}
return r.JobInfo, nil
}
func printJobDetail(url string, jobName string, dumpFlag bool) {
b := bytes.NewBufferString("")
jobItems, _ := getJobInfo(url, jobName, dumpFlag)
if len(jobItems) > 0 {
b.WriteString(fmt.Sprintf("[%s]\n", jobName))
} else {
b.WriteString(fmt.Sprintf("'%s' job is not found\n", jobName))
}
for cnt, job := range jobItems {
var running bool = false
if cnt >= 5 {
break
}
resultNumber := nanairo.FgColor("#0c0", strconv.Itoa(job.Number))
if job.Result == "" {
running = true
resultNumber = nanairo.FgColor("#cc0", strconv.Itoa(job.Number))
} else if job.Result != "SUCCESS" {
resultNumber = nanairo.FgColor("#c00", strconv.Itoa(job.Number))
}
humanReadableDurationValue := fmt.Sprintf("%ds", job.Duration/1000)
if job.Duration/1000 >= 60 {
humanReadableDurationValue = fmt.Sprintf("%dm%ds", job.Duration/1000/60, job.Duration/1000%60)
}
runningStr := ""
if running {
runningStr = " 🏗️"
}
b.WriteString(fmt.Sprintf(" [%4s] %s (%6s)%s\n", resultNumber,
time.Unix(int64(job.Timestamp)/1000, 0),
humanReadableDurationValue,
runningStr))
}
fmt.Print(b.String())
}
func jobCommand(c *cli.Context) {
url := Config.Get(c.String("name"))
for _, jobName := range c.Args() {
printJobDetail(url, jobName, c.Bool("dump"))
}
}
var JobCommand = cli.Command{
Name: "job",
Usage: "print job detail",
Action: jobCommand,
Flags: []cli.Flag{
cli.StringFlag{
Name: "name, n",
Value: "default",
Usage: "host key name(default is 'default')",
},
cli.BoolFlag{
Name: "verbose, v",
Usage: "verbose mode",
},
cli.BoolFlag{
Name: "dump, d",
Usage: "dump raw json data",
},
},
}