1 回答

TA貢獻(xiàn)1777條經(jīng)驗 獲得超3個贊
首先,請注意 martini 框架不再像他們的README 中所說的那樣維護(hù)。
然后,關(guān)于您的問題,這是因為 Martini 做了一些對我來說看起來很糟糕的事情:它需要一個http.ResponseWriter并假設(shè)它也是一個http.CloseNotifier,而絕對不能保證這一點。他們應(yīng)該采用一個自定義界面來包裝它們,如下所示:
type ResponseWriterCloseNotifier interface {
http.ResponseWriter
http.CloseNotifier
}
您可以在他們的源代碼中看到他們在自己的測試中遇到了同樣的問題,并使用了一些解決方法:https : //github.com/go-martini/martini/commit/063dfcd8b0f64f4e2c97f0bc27fa422969baa23b#L13
這是一些用它制作的工作代碼:
package main
import (
"net/http"
"net/http/httptest"
"net/http/httputil"
"net/url"
"testing"
"github.com/go-martini/martini"
"github.com/stretchr/testify/assert"
)
type closeNotifyingRecorder struct {
*httptest.ResponseRecorder
closed chan bool
}
func newCloseNotifyingRecorder() *closeNotifyingRecorder {
return &closeNotifyingRecorder{
httptest.NewRecorder(),
make(chan bool, 1),
}
}
func (c *closeNotifyingRecorder) close() {
c.closed <- true
}
func (c *closeNotifyingRecorder) CloseNotify() <-chan bool {
return c.closed
}
func TestReverseProxy(t *testing.T) {
// Mock backend
backendResponse := "I am the backend"
backend := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
w.Write([]byte(backendResponse))
}))
defer backend.Close()
backendURL, _ := url.Parse(backend.URL)
// Frontend
m := martini.Classic()
m.Get("/", func(w http.ResponseWriter, r *http.Request) {
proxy := httputil.NewSingleHostReverseProxy(backendURL)
proxy.ServeHTTP(w, r)
})
// Testing
req, _ := http.NewRequest("GET", "/", nil)
res := newCloseNotifyingRecorder()
m.ServeHTTP(res, req)
assert.Equal(t, 200, res.Code, "should be equal")
}
- 1 回答
- 0 關(guān)注
- 197 瀏覽
添加回答
舉報