mirror of
https://github.com/containers/podman.git
synced 2025-08-01 05:54:53 +08:00
Begin adding volume tests
Signed-off-by: Matthew Heon <matthew.heon@pm.me>
This commit is contained in:
@ -212,63 +212,6 @@ var _ = Describe("Podman run", func() {
|
|||||||
Expect(session.OutputToString()).To(ContainSubstring("100"))
|
Expect(session.OutputToString()).To(ContainSubstring("100"))
|
||||||
})
|
})
|
||||||
|
|
||||||
It("podman run with volume flag", func() {
|
|
||||||
SkipIfRootless()
|
|
||||||
Skip("Skip until we diagnose the regression of volume mounts")
|
|
||||||
mountPath := filepath.Join(podmanTest.TempDir, "secrets")
|
|
||||||
os.Mkdir(mountPath, 0755)
|
|
||||||
session := podmanTest.Podman([]string{"run", "--rm", "-v", fmt.Sprintf("%s:/run/test", mountPath), ALPINE, "cat", "/proc/self/mountinfo"})
|
|
||||||
session.WaitWithDefaultTimeout()
|
|
||||||
Expect(session.ExitCode()).To(Equal(0))
|
|
||||||
Expect(session.OutputToString()).To(ContainSubstring("/run/test rw,relatime"))
|
|
||||||
|
|
||||||
mountPath = filepath.Join(podmanTest.TempDir, "secrets")
|
|
||||||
os.Mkdir(mountPath, 0755)
|
|
||||||
session = podmanTest.Podman([]string{"run", "--rm", "-v", fmt.Sprintf("%s:/run/test:ro", mountPath), ALPINE, "cat", "/proc/self/mountinfo"})
|
|
||||||
session.WaitWithDefaultTimeout()
|
|
||||||
Expect(session.ExitCode()).To(Equal(0))
|
|
||||||
Expect(session.OutputToString()).To(ContainSubstring("/run/test ro,relatime"))
|
|
||||||
|
|
||||||
mountPath = filepath.Join(podmanTest.TempDir, "secrets")
|
|
||||||
os.Mkdir(mountPath, 0755)
|
|
||||||
session = podmanTest.Podman([]string{"run", "--rm", "-v", fmt.Sprintf("%s:/run/test:shared", mountPath), ALPINE, "cat", "/proc/self/mountinfo"})
|
|
||||||
session.WaitWithDefaultTimeout()
|
|
||||||
Expect(session.ExitCode()).To(Equal(0))
|
|
||||||
Expect(session.OutputToString()).To(ContainSubstring("/run/test rw,relatime, shared"))
|
|
||||||
})
|
|
||||||
|
|
||||||
It("podman run with --mount flag", func() {
|
|
||||||
if podmanTest.Host.Arch == "ppc64le" {
|
|
||||||
Skip("skip failing test on ppc64le")
|
|
||||||
}
|
|
||||||
mountPath := filepath.Join(podmanTest.TempDir, "secrets")
|
|
||||||
os.Mkdir(mountPath, 0755)
|
|
||||||
session := podmanTest.Podman([]string{"run", "--rm", "--mount", fmt.Sprintf("type=bind,src=%s,target=/run/test", mountPath), ALPINE, "grep", "/run/test", "/proc/self/mountinfo"})
|
|
||||||
session.WaitWithDefaultTimeout()
|
|
||||||
Expect(session.ExitCode()).To(Equal(0))
|
|
||||||
Expect(session.OutputToString()).To(ContainSubstring("/run/test rw"))
|
|
||||||
|
|
||||||
session = podmanTest.Podman([]string{"run", "--rm", "--mount", fmt.Sprintf("type=bind,src=%s,target=/run/test,ro", mountPath), ALPINE, "grep", "/run/test", "/proc/self/mountinfo"})
|
|
||||||
session.WaitWithDefaultTimeout()
|
|
||||||
Expect(session.ExitCode()).To(Equal(0))
|
|
||||||
Expect(session.OutputToString()).To(ContainSubstring("/run/test ro"))
|
|
||||||
|
|
||||||
session = podmanTest.Podman([]string{"run", "--rm", "--mount", fmt.Sprintf("type=bind,src=%s,target=/run/test,shared", mountPath), ALPINE, "grep", "/run/test", "/proc/self/mountinfo"})
|
|
||||||
session.WaitWithDefaultTimeout()
|
|
||||||
Expect(session.ExitCode()).To(Equal(0))
|
|
||||||
found, matches := session.GrepString("/run/test")
|
|
||||||
Expect(found).Should(BeTrue())
|
|
||||||
Expect(matches[0]).To(ContainSubstring("rw"))
|
|
||||||
Expect(matches[0]).To(ContainSubstring("shared"))
|
|
||||||
|
|
||||||
mountPath = filepath.Join(podmanTest.TempDir, "scratchpad")
|
|
||||||
os.Mkdir(mountPath, 0755)
|
|
||||||
session = podmanTest.Podman([]string{"run", "--rm", "--mount", "type=tmpfs,target=/run/test", ALPINE, "grep", "/run/test", "/proc/self/mountinfo"})
|
|
||||||
session.WaitWithDefaultTimeout()
|
|
||||||
Expect(session.ExitCode()).To(Equal(0))
|
|
||||||
Expect(session.OutputToString()).To(ContainSubstring("/run/test rw,nosuid,nodev,noexec,relatime - tmpfs"))
|
|
||||||
})
|
|
||||||
|
|
||||||
It("podman run with cidfile", func() {
|
It("podman run with cidfile", func() {
|
||||||
session := podmanTest.Podman([]string{"run", "--cidfile", tempdir + "cidfile", ALPINE, "ls"})
|
session := podmanTest.Podman([]string{"run", "--cidfile", tempdir + "cidfile", ALPINE, "ls"})
|
||||||
session.WaitWithDefaultTimeout()
|
session.WaitWithDefaultTimeout()
|
||||||
|
103
test/e2e/run_volume_test.go
Normal file
103
test/e2e/run_volume_test.go
Normal file
@ -0,0 +1,103 @@
|
|||||||
|
// +build !remoteclient
|
||||||
|
|
||||||
|
package integration
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"os"
|
||||||
|
"path/filepath"
|
||||||
|
|
||||||
|
. "github.com/containers/libpod/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.RestoreAllArtifacts()
|
||||||
|
})
|
||||||
|
|
||||||
|
AfterEach(func() {
|
||||||
|
podmanTest.Cleanup()
|
||||||
|
f := CurrentGinkgoTestDescription()
|
||||||
|
processTestResult(f)
|
||||||
|
})
|
||||||
|
|
||||||
|
It("podman run with volume flag", func() {
|
||||||
|
mountPath := filepath.Join(podmanTest.TempDir, "secrets")
|
||||||
|
os.Mkdir(mountPath, 0755)
|
||||||
|
session := podmanTest.Podman([]string{"run", "--rm", "-v", fmt.Sprintf("%s:/run/test", mountPath), ALPINE, "grep", "/run/test", "/proc/self/mountinfo"})
|
||||||
|
session.WaitWithDefaultTimeout()
|
||||||
|
Expect(session.ExitCode()).To(Equal(0))
|
||||||
|
Expect(session.OutputToString()).To(ContainSubstring("/run/test rw,relatime"))
|
||||||
|
|
||||||
|
mountPath = filepath.Join(podmanTest.TempDir, "secrets")
|
||||||
|
os.Mkdir(mountPath, 0755)
|
||||||
|
session = podmanTest.Podman([]string{"run", "--rm", "-v", fmt.Sprintf("%s:/run/test:ro", mountPath), ALPINE, "grep", "/run/test", "/proc/self/mountinfo"})
|
||||||
|
session.WaitWithDefaultTimeout()
|
||||||
|
Expect(session.ExitCode()).To(Equal(0))
|
||||||
|
Expect(session.OutputToString()).To(ContainSubstring("/run/test ro,relatime"))
|
||||||
|
|
||||||
|
mountPath = filepath.Join(podmanTest.TempDir, "secrets")
|
||||||
|
os.Mkdir(mountPath, 0755)
|
||||||
|
session = podmanTest.Podman([]string{"run", "--rm", "-v", fmt.Sprintf("%s:/run/test:shared", mountPath), ALPINE, "grep", "/run/test", "/proc/self/mountinfo"})
|
||||||
|
session.WaitWithDefaultTimeout()
|
||||||
|
Expect(session.ExitCode()).To(Equal(0))
|
||||||
|
found, matches := session.GrepString("/run/test")
|
||||||
|
Expect(found).Should(BeTrue())
|
||||||
|
Expect(matches[0]).To(ContainSubstring("rw"))
|
||||||
|
Expect(matches[0]).To(ContainSubstring("shared"))
|
||||||
|
})
|
||||||
|
|
||||||
|
It("podman run with --mount flag", func() {
|
||||||
|
if podmanTest.Host.Arch == "ppc64le" {
|
||||||
|
Skip("skip failing test on ppc64le")
|
||||||
|
}
|
||||||
|
mountPath := filepath.Join(podmanTest.TempDir, "secrets")
|
||||||
|
os.Mkdir(mountPath, 0755)
|
||||||
|
session := podmanTest.Podman([]string{"run", "--rm", "--mount", fmt.Sprintf("type=bind,src=%s,target=/run/test", mountPath), ALPINE, "grep", "/run/test", "/proc/self/mountinfo"})
|
||||||
|
session.WaitWithDefaultTimeout()
|
||||||
|
Expect(session.ExitCode()).To(Equal(0))
|
||||||
|
Expect(session.OutputToString()).To(ContainSubstring("/run/test rw"))
|
||||||
|
|
||||||
|
session = podmanTest.Podman([]string{"run", "--rm", "--mount", fmt.Sprintf("type=bind,src=%s,target=/run/test,ro", mountPath), ALPINE, "grep", "/run/test", "/proc/self/mountinfo"})
|
||||||
|
session.WaitWithDefaultTimeout()
|
||||||
|
Expect(session.ExitCode()).To(Equal(0))
|
||||||
|
Expect(session.OutputToString()).To(ContainSubstring("/run/test ro"))
|
||||||
|
|
||||||
|
session = podmanTest.Podman([]string{"run", "--rm", "--mount", fmt.Sprintf("type=bind,src=%s,target=/run/test,shared", mountPath), ALPINE, "grep", "/run/test", "/proc/self/mountinfo"})
|
||||||
|
session.WaitWithDefaultTimeout()
|
||||||
|
Expect(session.ExitCode()).To(Equal(0))
|
||||||
|
found, matches := session.GrepString("/run/test")
|
||||||
|
Expect(found).Should(BeTrue())
|
||||||
|
Expect(matches[0]).To(ContainSubstring("rw"))
|
||||||
|
Expect(matches[0]).To(ContainSubstring("shared"))
|
||||||
|
|
||||||
|
mountPath = filepath.Join(podmanTest.TempDir, "scratchpad")
|
||||||
|
os.Mkdir(mountPath, 0755)
|
||||||
|
session = podmanTest.Podman([]string{"run", "--rm", "--mount", "type=tmpfs,target=/run/test", ALPINE, "grep", "/run/test", "/proc/self/mountinfo"})
|
||||||
|
session.WaitWithDefaultTimeout()
|
||||||
|
Expect(session.ExitCode()).To(Equal(0))
|
||||||
|
Expect(session.OutputToString()).To(ContainSubstring("/run/test rw,nosuid,nodev,noexec,relatime - tmpfs"))
|
||||||
|
})
|
||||||
|
|
||||||
|
It("podman run with conflicting volumes errors", func() {
|
||||||
|
mountPath := filepath.Join(podmanTest.TmpDir, "secrets")
|
||||||
|
os.Mkdir(mountPath, 0755)
|
||||||
|
session := podmanTest.Podman([]string{"run", "-v", fmt.Sprintf("%s:/run/test", mountPath), "-v", "/tmp:/run/test", ALPINE, "ls"})
|
||||||
|
session.WaitWithDefaultTimeout()
|
||||||
|
Expect(session.ExitCode()).To(Equal(125))
|
||||||
|
})
|
||||||
|
})
|
Reference in New Issue
Block a user