mirror of
				https://github.com/containers/podman.git
				synced 2025-10-25 18:25:59 +08:00 
			
		
		
		
	 5acf8ae120
			
		
	
	5acf8ae120
	
	
	
		
			
			(Sorry, couldn't resist).
CI flakes have been coming down - thank you to everyone who has
been making them a priority.
This leaves a noisy subset that I've just been ignoring for months:
    Running: podman ... -p 8080:something
    ...cannot listen on the TCP port: listen tcp4 :8080: bind: address already in use
Sometimes these are one-time errors resolved on 2nd try; sometimes
they fail three times, forcing CI user to hit Rerun. In all cases
they make noise in my flake logs, which costs me time.
My assumption is that this has to do with ginkgo running random
tests in parallel. Since many e2e tests simplemindedly use 8080,
collisions are inevitable.
Solution: simplemindedly replace 8080 with other (also arbitrarily
picked) numbers. This is imperfect -- it requires human developers
to pick a number NNNN and 'grep NNNN test/e2e/*' before adding
new tests, which I am 100% confident ain't gonna happen -- but
it's better than what we have now.
Side note: I considered writing and using a RandomAvailablePort()
helper, but that would still be racy. Plus, it would be a pain
to interpolate strings into so many places. Finally, with this
hand-tooled approach, if/when we _do_ get conflicts on port NNNN,
it should be very easy to grep for NNNN, find the offending tests
that reuse that port, and fix one of them.
Signed-off-by: Ed Santiago <santiago@redhat.com>
		
	
		
			
				
	
	
		
			369 lines
		
	
	
		
			13 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			369 lines
		
	
	
		
			13 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package integration
 | |
| 
 | |
| import (
 | |
| 	"io/ioutil"
 | |
| 	"os"
 | |
| 	"path/filepath"
 | |
| 
 | |
| 	. "github.com/containers/podman/v3/test/utils"
 | |
| 	. "github.com/onsi/ginkgo"
 | |
| 	. "github.com/onsi/gomega"
 | |
| 	. "github.com/onsi/gomega/gexec"
 | |
| )
 | |
| 
 | |
| var _ = Describe("Podman commit", 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.SeedImages()
 | |
| 	})
 | |
| 
 | |
| 	AfterEach(func() {
 | |
| 		podmanTest.Cleanup()
 | |
| 		f := CurrentGinkgoTestDescription()
 | |
| 		processTestResult(f)
 | |
| 
 | |
| 	})
 | |
| 
 | |
| 	It("podman commit container", func() {
 | |
| 		_, ec, _ := podmanTest.RunLsContainer("test1")
 | |
| 		Expect(ec).To(Equal(0))
 | |
| 		Expect(podmanTest.NumberOfContainers()).To(Equal(1))
 | |
| 
 | |
| 		session := podmanTest.Podman([]string{"commit", "test1", "foobar.com/test1-image:latest"})
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session).Should(Exit(0))
 | |
| 
 | |
| 		check := podmanTest.Podman([]string{"inspect", "foobar.com/test1-image:latest"})
 | |
| 		check.WaitWithDefaultTimeout()
 | |
| 		data := check.InspectImageJSON()
 | |
| 		Expect(StringInSlice("foobar.com/test1-image:latest", data[0].RepoTags)).To(BeTrue())
 | |
| 	})
 | |
| 
 | |
| 	It("podman commit single letter container", func() {
 | |
| 		_, ec, _ := podmanTest.RunLsContainer("test1")
 | |
| 		Expect(ec).To(Equal(0))
 | |
| 		Expect(podmanTest.NumberOfContainers()).To(Equal(1))
 | |
| 
 | |
| 		session := podmanTest.Podman([]string{"commit", "test1", "a"})
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session).Should(Exit(0))
 | |
| 
 | |
| 		check := podmanTest.Podman([]string{"inspect", "localhost/a:latest"})
 | |
| 		check.WaitWithDefaultTimeout()
 | |
| 		data := check.InspectImageJSON()
 | |
| 		Expect(StringInSlice("localhost/a:latest", data[0].RepoTags)).To(BeTrue())
 | |
| 	})
 | |
| 
 | |
