forked from travis-ci/worker
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstep_upload_script.go
71 lines (55 loc) · 1.87 KB
/
step_upload_script.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
package worker
import (
"time"
gocontext "context"
"github.com/mitchellh/multistep"
"github.com/pkg/errors"
"github.com/sirupsen/logrus"
"github.com/travis-ci/worker/backend"
"github.com/travis-ci/worker/context"
"github.com/travis-ci/worker/metrics"
)
type stepUploadScript struct {
uploadTimeout time.Duration
}
func (s *stepUploadScript) Run(state multistep.StateBag) multistep.StepAction {
procCtx := state.Get("procCtx").(gocontext.Context)
ctx := state.Get("ctx").(gocontext.Context)
buildJob := state.Get("buildJob").(Job)
logWriter := state.Get("logWriter").(LogWriter)
processedAt := state.Get("processedAt").(time.Time)
instance := state.Get("instance").(backend.Instance)
script := state.Get("script").([]byte)
logger := context.LoggerFromContext(ctx).WithField("self", "step_upload_script")
ctx, cancel := gocontext.WithTimeout(ctx, s.uploadTimeout)
defer cancel()
if instance.SupportsProgress() {
writeFoldStart(logWriter, "step_upload_script", []byte("\033[33;1mUploading script\033[0m\r\n"))
defer writeFoldEnd(logWriter, "step_upload_script", []byte(""))
}
err := instance.UploadScript(ctx, script)
if err != nil {
errMetric := "worker.job.upload.error"
if errors.Cause(err) == backend.ErrStaleVM {
errMetric += ".stalevm"
}
metrics.Mark(errMetric)
logger.WithFields(logrus.Fields{
"err": err,
"upload_timeout": s.uploadTimeout,
}).Error("couldn't upload script, attempting requeue")
context.CaptureError(ctx, err)
err := buildJob.Requeue(procCtx)
if err != nil {
logger.WithField("err", err).Error("couldn't requeue job")
}
return multistep.ActionHalt
}
logger.WithFields(logrus.Fields{
"since_processed_ms": time.Since(processedAt).Seconds() * 1e3,
}).Info("uploaded script")
return multistep.ActionContinue
}
func (s *stepUploadScript) Cleanup(state multistep.StateBag) {
// Nothing to clean up
}