2015-05-30 12:43:09 +00:00
|
|
|
package gin
|
|
|
|
|
|
|
|
import (
|
2015-05-31 13:55:10 +00:00
|
|
|
"html/template"
|
2015-05-30 12:43:09 +00:00
|
|
|
"net/http"
|
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
2015-06-04 10:50:52 +00:00
|
|
|
func newMockWriter() *mockWriter {
|
|
|
|
return &mockWriter{
|
|
|
|
http.Header{},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
type mockWriter struct {
|
|
|
|
headers http.Header
|
|
|
|
}
|
2015-05-30 12:43:09 +00:00
|
|
|
|
2015-06-04 10:50:52 +00:00
|
|
|
func (m *mockWriter) Header() (h http.Header) {
|
|
|
|
return m.headers
|
2015-05-30 12:43:09 +00:00
|
|
|
}
|
|
|
|
|
2015-06-04 10:50:52 +00:00
|
|
|
func (m *mockWriter) Write(p []byte) (n int, err error) {
|
|
|
|
return len(p), nil
|
2015-05-30 12:43:09 +00:00
|
|
|
}
|
|
|
|
|
2015-06-04 10:50:52 +00:00
|
|
|
func (m *mockWriter) WriteString(s string) (n int, err error) {
|
|
|
|
return len(s), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (m *mockWriter) WriteHeader(int) {}
|
|
|
|
|
2015-05-30 12:43:09 +00:00
|
|
|
func runRequest(B *testing.B, r *Engine, method, path string) {
|
|
|
|
// create fake request
|
|
|
|
req, err := http.NewRequest(method, path, nil)
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
2015-06-04 10:50:52 +00:00
|
|
|
w := newMockWriter()
|
2015-05-30 12:43:09 +00:00
|
|
|
B.ReportAllocs()
|
|
|
|
B.ResetTimer()
|
|
|
|
for i := 0; i < B.N; i++ {
|
|
|
|
r.ServeHTTP(w, req)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkOneRoute(B *testing.B) {
|
|
|
|
router := New()
|
|
|
|
router.GET("/ping", func(c *Context) {})
|
|
|
|
runRequest(B, router, "GET", "/ping")
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkManyHandlers(B *testing.B) {
|
2015-06-04 10:50:52 +00:00
|
|
|
DefaultWriter = newMockWriter()
|
2015-05-30 12:43:09 +00:00
|
|
|
//router := Default()
|
|
|
|
router := New()
|
2015-05-31 02:37:05 +00:00
|
|
|
router.Use(Recovery(), Logger())
|
2015-05-30 12:43:09 +00:00
|
|
|
router.Use(func(c *Context) {})
|
|
|
|
router.GET("/ping", func(c *Context) {})
|
|
|
|
runRequest(B, router, "GET", "/ping")
|
|
|
|
}
|
|
|
|
|
|
|
|
func Benchmark5Params(B *testing.B) {
|
2015-06-04 10:50:52 +00:00
|
|
|
DefaultWriter = newMockWriter()
|
2015-05-30 12:43:09 +00:00
|
|
|
router := New()
|
|
|
|
router.Use(func(c *Context) {})
|
|
|
|
router.GET("/param/:param1/:params2/:param3/:param4/:param5", func(c *Context) {})
|
|
|
|
runRequest(B, router, "GET", "/param/path/to/parameter/john/12345")
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkOneRouteJSON(B *testing.B) {
|
|
|
|
router := New()
|
2015-06-04 10:50:52 +00:00
|
|
|
data := struct {
|
|
|
|
Status string `json:"status"`
|
|
|
|
}{"ok"}
|
2015-05-30 12:43:09 +00:00
|
|
|
router.GET("/json", func(c *Context) {
|
2015-05-31 13:55:10 +00:00
|
|
|
c.JSON(200, data)
|
2015-05-30 12:43:09 +00:00
|
|
|
})
|
|
|
|
runRequest(B, router, "GET", "/json")
|
|
|
|
}
|
|
|
|
|
2015-05-31 13:55:10 +00:00
|
|
|
var htmlContentType = []string{"text/html; charset=utf-8"}
|
|
|
|
|
|
|
|
func BenchmarkOneRouteHTML(B *testing.B) {
|
|
|
|
router := New()
|
|
|
|
t := template.Must(template.New("index").Parse(`
|
|
|
|
<html><body><h1>{{.}}</h1></body></html>`))
|
|
|
|
router.SetHTMLTemplate(t)
|
|
|
|
|
|
|
|
router.GET("/html", func(c *Context) {
|
|
|
|
c.HTML(200, "index", "hola")
|
|
|
|
})
|
|
|
|
runRequest(B, router, "GET", "/html")
|
|
|
|
}
|
|
|
|
|
2015-05-30 12:43:09 +00:00
|
|
|
func BenchmarkOneRouteString(B *testing.B) {
|
|
|
|
router := New()
|
|
|
|
router.GET("/text", func(c *Context) {
|
|
|
|
c.String(200, "this is a plain text")
|
|
|
|
})
|
|
|
|
runRequest(B, router, "GET", "/text")
|
|
|
|
}
|
|
|
|
|
2015-06-04 10:50:52 +00:00
|
|
|
func BenchmarkManyRoutesFist(B *testing.B) {
|
|
|
|
router := New()
|
|
|
|
router.Any("/ping", func(c *Context) {})
|
|
|
|
runRequest(B, router, "GET", "/ping")
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkManyRoutesLast(B *testing.B) {
|
2015-05-30 12:43:09 +00:00
|
|
|
router := New()
|
|
|
|
router.Any("/ping", func(c *Context) {})
|
2015-06-04 10:50:52 +00:00
|
|
|
runRequest(B, router, "OPTIONS", "/ping")
|
2015-05-30 12:43:09 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func Benchmark404(B *testing.B) {
|
|
|
|
router := New()
|
|
|
|
router.Any("/something", func(c *Context) {})
|
|
|
|
router.NoRoute(func(c *Context) {})
|
|
|
|
runRequest(B, router, "GET", "/ping")
|
|
|
|
}
|
|
|
|
|
|
|
|
func Benchmark404Many(B *testing.B) {
|
|
|
|
router := New()
|
|
|
|
router.GET("/", func(c *Context) {})
|
|
|
|
router.GET("/path/to/something", func(c *Context) {})
|
|
|
|
router.GET("/post/:id", func(c *Context) {})
|
|
|
|
router.GET("/view/:id", func(c *Context) {})
|
|
|
|
router.GET("/favicon.ico", func(c *Context) {})
|
|
|
|
router.GET("/robots.txt", func(c *Context) {})
|
|
|
|
router.GET("/delete/:id", func(c *Context) {})
|
|
|
|
router.GET("/user/:id/:mode", func(c *Context) {})
|
|
|
|
|
|
|
|
router.NoRoute(func(c *Context) {})
|
|
|
|
runRequest(B, router, "GET", "/viewfake")
|
|
|
|
}
|