| 	It("podman container commit container", func() {
 | |
| 		_, ec, _ := podmanTest.RunLsContainer("test1")
 | |
| 		Expect(ec).To(Equal(0))
 | |
| 		Expect(podmanTest.NumberOfContainers()).To(Equal(1))
 | |
| 
 | |
| 		session := podmanTest.Podman([]string{"container", "commit", "test1", "foobar.com/test1-image:latest"})
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session).Should(Exit(0))
 | |
| 
 | |
| 		check := podmanTest.Podman([]string{"image", "inspect", "foobar.com/test1-image:latest"})
 | |
| 		check.WaitWithDefaultTimeout()
 | |
| 		data := check.InspectImageJSON()
 | |
| 		Expect(StringInSlice("foobar.com/test1-image:latest", data[0].RepoTags)).To(BeTrue())
 | |
| 	})
 | |
| 
 | |
| 	It("podman commit container with message", func() {
 | |
| 		_, ec, _ := podmanTest.RunLsContainer("test1")
 | |
| 		Expect(ec).To(Equal(0))
 | |
| 		Expect(podmanTest.NumberOfContainers()).To(Equal(1))
 | |
| 
 | |
| 		session := podmanTest.Podman([]string{"commit", "-f", "docker", "--message", "testing-commit", "test1", "foobar.com/test1-image:latest"})
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session).Should(Exit(0))
 | |
| 
 | |
| 		check := podmanTest.Podman([]string{"inspect", "foobar.com/test1-image:latest"})
 | |
| 		check.WaitWithDefaultTimeout()
 | |
| 		data := check.InspectImageJSON()
 | |
| 		Expect(data[0].Comment).To(Equal("testing-commit"))
 | |
| 	})
 | |
| 
 | |
| 	It("podman commit container with author", func() {
 | |
| 		_, ec, _ := podmanTest.RunLsContainer("test1")
 | |
| 		Expect(ec).To(Equal(0))
 | |
| 		Expect(podmanTest.NumberOfContainers()).To(Equal(1))
 | |
| 
 | |
| 		session := podmanTest.Podman([]string{"commit", "--author", "snoopy", "test1", "foobar.com/test1-image:latest"})
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session).Should(Exit(0))
 | |
| 
 | |
| 		check := podmanTest.Podman([]string{"inspect", "foobar.com/test1-image:latest"})
 | |
| 		check.WaitWithDefaultTimeout()
 | |
| 		data := check.InspectImageJSON()
 | |
| 		Expect(data[0].Author).To(Equal("snoopy"))
 | |
| 	})
 | |
| 
 | |
| 	It("podman commit container with change flag", func() {
 | |
| 		test := podmanTest.Podman([]string{"run", "--name", "test1", "-d", ALPINE, "ls"})
 | |
| 		test.WaitWithDefaultTimeout()
 | |
| 		Expect(test).Should(Exit(0))
 | |
| 		Expect(podmanTest.NumberOfContainers()).To(Equal(1))
 | |
| 
 | |
| 		session := podmanTest.Podman([]string{"commit", "--change", "LABEL=image=blue", "test1", "foobar.com/test1-image:latest"})
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session).Should(Exit(0))
 | |
| 
 | |
| 		check := podmanTest.Podman([]string{"inspect", "foobar.com/test1-image:latest"})
 | |
| 		check.WaitWithDefaultTimeout()
 | |
| 		data := check.InspectImageJSON()
 | |
| 		foundBlue := false
 | |
| 		for _, i := range data[0].Labels {
 | |
| 			if i == "blue" {
 | |
| 				foundBlue = true
 | |
| 				break
 | |
| 			}
 | |
| 		}
 | |
| 		Expect(foundBlue).To(Equal(true))
 | |
| 	})
 | |
| 
 | |
| 	It("podman commit container with change flag and JSON entrypoint with =", func() {
 | |
| 		test := podmanTest.Podman([]string{"run", "--name", "test1", "-d", ALPINE, "ls"})
 | |
| 		test.WaitWithDefaultTimeout()
 | |
| 		Expect(test).Should(Exit(0))
 | |
| 		Expect(podmanTest.NumberOfContainers()).To(Equal(1))
 | |
| 
 | |
| 		session := podmanTest.Podman([]string{"commit", "--change", `ENTRYPOINT ["foo", "bar=baz"]`, "test1", "foobar.com/test1-image:latest"})
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session).Should(Exit(0))
 | |
| 
 | |
| 		check := podmanTest.Podman([]string{"inspect", "foobar.com/test1-image:latest"})
 | |
| 		check.WaitWithDefaultTimeout()
 | |
| 		data := check.InspectImageJSON()
 | |
| 		Expect(len(data)).To(Equal(1))
 | |
| 		Expect(len(data[0].Config.Entrypoint)).To(Equal(2))
 | |
| 		Expect(data[0].Config.Entrypoint[0]).To(Equal("foo"))
 | |
| 		Expect(data[0].Config.Entrypoint[1]).To(Equal("bar=baz"))
 | |
| 	})
 | |
