mirror of
				https://github.com/containers/podman.git
				synced 2025-10-26 02:35:43 +08:00 
			
		
		
		
	 433cbd5254
			
		
	
	433cbd5254
	
	
	
		
			
			Because our tests are getting so long, we want to be able to audit which tests are taking the longest to complete. This may indicate a bad test, bad CI, bad code, etc and therefore should be auditable. Also, make speed improvements to tests by making sure we only unpack caches images that actually get used. Signed-off-by: baude <bbaude@redhat.com> Closes: #1178 Approved by: mheon
		
			
				
	
	
		
			217 lines
		
	
	
		
			6.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			217 lines
		
	
	
		
			6.6 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()
 | |
| 	})
 | |
| 
 | |
| })
 |