fix the .Path and .Args when use the infra-command

Signed-off-by: zhangguanzhang <zhangguanzhang@qq.com>
This commit is contained in:
zhangguanzhang 2020-09-18 00:20:11 +08:00
parent f84f441bec
commit 5f6fff0899
2 changed files with 28 additions and 0 deletions

View File

@ -50,7 +50,11 @@ func (r *Runtime) makeInfraContainer(ctx context.Context, p *Pod, imgName, rawIm
entryPoint = config.Entrypoint entryPoint = config.Entrypoint
entryCmd = config.Entrypoint entryCmd = config.Entrypoint
} }
} else { // so use the InfraCommand
entrypointSet = true
entryCmd = entryPoint
} }
if len(config.Cmd) > 0 { if len(config.Cmd) > 0 {
// We can't use the default pause command, since we're // We can't use the default pause command, since we're
// sourcing from the image. If we didn't already set an // sourcing from the image. If we didn't already set an

View File

@ -345,6 +345,12 @@ var _ = Describe("Podman pod create", func() {
check1.WaitWithDefaultTimeout() check1.WaitWithDefaultTimeout()
Expect(check1.ExitCode()).To(Equal(0)) Expect(check1.ExitCode()).To(Equal(0))
Expect(check1.OutputToString()).To(Equal("/pause")) Expect(check1.OutputToString()).To(Equal("/pause"))
// check the Path and Args
check2 := podmanTest.Podman([]string{"container", "inspect", "--format", "{{.Path}}:{{.Args}}", data.Containers[0].ID})
check2.WaitWithDefaultTimeout()
Expect(check2.ExitCode()).To(Equal(0))
Expect(check2.OutputToString()).To(Equal("/pause:[/pause]"))
}) })
It("podman create pod with --infra-command", func() { It("podman create pod with --infra-command", func() {
@ -362,6 +368,12 @@ var _ = Describe("Podman pod create", func() {
check1.WaitWithDefaultTimeout() check1.WaitWithDefaultTimeout()
Expect(check1.ExitCode()).To(Equal(0)) Expect(check1.ExitCode()).To(Equal(0))
Expect(check1.OutputToString()).To(Equal("/pause1")) Expect(check1.OutputToString()).To(Equal("/pause1"))
// check the Path and Args
check2 := podmanTest.Podman([]string{"container", "inspect", "--format", "{{.Path}}:{{.Args}}", data.Containers[0].ID})
check2.WaitWithDefaultTimeout()
Expect(check2.ExitCode()).To(Equal(0))
Expect(check2.OutputToString()).To(Equal("/pause1:[/pause1]"))
}) })
It("podman create pod with --infra-image", func() { It("podman create pod with --infra-image", func() {
@ -383,6 +395,12 @@ entrypoint ["/fromimage"]
check1.WaitWithDefaultTimeout() check1.WaitWithDefaultTimeout()
Expect(check1.ExitCode()).To(Equal(0)) Expect(check1.ExitCode()).To(Equal(0))
Expect(check1.OutputToString()).To(Equal("/fromimage")) Expect(check1.OutputToString()).To(Equal("/fromimage"))
// check the Path and Args
check2 := podmanTest.Podman([]string{"container", "inspect", "--format", "{{.Path}}:{{.Args}}", data.Containers[0].ID})
check2.WaitWithDefaultTimeout()
Expect(check2.ExitCode()).To(Equal(0))
Expect(check2.OutputToString()).To(Equal("/fromimage:[/fromimage]"))
}) })
It("podman create pod with --infra-command --infra-image", func() { It("podman create pod with --infra-command --infra-image", func() {
@ -404,5 +422,11 @@ entrypoint ["/fromimage"]
check1.WaitWithDefaultTimeout() check1.WaitWithDefaultTimeout()
Expect(check1.ExitCode()).To(Equal(0)) Expect(check1.ExitCode()).To(Equal(0))
Expect(check1.OutputToString()).To(Equal("/fromcommand")) Expect(check1.OutputToString()).To(Equal("/fromcommand"))
// check the Path and Args
check2 := podmanTest.Podman([]string{"container", "inspect", "--format", "{{.Path}}:{{.Args}}", data.Containers[0].ID})
check2.WaitWithDefaultTimeout()
Expect(check2.ExitCode()).To(Equal(0))
Expect(check2.OutputToString()).To(Equal("/fromcommand:[/fromcommand]"))
}) })
}) })