integration-cli/docker_api_test.go
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)
 	}
 }