| 
 | |
| 	It("podman commit container with change CMD flag", func() {
 | |
| 		test := podmanTest.Podman([]string{"run", "--name", "test1", "-d", ALPINE, "ls"})
 | |
| 		test.WaitWithDefaultTimeout()
 | |
| 		Expect(test).Should(Exit(0))
 | |
| 		Expect(podmanTest.NumberOfContainers()).To(Equal(1))
 | |
| 
 | |
| 		session := podmanTest.Podman([]string{"commit", "--change", "CMD a b c", "test1", "foobar.com/test1-image:latest"})
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session).Should(Exit(0))
 | |
| 
 | |
| 		session = podmanTest.Podman([]string{"inspect", "--format", "{{.Config.Cmd}}", "foobar.com/test1-image:latest"})
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session).Should(Exit(0))
 | |
| 		Expect(session.OutputToString()).To(ContainSubstring("sh -c a b c"))
 | |
| 
 | |
| 		session = podmanTest.Podman([]string{"commit", "--change", "CMD=[\"a\",\"b\",\"c\"]", "test1", "foobar.com/test1-image:latest"})
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session).Should(Exit(0))
 | |
| 
 | |
| 		session = podmanTest.Podman([]string{"inspect", "--format", "{{.Config.Cmd}}", "foobar.com/test1-image:latest"})
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session).Should(Exit(0))
 | |
| 		Expect(session.OutputToString()).To(Not(ContainSubstring("sh -c")))
 | |
| 	})
 | |
| 
 | |
| 	It("podman commit container with pause flag", func() {
 | |
| 		_, ec, _ := podmanTest.RunLsContainer("test1")
 | |
| 		Expect(ec).To(Equal(0))
 | |
| 		Expect(podmanTest.NumberOfContainers()).To(Equal(1))
 | |
| 
 | |
| 		session := podmanTest.Podman([]string{"commit", "--pause=false", "test1", "foobar.com/test1-image:latest"})
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session).Should(Exit(0))
 | |
| 
 | |
| 		check := podmanTest.Podman([]string{"inspect", "foobar.com/test1-image:latest"})
 | |
| 		check.WaitWithDefaultTimeout()
 | |
| 		Expect(check).Should(Exit(0))
 | |
| 	})
 | |
| 
 | |
| 	It("podman commit with volumes mounts and no include-volumes", func() {
 | |
| 		s := podmanTest.Podman([]string{"run", "--name", "test1", "-v", "/tmp:/foo", "alpine", "date"})
 | |
| 		s.WaitWithDefaultTimeout()
 | |
| 		Expect(s).Should(Exit(0))
 | |
| 
 | |
| 		c := podmanTest.Podman([]string{"commit", "test1", "newimage"})
 | |
| 		c.WaitWithDefaultTimeout()
 | |
| 		Expect(c).Should(Exit(0))
 | |
| 
 | |
| 		inspect := podmanTest.Podman([]string{"inspect", "newimage"})
 | |
| 		inspect.WaitWithDefaultTimeout()
 | |
| 		Expect(inspect).Should(Exit(0))
 | |
| 		image := inspect.InspectImageJSON()
 | |
| 		_, ok := image[0].Config.Volumes["/foo"]
 | |
| 		Expect(ok).To(BeFalse())
 | |
| 	})
 | |
| 
 | |
