From 47e6ce19cd7c3ac457e141479ba5ab192de0aa24 Mon Sep 17 00:00:00 2001 From: Fang-Pen Lin Date: Fri, 16 Jun 2023 13:55:00 -0700 Subject: [PATCH] Pass in correct cwd value for hooks exe Signed-off-by: Fang-Pen Lin --- libpod/container_internal.go | 35 ++++++++++++++++++------------- libpod/container_internal_test.go | 11 ++++++++++ 2 files changed, 32 insertions(+), 14 deletions(-) diff --git a/libpod/container_internal.go b/libpod/container_internal.go index 441642a0f3..3188f1b40b 100644 --- a/libpod/container_internal.go +++ b/libpod/container_internal.go @@ -2094,14 +2094,17 @@ func (c *Container) postDeleteHooks(ctx context.Context) error { hook := hook logrus.Debugf("container %s: invoke poststop hook %d, path %s", c.ID(), i, hook.Path) var stderr, stdout bytes.Buffer - opts := exec.RunOptions{ - Hook: &hook, - State: state, - Stdout: &stdout, - Stderr: &stderr, - PostKillTimeout: exec.DefaultPostKillTimeout, - } - hookErr, err := exec.RunWithOptions(ctx, opts) //nolint:staticcheck + hookErr, err := exec.RunWithOptions( + ctx, + exec.RunOptions{ + Hook: &hook, + Dir: c.bundlePath(), + State: state, + Stdout: &stdout, + Stderr: &stderr, + PostKillTimeout: exec.DefaultPostKillTimeout, + }, + ) if err != nil { logrus.Warnf("Container %s: poststop hook %d: %v", c.ID(), i, err) if hookErr != err { @@ -2229,12 +2232,16 @@ func (c *Container) setupOCIHooks(ctx context.Context, config *spec.Spec) (map[s return nil, err } } - opts := exec.RuntimeConfigFilterOptions{ - Hooks: allHooks["precreate"], - Config: config, - PostKillTimeout: exec.DefaultPostKillTimeout, - } - hookErr, err := exec.RuntimeConfigFilterWithOptions(ctx, opts) //nolint:staticcheck + + hookErr, err := exec.RuntimeConfigFilterWithOptions( + ctx, + exec.RuntimeConfigFilterOptions{ + Hooks: allHooks["precreate"], + Dir: c.bundlePath(), + Config: config, + PostKillTimeout: exec.DefaultPostKillTimeout, + }, + ) if err != nil { logrus.Warnf("Container %s: precreate hook: %v", c.ID(), err) if hookErr != nil && hookErr != err { diff --git a/libpod/container_internal_test.go b/libpod/container_internal_test.go index b1e2bc1483..1c096d1d16 100644 --- a/libpod/container_internal_test.go +++ b/libpod/container_internal_test.go @@ -6,6 +6,7 @@ import ( "os" "path/filepath" "runtime" + "strings" "testing" "github.com/containers/storage/pkg/idtools" @@ -142,6 +143,7 @@ func TestPostDeleteHooks(t *testing.T) { statePath := filepath.Join(dir, "state") copyPath := filepath.Join(dir, "copy") + cwdPath := filepath.Join(dir, "cwd") c := Container{ runtime: &Runtime{}, config: &ContainerConfig{ @@ -169,6 +171,10 @@ func TestPostDeleteHooks(t *testing.T) { Path: hookPath, Args: []string{"sh", "-c", fmt.Sprintf("cp %s %s", statePath, copyPath)}, }, + rspec.Hook{ + Path: hookPath, + Args: []string{"sh", "-c", fmt.Sprintf("pwd >%s", cwdPath)}, + }, }, }, }, @@ -188,6 +194,11 @@ func TestPostDeleteHooks(t *testing.T) { assert.Regexp(t, stateRegexp, string(content)) }) } + content, err := os.ReadFile(cwdPath) + if err != nil { + t.Fatal(err) + } + assert.Equal(t, strings.TrimSuffix(string(content), "\n"), dir) } func init() {