mirror of
https://github.com/containers/podman.git
synced 2025-06-29 15:08:09 +08:00
Use version package to track all versions
* Server, bindings, and CLI all now pull version information from version package. * Current /libpod API version slaved to podman/libpod Version * Bindings validate against libpod API Minimal version * Remove pkg/bindings/bindings.go and updated tests Fixes: #9207 Signed-off-by: Jhon Honce <jhonce@redhat.com>
This commit is contained in:
@ -5,7 +5,7 @@ import (
|
|||||||
"strconv"
|
"strconv"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
podmanVersion "github.com/containers/podman/v3/version"
|
"github.com/containers/podman/v3/version"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Overwritten at build time
|
// Overwritten at build time
|
||||||
@ -42,8 +42,8 @@ func GetVersion() (Version, error) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
return Version{
|
return Version{
|
||||||
APIVersion: podmanVersion.APIVersion.String(),
|
APIVersion: version.APIVersion[version.Libpod][version.CurrentAPI].String(),
|
||||||
Version: podmanVersion.Version.String(),
|
Version: version.Version.String(),
|
||||||
GoVersion: runtime.Version(),
|
GoVersion: runtime.Version(),
|
||||||
GitCommit: gitCommit,
|
GitCommit: gitCommit,
|
||||||
BuiltTime: time.Unix(buildTime, 0).Format(time.ANSIC),
|
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/libpod/define"
|
||||||
"github.com/containers/podman/v3/pkg/api/handlers/utils"
|
"github.com/containers/podman/v3/pkg/api/handlers/utils"
|
||||||
"github.com/containers/podman/v3/pkg/domain/entities"
|
"github.com/containers/podman/v3/pkg/domain/entities"
|
||||||
|
"github.com/containers/podman/v3/version"
|
||||||
docker "github.com/docker/docker/api/types"
|
docker "github.com/docker/docker/api/types"
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
)
|
)
|
||||||
@ -35,20 +36,20 @@ func VersionHandler(w http.ResponseWriter, r *http.Request) {
|
|||||||
Name: "Podman Engine",
|
Name: "Podman Engine",
|
||||||
Version: versionInfo.Version,
|
Version: versionInfo.Version,
|
||||||
Details: map[string]string{
|
Details: map[string]string{
|
||||||
"APIVersion": utils.APIVersion[utils.LibpodTree][utils.CurrentAPIVersion].String(),
|
"APIVersion": version.APIVersion[version.Libpod][version.CurrentAPI].String(),
|
||||||
"Arch": goRuntime.GOARCH,
|
"Arch": goRuntime.GOARCH,
|
||||||
"BuildTime": time.Unix(versionInfo.Built, 0).Format(time.RFC3339),
|
"BuildTime": time.Unix(versionInfo.Built, 0).Format(time.RFC3339),
|
||||||
"Experimental": "true",
|
"Experimental": "true",
|
||||||
"GitCommit": versionInfo.GitCommit,
|
"GitCommit": versionInfo.GitCommit,
|
||||||
"GoVersion": versionInfo.GoVersion,
|
"GoVersion": versionInfo.GoVersion,
|
||||||
"KernelVersion": infoData.Host.Kernel,
|
"KernelVersion": infoData.Host.Kernel,
|
||||||
"MinAPIVersion": utils.APIVersion[utils.LibpodTree][utils.MinimalAPIVersion].String(),
|
"MinAPIVersion": version.APIVersion[version.Libpod][version.MinimalAPI].String(),
|
||||||
"Os": goRuntime.GOOS,
|
"Os": goRuntime.GOOS,
|
||||||
},
|
},
|
||||||
}}
|
}}
|
||||||
|
|
||||||
apiVersion := utils.APIVersion[utils.CompatTree][utils.CurrentAPIVersion]
|
apiVersion := version.APIVersion[version.Compat][version.CurrentAPI]
|
||||||
minVersion := utils.APIVersion[utils.CompatTree][utils.MinimalAPIVersion]
|
minVersion := version.APIVersion[version.Compat][version.MinimalAPI]
|
||||||
|
|
||||||
utils.WriteResponse(w, http.StatusOK, entities.ComponentVersion{
|
utils.WriteResponse(w, http.StatusOK, entities.ComponentVersion{
|
||||||
Version: docker.Version{
|
Version: docker.Version{
|
||||||
|
@ -10,49 +10,14 @@ import (
|
|||||||
"unsafe"
|
"unsafe"
|
||||||
|
|
||||||
"github.com/blang/semver"
|
"github.com/blang/semver"
|
||||||
|
"github.com/containers/podman/v3/version"
|
||||||
"github.com/gorilla/mux"
|
"github.com/gorilla/mux"
|
||||||
jsoniter "github.com/json-iterator/go"
|
jsoniter "github.com/json-iterator/go"
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
"github.com/sirupsen/logrus"
|
"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 (
|
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 returned when version not given by client
|
||||||
ErrVersionNotGiven = errors.New("version not given in URL path")
|
ErrVersionNotGiven = errors.New("version not given in URL path")
|
||||||
// ErrVersionNotSupported returned when given version is too old
|
// 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
|
// 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
|
// minimal API version <= client path version <= maximum API version focused on the endpoint tree from URL
|
||||||
func SupportedVersionWithDefaults(r *http.Request) (semver.Version, error) {
|
func SupportedVersionWithDefaults(r *http.Request) (semver.Version, error) {
|
||||||
tree := CompatTree
|
tree := version.Compat
|
||||||
if IsLibpodRequest(r) {
|
if IsLibpodRequest(r) {
|
||||||
tree = LibpodTree
|
tree = version.Libpod
|
||||||
}
|
}
|
||||||
|
|
||||||
return SupportedVersion(r,
|
return SupportedVersion(r,
|
||||||
fmt.Sprintf(">=%s <=%s", APIVersion[tree][MinimalAPIVersion].String(),
|
fmt.Sprintf(">=%s <=%s", version.APIVersion[tree][version.MinimalAPI].String(),
|
||||||
APIVersion[tree][CurrentAPIVersion].String()))
|
version.APIVersion[tree][version.CurrentAPI].String()))
|
||||||
}
|
}
|
||||||
|
|
||||||
// WriteResponse encodes the given value as JSON or string and renders it for http client
|
// WriteResponse encodes the given value as JSON or string and renders it for http client
|
||||||
|
@ -7,17 +7,18 @@ import (
|
|||||||
"net/http/httptest"
|
"net/http/httptest"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
"github.com/containers/podman/v3/version"
|
||||||
"github.com/gorilla/mux"
|
"github.com/gorilla/mux"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestSupportedVersion(t *testing.T) {
|
func TestSupportedVersion(t *testing.T) {
|
||||||
req, err := http.NewRequest("GET",
|
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)
|
nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
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()
|
rr := httptest.NewRecorder()
|
||||||
handler := http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
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/api/handlers/utils"
|
||||||
"github.com/containers/podman/v3/pkg/auth"
|
"github.com/containers/podman/v3/pkg/auth"
|
||||||
|
"github.com/containers/podman/v3/version"
|
||||||
"github.com/google/uuid"
|
"github.com/google/uuid"
|
||||||
"github.com/sirupsen/logrus"
|
"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
|
c = context.WithValue(c, "idletracker", s.idleTracker) // nolint
|
||||||
r = r.WithContext(c)
|
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))
|
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("Libpod-API-Version", lv)
|
||||||
w.Header().Set("Server", "Libpod/"+lv+" ("+runtime.GOOS+")")
|
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
|
// VersionedPath prepends the version parsing code
|
||||||
// any handler may override this default when registering URL(s)
|
// any handler may override this default when registering URL(s)
|
||||||
func VersionedPath(p string) string {
|
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/blang/semver"
|
||||||
"github.com/containers/podman/v3/pkg/terminal"
|
"github.com/containers/podman/v3/pkg/terminal"
|
||||||
|
"github.com/containers/podman/v3/version"
|
||||||
jsoniter "github.com/json-iterator/go"
|
jsoniter "github.com/json-iterator/go"
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
"github.com/sirupsen/logrus"
|
"github.com/sirupsen/logrus"
|
||||||
@ -25,7 +26,7 @@ var (
|
|||||||
BasePath = &url.URL{
|
BasePath = &url.URL{
|
||||||
Scheme: "http",
|
Scheme: "http",
|
||||||
Host: "d",
|
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
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
switch APIVersion.Compare(versionSrv) {
|
switch version.APIVersion[version.Libpod][version.MinimalAPI].Compare(versionSrv) {
|
||||||
case -1, 0:
|
case -1, 0:
|
||||||
// Server's job when Client version is equal or older
|
// Server's job when Client version is equal or older
|
||||||
return nil
|
return nil
|
||||||
case 1:
|
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) {
|
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() {
|
It("can run top in container", func() {
|
||||||
name := "TopAttachTest"
|
name := "TopAttachTest"
|
||||||
id, err := bt.RunTopContainer(&name, nil, nil)
|
id, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).ShouldNot(HaveOccurred())
|
Expect(err).ShouldNot(HaveOccurred())
|
||||||
|
|
||||||
tickTock := time.NewTimer(2 * time.Second)
|
tickTock := time.NewTimer(2 * time.Second)
|
||||||
|
@ -188,14 +188,14 @@ func (b *bindingTest) restoreImageFromCache(i testImage) {
|
|||||||
|
|
||||||
// Run a container within or without a pod
|
// Run a container within or without a pod
|
||||||
// and add or append the alpine image to it
|
// 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 := specgen.NewSpecGenerator(alpine.name, false)
|
||||||
s.Terminal = false
|
s.Terminal = false
|
||||||
s.Command = []string{"/usr/bin/top"}
|
s.Command = []string{"/usr/bin/top"}
|
||||||
if containerName != nil {
|
if containerName != nil {
|
||||||
s.Name = *containerName
|
s.Name = *containerName
|
||||||
}
|
}
|
||||||
if insidePod != nil && podName != nil {
|
if podName != nil {
|
||||||
s.Pod = *podName
|
s.Pod = *podName
|
||||||
}
|
}
|
||||||
ctr, err := containers.CreateWithSpec(b.conn, s, nil)
|
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() {
|
It("podman pause a running container by name", func() {
|
||||||
// Pausing by name should work
|
// Pausing by name should work
|
||||||
var name = "top"
|
var name = "top"
|
||||||
_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
_, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Pause(bt.conn, name, nil)
|
err = containers.Pause(bt.conn, name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
@ -69,7 +69,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
It("podman pause a running container by id", func() {
|
It("podman pause a running container by id", func() {
|
||||||
// Pausing by id should work
|
// Pausing by id should work
|
||||||
var name = "top"
|
var name = "top"
|
||||||
cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
cid, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Pause(bt.conn, cid, nil)
|
err = containers.Pause(bt.conn, cid, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
@ -83,7 +83,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
It("podman unpause a running container by name", func() {
|
It("podman unpause a running container by name", func() {
|
||||||
// Unpausing by name should work
|
// Unpausing by name should work
|
||||||
var name = "top"
|
var name = "top"
|
||||||
_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
_, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Pause(bt.conn, name, nil)
|
err = containers.Pause(bt.conn, name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
@ -99,7 +99,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
It("podman unpause a running container by ID", func() {
|
It("podman unpause a running container by ID", func() {
|
||||||
// Unpausing by ID should work
|
// Unpausing by ID should work
|
||||||
var name = "top"
|
var name = "top"
|
||||||
_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
_, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
// Pause by name
|
// Pause by name
|
||||||
err = containers.Pause(bt.conn, name, nil)
|
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() {
|
It("podman pause a paused container by name", func() {
|
||||||
// Pausing a paused container by name should fail
|
// Pausing a paused container by name should fail
|
||||||
var name = "top"
|
var name = "top"
|
||||||
_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
_, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Pause(bt.conn, name, nil)
|
err = containers.Pause(bt.conn, name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
@ -131,7 +131,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
It("podman pause a paused container by id", func() {
|
It("podman pause a paused container by id", func() {
|
||||||
// Pausing a paused container by id should fail
|
// Pausing a paused container by id should fail
|
||||||
var name = "top"
|
var name = "top"
|
||||||
cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
cid, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Pause(bt.conn, cid, nil)
|
err = containers.Pause(bt.conn, cid, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
@ -144,7 +144,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
It("podman pause a stopped container by name", func() {
|
It("podman pause a stopped container by name", func() {
|
||||||
// Pausing a stopped container by name should fail
|
// Pausing a stopped container by name should fail
|
||||||
var name = "top"
|
var name = "top"
|
||||||
_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
_, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Stop(bt.conn, name, nil)
|
err = containers.Stop(bt.conn, name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
@ -157,7 +157,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
It("podman pause a stopped container by id", func() {
|
It("podman pause a stopped container by id", func() {
|
||||||
// Pausing a stopped container by id should fail
|
// Pausing a stopped container by id should fail
|
||||||
var name = "top"
|
var name = "top"
|
||||||
cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
cid, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Stop(bt.conn, cid, nil)
|
err = containers.Stop(bt.conn, cid, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
@ -170,7 +170,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
It("podman remove a paused container by id without force", func() {
|
It("podman remove a paused container by id without force", func() {
|
||||||
// Removing a paused container without force should fail
|
// Removing a paused container without force should fail
|
||||||
var name = "top"
|
var name = "top"
|
||||||
cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
cid, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Pause(bt.conn, cid, nil)
|
err = containers.Pause(bt.conn, cid, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
@ -183,7 +183,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
It("podman remove a paused container by id with force", func() {
|
It("podman remove a paused container by id with force", func() {
|
||||||
// Removing a paused container with force should work
|
// Removing a paused container with force should work
|
||||||
var name = "top"
|
var name = "top"
|
||||||
cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
cid, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Pause(bt.conn, cid, nil)
|
err = containers.Pause(bt.conn, cid, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
@ -194,7 +194,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
It("podman stop a paused container by name", func() {
|
It("podman stop a paused container by name", func() {
|
||||||
// Stopping a paused container by name should fail
|
// Stopping a paused container by name should fail
|
||||||
var name = "top"
|
var name = "top"
|
||||||
_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
_, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Pause(bt.conn, name, nil)
|
err = containers.Pause(bt.conn, name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
@ -207,7 +207,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
It("podman stop a paused container by id", func() {
|
It("podman stop a paused container by id", func() {
|
||||||
// Stopping a paused container by id should fail
|
// Stopping a paused container by id should fail
|
||||||
var name = "top"
|
var name = "top"
|
||||||
cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
cid, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Pause(bt.conn, cid, nil)
|
err = containers.Pause(bt.conn, cid, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
@ -220,7 +220,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
It("podman stop a running container by name", func() {
|
It("podman stop a running container by name", func() {
|
||||||
// Stopping a running container by name should work
|
// Stopping a running container by name should work
|
||||||
var name = "top"
|
var name = "top"
|
||||||
_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
_, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Stop(bt.conn, name, nil)
|
err = containers.Stop(bt.conn, name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
@ -234,7 +234,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
It("podman stop a running container by ID", func() {
|
It("podman stop a running container by ID", func() {
|
||||||
// Stopping a running container by ID should work
|
// Stopping a running container by ID should work
|
||||||
var name = "top"
|
var name = "top"
|
||||||
cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
cid, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Stop(bt.conn, cid, nil)
|
err = containers.Stop(bt.conn, cid, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
@ -256,7 +256,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
Expect(code).To(BeNumerically("==", http.StatusNotFound))
|
Expect(code).To(BeNumerically("==", http.StatusNotFound))
|
||||||
|
|
||||||
errChan := make(chan error)
|
errChan := make(chan error)
|
||||||
_, err = bt.RunTopContainer(&name, nil, nil)
|
_, err = bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
go func() {
|
go func() {
|
||||||
exitCode, err = containers.Wait(bt.conn, name, nil)
|
exitCode, err = containers.Wait(bt.conn, name, nil)
|
||||||
@ -278,7 +278,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
running = define.ContainerStateRunning
|
running = define.ContainerStateRunning
|
||||||
)
|
)
|
||||||
errChan := make(chan error)
|
errChan := make(chan error)
|
||||||
_, err := bt.RunTopContainer(&name, nil, nil)
|
_, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
go func() {
|
go func() {
|
||||||
exitCode, err = containers.Wait(bt.conn, name, new(containers.WaitOptions).WithCondition([]define.ContainerStatus{pause}))
|
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
|
// a container that has no healthcheck should be a 409
|
||||||
var name = "top"
|
var name = "top"
|
||||||
bt.RunTopContainer(&name, bindings.PFalse, nil)
|
bt.RunTopContainer(&name, nil)
|
||||||
_, err = containers.RunHealthCheck(bt.conn, name, nil)
|
_, err = containers.RunHealthCheck(bt.conn, name, nil)
|
||||||
Expect(err).ToNot(BeNil())
|
Expect(err).ToNot(BeNil())
|
||||||
code, _ = bindings.CheckResponseCode(err)
|
code, _ = bindings.CheckResponseCode(err)
|
||||||
@ -376,7 +376,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
|
|
||||||
It("podman top", func() {
|
It("podman top", func() {
|
||||||
var name = "top"
|
var name = "top"
|
||||||
cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
cid, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
|
|
||||||
// By name
|
// By name
|
||||||
@ -414,7 +414,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
It("podman container exists in local storage by name", func() {
|
It("podman container exists in local storage by name", func() {
|
||||||
// Container existence check by name should work
|
// Container existence check by name should work
|
||||||
var name = "top"
|
var name = "top"
|
||||||
_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
_, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
containerExists, err := containers.Exists(bt.conn, name, nil)
|
containerExists, err := containers.Exists(bt.conn, name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
@ -424,7 +424,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
It("podman container exists in local storage by ID", func() {
|
It("podman container exists in local storage by ID", func() {
|
||||||
// Container existence check by ID should work
|
// Container existence check by ID should work
|
||||||
var name = "top"
|
var name = "top"
|
||||||
cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
cid, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
containerExists, err := containers.Exists(bt.conn, cid, nil)
|
containerExists, err := containers.Exists(bt.conn, cid, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
@ -434,7 +434,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
It("podman container exists in local storage by short ID", func() {
|
It("podman container exists in local storage by short ID", func() {
|
||||||
// Container existence check by short ID should work
|
// Container existence check by short ID should work
|
||||||
var name = "top"
|
var name = "top"
|
||||||
cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
cid, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
containerExists, err := containers.Exists(bt.conn, cid[0:12], nil)
|
containerExists, err := containers.Exists(bt.conn, cid[0:12], nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
@ -452,7 +452,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
It("podman kill a running container by name with SIGINT", func() {
|
It("podman kill a running container by name with SIGINT", func() {
|
||||||
// Killing a running container should work
|
// Killing a running container should work
|
||||||
var name = "top"
|
var name = "top"
|
||||||
_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
_, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Kill(bt.conn, name, new(containers.KillOptions).WithSignal("SIGINT"))
|
err = containers.Kill(bt.conn, name, new(containers.KillOptions).WithSignal("SIGINT"))
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
@ -463,7 +463,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
It("podman kill a running container by ID with SIGTERM", func() {
|
It("podman kill a running container by ID with SIGTERM", func() {
|
||||||
// Killing a running container by ID should work
|
// Killing a running container by ID should work
|
||||||
var name = "top"
|
var name = "top"
|
||||||
cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
cid, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Kill(bt.conn, cid, new(containers.KillOptions).WithSignal("SIGTERM"))
|
err = containers.Kill(bt.conn, cid, new(containers.KillOptions).WithSignal("SIGTERM"))
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
@ -474,7 +474,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
It("podman kill a running container by ID with SIGKILL", func() {
|
It("podman kill a running container by ID with SIGKILL", func() {
|
||||||
// Killing a running container by ID with TERM should work
|
// Killing a running container by ID with TERM should work
|
||||||
var name = "top"
|
var name = "top"
|
||||||
cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
cid, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Kill(bt.conn, cid, new(containers.KillOptions).WithSignal("SIGKILL"))
|
err = containers.Kill(bt.conn, cid, new(containers.KillOptions).WithSignal("SIGKILL"))
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
@ -483,7 +483,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
It("podman kill a running container by bogus signal", func() {
|
It("podman kill a running container by bogus signal", func() {
|
||||||
//Killing a running container by bogus signal should fail
|
//Killing a running container by bogus signal should fail
|
||||||
var name = "top"
|
var name = "top"
|
||||||
cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
cid, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Kill(bt.conn, cid, new(containers.KillOptions).WithSignal("foobar"))
|
err = containers.Kill(bt.conn, cid, new(containers.KillOptions).WithSignal("foobar"))
|
||||||
Expect(err).ToNot(BeNil())
|
Expect(err).ToNot(BeNil())
|
||||||
@ -495,9 +495,9 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
// Killing latest container should work
|
// Killing latest container should work
|
||||||
var name1 = "first"
|
var name1 = "first"
|
||||||
var name2 = "second"
|
var name2 = "second"
|
||||||
_, err := bt.RunTopContainer(&name1, bindings.PFalse, nil)
|
_, err := bt.RunTopContainer(&name1, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
_, err = bt.RunTopContainer(&name2, bindings.PFalse, nil)
|
_, err = bt.RunTopContainer(&name2, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
containerLatestList, err := containers.List(bt.conn, new(containers.ListOptions).WithLast(1))
|
containerLatestList, err := containers.List(bt.conn, new(containers.ListOptions).WithLast(1))
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
@ -526,7 +526,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
It("podman prune stopped containers", func() {
|
It("podman prune stopped containers", func() {
|
||||||
// Start and stop a container to enter in exited state.
|
// Start and stop a container to enter in exited state.
|
||||||
var name = "top"
|
var name = "top"
|
||||||
_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
_, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Stop(bt.conn, name, nil)
|
err = containers.Stop(bt.conn, name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
@ -541,7 +541,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
It("podman prune stopped containers with filters", func() {
|
It("podman prune stopped containers with filters", func() {
|
||||||
// Start and stop a container to enter in exited state.
|
// Start and stop a container to enter in exited state.
|
||||||
var name = "top"
|
var name = "top"
|
||||||
_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
_, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Stop(bt.conn, name, nil)
|
err = containers.Stop(bt.conn, name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
@ -575,7 +575,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
It("podman prune running containers", func() {
|
It("podman prune running containers", func() {
|
||||||
// Start the container.
|
// Start the container.
|
||||||
var name = "top"
|
var name = "top"
|
||||||
_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
_, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
|
|
||||||
// Check if the container is running.
|
// Check if the container is running.
|
||||||
@ -598,7 +598,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
|
|
||||||
It("podman inspect running container", func() {
|
It("podman inspect running container", func() {
|
||||||
var name = "top"
|
var name = "top"
|
||||||
_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
_, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
// Inspecting running container should succeed
|
// Inspecting running container should succeed
|
||||||
_, err = containers.Inspect(bt.conn, name, nil)
|
_, err = containers.Inspect(bt.conn, name, nil)
|
||||||
@ -607,7 +607,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
|
|
||||||
It("podman inspect stopped container", func() {
|
It("podman inspect stopped container", func() {
|
||||||
var name = "top"
|
var name = "top"
|
||||||
_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
_, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Stop(bt.conn, name, nil)
|
err = containers.Stop(bt.conn, name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
@ -618,7 +618,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
|
|
||||||
It("podman inspect running container with size", func() {
|
It("podman inspect running container with size", func() {
|
||||||
var name = "top"
|
var name = "top"
|
||||||
_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
_, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
_, err = containers.Inspect(bt.conn, name, new(containers.InspectOptions).WithSize(true))
|
_, err = containers.Inspect(bt.conn, name, new(containers.InspectOptions).WithSize(true))
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
@ -626,7 +626,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
|
|
||||||
It("podman inspect stopped container with size", func() {
|
It("podman inspect stopped container with size", func() {
|
||||||
var name = "top"
|
var name = "top"
|
||||||
_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
_, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Stop(bt.conn, name, nil)
|
err = containers.Stop(bt.conn, name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
@ -643,7 +643,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
|
|
||||||
It("podman remove running container by name", func() {
|
It("podman remove running container by name", func() {
|
||||||
var name = "top"
|
var name = "top"
|
||||||
_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
_, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
// Removing running container should fail
|
// Removing running container should fail
|
||||||
err = containers.Remove(bt.conn, name, nil)
|
err = containers.Remove(bt.conn, name, nil)
|
||||||
@ -654,7 +654,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
|
|
||||||
It("podman remove running container by ID", func() {
|
It("podman remove running container by ID", func() {
|
||||||
var name = "top"
|
var name = "top"
|
||||||
cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
cid, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
// Removing running container should fail
|
// Removing running container should fail
|
||||||
err = containers.Remove(bt.conn, cid, nil)
|
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() {
|
It("podman forcibly remove running container by name", func() {
|
||||||
var name = "top"
|
var name = "top"
|
||||||
_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
_, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
// Removing running container should fail
|
// Removing running container should fail
|
||||||
err = containers.Remove(bt.conn, name, new(containers.RemoveOptions).WithForce(true))
|
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() {
|
It("podman forcibly remove running container by ID", func() {
|
||||||
var name = "top"
|
var name = "top"
|
||||||
cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
cid, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
// Removing running container should fail
|
// Removing running container should fail
|
||||||
err = containers.Remove(bt.conn, cid, new(containers.RemoveOptions).WithForce(true))
|
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() {
|
It("podman remove running container and volume by name", func() {
|
||||||
var name = "top"
|
var name = "top"
|
||||||
_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
_, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
// Removing running container should fail
|
// Removing running container should fail
|
||||||
err = containers.Remove(bt.conn, name, new(containers.RemoveOptions).WithVolumes(true))
|
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() {
|
It("podman remove running container and volume by ID", func() {
|
||||||
var name = "top"
|
var name = "top"
|
||||||
cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
cid, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
// Removing running container should fail
|
// Removing running container should fail
|
||||||
err = containers.Remove(bt.conn, cid, new(containers.RemoveOptions).WithVolumes(true))
|
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() {
|
It("podman forcibly remove running container and volume by name", func() {
|
||||||
var name = "top"
|
var name = "top"
|
||||||
_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
_, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
// Removing running container should fail
|
// Removing running container should fail
|
||||||
err = containers.Remove(bt.conn, name, new(containers.RemoveOptions).WithVolumes(true).WithForce(true))
|
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() {
|
It("podman forcibly remove running container and volume by ID", func() {
|
||||||
var name = "top"
|
var name = "top"
|
||||||
cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
cid, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
// Removing running container should fail
|
// Removing running container should fail
|
||||||
err = containers.Remove(bt.conn, cid, new(containers.RemoveOptions).WithForce(true).WithVolumes(true))
|
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() {
|
It("List containers with filters", func() {
|
||||||
var name = "top"
|
var name = "top"
|
||||||
var name2 = "top2"
|
var name2 = "top2"
|
||||||
cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
cid, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
_, err = bt.RunTopContainer(&name2, bindings.PFalse, nil)
|
_, err = bt.RunTopContainer(&name2, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
s := specgen.NewSpecGenerator(alpine.name, false)
|
s := specgen.NewSpecGenerator(alpine.name, false)
|
||||||
s.Terminal = true
|
s.Terminal = true
|
||||||
@ -753,7 +753,7 @@ var _ = Describe("Podman containers ", func() {
|
|||||||
podName := "testpod"
|
podName := "testpod"
|
||||||
ctrName := "testctr"
|
ctrName := "testctr"
|
||||||
bt.Podcreate(&podName)
|
bt.Podcreate(&podName)
|
||||||
_, err := bt.RunTopContainer(&ctrName, bindings.PTrue, &podName)
|
_, err := bt.RunTopContainer(&ctrName, &podName)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
|
|
||||||
lastNum := 1
|
lastNum := 1
|
||||||
|
@ -4,7 +4,6 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/containers/podman/v3/pkg/api/handlers"
|
"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/containers/podman/v3/pkg/bindings/containers"
|
||||||
. "github.com/onsi/ginkgo"
|
. "github.com/onsi/ginkgo"
|
||||||
. "github.com/onsi/gomega"
|
. "github.com/onsi/gomega"
|
||||||
@ -33,7 +32,7 @@ var _ = Describe("Podman containers exec", func() {
|
|||||||
|
|
||||||
It("Podman exec create makes an exec session", func() {
|
It("Podman exec create makes an exec session", func() {
|
||||||
name := "testCtr"
|
name := "testCtr"
|
||||||
cid, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
cid, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
|
|
||||||
execConfig := new(handlers.ExecCreateConfig)
|
execConfig := new(handlers.ExecCreateConfig)
|
||||||
@ -53,7 +52,7 @@ var _ = Describe("Podman containers exec", func() {
|
|||||||
|
|
||||||
It("Podman exec create with bad command fails", func() {
|
It("Podman exec create with bad command fails", func() {
|
||||||
name := "testCtr"
|
name := "testCtr"
|
||||||
_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
_, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
|
|
||||||
execConfig := new(handlers.ExecCreateConfig)
|
execConfig := new(handlers.ExecCreateConfig)
|
||||||
|
@ -101,7 +101,7 @@ var _ = Describe("Podman images", func() {
|
|||||||
|
|
||||||
// Start a container with alpine image
|
// Start a container with alpine image
|
||||||
var top string = "top"
|
var top string = "top"
|
||||||
_, err = bt.RunTopContainer(&top, bindings.PFalse, nil)
|
_, err = bt.RunTopContainer(&top, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
// we should now have a container called "top" running
|
// we should now have a container called "top" running
|
||||||
containerResponse, err := containers.Inspect(bt.conn, "top", nil)
|
containerResponse, err := containers.Inspect(bt.conn, "top", nil)
|
||||||
|
@ -49,17 +49,17 @@ var _ = Describe("Podman info", func() {
|
|||||||
_, err := containers.CreateWithSpec(bt.conn, s, nil)
|
_, err := containers.CreateWithSpec(bt.conn, s, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
|
|
||||||
idPause, err := bt.RunTopContainer(nil, nil, nil)
|
idPause, err := bt.RunTopContainer(nil, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Pause(bt.conn, idPause, nil)
|
err = containers.Pause(bt.conn, idPause, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
|
|
||||||
idStop, err := bt.RunTopContainer(nil, nil, nil)
|
idStop, err := bt.RunTopContainer(nil, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Stop(bt.conn, idStop, nil)
|
err = containers.Stop(bt.conn, idStop, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
|
|
||||||
_, err = bt.RunTopContainer(nil, nil, nil)
|
_, err = bt.RunTopContainer(nil, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
|
|
||||||
info, err := system.Info(bt.conn, nil)
|
info, err := system.Info(bt.conn, nil)
|
||||||
|
@ -63,7 +63,7 @@ var _ = Describe("Podman pods", func() {
|
|||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
|
|
||||||
// Adding an alpine container to the existing pod
|
// Adding an alpine container to the existing pod
|
||||||
_, err = bt.RunTopContainer(nil, bindings.PTrue, &newpod)
|
_, err = bt.RunTopContainer(nil, &newpod)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
podSummary, err = pods.List(bt.conn, nil)
|
podSummary, err = pods.List(bt.conn, nil)
|
||||||
// Verify no errors.
|
// Verify no errors.
|
||||||
@ -93,7 +93,7 @@ var _ = Describe("Podman pods", func() {
|
|||||||
_, err = pods.Start(bt.conn, newpod, nil)
|
_, err = pods.Start(bt.conn, newpod, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
|
|
||||||
_, err = bt.RunTopContainer(nil, bindings.PTrue, &newpod)
|
_, err = bt.RunTopContainer(nil, &newpod)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
|
|
||||||
// Expected err with invalid filter params
|
// Expected err with invalid filter params
|
||||||
@ -179,7 +179,7 @@ var _ = Describe("Podman pods", func() {
|
|||||||
Expect(code).To(BeNumerically("==", http.StatusNotFound))
|
Expect(code).To(BeNumerically("==", http.StatusNotFound))
|
||||||
|
|
||||||
// Adding an alpine container to the existing pod
|
// Adding an alpine container to the existing pod
|
||||||
_, err = bt.RunTopContainer(nil, bindings.PTrue, &newpod)
|
_, err = bt.RunTopContainer(nil, &newpod)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
|
|
||||||
// Binding needs to be modified to inspect the pod state.
|
// Binding needs to be modified to inspect the pod state.
|
||||||
|
@ -4,7 +4,6 @@ import (
|
|||||||
"sync"
|
"sync"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/containers/podman/v3/pkg/bindings"
|
|
||||||
"github.com/containers/podman/v3/pkg/bindings/containers"
|
"github.com/containers/podman/v3/pkg/bindings/containers"
|
||||||
"github.com/containers/podman/v3/pkg/bindings/pods"
|
"github.com/containers/podman/v3/pkg/bindings/pods"
|
||||||
"github.com/containers/podman/v3/pkg/bindings/system"
|
"github.com/containers/podman/v3/pkg/bindings/system"
|
||||||
@ -41,7 +40,7 @@ var _ = Describe("Podman system", func() {
|
|||||||
|
|
||||||
It("podman events", func() {
|
It("podman events", func() {
|
||||||
var name = "top"
|
var name = "top"
|
||||||
_, err := bt.RunTopContainer(&name, bindings.PFalse, nil)
|
_, err := bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
|
|
||||||
filters := make(map[string][]string)
|
filters := make(map[string][]string)
|
||||||
@ -72,7 +71,7 @@ var _ = Describe("Podman system", func() {
|
|||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
// Start and stop a container to enter in exited state.
|
// Start and stop a container to enter in exited state.
|
||||||
var name = "top"
|
var name = "top"
|
||||||
_, err = bt.RunTopContainer(&name, bindings.PFalse, nil)
|
_, err = bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Stop(bt.conn, name, nil)
|
err = containers.Stop(bt.conn, name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
@ -98,14 +97,14 @@ var _ = Describe("Podman system", func() {
|
|||||||
|
|
||||||
// Start and stop a container to enter in exited state.
|
// Start and stop a container to enter in exited state.
|
||||||
var name = "top"
|
var name = "top"
|
||||||
_, err = bt.RunTopContainer(&name, bindings.PFalse, nil)
|
_, err = bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Stop(bt.conn, name, nil)
|
err = containers.Stop(bt.conn, name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
|
|
||||||
// Start container and leave in running
|
// Start container and leave in running
|
||||||
var name2 = "top2"
|
var name2 = "top2"
|
||||||
_, err = bt.RunTopContainer(&name2, bindings.PFalse, nil)
|
_, err = bt.RunTopContainer(&name2, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
|
|
||||||
// Adding an unused volume
|
// Adding an unused volume
|
||||||
@ -132,14 +131,14 @@ var _ = Describe("Podman system", func() {
|
|||||||
|
|
||||||
// Start and stop a container to enter in exited state.
|
// Start and stop a container to enter in exited state.
|
||||||
var name = "top"
|
var name = "top"
|
||||||
_, err = bt.RunTopContainer(&name, bindings.PFalse, nil)
|
_, err = bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Stop(bt.conn, name, nil)
|
err = containers.Stop(bt.conn, name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
|
|
||||||
// Start second container and leave in running
|
// Start second container and leave in running
|
||||||
var name2 = "top2"
|
var name2 = "top2"
|
||||||
_, err = bt.RunTopContainer(&name2, bindings.PFalse, nil)
|
_, err = bt.RunTopContainer(&name2, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
|
|
||||||
// Adding an unused volume should work
|
// 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.
|
// Start and stop a container to enter in exited state.
|
||||||
var name = "top"
|
var name = "top"
|
||||||
_, err = bt.RunTopContainer(&name, bindings.PFalse, nil)
|
_, err = bt.RunTopContainer(&name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
err = containers.Stop(bt.conn, name, nil)
|
err = containers.Stop(bt.conn, name, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
|
|
||||||
// Start second container and leave in running
|
// Start second container and leave in running
|
||||||
var name2 = "top2"
|
var name2 = "top2"
|
||||||
_, err = bt.RunTopContainer(&name2, bindings.PFalse, nil)
|
_, err = bt.RunTopContainer(&name2, nil)
|
||||||
Expect(err).To(BeNil())
|
Expect(err).To(BeNil())
|
||||||
|
|
||||||
// Adding an unused volume should work
|
// Adding an unused volume should work
|
||||||
|
@ -18,7 +18,7 @@ t HEAD libpod/_ping 200
|
|||||||
for i in /version version; do
|
for i in /version version; do
|
||||||
t GET $i 200 \
|
t GET $i 200 \
|
||||||
.Components[0].Name="Podman Engine" \
|
.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.MinAPIVersion=3.0.0 \
|
||||||
.Components[0].Details.Os=linux \
|
.Components[0].Details.Os=linux \
|
||||||
.ApiVersion=1.40 \
|
.ApiVersion=1.40 \
|
||||||
|
@ -4,13 +4,44 @@ import (
|
|||||||
"github.com/blang/semver"
|
"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.
|
// Version is the version of the build.
|
||||||
// NOTE: remember to bump the version at the top
|
// NOTE: remember to bump the version at the top
|
||||||
// of the top-level README.md file when this is
|
// of the top-level README.md file when this is
|
||||||
// bumped.
|
// bumped.
|
||||||
var Version = semver.MustParse("3.1.0-dev")
|
var Version = semver.MustParse("3.1.0-dev")
|
||||||
|
|
||||||
// APIVersion is the version for the remote
|
// See https://docs.docker.com/engine/api/v1.40/
|
||||||
// client API. It is used to determine compatibility
|
// libpod compat handlers are expected to honor docker API versions
|
||||||
// between a remote podman client and its backend
|
|
||||||
var APIVersion = semver.MustParse("3.0.0")
|
// 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"),
|
||||||
|
},
|
||||||
|
}
|
||||||
|
Reference in New Issue
Block a user