mirror of
https://github.com/ceph/ceph-csi.git
synced 2024-11-27 16:50:23 +00:00
185 lines
3.2 KiB
Go
185 lines
3.2 KiB
Go
// +build use_easyjson
|
|
|
|
package benchmark
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/mailru/easyjson"
|
|
"github.com/mailru/easyjson/jwriter"
|
|
)
|
|
|
|
func BenchmarkEJ_Unmarshal_M(b *testing.B) {
|
|
b.SetBytes(int64(len(largeStructText)))
|
|
for i := 0; i < b.N; i++ {
|
|
var s LargeStruct
|
|
err := s.UnmarshalJSON(largeStructText)
|
|
if err != nil {
|
|
b.Error(err)
|
|
}
|
|
}
|
|
}
|
|
|
|
func BenchmarkEJ_Unmarshal_S(b *testing.B) {
|
|
b.SetBytes(int64(len(smallStructText)))
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
var s Entities
|
|
err := s.UnmarshalJSON(smallStructText)
|
|
if err != nil {
|
|
b.Error(err)
|
|
}
|
|
}
|
|
}
|
|
|
|
func BenchmarkEJ_Marshal_M(b *testing.B) {
|
|
var l int64
|
|
for i := 0; i < b.N; i++ {
|
|
data, err := easyjson.Marshal(&largeStructData)
|
|
if err != nil {
|
|
b.Error(err)
|
|
}
|
|
l = int64(len(data))
|
|
}
|
|
b.SetBytes(l)
|
|
}
|
|
|
|
func BenchmarkEJ_Marshal_L(b *testing.B) {
|
|
var l int64
|
|
for i := 0; i < b.N; i++ {
|
|
data, err := easyjson.Marshal(&xlStructData)
|
|
if err != nil {
|
|
b.Error(err)
|
|
}
|
|
l = int64(len(data))
|
|
}
|
|
b.SetBytes(l)
|
|
}
|
|
|
|
func BenchmarkEJ_Marshal_L_ToWriter(b *testing.B) {
|
|
var l int64
|
|
out := &DummyWriter{}
|
|
for i := 0; i < b.N; i++ {
|
|
w := jwriter.Writer{}
|
|
xlStructData.MarshalEasyJSON(&w)
|
|
if w.Error != nil {
|
|
b.Error(w.Error)
|
|
}
|
|
|
|
l = int64(w.Size())
|
|
w.DumpTo(out)
|
|
}
|
|
b.SetBytes(l)
|
|
|
|
}
|
|
func BenchmarkEJ_Marshal_M_Parallel(b *testing.B) {
|
|
b.SetBytes(int64(len(largeStructText)))
|
|
|
|
b.RunParallel(func(pb *testing.PB) {
|
|
for pb.Next() {
|
|
_, err := largeStructData.MarshalJSON()
|
|
if err != nil {
|
|
b.Error(err)
|
|
}
|
|
}
|
|
})
|
|
}
|
|
|
|
func BenchmarkEJ_Marshal_M_ToWriter(b *testing.B) {
|
|
var l int64
|
|
out := &DummyWriter{}
|
|
for i := 0; i < b.N; i++ {
|
|
w := jwriter.Writer{}
|
|
largeStructData.MarshalEasyJSON(&w)
|
|
if w.Error != nil {
|
|
b.Error(w.Error)
|
|
}
|
|
|
|
l = int64(w.Size())
|
|
w.DumpTo(out)
|
|
}
|
|
b.SetBytes(l)
|
|
|
|
}
|
|
func BenchmarkEJ_Marshal_M_ToWriter_Parallel(b *testing.B) {
|
|
out := &DummyWriter{}
|
|
|
|
b.RunParallel(func(pb *testing.PB) {
|
|
var l int64
|
|
for pb.Next() {
|
|
w := jwriter.Writer{}
|
|
largeStructData.MarshalEasyJSON(&w)
|
|
if w.Error != nil {
|
|
b.Error(w.Error)
|
|
}
|
|
|
|
l = int64(w.Size())
|
|
w.DumpTo(out)
|
|
}
|
|
if l > 0 {
|
|
b.SetBytes(l)
|
|
}
|
|
})
|
|
|
|
}
|
|
|
|
func BenchmarkEJ_Marshal_L_Parallel(b *testing.B) {
|
|
var l int64
|
|
b.RunParallel(func(pb *testing.PB) {
|
|
for pb.Next() {
|
|
data, err := xlStructData.MarshalJSON()
|
|
if err != nil {
|
|
b.Error(err)
|
|
}
|
|
l = int64(len(data))
|
|
}
|
|
})
|
|
b.SetBytes(l)
|
|
}
|
|
|
|
func BenchmarkEJ_Marshal_L_ToWriter_Parallel(b *testing.B) {
|
|
out := &DummyWriter{}
|
|
b.RunParallel(func(pb *testing.PB) {
|
|
var l int64
|
|
for pb.Next() {
|
|
w := jwriter.Writer{}
|
|
|
|
xlStructData.MarshalEasyJSON(&w)
|
|
if w.Error != nil {
|
|
b.Error(w.Error)
|
|
}
|
|
l = int64(w.Size())
|
|
w.DumpTo(out)
|
|
}
|
|
if l > 0 {
|
|
b.SetBytes(l)
|
|
}
|
|
})
|
|
}
|
|
|
|
func BenchmarkEJ_Marshal_S(b *testing.B) {
|
|
var l int64
|
|
for i := 0; i < b.N; i++ {
|
|
data, err := smallStructData.MarshalJSON()
|
|
if err != nil {
|
|
b.Error(err)
|
|
}
|
|
l = int64(len(data))
|
|
}
|
|
b.SetBytes(l)
|
|
}
|
|
|
|
func BenchmarkEJ_Marshal_S_Parallel(b *testing.B) {
|
|
var l int64
|
|
b.RunParallel(func(pb *testing.PB) {
|
|
for pb.Next() {
|
|
data, err := smallStructData.MarshalJSON()
|
|
if err != nil {
|
|
b.Error(err)
|
|
}
|
|
l = int64(len(data))
|
|
}
|
|
})
|
|
b.SetBytes(l)
|
|
}
|