| 	It("podman commit with volume mounts and --include-volumes", func() {
 | |
| 		// We need to figure out how volumes are going to work correctly with the remote
 | |
| 		// client.  This does not currently work.
 | |
| 		SkipIfRemote("--testing Remote Volumes")
 | |
| 		s := podmanTest.Podman([]string{"run", "--name", "test1", "-v", "/tmp:/foo", "alpine", "date"})
 | |
| 		s.WaitWithDefaultTimeout()
 | |
| 		Expect(s).Should(Exit(0))
 | |
| 
 | |
| 		c := podmanTest.Podman([]string{"commit", "--include-volumes", "test1", "newimage"})
 | |
| 		c.WaitWithDefaultTimeout()
 | |
| 		Expect(c).Should(Exit(0))
 | |
| 
 | |
| 		inspect := podmanTest.Podman([]string{"inspect", "newimage"})
 | |
| 		inspect.WaitWithDefaultTimeout()
 | |
| 		Expect(inspect).Should(Exit(0))
 | |
| 		image := inspect.InspectImageJSON()
 | |
| 		_, ok := image[0].Config.Volumes["/foo"]
 | |
| 		Expect(ok).To(BeTrue())
 | |
| 
 | |
| 		r := podmanTest.Podman([]string{"run", "newimage"})
 | |
| 		r.WaitWithDefaultTimeout()
 | |
| 		Expect(r).Should(Exit(0))
 | |
| 	})
 | |
| 
 | |
| 	It("podman commit container check env variables", func() {
 | |
| 		s := podmanTest.Podman([]string{"run", "--name", "test1", "-e", "TEST=1=1-01=9.01", "-it", "alpine", "true"})
 | |
| 		s.WaitWithDefaultTimeout()
 | |
| 		Expect(s).Should(Exit(0))
 | |
| 
 | |
| 		c := podmanTest.Podman([]string{"commit", "test1", "newimage"})
 | |
| 		c.WaitWithDefaultTimeout()
 | |
| 		Expect(c).Should(Exit(0))
 | |
| 
 | |
| 		inspect := podmanTest.Podman([]string{"inspect", "newimage"})
 | |
| 		inspect.WaitWithDefaultTimeout()
 | |
| 		Expect(inspect).Should(Exit(0))
 | |
| 		image := inspect.InspectImageJSON()
 | |
| 
 | |
| 		envMap := make(map[string]bool)
 | |
| 		for _, v := range image[0].Config.Env {
 | |
| 			envMap[v] = true
 | |
| 		}
 | |
| 		Expect(envMap["TEST=1=1-01=9.01"]).To(BeTrue())
 | |
| 	})
 | |
| 
 | |
| 	It("podman commit container and print id to external file", func() {
 | |
| 		// Switch to temp dir and restore it afterwards
 | |
| 		cwd, err := os.Getwd()
 | |
| 		Expect(err).To(BeNil())
 | |
| 		Expect(os.Chdir(os.TempDir())).To(BeNil())
 | |
| 		targetPath, err := CreateTempDirInTempDir()
 | |
| 		if err != nil {
 | |
| 			os.Exit(1)
 | |
| 		}
 | |
| 		targetFile := filepath.Join(targetPath, "idFile")
 | |
| 		defer Expect(os.RemoveAll(targetFile)).To(BeNil())
 | |
| 		defer Expect(os.Chdir(cwd)).To(BeNil())
 | |
| 
 | |
| 		_, ec, _ := podmanTest.RunLsContainer("test1")
 | |
| 		Expect(ec).To(Equal(0))
 | |
| 		Expect(podmanTest.NumberOfContainers()).To(Equal(1))
 | |
| 
 | |
| 		session := podmanTest.Podman([]string{"commit", "test1", "foobar.com/test1-image:latest", "--iidfile", targetFile})
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session).Should(Exit(0))
 | |
| 
 | |
| 		id, _ := ioutil.ReadFile(targetFile)
 | |
| 		check := podmanTest.Podman([]string{"inspect", "foobar.com/test1-image:latest"})
 | |
| 		check.WaitWithDefaultTimeout()
 | |
| 		data := check.InspectImageJSON()
 | |
| 		Expect(data[0].ID).To(Equal(string(id)))
 | |
| 	})
 | |
| 
 | |
