z_all_bench_test.go 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248
  1. // Copyright (c) 2012-2018 Ugorji Nwoke. All rights reserved.
  2. // Use of this source code is governed by a MIT license found in the LICENSE file.
  3. // +build alltests codecgen
  4. // +build go1.7
  5. package codec
  6. // see notes in z_all_test.go
  7. import (
  8. "strconv"
  9. "sync"
  10. "testing"
  11. "time"
  12. )
  13. import . "github.com/ugorji/go/codec"
  14. var benchmarkGroupOnce sync.Once
  15. var benchmarkGroupSave struct {
  16. testUseIoEncDec int
  17. testUseReset bool
  18. benchDepth int
  19. benchMapStringKeyOnly bool
  20. benchInitDebug bool
  21. benchVerify bool
  22. benchDoInitBench bool
  23. benchUnscientificRes bool
  24. }
  25. func benchmarkGroupInitAll() {
  26. testInitAll() // calls flag.Parse
  27. benchmarkGroupSave.testUseIoEncDec = testUseIoEncDec
  28. benchmarkGroupSave.testUseReset = testUseReset
  29. benchmarkGroupSave.benchDepth = benchDepth
  30. benchmarkGroupSave.benchMapStringKeyOnly = benchMapStringKeyOnly
  31. benchmarkGroupSave.benchInitDebug = benchInitDebug
  32. benchmarkGroupSave.benchVerify = benchVerify
  33. benchmarkGroupSave.benchDoInitBench = benchDoInitBench
  34. benchmarkGroupSave.benchUnscientificRes = benchUnscientificRes
  35. }
  36. func benchmarkGroupReset() {
  37. testUseIoEncDec = benchmarkGroupSave.testUseIoEncDec
  38. testUseReset = benchmarkGroupSave.testUseReset
  39. benchDepth = benchmarkGroupSave.benchDepth
  40. benchMapStringKeyOnly = benchmarkGroupSave.benchMapStringKeyOnly
  41. benchInitDebug = benchmarkGroupSave.benchInitDebug
  42. benchVerify = benchmarkGroupSave.benchVerify
  43. benchDoInitBench = benchmarkGroupSave.benchDoInitBench
  44. benchUnscientificRes = benchmarkGroupSave.benchUnscientificRes
  45. }
  46. func benchmarkDivider() {
  47. // logTv(nil, "-------------------------------\n")
  48. println()
  49. }
  50. func benchmarkOneFn(fns []func(*testing.B)) func(*testing.B) {
  51. switch len(fns) {
  52. case 0:
  53. return nil
  54. case 1:
  55. return fns[0]
  56. default:
  57. return func(t *testing.B) {
  58. for _, f := range fns {
  59. f(t)
  60. }
  61. }
  62. }
  63. }
  64. func benchmarkSuiteNoop(b *testing.B) {
  65. testOnce.Do(testInitAll)
  66. b.ResetTimer()
  67. for i := 0; i < b.N; i++ {
  68. time.Sleep(10 * time.Millisecond)
  69. }
  70. }
  71. func benchmarkSuite(t *testing.B, fns ...func(t *testing.B)) {
  72. benchmarkGroupOnce.Do(benchmarkGroupInitAll)
  73. f := benchmarkOneFn(fns)
  74. // find . -name "*_test.go" | xargs grep -e 'flag.' | cut -d '&' -f 2 | cut -d ',' -f 1 | grep -e '^bench'
  75. testReinit() // so flag.Parse() is called first, and never called again
  76. benchReinit()
  77. testDecodeOptions = DecodeOptions{}
  78. testEncodeOptions = EncodeOptions{}
  79. benchmarkGroupReset()
  80. benchVerify = true
  81. benchDoInitBench = true
  82. benchUnscientificRes = true
  83. testReinit()
  84. benchReinit()
  85. t.Run("init-metrics....", func(t *testing.B) { t.Run("Benchmark__Noop.............", benchmarkSuiteNoop) })
  86. benchmarkGroupReset()
  87. benchVerify = false
  88. benchDoInitBench = false
  89. benchUnscientificRes = false
  90. testReinit()
  91. benchReinit()
  92. t.Run("options-false...", f)
  93. benchmarkGroupReset()
  94. testUseIoEncDec = 1024
  95. testReinit()
  96. benchReinit()
  97. t.Run("use-bufio-!bytes", f)
  98. benchmarkGroupReset()
  99. testUseReset = true
  100. testReinit()
  101. benchReinit()
  102. t.Run("reset-enc-dec...", f)
  103. benchmarkGroupReset()
  104. // benchVerify is kinda lame - serves no real purpose.
  105. // benchVerify = true
  106. // testReinit()
  107. // benchReinit()
  108. // t.Run("verify-on-decode", f)
  109. // benchVerify = false
  110. }
  111. func benchmarkVeryQuickSuite(t *testing.B, name string, fns ...func(t *testing.B)) {
  112. benchmarkDivider()
  113. benchmarkGroupOnce.Do(benchmarkGroupInitAll)
  114. benchmarkGroupReset()
  115. // bd=1 2 | ti=-1, 1024 |
  116. testUseIoEncDec = -1
  117. // benchDepth = depth
  118. testReinit()
  119. benchReinit()
  120. t.Run(name+"-bd"+strconv.Itoa(benchDepth)+"........", benchmarkOneFn(fns))
  121. benchmarkGroupReset()
  122. }
  123. func benchmarkQuickSuite(t *testing.B, name string, fns ...func(t *testing.B)) {
  124. benchmarkVeryQuickSuite(t, name, fns...)
  125. // encoded size of TestStruc is between 20K and 30K for bd=1 // consider buffer=1024 * 16 * benchDepth
  126. testUseIoEncDec = 1024 // (value of defEncByteBufSize): use smaller buffer, and more flushes - it's ok.
  127. // benchDepth = depth
  128. testReinit()
  129. benchReinit()
  130. t.Run(name+"-bd"+strconv.Itoa(benchDepth)+"-buf"+strconv.Itoa(testUseIoEncDec), benchmarkOneFn(fns))
  131. testUseIoEncDec = 0
  132. // benchDepth = depth
  133. testReinit()
  134. benchReinit()
  135. t.Run(name+"-bd"+strconv.Itoa(benchDepth)+"-io.....", benchmarkOneFn(fns))
  136. benchmarkGroupReset()
  137. }
  138. /*
  139. z='bench_test.go'
  140. find . -name "$z" | xargs grep -e '^func Benchmark.*Encode' | \
  141. cut -d '(' -f 1 | cut -d ' ' -f 2 | \
  142. while read f; do echo "t.Run(\"$f\", $f)"; done &&
  143. echo &&
  144. find . -name "$z" | xargs grep -e '^func Benchmark.*Decode' | \
  145. cut -d '(' -f 1 | cut -d ' ' -f 2 | \
  146. while read f; do echo "t.Run(\"$f\", $f)"; done
  147. */
  148. func benchmarkCodecGroup(t *testing.B) {
  149. benchmarkDivider()
  150. t.Run("Benchmark__Msgpack____Encode", Benchmark__Msgpack____Encode)
  151. t.Run("Benchmark__Binc_______Encode", Benchmark__Binc_______Encode)
  152. t.Run("Benchmark__Simple_____Encode", Benchmark__Simple_____Encode)
  153. t.Run("Benchmark__Cbor_______Encode", Benchmark__Cbor_______Encode)
  154. t.Run("Benchmark__Json_______Encode", Benchmark__Json_______Encode)
  155. t.Run("Benchmark__Std_Json___Encode", Benchmark__Std_Json___Encode)
  156. t.Run("Benchmark__Gob________Encode", Benchmark__Gob________Encode)
  157. // t.Run("Benchmark__Std_Xml____Encode", Benchmark__Std_Xml____Encode)
  158. benchmarkDivider()
  159. t.Run("Benchmark__Msgpack____Decode", Benchmark__Msgpack____Decode)
  160. t.Run("Benchmark__Binc_______Decode", Benchmark__Binc_______Decode)
  161. t.Run("Benchmark__Simple_____Decode", Benchmark__Simple_____Decode)
  162. t.Run("Benchmark__Cbor_______Decode", Benchmark__Cbor_______Decode)
  163. t.Run("Benchmark__Json_______Decode", Benchmark__Json_______Decode)
  164. t.Run("Benchmark__Std_Json___Decode", Benchmark__Std_Json___Decode)
  165. t.Run("Benchmark__Gob________Decode", Benchmark__Gob________Decode)
  166. // t.Run("Benchmark__Std_Xml____Decode", Benchmark__Std_Xml____Decode)
  167. }
  168. func BenchmarkCodecSuite(t *testing.B) { benchmarkSuite(t, benchmarkCodecGroup) }
  169. func benchmarkJsonEncodeGroup(t *testing.B) {
  170. t.Run("Benchmark__Json_______Encode", Benchmark__Json_______Encode)
  171. }
  172. func benchmarkJsonDecodeGroup(t *testing.B) {
  173. t.Run("Benchmark__Json_______Decode", Benchmark__Json_______Decode)
  174. }
  175. func benchmarkCborEncodeGroup(t *testing.B) {
  176. t.Run("Benchmark__Cbor_______Encode", Benchmark__Cbor_______Encode)
  177. }
  178. func benchmarkCborDecodeGroup(t *testing.B) {
  179. t.Run("Benchmark__Cbor_______Decode", Benchmark__Cbor_______Decode)
  180. }
  181. func BenchmarkCodecQuickSuite(t *testing.B) {
  182. benchmarkQuickSuite(t, "cbor", benchmarkCborEncodeGroup)
  183. benchmarkQuickSuite(t, "cbor", benchmarkCborDecodeGroup)
  184. benchmarkQuickSuite(t, "json", benchmarkJsonEncodeGroup)
  185. benchmarkQuickSuite(t, "json", benchmarkJsonDecodeGroup)
  186. // depths := [...]int{1, 4}
  187. // for _, d := range depths {
  188. // benchmarkQuickSuite(t, d, benchmarkJsonEncodeGroup)
  189. // benchmarkQuickSuite(t, d, benchmarkJsonDecodeGroup)
  190. // }
  191. // benchmarkQuickSuite(t, 1, benchmarkJsonEncodeGroup)
  192. // benchmarkQuickSuite(t, 4, benchmarkJsonEncodeGroup)
  193. // benchmarkQuickSuite(t, 1, benchmarkJsonDecodeGroup)
  194. // benchmarkQuickSuite(t, 4, benchmarkJsonDecodeGroup)
  195. // benchmarkQuickSuite(t, 1, benchmarkJsonEncodeGroup, benchmarkJsonDecodeGroup)
  196. // benchmarkQuickSuite(t, 4, benchmarkJsonEncodeGroup, benchmarkJsonDecodeGroup)
  197. // benchmarkQuickSuite(t, benchmarkJsonEncodeGroup)
  198. // benchmarkQuickSuite(t, benchmarkJsonDecodeGroup)
  199. }