2019-03-25 18:56:56 +02:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/http"
|
|
|
|
"net/http/httptest"
|
2020-04-04 17:12:38 +02:00
|
|
|
"sync"
|
2019-03-25 18:56:56 +02:00
|
|
|
"testing"
|
2020-04-04 17:12:38 +02:00
|
|
|
"time"
|
2019-03-25 18:56:56 +02:00
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
2019-06-23 21:41:23 +02:00
|
|
|
const localhost = "127.0.0.1"
|
|
|
|
const host = "test-server"
|
|
|
|
|
2019-03-25 18:56:56 +02:00
|
|
|
func TestGCPHealthcheckLiveness(t *testing.T) {
|
|
|
|
handler := func(w http.ResponseWriter, req *http.Request) {
|
|
|
|
w.Write([]byte("test"))
|
|
|
|
}
|
|
|
|
|
|
|
|
h := gcpHealthcheck(http.HandlerFunc(handler))
|
|
|
|
rw := httptest.NewRecorder()
|
|
|
|
r, _ := http.NewRequest("GET", "/liveness_check", nil)
|
2019-06-23 21:41:23 +02:00
|
|
|
r.RemoteAddr = localhost
|
|
|
|
r.Host = host
|
2019-03-25 18:56:56 +02:00
|
|
|
h.ServeHTTP(rw, r)
|
|
|
|
|
|
|
|
assert.Equal(t, 200, rw.Code)
|
|
|
|
assert.Equal(t, "OK", rw.Body.String())
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGCPHealthcheckReadiness(t *testing.T) {
|
|
|
|
handler := func(w http.ResponseWriter, req *http.Request) {
|
|
|
|
w.Write([]byte("test"))
|
|
|
|
}
|
|
|
|
|
|
|
|
h := gcpHealthcheck(http.HandlerFunc(handler))
|
|
|
|
rw := httptest.NewRecorder()
|
|
|
|
r, _ := http.NewRequest("GET", "/readiness_check", nil)
|
2019-06-23 21:41:23 +02:00
|
|
|
r.RemoteAddr = localhost
|
|
|
|
r.Host = host
|
2019-03-25 18:56:56 +02:00
|
|
|
h.ServeHTTP(rw, r)
|
|
|
|
|
|
|
|
assert.Equal(t, 200, rw.Code)
|
|
|
|
assert.Equal(t, "OK", rw.Body.String())
|
|
|
|
}
|
|
|
|
|
2019-03-25 19:03:22 +02:00
|
|
|
func TestGCPHealthcheckNotHealthcheck(t *testing.T) {
|
2019-03-25 18:56:56 +02:00
|
|
|
handler := func(w http.ResponseWriter, req *http.Request) {
|
|
|
|
w.Write([]byte("test"))
|
|
|
|
}
|
|
|
|
|
|
|
|
h := gcpHealthcheck(http.HandlerFunc(handler))
|
|
|
|
rw := httptest.NewRecorder()
|
2019-03-25 19:10:07 +02:00
|
|
|
r, _ := http.NewRequest("GET", "/not_any_check", nil)
|
2019-06-23 21:41:23 +02:00
|
|
|
r.RemoteAddr = localhost
|
|
|
|
r.Host = host
|
2019-03-25 18:56:56 +02:00
|
|
|
h.ServeHTTP(rw, r)
|
|
|
|
|
2019-03-25 19:03:22 +02:00
|
|
|
assert.Equal(t, "test", rw.Body.String())
|
2019-03-25 18:56:56 +02:00
|
|
|
}
|
2019-03-25 19:32:29 +02:00
|
|
|
|
|
|
|
func TestGCPHealthcheckIngress(t *testing.T) {
|
|
|
|
handler := func(w http.ResponseWriter, req *http.Request) {
|
|
|
|
w.Write([]byte("test"))
|
|
|
|
}
|
|
|
|
|
|
|
|
h := gcpHealthcheck(http.HandlerFunc(handler))
|
|
|
|
rw := httptest.NewRecorder()
|
|
|
|
r, _ := http.NewRequest("GET", "/", nil)
|
2019-06-23 21:41:23 +02:00
|
|
|
r.RemoteAddr = localhost
|
|
|
|
r.Host = host
|
2019-03-25 19:32:29 +02:00
|
|
|
r.Header.Set(userAgentHeader, googleHealthCheckUserAgent)
|
|
|
|
h.ServeHTTP(rw, r)
|
|
|
|
|
|
|
|
assert.Equal(t, 200, rw.Code)
|
|
|
|
assert.Equal(t, "", rw.Body.String())
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGCPHealthcheckNotIngress(t *testing.T) {
|
|
|
|
handler := func(w http.ResponseWriter, req *http.Request) {
|
|
|
|
w.Write([]byte("test"))
|
|
|
|
}
|
|
|
|
|
|
|
|
h := gcpHealthcheck(http.HandlerFunc(handler))
|
|
|
|
rw := httptest.NewRecorder()
|
|
|
|
r, _ := http.NewRequest("GET", "/foo", nil)
|
2019-06-23 21:41:23 +02:00
|
|
|
r.RemoteAddr = localhost
|
|
|
|
r.Host = host
|
2019-03-25 19:32:29 +02:00
|
|
|
r.Header.Set(userAgentHeader, googleHealthCheckUserAgent)
|
|
|
|
h.ServeHTTP(rw, r)
|
|
|
|
|
|
|
|
assert.Equal(t, "test", rw.Body.String())
|
|
|
|
}
|
2019-03-25 19:47:30 +02:00
|
|
|
|
|
|
|
func TestGCPHealthcheckNotIngressPut(t *testing.T) {
|
|
|
|
handler := func(w http.ResponseWriter, req *http.Request) {
|
|
|
|
w.Write([]byte("test"))
|
|
|
|
}
|
|
|
|
|
|
|
|
h := gcpHealthcheck(http.HandlerFunc(handler))
|
|
|
|
rw := httptest.NewRecorder()
|
|
|
|
r, _ := http.NewRequest("PUT", "/", nil)
|
2019-06-23 21:41:23 +02:00
|
|
|
r.RemoteAddr = localhost
|
|
|
|
r.Host = host
|
2019-03-25 19:47:30 +02:00
|
|
|
r.Header.Set(userAgentHeader, googleHealthCheckUserAgent)
|
|
|
|
h.ServeHTTP(rw, r)
|
|
|
|
|
|
|
|
assert.Equal(t, "test", rw.Body.String())
|
|
|
|
}
|
2019-10-17 17:37:36 +02:00
|
|
|
|
|
|
|
func TestRedirectToHTTPSTrue(t *testing.T) {
|
|
|
|
opts := NewOptions()
|
|
|
|
opts.ForceHTTPS = true
|
|
|
|
handler := func(w http.ResponseWriter, req *http.Request) {
|
|
|
|
w.Write([]byte("test"))
|
|
|
|
}
|
|
|
|
|
|
|
|
h := redirectToHTTPS(opts, http.HandlerFunc(handler))
|
|
|
|
rw := httptest.NewRecorder()
|
|
|
|
r, _ := http.NewRequest("GET", "/", nil)
|
|
|
|
h.ServeHTTP(rw, r)
|
|
|
|
|
|
|
|
assert.Equal(t, http.StatusPermanentRedirect, rw.Code, "status code should be %d, got: %d", http.StatusPermanentRedirect, rw.Code)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestRedirectToHTTPSFalse(t *testing.T) {
|
|
|
|
opts := NewOptions()
|
|
|
|
handler := func(w http.ResponseWriter, req *http.Request) {
|
|
|
|
w.Write([]byte("test"))
|
|
|
|
}
|
|
|
|
|
|
|
|
h := redirectToHTTPS(opts, http.HandlerFunc(handler))
|
|
|
|
rw := httptest.NewRecorder()
|
|
|
|
r, _ := http.NewRequest("GET", "/", nil)
|
|
|
|
h.ServeHTTP(rw, r)
|
|
|
|
|
|
|
|
assert.Equal(t, http.StatusOK, rw.Code, "status code should be %d, got: %d", http.StatusOK, rw.Code)
|
|
|
|
}
|
2019-10-17 23:04:24 +02:00
|
|
|
|
|
|
|
func TestRedirectNotWhenHTTPS(t *testing.T) {
|
|
|
|
opts := NewOptions()
|
|
|
|
opts.ForceHTTPS = true
|
|
|
|
handler := func(w http.ResponseWriter, req *http.Request) {
|
|
|
|
w.Write([]byte("test"))
|
|
|
|
}
|
|
|
|
|
|
|
|
h := redirectToHTTPS(opts, http.HandlerFunc(handler))
|
|
|
|
s := httptest.NewTLSServer(h)
|
|
|
|
defer s.Close()
|
|
|
|
|
|
|
|
opts.HTTPSAddress = s.URL
|
|
|
|
client := s.Client()
|
|
|
|
res, err := client.Get(s.URL)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("request to test server failed with error: %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
assert.Equal(t, http.StatusOK, res.StatusCode, "status code should be %d, got: %d", http.StatusOK, res.StatusCode)
|
|
|
|
}
|
2020-04-04 17:12:38 +02:00
|
|
|
|
|
|
|
func TestGracefulShutdown(t *testing.T) {
|
|
|
|
opts := NewOptions()
|
|
|
|
stop := make(chan struct{}, 1)
|
|
|
|
srv := Server{Handler: http.DefaultServeMux, Opts: opts, stop: stop}
|
|
|
|
var wg sync.WaitGroup
|
|
|
|
wg.Add(1)
|
|
|
|
go func() {
|
|
|
|
defer wg.Done()
|
|
|
|
srv.ServeHTTP()
|
|
|
|
}()
|
|
|
|
|
|
|
|
stop <- struct{}{} // emulate catching signals
|
|
|
|
|
|
|
|
// An idiomatic for sync.WaitGroup with timeout
|
|
|
|
c := make(chan struct{})
|
|
|
|
go func() {
|
|
|
|
defer close(c)
|
|
|
|
wg.Wait()
|
|
|
|
}()
|
|
|
|
select {
|
|
|
|
case <-c:
|
|
|
|
case <-time.After(1 * time.Second):
|
|
|
|
t.Fatal("Server should return gracefully but timeout has occurred")
|
|
|
|
}
|
|
|
|
|
|
|
|
assert.Len(t, stop, 0) // check if stop chan is empty
|
|
|
|
}
|