forgejo-runner-act/pkg/runner/runner.go

90 lines
2.5 KiB
Go
Raw Normal View History

2020-02-05 00:38:41 +00:00
package runner
import (
"context"
2020-02-05 00:38:41 +00:00
"io/ioutil"
"github.com/nektos/act/pkg/common"
"github.com/nektos/act/pkg/model"
log "github.com/sirupsen/logrus"
)
// Runner provides capabilities to run GitHub actions
type Runner interface {
NewPlanExecutor(plan *model.Plan) common.Executor
NewRunExecutor(run *model.Run, matrix map[string]interface{}) common.Executor
2020-02-05 00:38:41 +00:00
}
// Config contains the config for a new runner
type Config struct {
Workdir string // path to working directory
2020-02-05 00:38:41 +00:00
EventName string // name of event to run
EventPath string // path to JSON file to use for event.json in containers
ReuseContainers bool // reuse containers to maintain state
ForcePull bool // force pulling of the image, if already present
LogOutput bool // log the output from docker run
2020-02-05 00:38:41 +00:00
}
type runnerImpl struct {
config *Config
eventJSON string
}
// New Creates a new Runner
func New(runnerConfig *Config) (Runner, error) {
2020-02-05 00:38:41 +00:00
runner := &runnerImpl{
config: runnerConfig,
}
runner.eventJSON = "{}"
if runnerConfig.EventPath != "" {
2020-02-05 00:38:41 +00:00
log.Debugf("Reading event.json from %s", runner.config.EventPath)
eventJSONBytes, err := ioutil.ReadFile(runner.config.EventPath)
if err != nil {
return nil, err
2020-02-05 00:38:41 +00:00
}
runner.eventJSON = string(eventJSONBytes)
}
return runner, nil
2020-02-05 00:38:41 +00:00
}
func (runner *runnerImpl) NewPlanExecutor(plan *model.Plan) common.Executor {
2020-02-05 00:38:41 +00:00
pipeline := make([]common.Executor, 0)
for _, stage := range plan.Stages {
stageExecutor := make([]common.Executor, 0)
for _, run := range stage.Runs {
// TODO - don't just grab first index of each dimension
matrix := make(map[string]interface{})
if run.Job().Strategy != nil {
for mkey, mvals := range run.Job().Strategy.Matrix {
if mkey == "include" || mkey == "exclude" {
continue
}
matrix[mkey] = mvals[0]
}
}
stageExecutor = append(stageExecutor, runner.NewRunExecutor(run, matrix))
2020-02-05 00:38:41 +00:00
}
pipeline = append(pipeline, common.NewParallelExecutor(stageExecutor...))
}
return common.NewPipelineExecutor(pipeline...)
2020-02-05 00:38:41 +00:00
}
func (runner *runnerImpl) NewRunExecutor(run *model.Run, matrix map[string]interface{}) common.Executor {
rc := new(RunContext)
rc.Config = runner.config
rc.Run = run
rc.EventJSON = runner.eventJSON
rc.StepResults = make(map[string]*stepResult)
rc.Matrix = matrix
ee := rc.NewExpressionEvaluator()
rc.PlatformName = ee.Interpolate(run.Job().RunsOn)
return func(ctx context.Context) error {
ctx = WithJobLogger(ctx, rc.Run.String())
return rc.Executor()(ctx)
}
2020-02-05 00:38:41 +00:00
}