
Make sure the middleware cannot be initialized with out of range versions. Signed-off-by: Sebastiaan van Stijn <github@gone.nl>
146 lines
4.6 KiB
Go
146 lines
4.6 KiB
Go
package middleware // import "github.com/docker/docker/api/server/middleware"
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"net/http"
|
|
"net/http/httptest"
|
|
"runtime"
|
|
"testing"
|
|
|
|
"github.com/docker/docker/api"
|
|
"github.com/docker/docker/api/server/httputils"
|
|
"gotest.tools/v3/assert"
|
|
is "gotest.tools/v3/assert/cmp"
|
|
)
|
|
|
|
func TestNewVersionMiddlewareValidation(t *testing.T) {
|
|
tests := []struct {
|
|
doc, defaultVersion, minVersion, expectedErr string
|
|
}{
|
|
{
|
|
doc: "defaults",
|
|
defaultVersion: api.DefaultVersion,
|
|
minVersion: api.MinSupportedAPIVersion,
|
|
},
|
|
{
|
|
doc: "invalid default lower than min",
|
|
defaultVersion: api.MinSupportedAPIVersion,
|
|
minVersion: api.DefaultVersion,
|
|
expectedErr: fmt.Sprintf("invalid API version: the minimum API version (%s) is higher than the default version (%s)", api.DefaultVersion, api.MinSupportedAPIVersion),
|
|
},
|
|
{
|
|
doc: "invalid default too low",
|
|
defaultVersion: "0.1",
|
|
minVersion: api.MinSupportedAPIVersion,
|
|
expectedErr: fmt.Sprintf("invalid default API version (0.1): must be between %s and %s", api.MinSupportedAPIVersion, api.DefaultVersion),
|
|
},
|
|
{
|
|
doc: "invalid default too high",
|
|
defaultVersion: "9999.9999",
|
|
minVersion: api.DefaultVersion,
|
|
expectedErr: fmt.Sprintf("invalid default API version (9999.9999): must be between %s and %s", api.MinSupportedAPIVersion, api.DefaultVersion),
|
|
},
|
|
{
|
|
doc: "invalid minimum too low",
|
|
defaultVersion: api.MinSupportedAPIVersion,
|
|
minVersion: "0.1",
|
|
expectedErr: fmt.Sprintf("invalid minimum API version (0.1): must be between %s and %s", api.MinSupportedAPIVersion, api.DefaultVersion),
|
|
},
|
|
{
|
|
doc: "invalid minimum too high",
|
|
defaultVersion: api.DefaultVersion,
|
|
minVersion: "9999.9999",
|
|
expectedErr: fmt.Sprintf("invalid minimum API version (9999.9999): must be between %s and %s", api.MinSupportedAPIVersion, api.DefaultVersion),
|
|
},
|
|
}
|
|
|
|
for _, tc := range tests {
|
|
tc := tc
|
|
t.Run(tc.doc, func(t *testing.T) {
|
|
_, err := NewVersionMiddleware("1.2.3", tc.defaultVersion, tc.minVersion)
|
|
if tc.expectedErr == "" {
|
|
assert.Check(t, err)
|
|
} else {
|
|
assert.Check(t, is.Error(err, tc.expectedErr))
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestVersionMiddlewareVersion(t *testing.T) {
|
|
expectedVersion := "<not set>"
|
|
handler := func(ctx context.Context, w http.ResponseWriter, r *http.Request, vars map[string]string) error {
|
|
v := httputils.VersionFromContext(ctx)
|
|
assert.Check(t, is.Equal(expectedVersion, v))
|
|
return nil
|
|
}
|
|
|
|
m, err := NewVersionMiddleware("1.2.3", api.DefaultVersion, api.MinSupportedAPIVersion)
|
|
assert.NilError(t, err)
|
|
h := m.WrapHandler(handler)
|
|
|
|
req, _ := http.NewRequest(http.MethodGet, "/containers/json", nil)
|
|
resp := httptest.NewRecorder()
|
|
ctx := context.Background()
|
|
|
|
tests := []struct {
|
|
reqVersion string
|
|
expectedVersion string
|
|
errString string
|
|
}{
|
|
{
|
|
expectedVersion: api.DefaultVersion,
|
|
},
|
|
{
|
|
reqVersion: api.MinSupportedAPIVersion,
|
|
expectedVersion: api.MinSupportedAPIVersion,
|
|
},
|
|
{
|
|
reqVersion: "0.1",
|
|
errString: fmt.Sprintf("client version 0.1 is too old. Minimum supported API version is %s, please upgrade your client to a newer version", api.MinSupportedAPIVersion),
|
|
},
|
|
{
|
|
reqVersion: "9999.9999",
|
|
errString: fmt.Sprintf("client version 9999.9999 is too new. Maximum supported API version is %s", api.DefaultVersion),
|
|
},
|
|
}
|
|
|
|
for _, test := range tests {
|
|
expectedVersion = test.expectedVersion
|
|
|
|
err := h(ctx, resp, req, map[string]string{"version": test.reqVersion})
|
|
|
|
if test.errString != "" {
|
|
assert.Check(t, is.Error(err, test.errString))
|
|
} else {
|
|
assert.Check(t, err)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestVersionMiddlewareWithErrorsReturnsHeaders(t *testing.T) {
|
|
handler := func(ctx context.Context, w http.ResponseWriter, r *http.Request, vars map[string]string) error {
|
|
v := httputils.VersionFromContext(ctx)
|
|
assert.Check(t, len(v) != 0)
|
|
return nil
|
|
}
|
|
|
|
m, err := NewVersionMiddleware("1.2.3", api.DefaultVersion, api.MinSupportedAPIVersion)
|
|
assert.NilError(t, err)
|
|
h := m.WrapHandler(handler)
|
|
|
|
req, _ := http.NewRequest(http.MethodGet, "/containers/json", nil)
|
|
resp := httptest.NewRecorder()
|
|
ctx := context.Background()
|
|
|
|
vars := map[string]string{"version": "0.1"}
|
|
err = h(ctx, resp, req, vars)
|
|
assert.Check(t, is.ErrorContains(err, ""))
|
|
|
|
hdr := resp.Result().Header
|
|
assert.Check(t, is.Contains(hdr.Get("Server"), "Docker/1.2.3"))
|
|
assert.Check(t, is.Contains(hdr.Get("Server"), runtime.GOOS))
|
|
assert.Check(t, is.Equal(hdr.Get("API-Version"), api.DefaultVersion))
|
|
assert.Check(t, is.Equal(hdr.Get("OSType"), runtime.GOOS))
|
|
}
|