mirror of
				https://github.com/containers/podman.git
				synced 2025-10-25 10:16:43 +08:00 
			
		
		
		
	 b89a7c7406
			
		
	
	b89a7c7406
	
	
	
		
			
			When running integration tests in our CI, we observe a problem where paused containers are not able to be stopped; and therefore cannot be cleaned up. This leaves dangling mounts and sometimes zombied conmon processes. Signed-off-by: baude <bbaude@redhat.com>
		
			
				
	
	
		
			283 lines
		
	
	
		
			8.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			283 lines
		
	
	
		
			8.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package integration
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"os"
 | |
| 
 | |
| 	. "github.com/onsi/ginkgo"
 | |
| 	. "github.com/onsi/gomega"
 | |
| )
 | |
| 
 | |
| var _ = Describe("Podman pause", func() {
 | |
| 	var (
 | |
| 		tempdir    string
 | |
| 		err        error
 | |
| 		podmanTest PodmanTest
 | |
| 	)
 | |
| 
 | |
| 	pausedState := "Paused"
 | |
| 	createdState := "Created"
 | |
| 
 | |
| 	BeforeEach(func() {
 | |
| 		tempdir, err = CreateTempDirInTempDir()
 | |
| 		if err != nil {
 | |
| 			os.Exit(1)
 | |
| 		}
 | |
| 		podmanTest = PodmanCreate(tempdir)
 | |
| 		podmanTest.RestoreAllArtifacts()
 | |
| 	})
 | |
| 
 | |
| 	AfterEach(func() {
 | |
| 		podmanTest.Cleanup()
 | |
| 		f := CurrentGinkgoTestDescription()
 | |
| 		timedResult := fmt.Sprintf("Test: %s completed in %f seconds", f.TestText, f.Duration.Seconds())
 | |
| 		GinkgoWriter.Write([]byte(timedResult))
 | |
| 	})
 | |
| 
 | |
| 	It("podman pause bogus container", func() {
 | |
| 		session := podmanTest.Podman([]string{"pause", "foobar"})
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session.ExitCode()).To(Not(Equal(0)))
 | |
| 	})
 | |
| 
 | |
| 	It("podman unpause bogus container", func() {
 | |
| 		session := podmanTest.Podman([]string{"unpause", "foobar"})
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session.ExitCode()).To(Not(Equal(0)))
 | |
| 	})
 | |
| 
 | |
| 	It("podman pause a created container by id", func() {
 | |
| 		session := podmanTest.Podman([]string{"create", ALPINE, "ls"})
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session.ExitCode()).To(Equal(0))
 | |
| 		cid := session.OutputToString()
 | |
| 
 | |
| 		result := podmanTest.Podman([]string{"pause", cid})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 
 | |
| 		Expect(result.ExitCode()).To(Not(Equal(0)))
 | |
| 		Expect(podmanTest.NumberOfContainersRunning()).To(Equal(0))
 | |
| 		Expect(podmanTest.GetContainerStatus()).To(ContainSubstring(createdState))
 | |
| 	})
 | |
| 
 | |
| 	It("podman pause a running container by id", func() {
 | |
| 		session := podmanTest.RunTopContainer("")
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session.ExitCode()).To(Equal(0))
 | |
| 		cid := session.OutputToString()
 | |
| 
 | |
| 		result := podmanTest.Podman([]string{"pause", cid})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 
 | |
| 		Expect(result.ExitCode()).To(Equal(0))
 | |
| 		Expect(podmanTest.NumberOfContainersRunning()).To(Equal(0))
 | |
| 		Expect(podmanTest.GetContainerStatus()).To(ContainSubstring(pausedState))
 | |
| 
 | |
| 		result = podmanTest.Podman([]string{"unpause", cid})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 	})
 | |
| 
 | |
| 	It("podman unpause a running container by id", func() {
 | |
| 		session := podmanTest.RunTopContainer("")
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session.ExitCode()).To(Equal(0))
 | |
| 		cid := session.OutputToString()
 | |
| 
 | |
| 		result := podmanTest.Podman([]string{"unpause", cid})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 
 | |
| 		Expect(result.ExitCode()).To(Equal(125))
 | |
| 		Expect(podmanTest.NumberOfContainersRunning()).To(Equal(1))
 | |
| 
 | |
| 	})
 | |
| 
 | |
