From 67918333fa7fac871f9de707970f0ef5f564ab61 Mon Sep 17 00:00:00 2001 From: Jason Song Date: Tue, 31 Oct 2023 22:32:21 +0800 Subject: [PATCH] fix: panic --- pkg/container/docker_run.go | 32 +++++++++++++++++--------------- 1 file changed, 17 insertions(+), 15 deletions(-) diff --git a/pkg/container/docker_run.go b/pkg/container/docker_run.go index 5304707..fe13f29 100644 --- a/pkg/container/docker_run.go +++ b/pkg/container/docker_run.go @@ -16,29 +16,25 @@ import ( "strconv" "strings" - "github.com/docker/docker/api/types/network" - networktypes "github.com/docker/docker/api/types/network" - "github.com/gobwas/glob" - - "github.com/go-git/go-billy/v5/helper/polyfill" - "github.com/go-git/go-billy/v5/osfs" - "github.com/go-git/go-git/v5/plumbing/format/gitignore" - "github.com/joho/godotenv" - - "github.com/imdario/mergo" - "github.com/kballard/go-shellquote" - "github.com/spf13/pflag" - + "github.com/Masterminds/semver" "github.com/docker/cli/cli/compose/loader" "github.com/docker/cli/cli/connhelper" "github.com/docker/docker/api/types" "github.com/docker/docker/api/types/container" "github.com/docker/docker/api/types/mount" + "github.com/docker/docker/api/types/network" + networktypes "github.com/docker/docker/api/types/network" "github.com/docker/docker/client" "github.com/docker/docker/pkg/stdcopy" + "github.com/go-git/go-billy/v5/helper/polyfill" + "github.com/go-git/go-billy/v5/osfs" + "github.com/go-git/go-git/v5/plumbing/format/gitignore" + "github.com/gobwas/glob" + "github.com/imdario/mergo" + "github.com/joho/godotenv" + "github.com/kballard/go-shellquote" specs "github.com/opencontainers/image-spec/specs-go/v1" - - "github.com/Masterminds/semver" + "github.com/spf13/pflag" "golang.org/x/term" "github.com/nektos/act/pkg/common" @@ -523,11 +519,17 @@ func (cr *containerReference) extractFromImageEnv(env *map[string]string) common inspect, _, err := cr.cli.ImageInspectWithRaw(ctx, cr.input.Image) if err != nil { logger.Error(err) + return fmt.Errorf("inspect image: %w", err) + } + + if inspect.Config == nil { + return nil } imageEnv, err := godotenv.Unmarshal(strings.Join(inspect.Config.Env, "\n")) if err != nil { logger.Error(err) + return fmt.Errorf("unmarshal image env: %w", err) } for k, v := range imageEnv {