mirror of
				https://github.com/containers/podman.git
				synced 2025-10-25 02:04:43 +08:00 
			
		
		
		
	 74fcd9fef3
			
		
	
	74fcd9fef3
	
	
	
		
			
			The podman events aren't read until the given timestamp if the timestamp is in the future. It just reads all events until now and exits afterwards. This does not make sense and does not match docker. The correct behavior is to read all events until the given time is reached. This fixes a bug where the wrong event log file path was used when running first time with a new storage location. Fixes #8694 This also fixes the events api endpoint which only exited when an error occurred. Otherwise it just hung after reading all events. Signed-off-by: Paul Holzinger <paul.holzinger@web.de>
		
			
				
	
	
		
			193 lines
		
	
	
		
			6.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			193 lines
		
	
	
		
			6.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package integration
 | |
| 
 | |
| import (
 | |
| 	"encoding/json"
 | |
| 	"fmt"
 | |
| 	"os"
 | |
| 	"strings"
 | |
| 	"sync"
 | |
| 	"time"
 | |
| 
 | |
| 	. "github.com/containers/podman/v2/test/utils"
 | |
| 	"github.com/containers/storage/pkg/stringid"
 | |
| 	. "github.com/onsi/ginkgo"
 | |
| 	. "github.com/onsi/gomega"
 | |
| 	. "github.com/onsi/gomega/gexec"
 | |
| )
 | |
| 
 | |