| 	It("podman remove a paused container by id", func() {
 | |
| 		session := podmanTest.RunTopContainer("")
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session.ExitCode()).To(Equal(0))
 | |
| 		cid := session.OutputToString()
 | |
| 
 | |
| 		result := podmanTest.Podman([]string{"pause", cid})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 
 | |
| 		Expect(result.ExitCode()).To(Equal(0))
 | |
| 		Expect(podmanTest.NumberOfContainersRunning()).To(Equal(0))
 | |
| 		Expect(podmanTest.GetContainerStatus()).To(ContainSubstring(pausedState))
 | |
| 
 | |
| 		result = podmanTest.Podman([]string{"rm", cid})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 
 | |
| 		Expect(result.ExitCode()).To(Equal(125))
 | |
| 		Expect(podmanTest.NumberOfContainersRunning()).To(Equal(0))
 | |
| 		Expect(podmanTest.GetContainerStatus()).To(ContainSubstring(pausedState))
 | |
| 
 | |
| 		result = podmanTest.Podman([]string{"rm", "--force", cid})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 
 | |
| 		Expect(result.ExitCode()).To(Equal(125))
 | |
| 		Expect(podmanTest.NumberOfContainersRunning()).To(Equal(0))
 | |
| 		Expect(podmanTest.GetContainerStatus()).To(ContainSubstring(pausedState))
 | |
| 
 | |
| 		result = podmanTest.Podman([]string{"unpause", cid})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 
 | |
| 		Expect(result.ExitCode()).To(Equal(0))
 | |
| 		Expect(podmanTest.NumberOfContainersRunning()).To(Equal(1))
 | |
| 
 | |
| 		result = podmanTest.Podman([]string{"rm", "--force", cid})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 
 | |
| 		Expect(result.ExitCode()).To(Equal(0))
 | |
| 		Expect(podmanTest.NumberOfContainersRunning()).To(Equal(0))
 | |
| 
 | |
| 	})
 | |
| 
 | |
| 	It("podman stop a paused container by id", func() {
 | |
| 		session := podmanTest.RunTopContainer("")
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session.ExitCode()).To(Equal(0))
 | |
| 		cid := session.OutputToString()
 | |
| 
 | |
| 		result := podmanTest.Podman([]string{"pause", cid})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 
 | |
| 		Expect(result.ExitCode()).To(Equal(0))
 | |
| 		Expect(podmanTest.NumberOfContainersRunning()).To(Equal(0))
 | |
| 		Expect(podmanTest.GetContainerStatus()).To(ContainSubstring(pausedState))
 | |
| 
 | |
| 		result = podmanTest.Podman([]string{"stop", cid})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 
 | |
| 		Expect(result.ExitCode()).To(Equal(125))
 | |
| 		Expect(podmanTest.NumberOfContainersRunning()).To(Equal(0))
 | |
| 		Expect(podmanTest.GetContainerStatus()).To(ContainSubstring(pausedState))
 | |
| 
 | |
| 		result = podmanTest.Podman([]string{"unpause", cid})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 		Expect(result.ExitCode()).To(Equal(0))
 | |
| 		Expect(podmanTest.NumberOfContainersRunning()).To(Equal(1))
 | |
| 
 | |
| 		result = podmanTest.Podman([]string{"rm", cid})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 		Expect(result.ExitCode()).To(Equal(125))
 | |
| 		Expect(podmanTest.NumberOfContainersRunning()).To(Equal(1))
 | |
| 
 | |
| 		result = podmanTest.Podman([]string{"rm", "-f", cid})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 		Expect(result.ExitCode()).To(Equal(0))
 | |
| 		Expect(podmanTest.NumberOfContainersRunning()).To(Equal(0))
 | |
| 
 | |
| 	})
 | |
| 
 | |
| 	It("podman pause a running container by name", func() {
 | |
| 		session := podmanTest.RunTopContainer("test1")
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session.ExitCode()).To(Equal(0))
 | |
| 
 | |
| 		result := podmanTest.Podman([]string{"pause", "test1"})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 
 | |
| 		Expect(result.ExitCode()).To(Equal(0))
 | |
| 		Expect(podmanTest.NumberOfContainersRunning()).To(Equal(0))
 | |
| 		Expect(podmanTest.GetContainerStatus()).To(Equal(pausedState))
 | |
| 
 | |
| 		result = podmanTest.Podman([]string{"unpause", "test1"})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 	})
 | |
| 
 | |
