-
Notifications
You must be signed in to change notification settings - Fork 2
/
jobs.go
98 lines (78 loc) · 2.79 KB
/
jobs.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
package gocd
import (
"encoding/json"
"encoding/xml"
"net/http"
"path/filepath"
"github.com/jinzhu/copier"
"github.com/nikhilsbhat/gocd-sdk-go/pkg/errors"
)
// GetScheduledJobs returns all scheduled jobs from GoCD.
func (conf *client) GetScheduledJobs() (ScheduledJobs, error) {
var scheduledJobs ScheduledJobs
newClient := &client{}
if err := copier.CopyWithOption(newClient, conf, copier.Option{IgnoreEmpty: true, DeepCopy: true}); err != nil {
return scheduledJobs, err
}
resp, err := newClient.httpClient.R().
Get(APIJobFeedEndpoint)
if err != nil {
return scheduledJobs, &errors.APIError{Err: err, Message: "get scheduled jobs"}
}
if resp.StatusCode() != http.StatusOK {
return scheduledJobs, &errors.NonOkError{Code: resp.StatusCode(), Response: resp}
}
if err = xml.Unmarshal(resp.Body(), &scheduledJobs); err != nil {
return scheduledJobs, &errors.MarshalError{Err: err}
}
return scheduledJobs, nil
}
// RunFailedJobs runs all failed jobs from a selected pipeline.
func (conf *client) RunFailedJobs(stage Stage) (string, error) {
newClient := &client{}
if err := copier.CopyWithOption(newClient, conf, copier.Option{IgnoreEmpty: true, DeepCopy: true}); err != nil {
return "", err
}
resp, err := newClient.httpClient.R().
SetHeaders(map[string]string{
"Accept": HeaderVersionThree,
HeaderConfirm: "true",
}).
Post(filepath.Join(StageEndpoint, stage.Pipeline, stage.PipelineInstance, stage.Name, stage.StageCounter, "run-failed-jobs"))
if err != nil {
return "", &errors.APIError{Err: err, Message: "run failed jobs"}
}
if resp.StatusCode() != http.StatusAccepted {
return "", &errors.NonOkError{Code: resp.StatusCode(), Response: resp}
}
var message map[string]string
if err = json.Unmarshal(resp.Body(), &message); err != nil {
return "", &errors.MarshalError{Err: err}
}
return message["message"], nil
}
// RunJobs runs all selected jobs from a selected pipeline.
func (conf *client) RunJobs(stage Stage) (string, error) {
newClient := &client{}
if err := copier.CopyWithOption(newClient, conf, copier.Option{IgnoreEmpty: true, DeepCopy: true}); err != nil {
return "", err
}
resp, err := newClient.httpClient.R().
SetBody(stage).
SetHeaders(map[string]string{
"Accept": HeaderVersionThree,
HeaderConfirm: "true",
}).
Post(filepath.Join(StageEndpoint, stage.Pipeline, stage.PipelineInstance, stage.Name, stage.StageCounter, "run-selected-jobs"))
if err != nil {
return "", &errors.APIError{Err: err, Message: "run selected jobs"}
}
if resp.StatusCode() != http.StatusAccepted {
return "", &errors.NonOkError{Code: resp.StatusCode(), Response: resp}
}
var message map[string]string
if err = json.Unmarshal(resp.Body(), &message); err != nil {
return "", &errors.MarshalError{Err: err}
}
return message["message"], nil
}