| var _ = Describe("Podman events", func() {
 | |
| 	var (
 | |
| 		tempdir    string
 | |
| 		podmanTest *PodmanTestIntegration
 | |
| 	)
 | |
| 
 | |
| 	BeforeEach(func() {
 | |
| 		var err error
 | |
| 		tempdir, err = CreateTempDirInTempDir()
 | |
| 		if err != nil {
 | |
| 			os.Exit(1)
 | |
| 		}
 | |
| 		podmanTest = PodmanTestCreate(tempdir)
 | |
| 		podmanTest.Setup()
 | |
| 		podmanTest.SeedImages()
 | |
| 	})
 | |
| 
 | |
| 	AfterEach(func() {
 | |
| 		podmanTest.Cleanup()
 | |
| 		f := CurrentGinkgoTestDescription()
 | |
| 		processTestResult(f)
 | |
| 	})
 | |
| 
 | |
| 	// For most, all, of these tests we do not "live" test following a log because it may make a fragile test
 | |
| 	// system more complex.  Instead we run the "events" and then verify that the events are processed correctly.
 | |
| 	// Perhaps a future version of this test would put events in a go func and send output back over a channel
 | |
| 	// while events occur.
 | |
| 
 | |
| 	// These tests are only known to work on Fedora ATM.  Other distributions
 | |
| 	// will be skipped.
 | |
| 	It("podman events", func() {
 | |
| 		SkipIfNotFedora()
 | |
| 		_, ec, _ := podmanTest.RunLsContainer("")
 | |
| 		Expect(ec).To(Equal(0))
 | |
| 		result := podmanTest.Podman([]string{"events", "--stream=false"})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 		Expect(result.ExitCode()).To(BeZero())
 | |
| 	})
 | |
| 
 | |
| 	It("podman events with an event filter", func() {
 | |
| 		SkipIfNotFedora()
 | |
| 		_, ec, _ := podmanTest.RunLsContainer("")
 | |
| 		Expect(ec).To(Equal(0))
 | |
| 		result := podmanTest.Podman([]string{"events", "--stream=false", "--filter", "event=start"})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 		Expect(result.ExitCode()).To(Equal(0))
 | |
| 		Expect(len(result.OutputToStringArray()) >= 1)
 | |
| 	})
 | |
| 
 | |
| 	It("podman events with an event filter and container=cid", func() {
 | |
| 		Skip("Does not work on v2")
 | |
| 		SkipIfNotFedora()
 | |
| 		_, ec, cid := podmanTest.RunLsContainer("")
 | |
| 		Expect(ec).To(Equal(0))
 | |
| 		_, ec2, cid2 := podmanTest.RunLsContainer("")
 | |
| 		Expect(ec2).To(Equal(0))
 | |
| 		time.Sleep(5 * time.Second)
 | |
| 		result := podmanTest.Podman([]string{"events", "--stream=false", "--filter", "event=start", "--filter", fmt.Sprintf("container=%s", cid)})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 		Expect(result.ExitCode()).To(Equal(0))
 | |
| 		Expect(len(result.OutputToStringArray())).To(Equal(1))
 | |
| 		Expect(!strings.Contains(result.OutputToString(), cid2))
 | |
| 	})
 | |
| 
 | |
| 	It("podman events with a type and filter container=id", func() {
 | |
| 		SkipIfNotFedora()
 | |
| 		_, ec, cid := podmanTest.RunLsContainer("")
 | |
| 		Expect(ec).To(Equal(0))
 | |
| 		result := podmanTest.Podman([]string{"events", "--stream=false", "--filter", "type=pod", "--filter", fmt.Sprintf("container=%s", cid)})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 		Expect(result.ExitCode()).To(Equal(0))
 | |
| 		Expect(len(result.OutputToStringArray())).To(Equal(0))
 | |
| 	})
 | |
| 
 | |
| 	It("podman events with a type", func() {
 | |
| 		SkipIfNotFedora()
 | |
| 		setup := podmanTest.Podman([]string{"run", "-dt", "--pod", "new:foobarpod", ALPINE, "top"})
 | |
| 		setup.WaitWithDefaultTimeout()
 | |
| 		stop := podmanTest.Podman([]string{"pod", "stop", "foobarpod"})
 | |
| 		stop.WaitWithDefaultTimeout()
 | |
| 		Expect(stop.ExitCode()).To(Equal(0))
 | |
| 		Expect(setup.ExitCode()).To(Equal(0))
 | |
| 		result := podmanTest.Podman([]string{"events", "--stream=false", "--filter", "type=pod", "--filter", "pod=foobarpod"})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 		Expect(result.ExitCode()).To(Equal(0))
 | |
| 		fmt.Println(result.OutputToStringArray())
 | |
| 		Expect(len(result.OutputToStringArray()) >= 2)
 | |
| 	})
 | |
| 
 | |
| 	It("podman events --since", func() {
 | |
| 		SkipIfNotFedora()
 | |
| 		_, ec, _ := podmanTest.RunLsContainer("")
 | |
| 		Expect(ec).To(Equal(0))
 | |
| 		result := podmanTest.Podman([]string{"events", "--stream=false", "--since", "1m"})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 		Expect(result.ExitCode()).To(BeZero())
 | |
| 	})
 | |
| 
 | |
| 	It("podman events --until", func() {
 | |
| 		SkipIfNotFedora()
 | |
| 		_, ec, _ := podmanTest.RunLsContainer("")
 | |
| 		Expect(ec).To(Equal(0))
 | |
| 		result := podmanTest.Podman([]string{"events", "--stream=false", "--until", "1h"})
 | |
| 		result.WaitWithDefaultTimeout()
 | |
| 		Expect(result.ExitCode()).To(BeZero())
 | |
| 	})
 | |
| 
 | |
| 	It("podman events format", func() {
 | |
| 		SkipIfNotFedora()
 | |
| 		_, ec, _ := podmanTest.RunLsContainer("")
 | |
| 		Expect(ec).To(Equal(0))
 | |
| 
 | |
| 		test := podmanTest.Podman([]string{"events", "--stream=false", "--format", "json"})
 | |
| 		test.WaitWithDefaultTimeout()
 | |
| 		Expect(test).To(Exit(0))
 | |
| 
 | |
| 		jsonArr := test.OutputToStringArray()
 | |
| 		Expect(test.OutputToStringArray()).ShouldNot(BeEmpty())
 | |
| 
 | |
| 		eventsMap := make(map[string]string)
 | |
| 		err := json.Unmarshal([]byte(jsonArr[0]), &eventsMap)
 | |
| 		Expect(err).ToNot(HaveOccurred())
 | |
| 
 | |
| 		Expect(eventsMap).To(HaveKey("Status"))
 | |
| 
 | |
| 		test = podmanTest.Podman([]string{"events", "--stream=false", "--format", "{{json.}}"})
 | |
| 		test.WaitWithDefaultTimeout()
 | |
| 		Expect(test).To(Exit(0))
 | |
| 
 | |
| 		jsonArr = test.OutputToStringArray()
 | |
| 		Expect(test.OutputToStringArray()).ShouldNot(BeEmpty())
 | |
| 
 | |
| 		eventsMap = make(map[string]string)
 | |
| 		err = json.Unmarshal([]byte(jsonArr[0]), &eventsMap)
 | |
| 		Expect(err).ToNot(HaveOccurred())
 | |
| 
 | |
| 		Expect(eventsMap).To(HaveKey("Status"))
 | |
| 	})
 | |
| 
 | |
| 	It("podman events --until future", func() {
 | |
| 		name1 := stringid.GenerateNonCryptoID()
 | |
| 		name2 := stringid.GenerateNonCryptoID()
 | |
| 		name3 := stringid.GenerateNonCryptoID()
 | |
| 		session := podmanTest.Podman([]string{"create", "--name", name1, ALPINE})
 | |
| 		session.WaitWithDefaultTimeout()
 | |
| 		Expect(session.ExitCode()).To(Equal(0))
 | |
| 
 | |
| 		var wg sync.WaitGroup
 | |
| 		wg.Add(1)
 | |
| 		go func() {
 | |
| 			defer GinkgoRecover()
 | |
| 			defer wg.Done()
 | |
| 
 | |
| 			// wait 2 seconds to be sure events is running
 | |
| 			time.Sleep(time.Second * 2)
 | |
| 			session = podmanTest.Podman([]string{"create", "--name", name2, ALPINE})
 | |
| 			session.WaitWithDefaultTimeout()
 | |
| 			Expect(session.ExitCode()).To(Equal(0))
 | |
| 			session = podmanTest.Podman([]string{"create", "--name", name3, ALPINE})
 | |
| 			session.WaitWithDefaultTimeout()
 | |
| 			Expect(session.ExitCode()).To(Equal(0))
 | |
| 		}()
 | |
| 
 | |
| 		// unix timestamp in 10 seconds
 | |
| 		until := time.Now().Add(time.Second * 10).Unix()
 | |
| 		result := podmanTest.Podman([]string{"events", "--since", "30s", "--until", fmt.Sprint(until)})
 | |
| 		result.Wait(11)
 | |
| 		Expect(result.ExitCode()).To(BeZero())
 | |
| 		Expect(result.OutputToString()).To(ContainSubstring(name1))
 | |
| 		Expect(result.OutputToString()).To(ContainSubstring(name2))
 | |
| 		Expect(result.OutputToString()).To(ContainSubstring(name3))
 | |
| 
 | |
| 		wg.Wait()
 | |
| 	})
 | |
| })
 |