TUN-1956: Go 1.12 update
This commit is contained in:
parent
7c03e2cbd2
commit
3c0ea0db65
|
@ -1,4 +1,4 @@
|
||||||
pinned_go: &pinned_go go=1.11.5-1
|
pinned_go: &pinned_go go=1.12.7-1
|
||||||
build_dir: &build_dir /cfsetup_build/src/github.com/cloudflare/cloudflared/
|
build_dir: &build_dir /cfsetup_build/src/github.com/cloudflare/cloudflared/
|
||||||
default-flavor: stretch
|
default-flavor: stretch
|
||||||
stretch: &stretch
|
stretch: &stretch
|
||||||
|
|
|
@ -180,33 +180,6 @@ func TestValidateHTTPService_HTTP2HTTP(t *testing.T) {
|
||||||
}
|
}
|
||||||
panic("Shouldn't reach here")
|
panic("Shouldn't reach here")
|
||||||
})))
|
})))
|
||||||
|
|
||||||
// Integration-style test with a mock server
|
|
||||||
server, client, err := createMockServerAndClient(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
||||||
assert.Equal(t, hostname, r.Host)
|
|
||||||
w.WriteHeader(200)
|
|
||||||
}))
|
|
||||||
assert.NoError(t, err)
|
|
||||||
defer server.Close()
|
|
||||||
assert.Nil(t, ValidateHTTPService(originURL, hostname, client.Transport))
|
|
||||||
|
|
||||||
// this will fail if the client follows the 302
|
|
||||||
redirectServer, redirectClient, err := createMockServerAndClient(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
||||||
if r.URL.Path == "/followedRedirect" {
|
|
||||||
t.Fatal("shouldn't have followed the 302")
|
|
||||||
}
|
|
||||||
if r.Method == "CONNECT" {
|
|
||||||
assert.Equal(t, "127.0.0.1:443", r.Host)
|
|
||||||
} else {
|
|
||||||
assert.Equal(t, hostname, r.Host)
|
|
||||||
}
|
|
||||||
w.Header().Set("Location", "/followedRedirect")
|
|
||||||
w.WriteHeader(302)
|
|
||||||
}))
|
|
||||||
assert.NoError(t, err)
|
|
||||||
defer redirectServer.Close()
|
|
||||||
assert.Nil(t, ValidateHTTPService(originURL, hostname, redirectClient.Transport))
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Happy path 2: originURL is HTTPS, and HTTPS connections work
|
// Happy path 2: originURL is HTTPS, and HTTPS connections work
|
||||||
|
@ -235,36 +208,6 @@ func TestValidateHTTPService_HTTPS2HTTPS(t *testing.T) {
|
||||||
}
|
}
|
||||||
panic("Shouldn't reach here")
|
panic("Shouldn't reach here")
|
||||||
})))
|
})))
|
||||||
|
|
||||||
// Integration-style test with a mock server
|
|
||||||
server, client, err := createSecureMockServerAndClient(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
||||||
if r.Method == "CONNECT" {
|
|
||||||
assert.Equal(t, "127.0.0.1:443", r.Host)
|
|
||||||
} else {
|
|
||||||
assert.Equal(t, hostname, r.Host)
|
|
||||||
}
|
|
||||||
w.WriteHeader(200)
|
|
||||||
}))
|
|
||||||
assert.NoError(t, err)
|
|
||||||
defer server.Close()
|
|
||||||
assert.Nil(t, ValidateHTTPService(originURL, hostname, client.Transport))
|
|
||||||
|
|
||||||
// this will fail if the client follows the 302
|
|
||||||
redirectServer, redirectClient, err := createSecureMockServerAndClient(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
||||||
if r.URL.Path == "/followedRedirect" {
|
|
||||||
t.Fatal("shouldn't have followed the 302")
|
|
||||||
}
|
|
||||||
if r.Method == "CONNECT" {
|
|
||||||
assert.Equal(t, "127.0.0.1:443", r.Host)
|
|
||||||
} else {
|
|
||||||
assert.Equal(t, hostname, r.Host)
|
|
||||||
}
|
|
||||||
w.Header().Set("Location", "/followedRedirect")
|
|
||||||
w.WriteHeader(302)
|
|
||||||
}))
|
|
||||||
assert.NoError(t, err)
|
|
||||||
defer redirectServer.Close()
|
|
||||||
assert.Nil(t, ValidateHTTPService(originURL, hostname, redirectClient.Transport))
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Error path 1: originURL is HTTPS, but HTTP connections work
|
// Error path 1: originURL is HTTPS, but HTTP connections work
|
||||||
|
@ -293,37 +236,6 @@ func TestValidateHTTPService_HTTPS2HTTP(t *testing.T) {
|
||||||
}
|
}
|
||||||
panic("Shouldn't reach here")
|
panic("Shouldn't reach here")
|
||||||
})))
|
})))
|
||||||
|
|
||||||
// Integration-style test with a mock server
|
|
||||||
server, client, err := createMockServerAndClient(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
||||||
if r.Method == "CONNECT" {
|
|
||||||
assert.Equal(t, "127.0.0.1:1234", r.Host)
|
|
||||||
} else {
|
|
||||||
assert.Equal(t, hostname, r.Host)
|
|
||||||
}
|
|
||||||
w.WriteHeader(200)
|
|
||||||
}))
|
|
||||||
assert.NoError(t, err)
|
|
||||||
defer server.Close()
|
|
||||||
assert.Error(t, ValidateHTTPService(originURL, hostname, client.Transport))
|
|
||||||
|
|
||||||
// this will fail if the client follows the 302
|
|
||||||
redirectServer, redirectClient, err := createMockServerAndClient(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
|
||||||
if r.URL.Path == "/followedRedirect" {
|
|
||||||
t.Fatal("shouldn't have followed the 302")
|
|
||||||
}
|
|
||||||
if r.Method == "CONNECT" {
|
|
||||||
assert.Equal(t, "127.0.0.1:1234", r.Host)
|
|
||||||
} else {
|
|
||||||
assert.Equal(t, hostname, r.Host)
|
|
||||||
}
|
|
||||||
w.Header().Set("Location", "/followedRedirect")
|
|
||||||
w.WriteHeader(302)
|
|
||||||
}))
|
|
||||||
assert.NoError(t, err)
|
|
||||||
defer redirectServer.Close()
|
|
||||||
assert.Error(t, ValidateHTTPService(originURL, hostname, redirectClient.Transport))
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Error path 2: originURL is HTTP, but HTTPS connections work
|
// Error path 2: originURL is HTTP, but HTTPS connections work
|
||||||
|
@ -352,21 +264,11 @@ func TestValidateHTTPService_HTTP2HTTPS(t *testing.T) {
|
||||||
}
|
}
|
||||||
panic("Shouldn't reach here")
|
panic("Shouldn't reach here")
|
||||||
})))
|
})))
|
||||||
|
}
|
||||||
|
|
||||||
// Integration-style test with a mock server
|
// Ensure the client does not follow 302 responses
|
||||||
server, client, err := createSecureMockServerAndClient(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
func TestValidateHTTPService_NoFollowRedirects(t *testing.T) {
|
||||||
if r.Method == "CONNECT" {
|
hostname := "example.com"
|
||||||
assert.Equal(t, "127.0.0.1:1234", r.Host)
|
|
||||||
} else {
|
|
||||||
assert.Equal(t, hostname, r.Host)
|
|
||||||
}
|
|
||||||
w.WriteHeader(200)
|
|
||||||
}))
|
|
||||||
assert.NoError(t, err)
|
|
||||||
defer server.Close()
|
|
||||||
assert.Error(t, ValidateHTTPService(originURL, hostname, client.Transport))
|
|
||||||
|
|
||||||
// this will fail if the client follows the 302
|
|
||||||
redirectServer, redirectClient, err := createSecureMockServerAndClient(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
redirectServer, redirectClient, err := createSecureMockServerAndClient(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
||||||
if r.URL.Path == "/followedRedirect" {
|
if r.URL.Path == "/followedRedirect" {
|
||||||
t.Fatal("shouldn't have followed the 302")
|
t.Fatal("shouldn't have followed the 302")
|
||||||
|
@ -381,12 +283,12 @@ func TestValidateHTTPService_HTTP2HTTPS(t *testing.T) {
|
||||||
}))
|
}))
|
||||||
assert.NoError(t, err)
|
assert.NoError(t, err)
|
||||||
defer redirectServer.Close()
|
defer redirectServer.Close()
|
||||||
assert.Error(t, ValidateHTTPService(originURL, hostname, redirectClient.Transport))
|
assert.NoError(t, ValidateHTTPService(redirectServer.URL, hostname, redirectClient.Transport))
|
||||||
}
|
}
|
||||||
|
|
||||||
// error path 3: origin URL is nonresponsive
|
// Ensure validation times out when origin URL is nonresponsive
|
||||||
func TestValidateHTTPService_NonResponsiveOrigin(t *testing.T) {
|
func TestValidateHTTPService_NonResponsiveOrigin(t *testing.T) {
|
||||||
originURL := "https://127.0.0.1/"
|
originURL := "http://127.0.0.1/"
|
||||||
hostname := "example.com"
|
hostname := "example.com"
|
||||||
oldValidationTimeout := validationTimeout
|
oldValidationTimeout := validationTimeout
|
||||||
defer func() {
|
defer func() {
|
||||||
|
@ -394,7 +296,10 @@ func TestValidateHTTPService_NonResponsiveOrigin(t *testing.T) {
|
||||||
}()
|
}()
|
||||||
validationTimeout = 500 * time.Millisecond
|
validationTimeout = 500 * time.Millisecond
|
||||||
|
|
||||||
server, client, err := createSecureMockServerAndClient(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
// Use createMockServerAndClient, not createSecureMockServerAndClient.
|
||||||
|
// The latter will bail with HTTP 400 immediately on an http:// request,
|
||||||
|
// which defeats the purpose of a 'nonresponsive origin' test.
|
||||||
|
server, client, err := createMockServerAndClient(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
||||||
if r.Method == "CONNECT" {
|
if r.Method == "CONNECT" {
|
||||||
assert.Equal(t, "127.0.0.1:443", r.Host)
|
assert.Equal(t, "127.0.0.1:443", r.Host)
|
||||||
} else {
|
} else {
|
||||||
|
@ -409,6 +314,7 @@ func TestValidateHTTPService_NonResponsiveOrigin(t *testing.T) {
|
||||||
defer server.Close()
|
defer server.Close()
|
||||||
|
|
||||||
err = ValidateHTTPService(originURL, hostname, client.Transport)
|
err = ValidateHTTPService(originURL, hostname, client.Transport)
|
||||||
|
fmt.Println(err)
|
||||||
if err, ok := err.(net.Error); assert.True(t, ok) {
|
if err, ok := err.(net.Error); assert.True(t, ok) {
|
||||||
assert.True(t, err.Timeout())
|
assert.True(t, err.Timeout())
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue