mirror of
https://github.com/containers/podman.git
synced 2025-07-28 10:52:35 +08:00
Merge pull request #7239 from rhatdan/working
Fix handling of working dir
This commit is contained in:
@ -142,11 +142,6 @@ func (s *SpecGenerator) Validate() error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
// The following are defaults as needed by container creation
|
|
||||||
if len(s.WorkDir) < 1 {
|
|
||||||
s.WorkDir = "/"
|
|
||||||
}
|
|
||||||
|
|
||||||
// Set defaults if network info is not provided
|
// Set defaults if network info is not provided
|
||||||
if s.NetNS.NSMode == "" {
|
if s.NetNS.NSMode == "" {
|
||||||
s.NetNS.NSMode = Bridge
|
s.NetNS.NSMode = Bridge
|
||||||
|
@ -135,15 +135,18 @@ func CompleteSpec(ctx context.Context, r *libpod.Runtime, s *specgen.SpecGenerat
|
|||||||
s.Annotations = annotations
|
s.Annotations = annotations
|
||||||
|
|
||||||
// workdir
|
// workdir
|
||||||
|
if s.WorkDir == "" {
|
||||||
if newImage != nil {
|
if newImage != nil {
|
||||||
workingDir, err := newImage.WorkingDir(ctx)
|
workingDir, err := newImage.WorkingDir(ctx)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
if len(s.WorkDir) < 1 && len(workingDir) > 1 {
|
|
||||||
s.WorkDir = workingDir
|
s.WorkDir = workingDir
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if s.WorkDir == "" {
|
||||||
|
s.WorkDir = "/"
|
||||||
|
}
|
||||||
|
|
||||||
if len(s.SeccompProfilePath) < 1 {
|
if len(s.SeccompProfilePath) < 1 {
|
||||||
p, err := libpod.DefaultSeccompPath()
|
p, err := libpod.DefaultSeccompPath()
|
||||||
|
@ -241,14 +241,8 @@ func createContainerOptions(ctx context.Context, rt *libpod.Runtime, s *specgen.
|
|||||||
// If the user did not set an workdir but the image did, ensure it is
|
// If the user did not set an workdir but the image did, ensure it is
|
||||||
// created.
|
// created.
|
||||||
if s.WorkDir == "" && img != nil {
|
if s.WorkDir == "" && img != nil {
|
||||||
newWD, err := img.WorkingDir(ctx)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
if newWD != "" {
|
|
||||||
options = append(options, libpod.WithCreateWorkingDir())
|
options = append(options, libpod.WithCreateWorkingDir())
|
||||||
}
|
}
|
||||||
}
|
|
||||||
if s.StopSignal != nil {
|
if s.StopSignal != nil {
|
||||||
options = append(options, libpod.WithStopSignal(*s.StopSignal))
|
options = append(options, libpod.WithStopSignal(*s.StopSignal))
|
||||||
}
|
}
|
||||||
|
69
test/e2e/run_working_dir.go
Normal file
69
test/e2e/run_working_dir.go
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
package integration
|
||||||
|
|
||||||
|
import (
|
||||||
|
"os"
|
||||||
|
"strings"
|
||||||
|
|
||||||
|
. "github.com/containers/podman/v2/test/utils"
|
||||||
|
. "github.com/onsi/ginkgo"
|
||||||
|
. "github.com/onsi/gomega"
|
||||||
|
)
|
||||||
|
|
||||||
|
var _ = Describe("Podman run", func() {
|
||||||
|
var (
|
||||||
|
tempdir string
|
||||||
|
err error
|
||||||
|
podmanTest *PodmanTestIntegration
|
||||||
|
)
|
||||||
|
|
||||||
|
BeforeEach(func() {
|
||||||
|
tempdir, err = CreateTempDirInTempDir()
|
||||||
|
if err != nil {
|
||||||
|
os.Exit(1)
|
||||||
|
}
|
||||||
|
podmanTest = PodmanTestCreate(tempdir)
|
||||||
|
podmanTest.Setup()
|
||||||
|
podmanTest.SeedImages()
|
||||||
|
})
|
||||||
|
|
||||||
|
AfterEach(func() {
|
||||||
|
podmanTest.Cleanup()
|
||||||
|
f := CurrentGinkgoTestDescription()
|
||||||
|
processTestResult(f)
|
||||||
|
|
||||||
|
})
|
||||||
|
|
||||||
|
It("podman run a container without workdir", func() {
|
||||||
|
session := podmanTest.Podman([]string{"run", ALPINE, "pwd"})
|
||||||
|
session.WaitWithDefaultTimeout()
|
||||||
|
Expect(session.ExitCode()).To(Equal(0))
|
||||||
|
Expect(session.OutputToString()).To(Equal("/"))
|
||||||
|
})
|
||||||
|
|
||||||
|
It("podman run a container using non existing --workdir", func() {
|
||||||
|
if !strings.Contains(podmanTest.OCIRuntime, "crun") {
|
||||||
|
Skip("Test only works on crun")
|
||||||
|
}
|
||||||
|
session := podmanTest.Podman([]string{"run", "--workdir", "/home/foobar", ALPINE, "pwd"})
|
||||||
|
session.WaitWithDefaultTimeout()
|
||||||
|
Expect(session.ExitCode()).To(Equal(127))
|
||||||
|
})
|
||||||
|
|
||||||
|
It("podman run a container on an image with a workdir", func() {
|
||||||
|
SkipIfRemote()
|
||||||
|
dockerfile := `FROM alpine
|
||||||
|
RUN mkdir -p /home/foobar
|
||||||
|
WORKDIR /etc/foobar`
|
||||||
|
podmanTest.BuildImage(dockerfile, "test", "false")
|
||||||
|
|
||||||
|
session := podmanTest.Podman([]string{"run", "test", "pwd"})
|
||||||
|
session.WaitWithDefaultTimeout()
|
||||||
|
Expect(session.ExitCode()).To(Equal(0))
|
||||||
|
Expect(session.OutputToString()).To(Equal("/etc/foobar"))
|
||||||
|
|
||||||
|
session = podmanTest.Podman([]string{"run", "--workdir", "/home/foobar", "test", "pwd"})
|
||||||
|
session.WaitWithDefaultTimeout()
|
||||||
|
Expect(session.ExitCode()).To(Equal(0))
|
||||||
|
Expect(session.OutputToString()).To(Equal("/home/foobar"))
|
||||||
|
})
|
||||||
|
})
|
Reference in New Issue
Block a user