-
Notifications
You must be signed in to change notification settings - Fork 933
/
Copy pathtask.go
102 lines (81 loc) · 3.28 KB
/
task.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
package v7action
import (
"sort"
"strconv"
"time"
"code.cloudfoundry.org/cli/actor/actionerror"
"code.cloudfoundry.org/cli/api/cloudcontroller/ccerror"
"code.cloudfoundry.org/cli/api/cloudcontroller/ccv3"
"code.cloudfoundry.org/cli/api/cloudcontroller/ccv3/constant"
"code.cloudfoundry.org/cli/resources"
log "github.com/sirupsen/logrus"
)
// Run resources.Task runs the provided command in the application environment associated
// with the provided application GUID.
func (actor Actor) RunTask(appGUID string, task resources.Task) (resources.Task, Warnings, error) {
createdTask, warnings, err := actor.CloudControllerClient.CreateApplicationTask(appGUID, resources.Task(task))
if err != nil {
if e, ok := err.(ccerror.TaskWorkersUnavailableError); ok {
return resources.Task{}, Warnings(warnings), actionerror.TaskWorkersUnavailableError{Message: e.Error()}
}
}
return resources.Task(createdTask), Warnings(warnings), err
}
// GetApplicationTasks returns a list of tasks associated with the provided
// application GUID.
func (actor Actor) GetApplicationTasks(appGUID string, sortOrder SortOrder) ([]resources.Task, Warnings, error) {
tasks, warnings, err := actor.CloudControllerClient.GetApplicationTasks(appGUID)
actorWarnings := Warnings(warnings)
if err != nil {
return nil, actorWarnings, err
}
allTasks := []resources.Task{}
for _, task := range tasks {
allTasks = append(allTasks, resources.Task(task))
}
if sortOrder == Descending {
sort.Slice(allTasks, func(i int, j int) bool { return allTasks[i].SequenceID > allTasks[j].SequenceID })
} else {
sort.Slice(allTasks, func(i int, j int) bool { return allTasks[i].SequenceID < allTasks[j].SequenceID })
}
return allTasks, actorWarnings, nil
}
func (actor Actor) GetTaskBySequenceIDAndApplication(sequenceID int, appGUID string) (resources.Task, Warnings, error) {
tasks, warnings, err := actor.CloudControllerClient.GetApplicationTasks(
appGUID,
ccv3.Query{Key: ccv3.SequenceIDFilter, Values: []string{strconv.Itoa(sequenceID)}},
ccv3.Query{Key: ccv3.PerPage, Values: []string{"1"}},
ccv3.Query{Key: ccv3.Page, Values: []string{"1"}},
)
if err != nil {
return resources.Task{}, Warnings(warnings), err
}
if len(tasks) == 0 {
return resources.Task{}, Warnings(warnings), actionerror.TaskNotFoundError{SequenceID: sequenceID}
}
return resources.Task(tasks[0]), Warnings(warnings), nil
}
func (actor Actor) TerminateTask(taskGUID string) (resources.Task, Warnings, error) {
task, warnings, err := actor.CloudControllerClient.UpdateTaskCancel(taskGUID)
return resources.Task(task), Warnings(warnings), err
}
func (actor Actor) PollTask(task resources.Task) (resources.Task, Warnings, error) {
var allWarnings Warnings
for task.State != constant.TaskSucceeded && task.State != constant.TaskFailed {
time.Sleep(actor.Config.PollingInterval())
ccTask, warnings, err := actor.CloudControllerClient.GetTask(task.GUID)
log.WithFields(log.Fields{
"task_guid": task.GUID,
"state": task.State,
}).Debug("polling task state")
allWarnings = append(allWarnings, warnings...)
if err != nil {
return resources.Task{}, allWarnings, err
}
task = resources.Task(ccTask)
}
if task.State == constant.TaskFailed {
return task, allWarnings, actionerror.TaskFailedError{}
}
return task, allWarnings, nil
}