-
Notifications
You must be signed in to change notification settings - Fork 0
/
checker.go
92 lines (72 loc) · 1.44 KB
/
checker.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
package checker
import (
"fmt"
"sync"
"github.com/efureev/go-multierror"
)
type Checker struct {
list []ICmd
errors multierror.Collection
lgr ILogger
}
func (c *Checker) AddCmd(cmd ...ICmd) *Checker {
c.list = append(c.list, cmd...)
return c
}
func (c Checker) receiveErrors() error {
if c.errors.HasErrors() {
return c.errors
}
return nil
}
func (c *Checker) Run() error {
for _, cmd := range c.list {
cmd.SetLogger(c.lgr).Run()
c.addError(cmd.Result().Error())
}
return c.receiveErrors()
}
func (c *Checker) RunParallel() error {
wg := sync.WaitGroup{}
for _, cmd := range c.list {
if !cmd.Enable() {
continue
}
wg.Add(1)
go func(cmd ICmd, l ILogger) {
defer wg.Done()
l.Info(`[%s] checking...`, cmd.Name())
cmd.SetLogger(l).Run()
c.addError(multierror.Prefix(cmd.Result().Error(), cmd.Name()+`:`))
printResult(cmd, l)
}(cmd, c.lgr)
}
wg.Wait()
return c.receiveErrors()
}
func (c *Checker) SetLogger(l ILogger) *Checker {
c.lgr = l
return c
}
func (c *Checker) addError(err error) {
if err != nil {
c.errors.Append(err)
}
}
func NewChecker() *Checker {
return &Checker{}
}
func printResult(cmd ICmd, l ILogger) {
result := cmd.Result()
msg := fmt.Sprintf(`[%s] %s`, cmd.Name(), result.Status)
switch result.Status {
case StatusDone:
l.Success(msg)
l.Log(result.Info.String())
case StatusFailed:
l.Error(msg)
l.Log(result.Error().Error())
case StatusPending:
l.Log(msg)
}
}