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 testing_test
import (
"crypto/tls"
"crypto/x509"
"io/ioutil"
gc "launchpad.net/gocheck"
"net/http"
"net/url"
"reflect"
"testing"
jt "github.com/joyent/gocommon/testing"
"github.com/julienschmidt/httprouter"
)
type HTTPTestSuite struct {
jt.HTTPSuite
}
type HTTPSTestSuite struct {
jt.HTTPSuite
}
func Test(t *testing.T) {
gc.TestingT(t)
}
var _ = gc.Suite(&HTTPTestSuite{})
var _ = gc.Suite(&HTTPSTestSuite{jt.HTTPSuite{UseTLS: true}})
func HelloHandler(w http.ResponseWriter, r *http.Request, _ httprouter.Params) {
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.GET("/", HelloHandler)
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.GET("/", 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(reflect.TypeOf(err.(*url.Error).Err), gc.Equals, reflect.TypeOf(x509.UnknownAuthorityError{}))
// 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")
}
|