| 	It("podman commit should not commit secret", func() {
 | |
| 		secretsString := "somesecretdata"
 | |
| 		secretFilePath := filepath.Join(podmanTest.TempDir, "secret")
 | |
| 		err := ioutil.WriteFile(secretFilePath, []byte(secretsString), 0755)
 | |
| 		Expect(err).To(BeNil())
 | |
| 
 | |
| 		session := podmanTest.Podman([]string{"secret", "create", "mysecret", secretFilePath})
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session).Should(Exit(0))
 | |
| 
 | |
| 		session = podmanTest.Podman([]string{"run", "--secret", "mysecret", "--name", "secr", ALPINE, "cat", "/run/secrets/mysecret"})
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session).Should(Exit(0))
 | |
| 		Expect(session.OutputToString()).To(Equal(secretsString))
 | |
| 
 | |
| 		session = podmanTest.Podman([]string{"commit", "secr", "foobar.com/test1-image:latest"})
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session).Should(Exit(0))
 | |
| 
 | |
| 		session = podmanTest.Podman([]string{"run", "foobar.com/test1-image:latest", "cat", "/run/secrets/mysecret"})
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session).To(ExitWithError())
 | |
| 
 | |
| 	})
 | |
| 
 | |
| 	It("podman commit should not commit env secret", func() {
 | |
| 		secretsString := "somesecretdata"
 | |
| 		secretFilePath := filepath.Join(podmanTest.TempDir, "secret")
 | |
| 		err := ioutil.WriteFile(secretFilePath, []byte(secretsString), 0755)
 | |
| 		Expect(err).To(BeNil())
 | |
| 
 | |
| 		session := podmanTest.Podman([]string{"secret", "create", "mysecret", secretFilePath})
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session).Should(Exit(0))
 | |
| 
 | |
| 		session = podmanTest.Podman([]string{"run", "--secret", "source=mysecret,type=env", "--name", "secr", ALPINE, "printenv", "mysecret"})
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session).Should(Exit(0))
 | |
| 		Expect(session.OutputToString()).To(Equal(secretsString))
 | |
| 
 | |
| 		session = podmanTest.Podman([]string{"commit", "secr", "foobar.com/test1-image:latest"})
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session).Should(Exit(0))
 | |
| 
 | |
| 		session = podmanTest.Podman([]string{"run", "foobar.com/test1-image:latest", "printenv", "mysecret"})
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session.OutputToString()).To(Not(ContainSubstring(secretsString)))
 | |
| 	})
 | |
| 
 | |
| 	It("podman commit adds exposed ports", func() {
 | |
| 		name := "testcon"
 | |
| 		s := podmanTest.Podman([]string{"run", "--name", name, "-p", "8585:80", ALPINE, "true"})
 | |
| 		s.WaitWithDefaultTimeout()
 | |
| 		Expect(s).Should(Exit(0))
 | |
| 
 | |
| 		newImageName := "newimage"
 | |
| 		c := podmanTest.Podman([]string{"commit", name, newImageName})
 | |
| 		c.WaitWithDefaultTimeout()
 | |
| 		Expect(c).Should(Exit(0))
 | |
| 
 | |
| 		inspect := podmanTest.Podman([]string{"inspect", newImageName})
 | |
| 		inspect.WaitWithDefaultTimeout()
 | |
| 		Expect(inspect).Should(Exit(0))
 | |
| 		images := inspect.InspectImageJSON()
 | |
| 		Expect(images).To(HaveLen(1))
 | |
| 		Expect(images[0].Config.ExposedPorts).To(HaveKey("80/tcp"))
 | |
| 
 | |
| 		name = "testcon2"
 | |
| 		s = podmanTest.Podman([]string{"run", "--name", name, "-d", nginx})
 | |
| 		s.WaitWithDefaultTimeout()
 | |
| 		Expect(s).Should(Exit(0))
 | |
| 
 | |
| 		newImageName = "newimage2"
 | |
| 		c = podmanTest.Podman([]string{"commit", name, newImageName})
 | |
| 		c.WaitWithDefaultTimeout()
 | |
| 		Expect(c).Should(Exit(0))
 | |
| 
 | |
| 		inspect = podmanTest.Podman([]string{"inspect", newImageName})
 | |
| 		inspect.WaitWithDefaultTimeout()
 | |
| 		Expect(inspect).Should(Exit(0))
 | |
| 		images = inspect.InspectImageJSON()
 | |
| 		Expect(images).To(HaveLen(1))
 | |
| 		Expect(images[0].Config.ExposedPorts).To(HaveKey("80/tcp"))
 | |
| 	})
 | |
| })
 |