mirror of
				https://github.com/containers/podman.git
				synced 2025-10-25 18:25:59 +08:00 
			
		
		
		
	 d5e690914d
			
		
	
	d5e690914d
	
	
	
		
			
			A pause container is added to the pod if the user opts in. The default pause image and command can be overridden. Pause containers are ignored in ps unless the -a option is present. Pod inspect and pod ps show shared namespaces and pause container. A pause container can't be removed with podman rm, and a pod can be removed if it only has a pause container. Signed-off-by: haircommander <pehunt@redhat.com> Closes: #1187 Approved by: mheon
		
			
				
	
	
		
			83 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			83 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package integration
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"os"
 | |
| 
 | |
| 	. "github.com/onsi/ginkgo"
 | |
| 	. "github.com/onsi/gomega"
 | |
| )
 | |
| 
 | |
| var _ = Describe("Podman pod create", func() {
 | |
| 	var (
 | |
| 		tempdir    string
 | |
| 		err        error
 | |
| 		podmanTest PodmanTest
 | |
| 	)
 | |
| 
 | |
| 	BeforeEach(func() {
 | |
| 		tempdir, err = CreateTempDirInTempDir()
 | |
| 		if err != nil {
 | |
| 			os.Exit(1)
 | |
| 		}
 | |
| 		podmanTest = PodmanCreate(tempdir)
 | |
| 		podmanTest.RestoreAllArtifacts()
 | |
| 	})
 | |
| 
 | |
| 	AfterEach(func() {
 | |
| 		podmanTest.CleanupPod()
 | |
| 		f := CurrentGinkgoTestDescription()
 | |
| 		timedResult := fmt.Sprintf("Test: %s completed in %f seconds", f.TestText, f.Duration.Seconds())
 | |
| 		GinkgoWriter.Write([]byte(timedResult))
 | |
| 	})
 | |
| 
 | |
| 	It("podman create pod", func() {
 | |
| 		_, ec, podID := podmanTest.CreatePod("")
 | |
| 		Expect(ec).To(Equal(0))
 | |
| 
 | |
| 		check := podmanTest.Podman([]string{"pod", "ps", "-q", "--no-trunc"})
 | |
| 		check.WaitWithDefaultTimeout()
 | |
| 		match, _ := check.GrepString(podID)
 | |
| 		Expect(match).To(BeTrue())
 | |
| 		Expect(len(check.OutputToStringArray())).To(Equal(1))
 | |
| 	})
 | |
| 
 | |
| 	It("podman create pod with name", func() {
 | |
| 		name := "test"
 | |
| 		_, ec, _ := podmanTest.CreatePod(name)
 | |
| 		Expect(ec).To(Equal(0))
 | |
| 
 | |
| 		check := podmanTest.Podman([]string{"pod", "ps", "--no-trunc"})
 | |
| 		check.WaitWithDefaultTimeout()
 | |
| 		match, _ := check.GrepString(name)
 | |
| 		Expect(match).To(BeTrue())
 | |
| 	})
 | |
| 
 | |
| 	It("podman create pod with doubled name", func() {
 | |
| 		name := "test"
 | |
| 		_, ec, _ := podmanTest.CreatePod(name)
 | |
| 		Expect(ec).To(Equal(0))
 | |
| 
 | |
| 		_, ec2, _ := podmanTest.CreatePod(name)
 | |
| 		Expect(ec2).To(Not(Equal(0)))
 | |
| 
 | |
| 		check := podmanTest.Podman([]string{"pod", "ps", "-q"})
 | |
| 		check.WaitWithDefaultTimeout()
 | |
| 		Expect(len(check.OutputToStringArray())).To(Equal(1))
 | |
| 	})
 | |
| 
 | |
| 	It("podman create pod with same name as ctr", func() {
 | |
| 		name := "test"
 | |
| 		session := podmanTest.Podman([]string{"create", "--name", name, ALPINE, "ls"})
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session.ExitCode()).To(Equal(0))
 | |
| 
 | |
| 		_, ec, _ := podmanTest.CreatePod(name)
 | |
| 		Expect(ec).To(Not(Equal(0)))
 | |
| 
 | |
| 		check := podmanTest.Podman([]string{"pod", "ps", "-q"})
 | |
| 		check.WaitWithDefaultTimeout()
 | |
| 		Expect(len(check.OutputToStringArray())).To(Equal(1))
 | |
| 	})
 | |
| })
 |