f7e417ea |
package main
import ( |
fe6b88e3 |
"fmt" |
f7e417ea |
"net/http" |
6287ec90 |
"net/http/httptest" |
7fcf8497 |
"net/http/httputil" |
6287ec90 |
"os/exec" |
910322a8 |
"strconv"
"strings" |
7fcf8497 |
"time" |
f7e417ea |
|
910322a8 |
"github.com/docker/docker/api" |
710817a7 |
"github.com/docker/docker/pkg/integration/checker" |
f7e417ea |
"github.com/go-check/check"
)
func (s *DockerSuite) TestApiOptionsRoute(c *check.C) {
status, _, err := sockRequest("OPTIONS", "/", nil) |
710817a7 |
c.Assert(err, checker.IsNil)
c.Assert(status, checker.Equals, http.StatusOK) |
f7e417ea |
}
func (s *DockerSuite) TestApiGetEnabledCors(c *check.C) {
res, body, err := sockRequestRaw("GET", "/version", nil, "") |
710817a7 |
c.Assert(err, checker.IsNil)
c.Assert(res.StatusCode, checker.Equals, http.StatusOK) |
18faf6f9 |
body.Close() |
f7e417ea |
// TODO: @runcom incomplete tests, why old integration tests had this headers
// and here none of the headers below are in the response?
//c.Log(res.Header)
//c.Assert(res.Header.Get("Access-Control-Allow-Origin"), check.Equals, "*")
//c.Assert(res.Header.Get("Access-Control-Allow-Headers"), check.Equals, "Origin, X-Requested-With, Content-Type, Accept, X-Registry-Auth")
} |
7fcf8497 |
|
910322a8 |
func (s *DockerSuite) TestApiVersionStatusCode(c *check.C) { |
7fcf8497 |
conn, err := sockConn(time.Duration(10 * time.Second)) |
710817a7 |
c.Assert(err, checker.IsNil) |
7fcf8497 |
client := httputil.NewClientConn(conn, nil)
defer client.Close()
req, err := http.NewRequest("GET", "/v999.0/version", nil) |
710817a7 |
c.Assert(err, checker.IsNil) |
543cf79f |
req.Header.Set("User-Agent", "Docker-Client/999.0 (os)") |
7fcf8497 |
res, err := client.Do(req) |
710817a7 |
c.Assert(res.StatusCode, checker.Equals, http.StatusBadRequest) |
7fcf8497 |
} |
910322a8 |
func (s *DockerSuite) TestApiClientVersionNewerThanServer(c *check.C) { |
278e7580 |
v := strings.Split(api.DefaultVersion.String(), ".") |
910322a8 |
vMinInt, err := strconv.Atoi(v[1]) |
710817a7 |
c.Assert(err, checker.IsNil) |
910322a8 |
vMinInt++
v[1] = strconv.Itoa(vMinInt)
version := strings.Join(v, ".")
status, body, err := sockRequest("GET", "/v"+version+"/version", nil) |
710817a7 |
c.Assert(err, checker.IsNil)
c.Assert(status, checker.Equals, http.StatusBadRequest) |
fe6b88e3 |
expected := fmt.Sprintf("client is newer than server (client API version: %s, server API version: %s)", version, api.DefaultVersion)
c.Assert(strings.TrimSpace(string(body)), checker.Equals, expected) |
910322a8 |
}
func (s *DockerSuite) TestApiClientVersionOldNotSupported(c *check.C) { |
278e7580 |
v := strings.Split(api.MinVersion.String(), ".") |
910322a8 |
vMinInt, err := strconv.Atoi(v[1]) |
710817a7 |
c.Assert(err, checker.IsNil) |
910322a8 |
vMinInt--
v[1] = strconv.Itoa(vMinInt)
version := strings.Join(v, ".")
status, body, err := sockRequest("GET", "/v"+version+"/version", nil) |
710817a7 |
c.Assert(err, checker.IsNil)
c.Assert(status, checker.Equals, http.StatusBadRequest) |
fe6b88e3 |
expected := fmt.Sprintf("client version %s is too old. Minimum supported API version is %s, please upgrade your client to a newer version", version, api.MinVersion)
c.Assert(strings.TrimSpace(string(body)), checker.Equals, expected) |
910322a8 |
} |
6287ec90 |
func (s *DockerSuite) TestApiDockerApiVersion(c *check.C) {
var svrVersion string
server := httptest.NewServer(http.HandlerFunc(
func(w http.ResponseWriter, r *http.Request) {
url := r.URL.Path
svrVersion = url
}))
defer server.Close()
// Test using the env var first
cmd := exec.Command(dockerBinary, "-H="+server.URL[7:], "version") |
f4a1e3db |
cmd.Env = appendBaseEnv(false, "DOCKER_API_VERSION=xxx") |
6287ec90 |
out, _, _ := runCommandWithOutput(cmd)
c.Assert(svrVersion, check.Equals, "/vxxx/version")
if !strings.Contains(out, "API version: xxx") {
c.Fatalf("Out didn't have 'xxx' for the API version, had:\n%s", out)
}
} |