|
@@ -1,31 +1,42 @@
|
|
|
package gin
|
|
package gin
|
|
|
|
|
|
|
|
import (
|
|
import (
|
|
|
- "bytes"
|
|
|
|
|
"html/template"
|
|
"html/template"
|
|
|
"net/http"
|
|
"net/http"
|
|
|
- "net/http/httptest"
|
|
|
|
|
"testing"
|
|
"testing"
|
|
|
)
|
|
)
|
|
|
|
|
|
|
|
-type FakeWriter struct{}
|
|
|
|
|
|
|
+func newMockWriter() *mockWriter {
|
|
|
|
|
+ return &mockWriter{
|
|
|
|
|
+ http.Header{},
|
|
|
|
|
+ }
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+type mockWriter struct {
|
|
|
|
|
+ headers http.Header
|
|
|
|
|
+}
|
|
|
|
|
|
|
|
-func (_ FakeWriter) Write(d []byte) (int, error) {
|
|
|
|
|
- return 0, nil
|
|
|
|
|
|
|
+func (m *mockWriter) Header() (h http.Header) {
|
|
|
|
|
+ return m.headers
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
-func (_ FakeWriter) WriteString(d string) (int, error) {
|
|
|
|
|
- return 0, nil
|
|
|
|
|
|
|
+func (m *mockWriter) Write(p []byte) (n int, err error) {
|
|
|
|
|
+ return len(p), nil
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
+func (m *mockWriter) WriteString(s string) (n int, err error) {
|
|
|
|
|
+ return len(s), nil
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+func (m *mockWriter) WriteHeader(int) {}
|
|
|
|
|
+
|
|
|
func runRequest(B *testing.B, r *Engine, method, path string) {
|
|
func runRequest(B *testing.B, r *Engine, method, path string) {
|
|
|
// create fake request
|
|
// create fake request
|
|
|
req, err := http.NewRequest(method, path, nil)
|
|
req, err := http.NewRequest(method, path, nil)
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
panic(err)
|
|
panic(err)
|
|
|
}
|
|
}
|
|
|
- w := httptest.NewRecorder()
|
|
|
|
|
-
|
|
|
|
|
|
|
+ w := newMockWriter()
|
|
|
B.ReportAllocs()
|
|
B.ReportAllocs()
|
|
|
B.ResetTimer()
|
|
B.ResetTimer()
|
|
|
for i := 0; i < B.N; i++ {
|
|
for i := 0; i < B.N; i++ {
|
|
@@ -40,7 +51,7 @@ func BenchmarkOneRoute(B *testing.B) {
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkManyHandlers(B *testing.B) {
|
|
func BenchmarkManyHandlers(B *testing.B) {
|
|
|
- DefaultWriter = FakeWriter{}
|
|
|
|
|
|
|
+ DefaultWriter = newMockWriter()
|
|
|
//router := Default()
|
|
//router := Default()
|
|
|
router := New()
|
|
router := New()
|
|
|
router.Use(Recovery(), Logger())
|
|
router.Use(Recovery(), Logger())
|
|
@@ -50,7 +61,7 @@ func BenchmarkManyHandlers(B *testing.B) {
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
func Benchmark5Params(B *testing.B) {
|
|
func Benchmark5Params(B *testing.B) {
|
|
|
- DefaultWriter = new(bytes.Buffer)
|
|
|
|
|
|
|
+ DefaultWriter = newMockWriter()
|
|
|
router := New()
|
|
router := New()
|
|
|
router.Use(func(c *Context) {})
|
|
router.Use(func(c *Context) {})
|
|
|
router.GET("/param/:param1/:params2/:param3/:param4/:param5", func(c *Context) {})
|
|
router.GET("/param/:param1/:params2/:param3/:param4/:param5", func(c *Context) {})
|
|
@@ -59,9 +70,9 @@ func Benchmark5Params(B *testing.B) {
|
|
|
|
|
|
|
|
func BenchmarkOneRouteJSON(B *testing.B) {
|
|
func BenchmarkOneRouteJSON(B *testing.B) {
|
|
|
router := New()
|
|
router := New()
|
|
|
- data := H{
|
|
|
|
|
- "status": "ok",
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ data := struct {
|
|
|
|
|
+ Status string `json:"status"`
|
|
|
|
|
+ }{"ok"}
|
|
|
router.GET("/json", func(c *Context) {
|
|
router.GET("/json", func(c *Context) {
|
|
|
c.JSON(200, data)
|
|
c.JSON(200, data)
|
|
|
})
|
|
})
|
|
@@ -77,9 +88,6 @@ func BenchmarkOneRouteHTML(B *testing.B) {
|
|
|
router.SetHTMLTemplate(t)
|
|
router.SetHTMLTemplate(t)
|
|
|
|
|
|
|
|
router.GET("/html", func(c *Context) {
|
|
router.GET("/html", func(c *Context) {
|
|
|
- //c.Writer.Header()["Content-Type"] = htmlContentType
|
|
|
|
|
- //t.ExecuteTemplate(c.Writer, "index", "hola")
|
|
|
|
|
-
|
|
|
|
|
c.HTML(200, "index", "hola")
|
|
c.HTML(200, "index", "hola")
|
|
|
})
|
|
})
|
|
|
runRequest(B, router, "GET", "/html")
|
|
runRequest(B, router, "GET", "/html")
|
|
@@ -93,10 +101,16 @@ func BenchmarkOneRouteString(B *testing.B) {
|
|
|
runRequest(B, router, "GET", "/text")
|
|
runRequest(B, router, "GET", "/text")
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
-func BenchmarkManyRoutes(B *testing.B) {
|
|
|
|
|
|
|
+func BenchmarkManyRoutesFist(B *testing.B) {
|
|
|
|
|
+ router := New()
|
|
|
|
|
+ router.Any("/ping", func(c *Context) {})
|
|
|
|
|
+ runRequest(B, router, "GET", "/ping")
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+func BenchmarkManyRoutesLast(B *testing.B) {
|
|
|
router := New()
|
|
router := New()
|
|
|
router.Any("/ping", func(c *Context) {})
|
|
router.Any("/ping", func(c *Context) {})
|
|
|
- runRequest(B, router, "PUT", "/ping")
|
|
|
|
|
|
|
+ runRequest(B, router, "OPTIONS", "/ping")
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
func Benchmark404(B *testing.B) {
|
|
func Benchmark404(B *testing.B) {
|