You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
184 lines
3.2 KiB
184 lines
3.2 KiB
// +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) |
|
}
|
|
|