2017-11-15 06:51:15 -06:00
|
|
|
package middleware
|
|
|
|
|
|
|
|
import (
|
|
|
|
"path/filepath"
|
|
|
|
"testing"
|
|
|
|
|
2018-03-06 16:59:45 -06:00
|
|
|
ms "github.com/go-macaron/session"
|
2017-11-15 06:51:15 -06:00
|
|
|
"github.com/grafana/grafana/pkg/bus"
|
2018-03-06 16:59:45 -06:00
|
|
|
m "github.com/grafana/grafana/pkg/models"
|
|
|
|
"github.com/grafana/grafana/pkg/services/session"
|
2017-11-15 06:51:15 -06:00
|
|
|
. "github.com/smartystreets/goconvey/convey"
|
|
|
|
"gopkg.in/macaron.v1"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestRecoveryMiddleware(t *testing.T) {
|
|
|
|
Convey("Given an api route that panics", t, func() {
|
2018-03-22 06:37:35 -05:00
|
|
|
apiURL := "/api/whatever"
|
|
|
|
recoveryScenario("recovery middleware should return json", apiURL, func(sc *scenarioContext) {
|
2017-11-15 06:51:15 -06:00
|
|
|
sc.handlerFunc = PanicHandler
|
2018-03-22 06:37:35 -05:00
|
|
|
sc.fakeReq("GET", apiURL).exec()
|
2017-11-15 06:51:15 -06:00
|
|
|
sc.req.Header.Add("content-type", "application/json")
|
|
|
|
|
|
|
|
So(sc.resp.Code, ShouldEqual, 500)
|
|
|
|
So(sc.respJson["message"], ShouldStartWith, "Internal Server Error - Check the Grafana server logs for the detailed error message.")
|
|
|
|
So(sc.respJson["error"], ShouldStartWith, "Server Error")
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
Convey("Given a non-api route that panics", t, func() {
|
2018-03-22 06:37:35 -05:00
|
|
|
apiURL := "/whatever"
|
|
|
|
recoveryScenario("recovery middleware should return html", apiURL, func(sc *scenarioContext) {
|
2017-11-15 06:51:15 -06:00
|
|
|
sc.handlerFunc = PanicHandler
|
2018-03-22 06:37:35 -05:00
|
|
|
sc.fakeReq("GET", apiURL).exec()
|
2017-11-15 06:51:15 -06:00
|
|
|
|
|
|
|
So(sc.resp.Code, ShouldEqual, 500)
|
|
|
|
So(sc.resp.Header().Get("content-type"), ShouldEqual, "text/html; charset=UTF-8")
|
|
|
|
So(sc.resp.Body.String(), ShouldContainSubstring, "<title>Grafana - Error</title>")
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2018-03-07 10:54:50 -06:00
|
|
|
func PanicHandler(c *m.ReqContext) {
|
2017-11-15 06:51:15 -06:00
|
|
|
panic("Handler has panicked")
|
|
|
|
}
|
|
|
|
|
|
|
|
func recoveryScenario(desc string, url string, fn scenarioFunc) {
|
|
|
|
Convey(desc, func() {
|
|
|
|
defer bus.ClearBusHandlers()
|
|
|
|
|
|
|
|
sc := &scenarioContext{
|
|
|
|
url: url,
|
|
|
|
}
|
|
|
|
viewsPath, _ := filepath.Abs("../../public/views")
|
|
|
|
|
|
|
|
sc.m = macaron.New()
|
|
|
|
sc.m.Use(Recovery())
|
|
|
|
|
|
|
|
sc.m.Use(macaron.Renderer(macaron.RenderOptions{
|
|
|
|
Directory: viewsPath,
|
|
|
|
Delims: macaron.Delims{Left: "[[", Right: "]]"},
|
|
|
|
}))
|
|
|
|
|
|
|
|
sc.m.Use(GetContextHandler())
|
|
|
|
// mock out gc goroutine
|
2018-03-06 16:59:45 -06:00
|
|
|
session.StartSessionGC = func() {}
|
2018-03-15 15:23:33 -05:00
|
|
|
sc.m.Use(Sessioner(&ms.Options{}, 0))
|
2017-11-15 06:51:15 -06:00
|
|
|
sc.m.Use(OrgRedirect())
|
|
|
|
sc.m.Use(AddDefaultResponseHeaders())
|
|
|
|
|
2018-03-07 10:54:50 -06:00
|
|
|
sc.defaultHandler = func(c *m.ReqContext) {
|
2017-11-15 06:51:15 -06:00
|
|
|
sc.context = c
|
|
|
|
if sc.handlerFunc != nil {
|
|
|
|
sc.handlerFunc(sc.context)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
sc.m.Get(url, sc.defaultHandler)
|
|
|
|
|
|
|
|
fn(sc)
|
|
|
|
})
|
|
|
|
}
|