-
Notifications
You must be signed in to change notification settings - Fork 81
/
task_status.go
78 lines (63 loc) · 2.22 KB
/
task_status.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
package sort
import (
"bytes"
"fmt"
"sort"
"text/template"
"github.com/openshift-pipelines/pipelines-as-code/pkg/formatting"
"github.com/openshift-pipelines/pipelines-as-code/pkg/params"
"github.com/openshift-pipelines/pipelines-as-code/pkg/params/info"
tektonv1 "github.com/tektoncd/pipeline/pkg/apis/pipeline/v1"
)
type tkr struct {
taskLogURL string
*tektonv1.PipelineRunTaskRunStatus
}
func (t tkr) ConsoleLogURL() string {
name := t.PipelineTaskName
if t.Status != nil && t.Status.TaskSpec != nil && t.Status.TaskSpec.DisplayName != "" {
name = t.Status.TaskSpec.DisplayName
}
return fmt.Sprintf("[%s](%s)", name, t.taskLogURL)
}
type taskrunList []tkr
func (trs taskrunList) Len() int { return len(trs) }
func (trs taskrunList) Swap(i, j int) { trs[i], trs[j] = trs[j], trs[i] }
func (trs taskrunList) Less(i, j int) bool {
if trs[j].Status == nil || trs[j].Status.StartTime == nil {
return false
}
if trs[i].Status == nil || trs[i].Status.StartTime == nil {
return true
}
return trs[j].Status.StartTime.Before(trs[i].Status.StartTime)
}
// TaskStatusTmpl generate a template of all status of a TaskRuns sorted to a statusTemplate as defined by the git provider.
func TaskStatusTmpl(pr *tektonv1.PipelineRun, trStatus map[string]*tektonv1.PipelineRunTaskRunStatus, runs *params.Run, config *info.ProviderConfig) (string, error) {
trl := taskrunList{}
outputBuffer := bytes.Buffer{}
if len(trStatus) == 0 {
return "PipelineRun has no taskruns", nil
}
for _, taskrunStatus := range trStatus {
trl = append(trl, tkr{
taskLogURL: runs.Clients.ConsoleUI.TaskLogURL(pr, taskrunStatus),
PipelineRunTaskRunStatus: taskrunStatus,
})
}
sort.Sort(sort.Reverse(trl))
funcMap := template.FuncMap{
"formatDuration": formatting.Duration,
"formatCondition": formatting.ConditionEmoji,
}
if config.SkipEmoji {
funcMap["formatCondition"] = formatting.ConditionSad
}
data := struct{ TaskRunList taskrunList }{TaskRunList: trl}
t := template.Must(template.New("Task Status").Funcs(funcMap).Parse(config.TaskStatusTMPL))
if err := t.Execute(&outputBuffer, data); err != nil {
_, _ = fmt.Fprintf(&outputBuffer, "failed to execute template: ")
return "", err
}
return outputBuffer.String(), nil
}