mirror of https://github.com/containers/podman.git
				
				
				
			
		
			
				
	
	
		
			155 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			Go
		
	
	
	
			
		
		
	
	
			155 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			Go
		
	
	
	
| package e2e_test
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"io"
 | |
| 	"net"
 | |
| 	"net/http"
 | |
| 	"net/url"
 | |
| 	"os"
 | |
| 	"path"
 | |
| 	"path/filepath"
 | |
| 	"time"
 | |
| 
 | |
| 	. "github.com/onsi/ginkgo/v2"
 | |
| 	. "github.com/onsi/gomega"
 | |
| 	. "github.com/onsi/gomega/gexec"
 | |
| )
 | |
| 
 | |
| var _ = Describe("run basic podman commands", func() {
 | |
| 	var (
 | |
| 		mb      *machineTestBuilder
 | |
| 		testDir string
 | |
| 	)
 | |
| 
 | |
| 	BeforeEach(func() {
 | |
| 		testDir, mb = setup()
 | |
| 	})
 | |
| 	AfterEach(func() {
 | |
| 		teardown(originalHomeDir, testDir, mb)
 | |
| 	})
 | |
| 
 | |
| 	It("Basic ops", func() {
 | |
| 		// golangci-lint has trouble with actually skipping tests marked Skip
 | |
| 		// so skip it on cirrus envs and where CIRRUS_CI isn't set.
 | |
| 		name := randomString()
 | |
| 		i := new(initMachine)
 | |
| 		session, err := mb.setName(name).setCmd(i.withImagePath(mb.imagePath).withNow()).run()
 | |
| 		Expect(err).ToNot(HaveOccurred())
 | |
| 		Expect(session).To(Exit(0))
 | |
| 
 | |
| 		bm := basicMachine{}
 | |
| 		imgs, err := mb.setCmd(bm.withPodmanCommand([]string{"images", "-q"})).run()
 | |
| 		Expect(err).ToNot(HaveOccurred())
 | |
| 		Expect(imgs).To(Exit(0))
 | |
| 		Expect(imgs.outputToStringSlice()).To(BeEmpty())
 | |
| 
 | |
| 		newImgs, err := mb.setCmd(bm.withPodmanCommand([]string{"pull", "quay.io/libpod/alpine_nginx"})).run()
 | |
| 		Expect(err).ToNot(HaveOccurred())
 | |
| 		Expect(newImgs).To(Exit(0))
 | |
| 		Expect(newImgs.outputToStringSlice()).To(HaveLen(1))
 | |
| 
 | |
| 		runAlp, err := mb.setCmd(bm.withPodmanCommand([]string{"run", "quay.io/libpod/alpine_nginx", "cat", "/etc/os-release"})).run()
 | |
| 		Expect(err).ToNot(HaveOccurred())
 | |
| 		Expect(runAlp).To(Exit(0))
 | |
| 		Expect(runAlp.outputToString()).To(ContainSubstring("Alpine Linux"))
 | |
| 
 | |
| 		rmCon, err := mb.setCmd(bm.withPodmanCommand([]string{"rm", "-a"})).run()
 | |
| 		Expect(err).ToNot(HaveOccurred())
 | |
| 		Expect(rmCon).To(Exit(0))
 | |
| 	})
 | |
| 
 | |
| 	It("Podman ops with port forwarding and gvproxy", func() {
 | |
| 		name := randomString()
 | |
| 		i := new(initMachine)
 | |
| 		session, err := mb.setName(name).setCmd(i.withImagePath(mb.imagePath).withNow()).run()
 | |
| 		Expect(err).ToNot(HaveOccurred())
 | |
| 		Expect(session).To(Exit(0))
 | |
| 
 | |
| 		ctrName := "test"
 | |
| 		bm := basicMachine{}
 | |
| 		runAlp, err := mb.setCmd(bm.withPodmanCommand([]string{"run", "-dt", "--name", ctrName, "-p", "62544:80", "quay.io/libpod/alpine_nginx"})).run()
 | |
| 		Expect(err).ToNot(HaveOccurred())
 | |
| 		Expect(runAlp).To(Exit(0))
 | |
| 		testHTTPServer("62544", false, "podman rulez")
 | |
| 
 | |
| 		// Test exec in machine scenario: https://github.com/containers/podman/issues/20821
 | |
| 		exec, err := mb.setCmd(bm.withPodmanCommand([]string{"exec", ctrName, "true"})).run()
 | |
| 		Expect(err).ToNot(HaveOccurred())
 | |
| 		Expect(exec).To(Exit(0))
 | |
| 
 | |
| 		out, err := pgrep("gvproxy")
 | |
| 		Expect(err).ToNot(HaveOccurred())
 | |
| 		Expect(out).ToNot(BeEmpty())
 | |
| 
 | |
| 		rmCon, err := mb.setCmd(bm.withPodmanCommand([]string{"rm", "-af"})).run()
 | |
| 		Expect(err).ToNot(HaveOccurred())
 | |
| 		Expect(rmCon).To(Exit(0))
 | |
| 		testHTTPServer("62544", true, "")
 | |
| 
 | |
| 		stop := new(stopMachine)
 | |
| 		stopSession, err := mb.setCmd(stop).run()
 | |
| 		Expect(err).ToNot(HaveOccurred())
 | |
| 		Expect(stopSession).To(Exit(0))
 | |
| 
 | |
| 		// gxproxy should exit after machine is stopped
 | |
| 		out, _ = pgrep("gvproxy")
 | |
| 		Expect(out).ToNot(ContainSubstring("gvproxy"))
 | |
| 	})
 | |
| 
 | |
| 	It("podman volume on non-standard path", func() {
 | |
| 		skipIfWSL("Requires standard volume handling")
 | |
| 		dir, err := os.MkdirTemp("", "machine-volume")
 | |
| 		Expect(err).ToNot(HaveOccurred())
 | |
| 		defer os.RemoveAll(dir)
 | |
| 
 | |
| 		testString := "abcdefg1234567"
 | |
| 		testFile := "testfile"
 | |
| 		err = os.WriteFile(filepath.Join(dir, testFile), []byte(testString), 0644)
 | |
| 		Expect(err).ToNot(HaveOccurred())
 | |
| 
 | |
| 		name := randomString()
 | |
| 		machinePath := "/does/not/exist"
 | |
| 		init := new(initMachine).withVolume(fmt.Sprintf("%s:%s", dir, machinePath)).withImagePath(mb.imagePath).withNow()
 | |
| 		session, err := mb.setName(name).setCmd(init).run()
 | |
| 		Expect(err).ToNot(HaveOccurred())
 | |
| 		Expect(session).To(Exit(0))
 | |
| 
 | |
| 		// Must use path.Join to ensure forward slashes are used, even on Windows.
 | |
| 		ssh := new(sshMachine).withSSHCommand([]string{"cat", path.Join(machinePath, testFile)})
 | |
| 		ls, err := mb.setName(name).setCmd(ssh).run()
 | |
| 		Expect(err).ToNot(HaveOccurred())
 | |
| 		Expect(ls).To(Exit(0))
 | |
| 		Expect(ls.outputToString()).To(ContainSubstring(testString))
 | |
| 	})
 | |
| })
 | |
| 
 | |
| func testHTTPServer(port string, shouldErr bool, expectedResponse string) {
 | |
| 	address := url.URL{
 | |
| 		Scheme: "http",
 | |
| 		Host:   net.JoinHostPort("localhost", port),
 | |
| 	}
 | |
| 
 | |
| 	interval := 250 * time.Millisecond
 | |
| 	var err error
 | |
| 	var resp *http.Response
 | |
| 	for i := 0; i < 6; i++ {
 | |
| 		resp, err = http.Get(address.String())
 | |
| 		if err != nil && shouldErr {
 | |
| 			Expect(err.Error()).To(ContainSubstring(expectedResponse))
 | |
| 			return
 | |
| 		}
 | |
| 		if err == nil {
 | |
| 			defer resp.Body.Close()
 | |
| 			break
 | |
| 		}
 | |
| 		time.Sleep(interval)
 | |
| 		interval *= 2
 | |
| 	}
 | |
| 	Expect(err).ToNot(HaveOccurred())
 | |
| 
 | |
| 	body, err := io.ReadAll(resp.Body)
 | |
| 	Expect(err).ToNot(HaveOccurred())
 | |
| 	Expect(string(body)).Should(Equal(expectedResponse))
 | |
| }
 |