forked from go-zoo/bone
-
Notifications
You must be signed in to change notification settings - Fork 0
/
bone_bench_test.go
113 lines (92 loc) · 2.68 KB
/
bone_bench_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
package bone
import (
"net/http"
"net/http/httptest"
"testing"
"github.com/daryl/zeus"
"github.com/gorilla/mux"
"github.com/gorilla/pat"
"github.com/julienschmidt/httprouter"
)
// Test the ns/op
func BenchmarkBoneMux(b *testing.B) {
request, _ := http.NewRequest("GET", "/sd", nil)
response := httptest.NewRecorder()
muxx := New()
muxx.Get("/", http.HandlerFunc(Bench))
muxx.Post("/a", http.HandlerFunc(Bench))
muxx.Get("/aas", http.HandlerFunc(Bench))
muxx.Get("/aasr", http.HandlerFunc(Bench))
muxx.Get("/sd", http.HandlerFunc(Bench))
muxx.Get("/sd/:p", http.HandlerFunc(Bench))
for n := 0; n < b.N; n++ {
muxx.ServeHTTP(response, request)
}
}
// Test daryl/zeus ns/op
func BenchmarkZeusMux(b *testing.B) {
request, _ := http.NewRequest("GET", "/aas", nil)
response := httptest.NewRecorder()
muxx := zeus.New()
muxx.GET("/", Bench)
muxx.POST("/a", Bench)
muxx.GET("/aas", Bench)
muxx.GET("/sd/:p", Bench)
for n := 0; n < b.N; n++ {
muxx.ServeHTTP(response, request)
}
}
// Test httprouter ns/op
func BenchmarkHttpRouterMux(b *testing.B) {
request, _ := http.NewRequest("GET", "/aas", nil)
response := httptest.NewRecorder()
muxx := httprouter.New()
muxx.Handler("GET", "/", http.HandlerFunc(Bench))
muxx.Handler("POST", "/a", http.HandlerFunc(Bench))
muxx.Handler("GET", "/aas", http.HandlerFunc(Bench))
for n := 0; n < b.N; n++ {
muxx.ServeHTTP(response, request)
}
}
// Test net/http ns/op
func BenchmarkNetHttpMux(b *testing.B) {
request, _ := http.NewRequest("GET", "/", nil)
response := httptest.NewRecorder()
muxx := http.NewServeMux()
muxx.HandleFunc("/", Bench)
for n := 0; n < b.N; n++ {
muxx.ServeHTTP(response, request)
}
}
// Test gorilla/mux ns/op
func BenchmarkGorillaMux(b *testing.B) {
request, _ := http.NewRequest("GET", "/", nil)
response := httptest.NewRecorder()
muxx := mux.NewRouter()
muxx.Handle("/", http.HandlerFunc(Bench))
for n := 0; n < b.N; n++ {
muxx.ServeHTTP(response, request)
}
}
// Test gorilla/pat ns/op
func BenchmarkGorillaPatMux(b *testing.B) {
request, _ := http.NewRequest("GET", "/", nil)
response := httptest.NewRecorder()
muxx := pat.New()
muxx.Get("/", Bench)
for n := 0; n < b.N; n++ {
muxx.ServeHTTP(response, request)
}
}
func Bench(rw http.ResponseWriter, req *http.Request) {
rw.Write([]byte("b"))
}
/* ### Result ###
BenchmarkBoneMux 10000000 118 ns/op
BenchmarkZeusMux 100000 54813 ns/op
BenchmarkHttpRouterMux 10000000 143 ns/op
BenchmarkNetHttpMux 3000000 548 ns/op
BenchmarkGorillaMux 300000 3333 ns/op
BenchmarkGorillaPatMux 1000000 1889 ns/op
ok github.com/squiidz/bone 14.084s
*/