forked from travis-ci/worker
-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathstep_generate_script.go
73 lines (55 loc) · 1.71 KB
/
step_generate_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
72
73
package worker
import (
"time"
gocontext "context"
"github.com/cenk/backoff"
"github.com/mitchellh/multistep"
"github.com/travis-ci/worker/context"
"go.opencensus.io/trace"
)
type stepGenerateScript struct {
generator BuildScriptGenerator
}
func (s *stepGenerateScript) Run(state multistep.StateBag) multistep.StepAction {
buildJob := state.Get("buildJob").(Job)
ctx := state.Get("ctx").(gocontext.Context)
defer context.TimeSince(ctx, "step_generate_script_run", time.Now())
ctx, span := trace.StartSpan(ctx, "GenerateScript.Run")
defer span.End()
logger := context.LoggerFromContext(ctx).WithField("self", "step_generate_script")
b := backoff.NewExponentialBackOff()
b.MaxInterval = 10 * time.Second
b.MaxElapsedTime = time.Minute
var script []byte
var err error
switch job := buildJob.(type) {
case BuildScriptGenerator:
logger.Info("using job to get script")
script, err = job.Generate(ctx, buildJob)
default:
logger.Info("using build script generator to generate script")
err = backoff.Retry(func() (err error) {
script, err = s.generator.Generate(ctx, buildJob)
return
}, b)
}
if err != nil {
state.Put("err", err)
span.SetStatus(trace.Status{
Code: trace.StatusCodeUnavailable,
Message: err.Error(),
})
logger.WithField("err", err).Error("couldn't generate build script, erroring job")
err := buildJob.Error(ctx, "An error occurred while generating the build script.")
if err != nil {
logger.WithField("err", err).Error("couldn't requeue job")
}
return multistep.ActionHalt
}
logger.Info("generated script")
state.Put("script", script)
return multistep.ActionContinue
}
func (s *stepGenerateScript) Cleanup(multistep.StateBag) {
// Nothing to clean up
}