| 	It("podman pause a running container by id and another by name", func() {
 | |
| 		session1 := podmanTest.RunTopContainer("test1")
 | |
| 		session1.WaitWithDefaultTimeout()
 | |
| 		Expect(session1.ExitCode()).To(Equal(0))
 | |
| 
 | |
| 		session2 := podmanTest.RunTopContainer("")
 | |
| 		session2.WaitWithDefaultTimeout()
 | |
| 		Expect(session2.ExitCode()).To(Equal(0))
 | |
| 		cid2 := session2.OutputToString()
 | |
| 
 | |
| 		result := podmanTest.Podman([]string{"pause", cid2})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 
 | |
| 		Expect(result.ExitCode()).To(Equal(0))
 | |
| 		Expect(podmanTest.NumberOfContainersRunning()).To(Equal(1))
 | |
| 
 | |
| 		result = podmanTest.Podman([]string{"pause", "test1"})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 
 | |
| 		Expect(result.ExitCode()).To(Equal(0))
 | |
| 		Expect(podmanTest.NumberOfContainersRunning()).To(Equal(0))
 | |
| 
 | |
| 		result = podmanTest.Podman([]string{"unpause", "test1"})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 		result = podmanTest.Podman([]string{"unpause", cid2})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 	})
 | |
| 
 | |
| 	It("Pause all containers (no containers exist)", func() {
 | |
| 		result := podmanTest.Podman([]string{"pause", "--all"})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 		Expect(result.ExitCode()).To(Equal(0))
 | |
| 		Expect(podmanTest.NumberOfContainersRunning()).To(Equal(0))
 | |
| 
 | |
| 	})
 | |
| 
 | |
| 	It("Unpause all containers (no paused containers exist)", func() {
 | |
| 		result := podmanTest.Podman([]string{"unpause", "--all"})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 		Expect(result.ExitCode()).To(Equal(0))
 | |
| 		Expect(podmanTest.NumberOfContainersRunning()).To(Equal(0))
 | |
| 	})
 | |
| 
 | |
| 	It("Pause a bunch of running containers", func() {
 | |
| 		podmanTest.RestoreArtifact(nginx)
 | |
| 		for i := 0; i < 3; i++ {
 | |
| 			name := fmt.Sprintf("test%d", i)
 | |
| 			run := podmanTest.Podman([]string{"run", "-dt", "--name", name, nginx})
 | |
| 			run.WaitWithDefaultTimeout()
 | |
| 			Expect(run.ExitCode()).To(Equal(0))
 | |
| 
 | |
| 		}
 | |
| 		running := podmanTest.Podman([]string{"ps", "-q"})
 | |
| 		running.WaitWithDefaultTimeout()
 | |
| 		Expect(running.ExitCode()).To(Equal(0))
 | |
| 		Expect(len(running.OutputToStringArray())).To(Equal(3))
 | |
| 
 | |
| 		pause := podmanTest.Podman([]string{"pause", "--all"})
 | |
| 		pause.WaitWithDefaultTimeout()
 | |
| 		Expect(pause.ExitCode()).To(Equal(0))
 | |
| 
 | |
| 		running = podmanTest.Podman([]string{"ps", "-q"})
 | |
| 		running.WaitWithDefaultTimeout()
 | |
| 		Expect(running.ExitCode()).To(Equal(0))
 | |
| 		Expect(len(running.OutputToStringArray())).To(Equal(0))
 | |
| 
 | |
| 		unpause := podmanTest.Podman([]string{"unpause", "--all"})
 | |
| 		unpause.WaitWithDefaultTimeout()
 | |
| 		Expect(unpause.ExitCode()).To(Equal(0))
 | |
| 	})
 | |
| 
 | |
| 	It("Unpause a bunch of running containers", func() {
 | |
| 		podmanTest.RestoreArtifact(nginx)
 | |
| 		for i := 0; i < 3; i++ {
 | |
| 			name := fmt.Sprintf("test%d", i)
 | |
| 			run := podmanTest.Podman([]string{"run", "-dt", "--name", name, nginx})
 | |
| 			run.WaitWithDefaultTimeout()
 | |
| 			Expect(run.ExitCode()).To(Equal(0))
 | |
| 
 | |
| 		}
 | |
| 		pause := podmanTest.Podman([]string{"pause", "--all"})
 | |
| 		pause.WaitWithDefaultTimeout()
 | |
| 		Expect(pause.ExitCode()).To(Equal(0))
 | |
| 
 | |
| 		unpause := podmanTest.Podman([]string{"unpause", "--all"})
 | |
| 		unpause.WaitWithDefaultTimeout()
 | |
| 		Expect(unpause.ExitCode()).To(Equal(0))
 | |
| 
 | |
| 		running := podmanTest.Podman([]string{"ps", "-q"})
 | |
| 		running.WaitWithDefaultTimeout()
 | |
| 		Expect(running.ExitCode()).To(Equal(0))
 | |
| 		Expect(len(running.OutputToStringArray())).To(Equal(3))
 | |
| 	})
 | |
| 
 | |
| })
 |