From 6769d4dbc15eb57c3887b7f60de23731cbc5cacb Mon Sep 17 00:00:00 2001 From: Earl Warren Date: Sun, 2 Jul 2023 10:39:22 +0200 Subject: [PATCH] [FORGEJO] informative errors when local action is not found (cherry picked from commit cefe3d8dab38ca670b365b65e545b177da902dc3) --- pkg/runner/action.go | 7 +++++++ pkg/runner/step_action_local.go | 2 ++ 2 files changed, 9 insertions(+) diff --git a/pkg/runner/action.go b/pkg/runner/action.go index f769eee..0932359 100644 --- a/pkg/runner/action.go +++ b/pkg/runner/action.go @@ -42,6 +42,9 @@ var trampoline embed.FS func readActionImpl(ctx context.Context, step *model.Step, actionDir string, actionPath string, readFile actionYamlReader, writeFile fileWriter) (*model.Action, error) { logger := common.Logger(ctx) reader, closer, err := readFile("action.yml") + if err != nil { + logger.Debugf("readActionImpl actionDir %s actionPath %s failed %v", actionDir, actionPath, err) + } if os.IsNotExist(err) { reader, closer, err = readFile("action.yaml") if err != nil { @@ -444,11 +447,15 @@ func getContainerActionPaths(step *model.Step, actionDir string, rc *RunContext) actionName = strings.ReplaceAll(actionName, "\\", "/") } } + common.Logger(context.Background()).Debugf("getContainerActionPaths step.Type %s, rc.Config.Workdir %s, actionName %s, containerActionDir %s", step.Type().String(), rc.Config.Workdir, actionName, containerActionDir) return actionName, containerActionDir } func getOsSafeRelativePath(s, prefix string) string { actionName := strings.TrimPrefix(s, prefix) + if s == actionName { + common.Logger(context.Background()).Errorf("getOsSafeRelativePath %s does not beging with %s", s, prefix) + } if runtime.GOOS == "windows" { actionName = strings.ReplaceAll(actionName, "\\", "/") } diff --git a/pkg/runner/step_action_local.go b/pkg/runner/step_action_local.go index a745e68..c288295 100644 --- a/pkg/runner/step_action_local.go +++ b/pkg/runner/step_action_local.go @@ -44,10 +44,12 @@ func (sal *stepActionLocal) main() common.Executor { return func(filename string) (io.Reader, io.Closer, error) { tars, err := sal.RunContext.JobContainer.GetContainerArchive(ctx, path.Join(cpath, filename)) if err != nil { + common.Logger(context.Background()).Debugf("stepActionLocal reader %s failed %v", path.Join(cpath, filename), err) return nil, nil, os.ErrNotExist } treader := tar.NewReader(tars) if _, err := treader.Next(); err != nil { + common.Logger(context.Background()).Debugf("stepActionLocal reader %s failed %v", path.Join(cpath, filename), err) return nil, nil, os.ErrNotExist } return treader, tars, nil