-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwatch.go
48 lines (45 loc) · 1.26 KB
/
watch.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
package jobnotify
import (
"golang.org/x/xerrors"
batchv1 "k8s.io/api/batch/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/cli-runtime/pkg/genericclioptions"
"k8s.io/client-go/kubernetes"
)
func watch(resource, namespace string) (*jobResult, error) {
configFlags := &genericclioptions.ConfigFlags{}
restConfig, err := configFlags.ToRESTConfig()
if err != nil {
return nil, err
}
client := kubernetes.NewForConfigOrDie(restConfig)
_, err = client.BatchV1().Jobs(namespace).Get(resource, metav1.GetOptions{})
if err != nil {
return nil, err
}
watcher, err := client.BatchV1().Jobs(namespace).Watch(metav1.ListOptions{})
if err != nil {
return nil, err
}
now := metav1.Now()
for event := range watcher.ResultChan() {
job := event.Object.(*batchv1.Job)
jobName := job.Name
if resource != jobName {
continue
}
if job.Status.CompletionTime.Before(&now) {
return nil, xerrors.New("specified job has already finished.")
}
if *job.Spec.Completions == job.Status.Succeeded {
return &jobResult{
name: resource,
startedAt: job.Status.StartTime,
completedAt: job.Status.CompletionTime,
completed: job.Status.Succeeded,
failed: job.Status.Failed,
}, nil
}
}
return nil, xerrors.New("unexpected error")
}