Merge pull request #9601 from jwhonce/issues/9207
Use version package to track all versions
This commit is contained in:
		
						commit
						87a78c059d
					
				| 
						 | 
				
			
			@ -5,7 +5,7 @@ import (
 | 
			
		|||
	"strconv"
 | 
			
		||||
	"time"
 | 
			
		||||
 | 
			
		||||
	podmanVersion "github.com/containers/podman/v3/version"
 | 
			
		||||
	"github.com/containers/podman/v3/version"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
// Overwritten at build time
 | 
			
		||||
| 
						 | 
				
			
			@ -42,8 +42,8 @@ func GetVersion() (Version, error) {
 | 
			
		|||
		}
 | 
			
		||||
	}
 | 
			
		||||
	return Version{
 | 
			
		||||
		APIVersion: podmanVersion.APIVersion.String(),
 | 
			
		||||
		Version:    podmanVersion.Version.String(),
 | 
			
		||||
		APIVersion: version.APIVersion[version.Libpod][version.CurrentAPI].String(),
 | 
			
		||||
		Version:    version.Version.String(),
 | 
			
		||||
		GoVersion:  runtime.Version(),
 | 
			
		||||
		GitCommit:  gitCommit,
 | 
			
		||||
		BuiltTime:  time.Unix(buildTime, 0).Format(time.ANSIC),
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -10,6 +10,7 @@ import (
 | 
			
		|||
	"github.com/containers/podman/v3/libpod/define"
 | 
			
		||||
	"github.com/containers/podman/v3/pkg/api/handlers/utils"
 | 
			
		||||
	"github.com/containers/podman/v3/pkg/domain/entities"
 | 
			
		||||
	"github.com/containers/podman/v3/version"
 | 
			
		||||
	docker "github.com/docker/docker/api/types"
 | 
			
		||||
	"github.com/pkg/errors"
 | 
			
		||||
)
 | 
			
		||||
| 
						 | 
				
			
			@ -35,20 +36,20 @@ func VersionHandler(w http.ResponseWriter, r *http.Request) {
 | 
			
		|||
		Name:    "Podman Engine",
 | 
			
		||||
		Version: versionInfo.Version,
 | 
			
		||||
		Details: map[string]string{
 | 
			
		||||
			"APIVersion":    utils.APIVersion[utils.LibpodTree][utils.CurrentAPIVersion].String(),
 | 
			
		||||
			"APIVersion":    version.APIVersion[version.Libpod][version.CurrentAPI].String(),
 | 
			
		||||
			"Arch":          goRuntime.GOARCH,
 | 
			
		||||
			"BuildTime":     time.Unix(versionInfo.Built, 0).Format(time.RFC3339),
 | 
			
		||||
			"Experimental":  "true",
 | 
			
		||||
			"GitCommit":     versionInfo.GitCommit,
 | 
			
		||||
			"GoVersion":     versionInfo.GoVersion,
 | 
			
		||||
			"KernelVersion": infoData.Host.Kernel,
 | 
			
		||||
			"MinAPIVersion": utils.APIVersion[utils.LibpodTree][utils.MinimalAPIVersion].String(),
 | 
			
		||||
			"MinAPIVersion": version.APIVersion[version.Libpod][version.MinimalAPI].String(),
 | 
			
		||||
			"Os":            goRuntime.GOOS,
 | 
			
		||||
		},
 | 
			
		||||
	}}
 | 
			
		||||
 | 
			
		||||
	apiVersion := utils.APIVersion[utils.CompatTree][utils.CurrentAPIVersion]
 | 
			
		||||
	minVersion := utils.APIVersion[utils.CompatTree][utils.MinimalAPIVersion]
 | 
			
		||||
	apiVersion := version.APIVersion[version.Compat][version.CurrentAPI]
 | 
			
		||||
	minVersion := version.APIVersion[version.Compat][version.MinimalAPI]
 | 
			
		||||
 | 
			
		||||
	utils.WriteResponse(w, http.StatusOK, entities.ComponentVersion{
 | 
			
		||||
		Version: docker.Version{
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -10,49 +10,14 @@ import (
 | 
			
		|||
	"unsafe"
 | 
			
		||||
 | 
			
		||||
	"github.com/blang/semver"
 | 
			
		||||
	"github.com/containers/podman/v3/version"
 | 
			
		||||
	"github.com/gorilla/mux"
 | 
			
		||||
	jsoniter "github.com/json-iterator/go"
 | 
			
		||||
	"github.com/pkg/errors"
 | 
			
		||||
	"github.com/sirupsen/logrus"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
type (
 | 
			
		||||
	// VersionTree determines which API endpoint tree for version
 | 
			
		||||
	VersionTree int
 | 
			
		||||
	// VersionLevel determines which API level, current or something from the past
 | 
			
		||||
	VersionLevel int
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
const (
 | 
			
		||||
	// LibpodTree supports Libpod endpoints
 | 
			
		||||
	LibpodTree = VersionTree(iota)
 | 
			
		||||
	// CompatTree supports Libpod endpoints
 | 
			
		||||
	CompatTree
 | 
			
		||||
 | 
			
		||||
	// CurrentAPIVersion announces what is the current API level
 | 
			
		||||
	CurrentAPIVersion = VersionLevel(iota)
 | 
			
		||||
	// MinimalAPIVersion announces what is the oldest API level supported
 | 
			
		||||
	MinimalAPIVersion
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
var (
 | 
			
		||||
	// See https://docs.docker.com/engine/api/v1.40/
 | 
			
		||||
	// libpod compat handlers are expected to honor docker API versions
 | 
			
		||||
 | 
			
		||||
	// APIVersion provides the current and minimal API versions for compat and libpod endpoint trees
 | 
			
		||||
	// Note: GET|HEAD /_ping is never versioned and provides the API-Version and Libpod-API-Version headers to allow
 | 
			
		||||
	//       clients to shop for the Version they wish to support
 | 
			
		||||
	APIVersion = map[VersionTree]map[VersionLevel]semver.Version{
 | 
			
		||||
		LibpodTree: {
 | 
			
		||||
			CurrentAPIVersion: semver.MustParse("3.0.0"),
 | 
			
		||||
			MinimalAPIVersion: semver.MustParse("3.0.0"),
 | 
			
		||||
		},
 | 
			
		||||
		CompatTree: {
 | 
			
		||||
			CurrentAPIVersion: semver.MustParse("1.40.0"),
 | 
			
		||||
			MinimalAPIVersion: semver.MustParse("1.24.0"),
 | 
			
		||||
		},
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// ErrVersionNotGiven returned when version not given by client
 | 
			
		||||
	ErrVersionNotGiven = errors.New("version not given in URL path")
 | 
			
		||||
	// ErrVersionNotSupported returned when given version is too old
 | 
			
		||||
| 
						 | 
				
			
			@ -98,14 +63,14 @@ func SupportedVersion(r *http.Request, condition string) (semver.Version, error)
 | 
			
		|||
// SupportedVersionWithDefaults validates that the version provided by client valid is supported by server
 | 
			
		||||
// minimal API version <= client path version <= maximum API version focused on the endpoint tree from URL
 | 
			
		||||
func SupportedVersionWithDefaults(r *http.Request) (semver.Version, error) {
 | 
			
		||||
	tree := CompatTree
 | 
			
		||||
	tree := version.Compat
 | 
			
		||||
	if IsLibpodRequest(r) {
 | 
			
		||||
		tree = LibpodTree
 | 
			
		||||
		tree = version.Libpod
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return SupportedVersion(r,
 | 
			
		||||
		fmt.Sprintf(">=%s <=%s", APIVersion[tree][MinimalAPIVersion].String(),
 | 
			
		||||
			APIVersion[tree][CurrentAPIVersion].String()))
 | 
			
		||||
		fmt.Sprintf(">=%s <=%s", version.APIVersion[tree][version.MinimalAPI].String(),
 | 
			
		||||
			version.APIVersion[tree][version.CurrentAPI].String()))
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// WriteResponse encodes the given value as JSON or string and renders it for http client
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -7,17 +7,18 @@ import (
 | 
			
		|||
	"net/http/httptest"
 | 
			
		||||
	"testing"
 | 
			
		||||
 | 
			
		||||
	"github.com/containers/podman/v3/version"
 | 
			
		||||
	"github.com/gorilla/mux"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func TestSupportedVersion(t *testing.T) {
 | 
			
		||||
	req, err := http.NewRequest("GET",
 | 
			
		||||
		fmt.Sprintf("/v%s/libpod/testing/versions", APIVersion[LibpodTree][CurrentAPIVersion]),
 | 
			
		||||
		fmt.Sprintf("/v%s/libpod/testing/versions", version.APIVersion[version.Libpod][version.CurrentAPI]),
 | 
			
		||||
		nil)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		t.Fatal(err)
 | 
			
		||||
	}
 | 
			
		||||
	req = mux.SetURLVars(req, map[string]string{"version": APIVersion[LibpodTree][CurrentAPIVersion].String()})
 | 
			
		||||
	req = mux.SetURLVars(req, map[string]string{"version": version.APIVersion[version.Libpod][version.CurrentAPI].String()})
 | 
			
		||||
 | 
			
		||||
	rr := httptest.NewRecorder()
 | 
			
		||||
	handler := http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -8,6 +8,7 @@ import (
 | 
			
		|||
 | 
			
		||||
	"github.com/containers/podman/v3/pkg/api/handlers/utils"
 | 
			
		||||
	"github.com/containers/podman/v3/pkg/auth"
 | 
			
		||||
	"github.com/containers/podman/v3/version"
 | 
			
		||||
	"github.com/google/uuid"
 | 
			
		||||
	"github.com/sirupsen/logrus"
 | 
			
		||||
)
 | 
			
		||||
| 
						 | 
				
			
			@ -55,10 +56,10 @@ func (s *APIServer) APIHandler(h http.HandlerFunc) http.HandlerFunc {
 | 
			
		|||
			c = context.WithValue(c, "idletracker", s.idleTracker)    // nolint
 | 
			
		||||
			r = r.WithContext(c)
 | 
			
		||||
 | 
			
		||||
			cv := utils.APIVersion[utils.CompatTree][utils.CurrentAPIVersion]
 | 
			
		||||
			cv := version.APIVersion[version.Compat][version.CurrentAPI]
 | 
			
		||||
			w.Header().Set("API-Version", fmt.Sprintf("%d.%d", cv.Major, cv.Minor))
 | 
			
		||||
 | 
			
		||||
			lv := utils.APIVersion[utils.LibpodTree][utils.CurrentAPIVersion].String()
 | 
			
		||||
			lv := version.APIVersion[version.Libpod][version.CurrentAPI].String()
 | 
			
		||||
			w.Header().Set("Libpod-API-Version", lv)
 | 
			
		||||
			w.Header().Set("Server", "Libpod/"+lv+" ("+runtime.GOOS+")")
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -72,5 +73,5 @@ func (s *APIServer) APIHandler(h http.HandlerFunc) http.HandlerFunc {
 | 
			
		|||
// VersionedPath prepends the version parsing code
 | 
			
		||||
// any handler may override this default when registering URL(s)
 | 
			
		||||
func VersionedPath(p string) string {
 | 
			
		||||
	return "/v{version:[0-9][0-9.]*}" + p
 | 
			
		||||
	return "/v{version:[0-9][0-9A-Za-z.-]*}" + p
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,26 +0,0 @@
 | 
			
		|||
// Package bindings provides golang-based access
 | 
			
		||||
// to the Podman REST API.  Users can then interact with API endpoints
 | 
			
		||||
// to manage containers, images, pods, etc.
 | 
			
		||||
//
 | 
			
		||||
// This package exposes a series of methods that allow users to firstly
 | 
			
		||||
// create their connection with the API endpoints.  Once the connection
 | 
			
		||||
// is established, users can then manage the Podman container runtime.
 | 
			
		||||
package bindings
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"github.com/blang/semver"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
var (
 | 
			
		||||
	// PTrue is a convenience variable that can be used in bindings where
 | 
			
		||||
	// a pointer to a bool (optional parameter) is required.
 | 
			
		||||
	pTrue = true
 | 
			
		||||
	PTrue = &pTrue
 | 
			
		||||
	// PFalse is a convenience variable that can be used in bindings where
 | 
			
		||||
	// a pointer to a bool (optional parameter) is required.
 | 
			
		||||
	pFalse = false
 | 
			
		||||
	PFalse = &pFalse
 | 
			
		||||
 | 
			
		||||
	// APIVersion - podman will fail to run if this value is wrong
 | 
			
		||||
	APIVersion = semver.MustParse("2.0.0")
 | 
			
		||||
)
 | 
			
		||||
| 
						 | 
				
			
			@ -14,6 +14,7 @@ import (
 | 
			
		|||
 | 
			
		||||
	"github.com/blang/semver"
 | 
			
		||||
	"github.com/containers/podman/v3/pkg/terminal"
 | 
			
		||||
	"github.com/containers/podman/v3/version"
 | 
			
		||||
	jsoniter "github.com/json-iterator/go"
 | 
			
		||||
	"github.com/pkg/errors"
 | 
			
		||||
	"github.com/sirupsen/logrus"
 | 
			
		||||
| 
						 | 
				
			
			@ -25,7 +26,7 @@ var (
 | 
			
		|||
	BasePath = &url.URL{
 | 
			
		||||
		Scheme: "http",
 | 
			
		||||
		Host:   "d",
 | 
			
		||||
		Path:   "/v" + APIVersion.String() + "/libpod",
 | 
			
		||||
		Path:   "/v" + version.APIVersion[version.Libpod][version.CurrentAPI].String() + "/libpod",
 | 
			
		||||
	}
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -168,15 +169,16 @@ func pingNewConnection(ctx context.Context) error {
 | 
			
		|||
			return err
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		switch APIVersion.Compare(versionSrv) {
 | 
			
		||||
		switch version.APIVersion[version.Libpod][version.MinimalAPI].Compare(versionSrv) {
 | 
			
		||||
		case -1, 0:
 | 
			
		||||
			// Server's job when Client version is equal or older
 | 
			
		||||
			return nil
 | 
			
		||||
		case 1:
 | 
			
		||||
			return errors.Errorf("server API version is too old. Client %q server %q", APIVersion.String(), versionSrv.String())
 | 
			
		||||
			return errors.Errorf("server API version is too old. Client %q server %q",
 | 
			
		||||
				version.APIVersion[version.Libpod][version.MinimalAPI].String(), versionSrv.String())
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
	return errors.Errorf("ping response was %q", response.StatusCode)
 | 
			
		||||
	return errors.Errorf("ping response was %d", response.StatusCode)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func sshClient(_url *url.URL, secure bool, passPhrase string, identity string) (Connection, error) {
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -35,7 +35,7 @@ var _ = Describe("Podman containers attach", func() {
 | 
			
		|||
 | 
			
		||||
	It("can run top in container", func() {
 | 
			
		||||
		name := "TopAttachTest"
 | 
			
		||||
		id, err := bt.RunTopContainer(&name, nil, nil)
 | 
			
		||||
		id, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).ShouldNot(HaveOccurred())
 | 
			
		||||
 | 
			
		||||
		tickTock := time.NewTimer(2 * time.Second)
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -188,14 +188,14 @@ func (b *bindingTest) restoreImageFromCache(i testImage) {
 | 
			
		|||
 | 
			
		||||
// Run a container within or without a pod
 | 
			
		||||
// and add or append the alpine image to it
 | 
			
		||||
func (b *bindingTest) RunTopContainer(containerName *string, insidePod *bool, podName *string) (string, error) {
 | 
			
		||||
func (b *bindingTest) RunTopContainer(containerName *string, podName *string) (string, error) {
 | 
			
		||||
	s := specgen.NewSpecGenerator(alpine.name, false)
 | 
			
		||||
	s.Terminal = false
 | 
			
		||||
	s.Command = []string{"/usr/bin/top"}
 | 
			
		||||
	if containerName != nil {
 | 
			
		||||
		s.Name = *containerName
 | 
			
		||||
	}
 | 
			
		||||
	if insidePod != nil && podName != nil {
 | 
			
		||||
	if podName != nil {
 | 
			
		||||
		s.Pod = *podName
 | 
			
		||||
	}
 | 
			
		||||
	ctr, err := containers.CreateWithSpec(b.conn, s, nil)
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -55,7 +55,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
	It("podman pause a running container by name", func() {
 | 
			
		||||
		// Pausing by name should work
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Pause(bt.conn, name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -69,7 +69,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
	It("podman pause a running container by id", func() {
 | 
			
		||||
		// Pausing by id should work
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Pause(bt.conn, cid, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -83,7 +83,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
	It("podman unpause a running container by name", func() {
 | 
			
		||||
		// Unpausing by name should work
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Pause(bt.conn, name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -99,7 +99,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
	It("podman unpause a running container by ID", func() {
 | 
			
		||||
		// Unpausing by ID should work
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		// Pause by name
 | 
			
		||||
		err = containers.Pause(bt.conn, name, nil)
 | 
			
		||||
| 
						 | 
				
			
			@ -118,7 +118,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
	It("podman pause a paused container by name", func() {
 | 
			
		||||
		// Pausing a paused container by name should fail
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Pause(bt.conn, name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -131,7 +131,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
	It("podman pause a paused container by id", func() {
 | 
			
		||||
		// Pausing a paused container by id should fail
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Pause(bt.conn, cid, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -144,7 +144,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
	It("podman pause a stopped container by name", func() {
 | 
			
		||||
		// Pausing a stopped container by name should fail
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Stop(bt.conn, name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -157,7 +157,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
	It("podman pause a stopped container by id", func() {
 | 
			
		||||
		// Pausing a stopped container by id should fail
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Stop(bt.conn, cid, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -170,7 +170,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
	It("podman remove a paused container by id without force", func() {
 | 
			
		||||
		// Removing a paused container without force should fail
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Pause(bt.conn, cid, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -183,7 +183,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
	It("podman remove a paused container by id with force", func() {
 | 
			
		||||
		// Removing a paused container with force should work
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Pause(bt.conn, cid, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -194,7 +194,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
	It("podman stop a paused container by name", func() {
 | 
			
		||||
		// Stopping a paused container by name should fail
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Pause(bt.conn, name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -207,7 +207,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
	It("podman stop a paused container by id", func() {
 | 
			
		||||
		// Stopping a paused container by id should fail
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Pause(bt.conn, cid, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -220,7 +220,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
	It("podman stop a running container by name", func() {
 | 
			
		||||
		// Stopping a running container by name should work
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Stop(bt.conn, name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -234,7 +234,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
	It("podman stop a running container by ID", func() {
 | 
			
		||||
		// Stopping a running container by ID should work
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Stop(bt.conn, cid, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -256,7 +256,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
		Expect(code).To(BeNumerically("==", http.StatusNotFound))
 | 
			
		||||
 | 
			
		||||
		errChan := make(chan error)
 | 
			
		||||
		_, err = bt.RunTopContainer(&name, nil, nil)
 | 
			
		||||
		_, err = bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		go func() {
 | 
			
		||||
			exitCode, err = containers.Wait(bt.conn, name, nil)
 | 
			
		||||
| 
						 | 
				
			
			@ -278,7 +278,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
			running        = define.ContainerStateRunning
 | 
			
		||||
		)
 | 
			
		||||
		errChan := make(chan error)
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, nil, nil)
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		go func() {
 | 
			
		||||
			exitCode, err = containers.Wait(bt.conn, name, new(containers.WaitOptions).WithCondition([]define.ContainerStatus{pause}))
 | 
			
		||||
| 
						 | 
				
			
			@ -317,7 +317,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
 | 
			
		||||
		// a container that has no healthcheck should be a 409
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		bt.RunTopContainer(&name, nil)
 | 
			
		||||
		_, err = containers.RunHealthCheck(bt.conn, name, nil)
 | 
			
		||||
		Expect(err).ToNot(BeNil())
 | 
			
		||||
		code, _ = bindings.CheckResponseCode(err)
 | 
			
		||||
| 
						 | 
				
			
			@ -376,7 +376,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
 | 
			
		||||
	It("podman top", func() {
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
 | 
			
		||||
		// By name
 | 
			
		||||
| 
						 | 
				
			
			@ -414,7 +414,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
	It("podman container exists in local storage by name", func() {
 | 
			
		||||
		// Container existence check by name should work
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		containerExists, err := containers.Exists(bt.conn, name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -424,7 +424,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
	It("podman container exists in local storage by ID", func() {
 | 
			
		||||
		// Container existence check by ID should work
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		containerExists, err := containers.Exists(bt.conn, cid, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -434,7 +434,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
	It("podman container exists in local storage by short ID", func() {
 | 
			
		||||
		// Container existence check by short ID should work
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		containerExists, err := containers.Exists(bt.conn, cid[0:12], nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -452,7 +452,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
	It("podman kill a running container by name with SIGINT", func() {
 | 
			
		||||
		// Killing a running container should work
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Kill(bt.conn, name, new(containers.KillOptions).WithSignal("SIGINT"))
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -463,7 +463,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
	It("podman kill a running container by ID with SIGTERM", func() {
 | 
			
		||||
		// Killing a running container by ID should work
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Kill(bt.conn, cid, new(containers.KillOptions).WithSignal("SIGTERM"))
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -474,7 +474,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
	It("podman kill a running container by ID with SIGKILL", func() {
 | 
			
		||||
		// Killing a running container by ID with TERM should work
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Kill(bt.conn, cid, new(containers.KillOptions).WithSignal("SIGKILL"))
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -483,7 +483,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
	It("podman kill a running container by bogus signal", func() {
 | 
			
		||||
		//Killing a running container by bogus signal should fail
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Kill(bt.conn, cid, new(containers.KillOptions).WithSignal("foobar"))
 | 
			
		||||
		Expect(err).ToNot(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -495,9 +495,9 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
		// Killing latest container should work
 | 
			
		||||
		var name1 = "first"
 | 
			
		||||
		var name2 = "second"
 | 
			
		||||
		_, err := bt.RunTopContainer(&name1, bindings.PFalse, nil)
 | 
			
		||||
		_, err := bt.RunTopContainer(&name1, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		_, err = bt.RunTopContainer(&name2, bindings.PFalse, nil)
 | 
			
		||||
		_, err = bt.RunTopContainer(&name2, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		containerLatestList, err := containers.List(bt.conn, new(containers.ListOptions).WithLast(1))
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -526,7 +526,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
	It("podman prune stopped containers", func() {
 | 
			
		||||
		// Start and stop a container to enter in exited state.
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Stop(bt.conn, name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -541,7 +541,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
	It("podman prune stopped containers with filters", func() {
 | 
			
		||||
		// Start and stop a container to enter in exited state.
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Stop(bt.conn, name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -575,7 +575,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
	It("podman prune running containers", func() {
 | 
			
		||||
		// Start the container.
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
 | 
			
		||||
		// Check if the container is running.
 | 
			
		||||
| 
						 | 
				
			
			@ -598,7 +598,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
 | 
			
		||||
	It("podman inspect running container", func() {
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		// Inspecting running container should succeed
 | 
			
		||||
		_, err = containers.Inspect(bt.conn, name, nil)
 | 
			
		||||
| 
						 | 
				
			
			@ -607,7 +607,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
 | 
			
		||||
	It("podman inspect stopped container", func() {
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Stop(bt.conn, name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -618,7 +618,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
 | 
			
		||||
	It("podman inspect running container with size", func() {
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		_, err = containers.Inspect(bt.conn, name, new(containers.InspectOptions).WithSize(true))
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -626,7 +626,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
 | 
			
		||||
	It("podman inspect stopped container with size", func() {
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Stop(bt.conn, name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -643,7 +643,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
 | 
			
		||||
	It("podman remove running container by name", func() {
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		// Removing running container should fail
 | 
			
		||||
		err = containers.Remove(bt.conn, name, nil)
 | 
			
		||||
| 
						 | 
				
			
			@ -654,7 +654,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
 | 
			
		||||
	It("podman remove running container by ID", func() {
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		// Removing running container should fail
 | 
			
		||||
		err = containers.Remove(bt.conn, cid, nil)
 | 
			
		||||
| 
						 | 
				
			
			@ -665,7 +665,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
 | 
			
		||||
	It("podman forcibly remove running container by name", func() {
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		// Removing running container should fail
 | 
			
		||||
		err = containers.Remove(bt.conn, name, new(containers.RemoveOptions).WithForce(true))
 | 
			
		||||
| 
						 | 
				
			
			@ -676,7 +676,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
 | 
			
		||||
	It("podman forcibly remove running container by ID", func() {
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		// Removing running container should fail
 | 
			
		||||
		err = containers.Remove(bt.conn, cid, new(containers.RemoveOptions).WithForce(true))
 | 
			
		||||
| 
						 | 
				
			
			@ -687,7 +687,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
 | 
			
		||||
	It("podman remove running container and volume by name", func() {
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		// Removing running container should fail
 | 
			
		||||
		err = containers.Remove(bt.conn, name, new(containers.RemoveOptions).WithVolumes(true))
 | 
			
		||||
| 
						 | 
				
			
			@ -698,7 +698,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
 | 
			
		||||
	It("podman remove running container and volume by ID", func() {
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		// Removing running container should fail
 | 
			
		||||
		err = containers.Remove(bt.conn, cid, new(containers.RemoveOptions).WithVolumes(true))
 | 
			
		||||
| 
						 | 
				
			
			@ -709,7 +709,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
 | 
			
		||||
	It("podman forcibly remove running container and volume by name", func() {
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		// Removing running container should fail
 | 
			
		||||
		err = containers.Remove(bt.conn, name, new(containers.RemoveOptions).WithVolumes(true).WithForce(true))
 | 
			
		||||
| 
						 | 
				
			
			@ -720,7 +720,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
 | 
			
		||||
	It("podman forcibly remove running container and volume by ID", func() {
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		// Removing running container should fail
 | 
			
		||||
		err = containers.Remove(bt.conn, cid, new(containers.RemoveOptions).WithForce(true).WithVolumes(true))
 | 
			
		||||
| 
						 | 
				
			
			@ -732,9 +732,9 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
	It("List containers with filters", func() {
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		var name2 = "top2"
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		_, err = bt.RunTopContainer(&name2, bindings.PFalse, nil)
 | 
			
		||||
		_, err = bt.RunTopContainer(&name2, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		s := specgen.NewSpecGenerator(alpine.name, false)
 | 
			
		||||
		s.Terminal = true
 | 
			
		||||
| 
						 | 
				
			
			@ -753,7 +753,7 @@ var _ = Describe("Podman containers ", func() {
 | 
			
		|||
		podName := "testpod"
 | 
			
		||||
		ctrName := "testctr"
 | 
			
		||||
		bt.Podcreate(&podName)
 | 
			
		||||
		_, err := bt.RunTopContainer(&ctrName, bindings.PTrue, &podName)
 | 
			
		||||
		_, err := bt.RunTopContainer(&ctrName, &podName)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
 | 
			
		||||
		lastNum := 1
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -4,7 +4,6 @@ import (
 | 
			
		|||
	"time"
 | 
			
		||||
 | 
			
		||||
	"github.com/containers/podman/v3/pkg/api/handlers"
 | 
			
		||||
	"github.com/containers/podman/v3/pkg/bindings"
 | 
			
		||||
	"github.com/containers/podman/v3/pkg/bindings/containers"
 | 
			
		||||
	. "github.com/onsi/ginkgo"
 | 
			
		||||
	. "github.com/onsi/gomega"
 | 
			
		||||
| 
						 | 
				
			
			@ -33,7 +32,7 @@ var _ = Describe("Podman containers exec", func() {
 | 
			
		|||
 | 
			
		||||
	It("Podman exec create makes an exec session", func() {
 | 
			
		||||
		name := "testCtr"
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		cid, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
 | 
			
		||||
		execConfig := new(handlers.ExecCreateConfig)
 | 
			
		||||
| 
						 | 
				
			
			@ -53,7 +52,7 @@ var _ = Describe("Podman containers exec", func() {
 | 
			
		|||
 | 
			
		||||
	It("Podman exec create with bad command fails", func() {
 | 
			
		||||
		name := "testCtr"
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
 | 
			
		||||
		execConfig := new(handlers.ExecCreateConfig)
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -101,7 +101,7 @@ var _ = Describe("Podman images", func() {
 | 
			
		|||
 | 
			
		||||
		// Start a container with alpine image
 | 
			
		||||
		var top string = "top"
 | 
			
		||||
		_, err = bt.RunTopContainer(&top, bindings.PFalse, nil)
 | 
			
		||||
		_, err = bt.RunTopContainer(&top, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		// we should now have a container called "top" running
 | 
			
		||||
		containerResponse, err := containers.Inspect(bt.conn, "top", nil)
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -49,17 +49,17 @@ var _ = Describe("Podman info", func() {
 | 
			
		|||
		_, err := containers.CreateWithSpec(bt.conn, s, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
 | 
			
		||||
		idPause, err := bt.RunTopContainer(nil, nil, nil)
 | 
			
		||||
		idPause, err := bt.RunTopContainer(nil, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Pause(bt.conn, idPause, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
 | 
			
		||||
		idStop, err := bt.RunTopContainer(nil, nil, nil)
 | 
			
		||||
		idStop, err := bt.RunTopContainer(nil, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Stop(bt.conn, idStop, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
 | 
			
		||||
		_, err = bt.RunTopContainer(nil, nil, nil)
 | 
			
		||||
		_, err = bt.RunTopContainer(nil, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
 | 
			
		||||
		info, err := system.Info(bt.conn, nil)
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -63,7 +63,7 @@ var _ = Describe("Podman pods", func() {
 | 
			
		|||
		Expect(err).To(BeNil())
 | 
			
		||||
 | 
			
		||||
		// Adding an alpine container to the existing pod
 | 
			
		||||
		_, err = bt.RunTopContainer(nil, bindings.PTrue, &newpod)
 | 
			
		||||
		_, err = bt.RunTopContainer(nil, &newpod)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		podSummary, err = pods.List(bt.conn, nil)
 | 
			
		||||
		// Verify no errors.
 | 
			
		||||
| 
						 | 
				
			
			@ -93,7 +93,7 @@ var _ = Describe("Podman pods", func() {
 | 
			
		|||
		_, err = pods.Start(bt.conn, newpod, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
 | 
			
		||||
		_, err = bt.RunTopContainer(nil, bindings.PTrue, &newpod)
 | 
			
		||||
		_, err = bt.RunTopContainer(nil, &newpod)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
 | 
			
		||||
		// Expected err with invalid filter params
 | 
			
		||||
| 
						 | 
				
			
			@ -179,7 +179,7 @@ var _ = Describe("Podman pods", func() {
 | 
			
		|||
		Expect(code).To(BeNumerically("==", http.StatusNotFound))
 | 
			
		||||
 | 
			
		||||
		// Adding an alpine container to the existing pod
 | 
			
		||||
		_, err = bt.RunTopContainer(nil, bindings.PTrue, &newpod)
 | 
			
		||||
		_, err = bt.RunTopContainer(nil, &newpod)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
 | 
			
		||||
		// Binding needs to be modified to inspect the pod state.
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -4,7 +4,6 @@ import (
 | 
			
		|||
	"sync"
 | 
			
		||||
	"time"
 | 
			
		||||
 | 
			
		||||
	"github.com/containers/podman/v3/pkg/bindings"
 | 
			
		||||
	"github.com/containers/podman/v3/pkg/bindings/containers"
 | 
			
		||||
	"github.com/containers/podman/v3/pkg/bindings/pods"
 | 
			
		||||
	"github.com/containers/podman/v3/pkg/bindings/system"
 | 
			
		||||
| 
						 | 
				
			
			@ -41,7 +40,7 @@ var _ = Describe("Podman system", func() {
 | 
			
		|||
 | 
			
		||||
	It("podman events", func() {
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		_, err := bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
 | 
			
		||||
		filters := make(map[string][]string)
 | 
			
		||||
| 
						 | 
				
			
			@ -72,7 +71,7 @@ var _ = Describe("Podman system", func() {
 | 
			
		|||
		Expect(err).To(BeNil())
 | 
			
		||||
		// Start and stop a container to enter in exited state.
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		_, err = bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		_, err = bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Stop(bt.conn, name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
| 
						 | 
				
			
			@ -98,14 +97,14 @@ var _ = Describe("Podman system", func() {
 | 
			
		|||
 | 
			
		||||
		// Start and stop a container to enter in exited state.
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		_, err = bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		_, err = bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Stop(bt.conn, name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
 | 
			
		||||
		// Start container and leave in running
 | 
			
		||||
		var name2 = "top2"
 | 
			
		||||
		_, err = bt.RunTopContainer(&name2, bindings.PFalse, nil)
 | 
			
		||||
		_, err = bt.RunTopContainer(&name2, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
 | 
			
		||||
		// Adding an unused volume
 | 
			
		||||
| 
						 | 
				
			
			@ -132,14 +131,14 @@ var _ = Describe("Podman system", func() {
 | 
			
		|||
 | 
			
		||||
		// Start and stop a container to enter in exited state.
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		_, err = bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		_, err = bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Stop(bt.conn, name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
 | 
			
		||||
		// Start second container and leave in running
 | 
			
		||||
		var name2 = "top2"
 | 
			
		||||
		_, err = bt.RunTopContainer(&name2, bindings.PFalse, nil)
 | 
			
		||||
		_, err = bt.RunTopContainer(&name2, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
 | 
			
		||||
		// Adding an unused volume should work
 | 
			
		||||
| 
						 | 
				
			
			@ -167,14 +166,14 @@ var _ = Describe("Podman system", func() {
 | 
			
		|||
 | 
			
		||||
		// Start and stop a container to enter in exited state.
 | 
			
		||||
		var name = "top"
 | 
			
		||||
		_, err = bt.RunTopContainer(&name, bindings.PFalse, nil)
 | 
			
		||||
		_, err = bt.RunTopContainer(&name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
		err = containers.Stop(bt.conn, name, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
 | 
			
		||||
		// Start second container and leave in running
 | 
			
		||||
		var name2 = "top2"
 | 
			
		||||
		_, err = bt.RunTopContainer(&name2, bindings.PFalse, nil)
 | 
			
		||||
		_, err = bt.RunTopContainer(&name2, nil)
 | 
			
		||||
		Expect(err).To(BeNil())
 | 
			
		||||
 | 
			
		||||
		// Adding an unused volume should work
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -18,7 +18,7 @@ t HEAD libpod/_ping 200
 | 
			
		|||
for i in /version version; do
 | 
			
		||||
    t GET  $i      200                           \
 | 
			
		||||
      .Components[0].Name="Podman Engine"        \
 | 
			
		||||
      .Components[0].Details.APIVersion=3.0.0    \
 | 
			
		||||
      .Components[0].Details.APIVersion=3.1.0-dev    \
 | 
			
		||||
      .Components[0].Details.MinAPIVersion=3.0.0 \
 | 
			
		||||
      .Components[0].Details.Os=linux            \
 | 
			
		||||
      .ApiVersion=1.40                          \
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -4,13 +4,44 @@ import (
 | 
			
		|||
	"github.com/blang/semver"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
type (
 | 
			
		||||
	// Tree determines which API endpoint tree for version
 | 
			
		||||
	Tree int
 | 
			
		||||
	// Level determines which API level, current or something from the past
 | 
			
		||||
	Level int
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
const (
 | 
			
		||||
	// Libpod supports Libpod endpoints
 | 
			
		||||
	Libpod = Tree(iota)
 | 
			
		||||
	// Compat supports Libpod endpoints
 | 
			
		||||
	Compat
 | 
			
		||||
 | 
			
		||||
	// CurrentAPI announces what is the current API level
 | 
			
		||||
	CurrentAPI = Level(iota)
 | 
			
		||||
	// MinimalAPI announces what is the oldest API level supported
 | 
			
		||||
	MinimalAPI
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
// Version is the version of the build.
 | 
			
		||||
// NOTE: remember to bump the version at the top
 | 
			
		||||
// of the top-level README.md file when this is
 | 
			
		||||
// bumped.
 | 
			
		||||
var Version = semver.MustParse("3.1.0-dev")
 | 
			
		||||
 | 
			
		||||
// APIVersion is the version for the remote
 | 
			
		||||
// client API.  It is used to determine compatibility
 | 
			
		||||
// between a remote podman client and its backend
 | 
			
		||||
var APIVersion = semver.MustParse("3.0.0")
 | 
			
		||||
// See https://docs.docker.com/engine/api/v1.40/
 | 
			
		||||
// libpod compat handlers are expected to honor docker API versions
 | 
			
		||||
 | 
			
		||||
// APIVersion provides the current and minimal API versions for compat and libpod endpoint trees
 | 
			
		||||
// Note: GET|HEAD /_ping is never versioned and provides the API-Version and Libpod-API-Version headers to allow
 | 
			
		||||
//       clients to shop for the Version they wish to support
 | 
			
		||||
var APIVersion = map[Tree]map[Level]semver.Version{
 | 
			
		||||
	Libpod: {
 | 
			
		||||
		CurrentAPI: Version,
 | 
			
		||||
		MinimalAPI: semver.MustParse("3.0.0"),
 | 
			
		||||
	},
 | 
			
		||||
	Compat: {
 | 
			
		||||
		CurrentAPI: semver.MustParse("1.40.0"),
 | 
			
		||||
		MinimalAPI: semver.MustParse("1.24.0"),
 | 
			
		||||
	},
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in New Issue