12345678910111213141516171819202122232425262728293031 |
- package tango
- import (
- "bytes"
- "net/http"
- "net/http/httptest"
- "testing"
- "os"
- )
- func TestRecovery(t *testing.T) {
- buff := bytes.NewBufferString("")
- recorder := httptest.NewRecorder()
- recorder.Body = buff
- n := NewWithLog(NewLogger(os.Stdout))
- n.Use(Recovery(true))
- n.UseHandler(http.HandlerFunc(func(res http.ResponseWriter, req *http.Request) {
- panic("here is a panic!")
- }))
- req, err := http.NewRequest("GET", "http://localhost:8000/", nil)
- if err != nil {
- t.Error(err)
- }
- n.ServeHTTP(recorder, req)
- expect(t, recorder.Code, http.StatusInternalServerError)
- refute(t, recorder.Body.Len(), 0)
- refute(t, len(buff.String()), 0)
- }
|