2019-01-12 22:45:25 -06:00
|
|
|
package cmd
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
"os"
|
|
|
|
|
|
|
|
"github.com/nektos/act/actions"
|
|
|
|
"github.com/nektos/act/common"
|
|
|
|
log "github.com/sirupsen/logrus"
|
|
|
|
"github.com/spf13/cobra"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Execute is the entry point to running the CLI
|
|
|
|
func Execute(ctx context.Context, version string) {
|
2019-01-17 02:15:35 -06:00
|
|
|
runnerConfig := &actions.RunnerConfig{Ctx: ctx}
|
2019-01-12 22:45:25 -06:00
|
|
|
var rootCmd = &cobra.Command{
|
2019-01-17 02:15:35 -06:00
|
|
|
Use: "act [event name to run]",
|
|
|
|
Short: "Run Github actions locally by specifying the event name (e.g. `push`) or an action name directly.",
|
|
|
|
Args: cobra.MaximumNArgs(1),
|
|
|
|
RunE: newRunCommand(runnerConfig),
|
|
|
|
PersistentPreRun: setupLogging,
|
|
|
|
Version: version,
|
|
|
|
SilenceUsage: true,
|
2019-01-12 22:45:25 -06:00
|
|
|
}
|
2019-01-17 02:15:35 -06:00
|
|
|
rootCmd.Flags().BoolP("list", "l", false, "list actions")
|
|
|
|
rootCmd.Flags().StringP("action", "a", "", "run action")
|
2019-01-17 02:45:37 -06:00
|
|
|
rootCmd.Flags().BoolVarP(&runnerConfig.ReuseContainers, "reuse", "r", false, "reuse action containers to maintain state")
|
2019-01-17 02:15:35 -06:00
|
|
|
rootCmd.Flags().StringVarP(&runnerConfig.EventPath, "event", "e", "", "path to event JSON file")
|
|
|
|
rootCmd.PersistentFlags().BoolP("verbose", "v", false, "verbose output")
|
|
|
|
rootCmd.PersistentFlags().BoolVarP(&runnerConfig.Dryrun, "dryrun", "n", false, "dryrun mode")
|
|
|
|
rootCmd.PersistentFlags().StringVarP(&runnerConfig.WorkflowPath, "file", "f", "./.github/main.workflow", "path to workflow file")
|
|
|
|
rootCmd.PersistentFlags().StringVarP(&runnerConfig.WorkingDir, "directory", "C", ".", "working directory")
|
2019-01-12 22:45:25 -06:00
|
|
|
if err := rootCmd.Execute(); err != nil {
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2019-01-17 02:15:35 -06:00
|
|
|
func setupLogging(cmd *cobra.Command, args []string) {
|
|
|
|
verbose, _ := cmd.Flags().GetBool("verbose")
|
|
|
|
if verbose {
|
|
|
|
log.SetLevel(log.DebugLevel)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func newRunCommand(runnerConfig *actions.RunnerConfig) func(*cobra.Command, []string) error {
|
2019-01-12 22:45:25 -06:00
|
|
|
return func(cmd *cobra.Command, args []string) error {
|
2019-01-17 02:15:35 -06:00
|
|
|
if len(args) == 0 {
|
|
|
|
runnerConfig.EventName = "push"
|
|
|
|
} else {
|
|
|
|
runnerConfig.EventName = args[0]
|
2019-01-12 22:45:25 -06:00
|
|
|
}
|
|
|
|
|
2019-01-17 02:15:35 -06:00
|
|
|
// create the runner
|
|
|
|
runner, err := actions.NewRunner(runnerConfig)
|
2019-01-12 22:45:25 -06:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2019-01-17 02:15:35 -06:00
|
|
|
defer runner.Close()
|
2019-01-12 22:45:25 -06:00
|
|
|
|
2019-01-17 02:15:35 -06:00
|
|
|
// check if we should just print the graph
|
|
|
|
list, err := cmd.Flags().GetBool("list")
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2019-01-12 22:45:25 -06:00
|
|
|
if list {
|
2019-01-17 02:15:35 -06:00
|
|
|
return drawGraph(runner)
|
2019-01-12 22:45:25 -06:00
|
|
|
}
|
|
|
|
|
2019-01-17 02:15:35 -06:00
|
|
|
// check if we are running just a single action
|
|
|
|
actionName, err := cmd.Flags().GetString("action")
|
|
|
|
if err != nil {
|
|
|
|
return err
|
2019-01-16 15:11:32 -06:00
|
|
|
}
|
2019-01-12 22:45:25 -06:00
|
|
|
if actionName != "" {
|
2019-01-17 02:15:35 -06:00
|
|
|
return runner.RunActions(actionName)
|
2019-01-12 22:45:25 -06:00
|
|
|
}
|
|
|
|
|
2019-01-17 02:15:35 -06:00
|
|
|
// run the event in the RunnerRonfig
|
|
|
|
return runner.RunEvent()
|
2019-01-12 22:45:25 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-01-17 02:15:35 -06:00
|
|
|
func drawGraph(runner actions.Runner) error {
|
|
|
|
eventNames := runner.ListEvents()
|
2019-01-12 22:45:25 -06:00
|
|
|
for _, eventName := range eventNames {
|
2019-01-17 02:15:35 -06:00
|
|
|
graph, err := runner.GraphEvent(eventName)
|
2019-01-12 22:45:25 -06:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
drawings := make([]*common.Drawing, 0)
|
|
|
|
eventPen := common.NewPen(common.StyleDoubleLine, 91 /*34*/)
|
|
|
|
|
|
|
|
drawings = append(drawings, eventPen.DrawBoxes(fmt.Sprintf("EVENT: %s", eventName)))
|
|
|
|
|
|
|
|
actionPen := common.NewPen(common.StyleSingleLine, 96)
|
|
|
|
arrowPen := common.NewPen(common.StyleNoLine, 97)
|
|
|
|
drawings = append(drawings, arrowPen.DrawArrow())
|
|
|
|
for i, stage := range graph {
|
|
|
|
if i > 0 {
|
|
|
|
drawings = append(drawings, arrowPen.DrawArrow())
|
|
|
|
}
|
|
|
|
drawings = append(drawings, actionPen.DrawBoxes(stage...))
|
|
|
|
}
|
|
|
|
|
|
|
|
maxWidth := 0
|
|
|
|
for _, d := range drawings {
|
|
|
|
if d.GetWidth() > maxWidth {
|
|
|
|
maxWidth = d.GetWidth()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, d := range drawings {
|
|
|
|
d.Draw(os.Stdout, maxWidth)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|