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) }) }