mirror of
https://github.com/containers/podman.git
synced 2025-06-21 01:19:15 +08:00
Merge pull request #14501 from cdoern/podUTS
podman pod create --uts support
This commit is contained in:
@ -11,9 +11,10 @@ import (
|
||||
|
||||
var _ = Describe("Podman pod clone", func() {
|
||||
var (
|
||||
tempdir string
|
||||
err error
|
||||
podmanTest *PodmanTestIntegration
|
||||
tempdir string
|
||||
err error
|
||||
podmanTest *PodmanTestIntegration
|
||||
hostname, _ = os.Hostname()
|
||||
)
|
||||
|
||||
BeforeEach(func() {
|
||||
@ -155,4 +156,39 @@ var _ = Describe("Podman pod clone", func() {
|
||||
Expect(strings[0]).Should(ContainSubstring("size=10240k"))
|
||||
})
|
||||
|
||||
It("podman pod create --uts test", func() {
|
||||
SkipIfRemote("hostname for the custom NS test is not as expected on the remote client")
|
||||
|
||||
session := podmanTest.Podman([]string{"pod", "create"})
|
||||
session.WaitWithDefaultTimeout()
|
||||
Expect(session).Should(Exit(0))
|
||||
|
||||
session = podmanTest.Podman([]string{"pod", "clone", "--uts", "host", session.OutputToString()})
|
||||
session.WaitWithDefaultTimeout()
|
||||
Expect(session).Should(Exit(0))
|
||||
|
||||
session = podmanTest.Podman([]string{"run", "-it", "--pod", session.OutputToString(), ALPINE, "printenv", "HOSTNAME"})
|
||||
session.WaitWithDefaultTimeout()
|
||||
Expect(session).Should(Exit(0))
|
||||
Expect(session.OutputToString()).To(ContainSubstring(hostname))
|
||||
|
||||
podName := "utsPod"
|
||||
ns := "ns:/proc/self/ns/"
|
||||
|
||||
session = podmanTest.Podman([]string{"pod", "create"})
|
||||
session.WaitWithDefaultTimeout()
|
||||
Expect(session).Should(Exit(0))
|
||||
|
||||
// just share uts with a custom path
|
||||
podCreate := podmanTest.Podman([]string{"pod", "clone", "--uts", ns, "--name", podName, session.OutputToString()})
|
||||
podCreate.WaitWithDefaultTimeout()
|
||||
Expect(podCreate).Should(Exit(0))
|
||||
|
||||
podInspect := podmanTest.Podman([]string{"pod", "inspect", podName})
|
||||
podInspect.WaitWithDefaultTimeout()
|
||||
Expect(podInspect).Should(Exit(0))
|
||||
podJSON := podInspect.InspectPodToJSON()
|
||||
Expect(podJSON.InfraConfig).To(HaveField("UtsNS", ns))
|
||||
})
|
||||
|
||||
})
|
||||
|
@ -23,9 +23,10 @@ import (
|
||||
|
||||
var _ = Describe("Podman pod create", func() {
|
||||
var (
|
||||
tempdir string
|
||||
err error
|
||||
podmanTest *PodmanTestIntegration
|
||||
tempdir string
|
||||
err error
|
||||
podmanTest *PodmanTestIntegration
|
||||
hostname, _ = os.Hostname()
|
||||
)
|
||||
|
||||
BeforeEach(func() {
|
||||
@ -1136,4 +1137,30 @@ ENTRYPOINT ["sleep","99999"]
|
||||
Expect(run).ShouldNot(Exit(0))
|
||||
})
|
||||
|
||||
It("podman pod create --uts test", func() {
|
||||
session := podmanTest.Podman([]string{"pod", "create", "--uts", "host"})
|
||||
session.WaitWithDefaultTimeout()
|
||||
Expect(session).Should(Exit(0))
|
||||
|
||||
session = podmanTest.Podman([]string{"run", "-it", "--pod", session.OutputToString(), ALPINE, "printenv", "HOSTNAME"})
|
||||
session.WaitWithDefaultTimeout()
|
||||
Expect(session).Should(Exit(0))
|
||||
if !IsRemote() { // remote hostname will not match os.Hostname()
|
||||
Expect(session.OutputToString()).To(ContainSubstring(hostname))
|
||||
}
|
||||
|
||||
podName := "utsPod"
|
||||
ns := "ns:/proc/self/ns/"
|
||||
|
||||
// just share uts with a custom path
|
||||
podCreate := podmanTest.Podman([]string{"pod", "create", "--uts", ns, "--name", podName, "--share", "uts"})
|
||||
podCreate.WaitWithDefaultTimeout()
|
||||
Expect(podCreate).Should(Exit(0))
|
||||
|
||||
podInspect := podmanTest.Podman([]string{"pod", "inspect", podName})
|
||||
podInspect.WaitWithDefaultTimeout()
|
||||
Expect(podInspect).Should(Exit(0))
|
||||
podJSON := podInspect.InspectPodToJSON()
|
||||
Expect(podJSON.InfraConfig).To(HaveField("UtsNS", ns))
|
||||
})
|
||||
})
|
||||
|
Reference in New Issue
Block a user