VictoriaMetrics/lib/stringsutil/less_natural_timing_test.go

60 lines
2 KiB
Go
Raw Permalink Normal View History

package stringsutil
import (
"testing"
)
func BenchmarkLessNatural(b *testing.B) {
b.Run("distinct_string_prefixes", func(b *testing.B) {
benchmarkLessNatural(b, []string{
"aaa", "bbb", "ccc", "ddd", "eee", "fff", "g", "hh", "kkk", "ooo", "ppppp", "wwww", "zzz", "qqq",
})
})
b.Run("distinct_numeric_values", func(b *testing.B) {
benchmarkLessNatural(b, []string{
"111", "222", "333", "44", "5555", "666", "7", "88", "999", "000", "123", "452", "34", "234",
})
})
b.Run("common_string_prefixes_distinct_string_suffixes", func(b *testing.B) {
benchmarkLessNatural(b, []string{
"XXXaaa", "XXXbbb", "XXXccc", "XXXddd", "XXXeee", "XXXfff", "XXXg", "XXXhh", "XXXkkk", "XXXooo", "XXXppppp", "XXXwwww", "XXXzzz", "XXXqqq",
})
})
b.Run("common_string_prefixes_distinct_numeric_suffixes", func(b *testing.B) {
benchmarkLessNatural(b, []string{
"XXX111", "XXX222", "XXX33", "XXX4", "XXX555", "XXX666", "XXX7", "XXX88", "XXX999", "XXX000", "XXX12345", "XXX3211", "XXX873", "XXX98",
})
})
b.Run("common_string_values", func(b *testing.B) {
benchmarkLessNatural(b, []string{
"XXXXX", "XXXXX", "XXXXX", "XXXXX", "XXXXX", "XXXXX", "XXXXX", "XXXXX", "XXXXX", "XXXXX", "XXXXX", "XXXXX", "XXXXX", "XXXXX",
})
})
b.Run("common_numeric_prefixes", func(b *testing.B) {
benchmarkLessNatural(b, []string{
"111aaa", "111bbb", "111ccc", "111ddd", "111eee", "111fff", "111g", "111hh", "111kkk", "111ooo", "111ppppp", "111wwww", "111zzz", "111qqq",
})
})
b.Run("common_numeric_values", func(b *testing.B) {
benchmarkLessNatural(b, []string{
"11111", "11111", "11111", "11111", "11111", "11111", "11111", "11111", "11111", "11111", "11111", "11111", "11111", "11111",
})
})
}
func benchmarkLessNatural(b *testing.B, a []string) {
b.ReportAllocs()
b.SetBytes(int64(len(a) - 1))
b.RunParallel(func(pb *testing.PB) {
n := uint64(0)
for pb.Next() {
for i := 1; i < len(a); i++ {
if LessNatural(a[i-1], a[i]) {
n++
}
}
}
GlobalSink.Add(n)
})
}