mirror of https://github.com/helm/helm
parent
145d5e0c11
commit
db9ab4aa4d
@ -0,0 +1,65 @@
|
|||||||
|
package dm
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"io"
|
||||||
|
"net/http"
|
||||||
|
"net/http/httputil"
|
||||||
|
"os"
|
||||||
|
)
|
||||||
|
|
||||||
|
type debugTransport struct {
|
||||||
|
// Writer is the logging destination
|
||||||
|
Writer io.Writer
|
||||||
|
|
||||||
|
http.RoundTripper
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewDebugTransport(rt http.RoundTripper) http.RoundTripper {
|
||||||
|
return debugTransport{
|
||||||
|
RoundTripper: rt,
|
||||||
|
Writer: os.Stderr,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (tr debugTransport) CancelRequest(req *http.Request) {
|
||||||
|
type canceler interface {
|
||||||
|
CancelRequest(*http.Request)
|
||||||
|
}
|
||||||
|
if cr, ok := tr.transport().(canceler); ok {
|
||||||
|
cr.CancelRequest(req)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (tr debugTransport) RoundTrip(req *http.Request) (*http.Response, error) {
|
||||||
|
tr.logRequest(req)
|
||||||
|
resp, err := tr.transport().RoundTrip(req)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
tr.logResponse(resp)
|
||||||
|
return resp, err
|
||||||
|
}
|
||||||
|
|
||||||
|
func (tr debugTransport) transport() http.RoundTripper {
|
||||||
|
if tr.RoundTripper != nil {
|
||||||
|
return tr.RoundTripper
|
||||||
|
}
|
||||||
|
return http.DefaultTransport
|
||||||
|
}
|
||||||
|
|
||||||
|
func (tr debugTransport) logRequest(req *http.Request) {
|
||||||
|
dump, err := httputil.DumpRequestOut(req, true)
|
||||||
|
if err != nil {
|
||||||
|
fmt.Fprintf(tr.Writer, "%s: %s\n", "could not dump request", err)
|
||||||
|
}
|
||||||
|
fmt.Fprint(tr.Writer, string(dump))
|
||||||
|
}
|
||||||
|
|
||||||
|
func (tr debugTransport) logResponse(resp *http.Response) {
|
||||||
|
dump, err := httputil.DumpResponse(resp, true)
|
||||||
|
if err != nil {
|
||||||
|
fmt.Fprintf(tr.Writer, "%s: %s\n", "could not dump response", err)
|
||||||
|
}
|
||||||
|
fmt.Fprint(tr.Writer, string(dump))
|
||||||
|
}
|
@ -0,0 +1,49 @@
|
|||||||
|
package dm
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bytes"
|
||||||
|
"net/http"
|
||||||
|
"net/http/httptest"
|
||||||
|
"strings"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestDebugTransport(t *testing.T) {
|
||||||
|
handler := func(w http.ResponseWriter, req *http.Request) {
|
||||||
|
w.Header().Set("Content-Type", "application/json")
|
||||||
|
w.WriteHeader(http.StatusOK)
|
||||||
|
w.Write([]byte(`{"status":"awesome"}`))
|
||||||
|
}
|
||||||
|
|
||||||
|
server := httptest.NewServer(http.HandlerFunc(handler))
|
||||||
|
defer server.Close()
|
||||||
|
|
||||||
|
var output bytes.Buffer
|
||||||
|
|
||||||
|
client := &http.Client{
|
||||||
|
Transport: debugTransport{
|
||||||
|
Writer: &output,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
_, err := client.Get(server.URL)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err.Error())
|
||||||
|
}
|
||||||
|
|
||||||
|
expected := []string{
|
||||||
|
"GET / HTTP/1.1",
|
||||||
|
"Accept-Encoding: gzip",
|
||||||
|
"HTTP/1.1 200 OK",
|
||||||
|
"Content-Length: 20",
|
||||||
|
"Content-Type: application/json",
|
||||||
|
`{"status":"awesome"}`,
|
||||||
|
}
|
||||||
|
actual := output.String()
|
||||||
|
|
||||||
|
for _, match := range expected {
|
||||||
|
if !strings.Contains(actual, match) {
|
||||||
|
t.Errorf("Expected %s to contain %s", actual, match)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in new issue