1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
|
package httpsuite
import (
"crypto/tls"
"crypto/x509"
"errors"
"io/ioutil"
"net/http"
"testing"
gc "gopkg.in/check.v1"
)
type HTTPTestSuite struct {
HTTPSuite
}
type HTTPSTestSuite struct {
HTTPSuite
}
func Test(t *testing.T) {
gc.TestingT(t)
}
var _ = gc.Suite(&HTTPTestSuite{})
var _ = gc.Suite(&HTTPSTestSuite{HTTPSuite{UseTLS: true}})
type HelloHandler struct{}
func (h *HelloHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
w.Header().Set("Content-Type", "text/plain")
w.WriteHeader(200)
w.Write([]byte("Hello World\n"))
}
func (s *HTTPTestSuite) TestHelloWorld(c *gc.C) {
s.Mux.Handle("/", &HelloHandler{})
// fmt.Printf("Running HelloWorld\n")
response, err := http.Get(s.Server.URL)
c.Check(err, gc.IsNil)
content, err := ioutil.ReadAll(response.Body)
response.Body.Close()
c.Check(err, gc.IsNil)
c.Check(response.Status, gc.Equals, "200 OK")
c.Check(response.StatusCode, gc.Equals, 200)
c.Check(string(content), gc.Equals, "Hello World\n")
}
func (s *HTTPSTestSuite) TestHelloWorldWithTLS(c *gc.C) {
s.Mux.Handle("/", &HelloHandler{})
c.Check(s.Server.URL[:8], gc.Equals, "https://")
response, err := http.Get(s.Server.URL)
// Default http.Get fails because the cert is self-signed
c.Assert(err, gc.NotNil)
c.Assert(errors.As(err, &x509.UnknownAuthorityError{}), gc.Equals, true)
// Connect again with a Client that doesn't validate the cert
insecureClient := &http.Client{Transport: &http.Transport{
TLSClientConfig: &tls.Config{InsecureSkipVerify: true}}}
response, err = insecureClient.Get(s.Server.URL)
c.Assert(err, gc.IsNil)
content, err := ioutil.ReadAll(response.Body)
response.Body.Close()
c.Check(err, gc.IsNil)
c.Check(response.Status, gc.Equals, "200 OK")
c.Check(response.StatusCode, gc.Equals, 200)
c.Check(string(content), gc.Equals, "Hello World\n")
}
|