2016-01-12 14:06:59 +03:00
|
|
|
package match
|
|
|
|
|
|
|
|
import (
|
|
|
|
"reflect"
|
|
|
|
"testing"
|
2016-02-23 14:46:20 +03:00
|
|
|
"unicode/utf8"
|
2016-01-12 14:06:59 +03:00
|
|
|
)
|
|
|
|
|
2016-02-02 22:03:37 +03:00
|
|
|
var bench_separators = []rune{'.'}
|
|
|
|
|
2016-01-18 13:07:28 +03:00
|
|
|
const bench_pattern = "abcdefghijklmnopqrstuvwxyz0123456789"
|
|
|
|
|
2016-02-02 22:03:37 +03:00
|
|
|
func TestAppendMerge(t *testing.T) {
|
2016-01-12 14:06:59 +03:00
|
|
|
for id, test := range []struct {
|
2016-02-02 22:03:37 +03:00
|
|
|
segments [2][]int
|
2016-01-12 14:06:59 +03:00
|
|
|
exp []int
|
|
|
|
}{
|
|
|
|
{
|
2016-02-02 22:03:37 +03:00
|
|
|
[2][]int{
|
2016-01-12 14:06:59 +03:00
|
|
|
[]int{0, 6, 7},
|
|
|
|
[]int{0, 1, 3},
|
|
|
|
},
|
2016-02-02 22:03:37 +03:00
|
|
|
[]int{0, 1, 3, 6, 7},
|
2016-01-12 14:06:59 +03:00
|
|
|
},
|
|
|
|
{
|
2016-02-02 22:03:37 +03:00
|
|
|
[2][]int{
|
2016-01-12 14:06:59 +03:00
|
|
|
[]int{0, 1, 3, 6, 7},
|
2016-02-02 22:03:37 +03:00
|
|
|
[]int{0, 1, 10},
|
2016-01-12 14:06:59 +03:00
|
|
|
},
|
2016-02-02 22:03:37 +03:00
|
|
|
[]int{0, 1, 3, 6, 7, 10},
|
2016-01-12 14:06:59 +03:00
|
|
|
},
|
|
|
|
} {
|
2016-02-02 22:03:37 +03:00
|
|
|
act := appendMerge(test.segments[0], test.segments[1])
|
2016-01-12 14:06:59 +03:00
|
|
|
if !reflect.DeepEqual(act, test.exp) {
|
|
|
|
t.Errorf("#%d merge sort segments unexpected:\nact: %v\nexp:%v", id, act, test.exp)
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-02-02 22:03:37 +03:00
|
|
|
|
|
|
|
func BenchmarkAppendMerge(b *testing.B) {
|
|
|
|
s1 := []int{0, 1, 3, 6, 7}
|
|
|
|
s2 := []int{0, 1, 3}
|
|
|
|
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
|
|
appendMerge(s1, s2)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkAppendMergeParallel(b *testing.B) {
|
|
|
|
s1 := []int{0, 1, 3, 6, 7}
|
|
|
|
s2 := []int{0, 1, 3}
|
|
|
|
|
|
|
|
b.RunParallel(func(pb *testing.PB) {
|
|
|
|
for pb.Next() {
|
|
|
|
appendMerge(s1, s2)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkReverse(b *testing.B) {
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
|
|
reverseSegments([]int{1, 2, 3, 4})
|
|
|
|
}
|
|
|
|
}
|
2016-02-23 14:46:20 +03:00
|
|
|
|
|
|
|
func getTable() []int {
|
|
|
|
table := make([]int, utf8.MaxRune+1)
|
|
|
|
for i := 0; i <= utf8.MaxRune; i++ {
|
|
|
|
table[i] = utf8.RuneLen(rune(i))
|
|
|
|
}
|
|
|
|
|
|
|
|
return table
|
|
|
|
}
|
|
|
|
|
|
|
|
var table = getTable()
|
|
|
|
|
|
|
|
const runeToLen = 'q'
|
|
|
|
|
|
|
|
func BenchmarkRuneLenFromTable(b *testing.B) {
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
|
|
_ = table[runeToLen]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func BenchmarkRuneLenFromUTF8(b *testing.B) {
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
|
|
_ = utf8.RuneLen(runeToLen)
|
|
|
|
}
|
|
|
|
}
|