transfer.sh/vendor/github.com/google/martian/martianlog/logger_test.go

137 lines
3.5 KiB
Go
Raw Normal View History

2019-03-17 20:19:56 +01:00
// Copyright 2015 Google Inc. All rights reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package martianlog
import (
"bytes"
"compress/gzip"
"fmt"
"net/http"
"strings"
"testing"
"github.com/google/martian"
"github.com/google/martian/parse"
"github.com/google/martian/proxyutil"
)
func ExampleLogger() {
l := NewLogger()
l.SetLogFunc(func(line string) {
// Remove \r to make it easier to test with examples.
fmt.Print(strings.Replace(line, "\r", "", -1))
})
l.SetDecode(true)
buf := new(bytes.Buffer)
gw := gzip.NewWriter(buf)
gw.Write([]byte("request content"))
gw.Close()
req, err := http.NewRequest("GET", "http://example.com/path?querystring", buf)
if err != nil {
fmt.Println(err)
return
}
req.TransferEncoding = []string{"chunked"}
req.Header.Set("Content-Encoding", "gzip")
_, remove, err := martian.TestContext(req, nil, nil)
if err != nil {
fmt.Println(err)
return
}
defer remove()
if err := l.ModifyRequest(req); err != nil {
fmt.Println(err)
return
}
res := proxyutil.NewResponse(200, strings.NewReader("response content"), req)
res.ContentLength = 16
res.Header.Set("Date", "Tue, 15 Nov 1994 08:12:31 GMT")
res.Header.Set("Other-Header", "values")
if err := l.ModifyResponse(res); err != nil {
fmt.Println(err)
return
}
// Output:
// --------------------------------------------------------------------------------
// Request to http://example.com/path?querystring
// --------------------------------------------------------------------------------
// GET http://example.com/path?querystring HTTP/1.1
// Host: example.com
// Transfer-Encoding: chunked
// Content-Encoding: gzip
//
// request content
//
// --------------------------------------------------------------------------------
//
// --------------------------------------------------------------------------------
// Response from http://example.com/path?querystring
// --------------------------------------------------------------------------------
// HTTP/1.1 200 OK
// Content-Length: 16
// Date: Tue, 15 Nov 1994 08:12:31 GMT
// Other-Header: values
//
// response content
// --------------------------------------------------------------------------------
}
func TestLoggerFromJSON(t *testing.T) {
msg := []byte(`{
"log.Logger": {
"scope": ["request", "response"],
"headersOnly": true,
"decode": true
}
}`)
r, err := parse.FromJSON(msg)
if err != nil {
t.Fatalf("parse.FromJSON(): got %v, want no error", err)
}
reqmod := r.RequestModifier()
if reqmod == nil {
t.Fatal("r.RequestModifier(): got nil, want not nil")
}
if _, ok := reqmod.(*Logger); !ok {
t.Error("reqmod.(*Logger): got !ok, want ok")
}
resmod := r.ResponseModifier()
if resmod == nil {
t.Fatal("r.ResponseModifier(): got nil, want not nil")
}
l, ok := resmod.(*Logger)
if !ok {
t.Error("resmod.(*Logger); got !ok, want ok")
}
if !l.headersOnly {
t.Error("l.headersOnly: got false, want true")
}
if !l.decode {
t.Error("l.decode: got false, want true")
}
}