generated from moul/golang-repo-template
-
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathslice_test.go
140 lines (126 loc) · 2.75 KB
/
slice_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
package u_test
import (
"fmt"
"math/rand"
"strconv"
"testing"
"moul.io/u"
)
func ExampleUniqueStrings() {
fmt.Println(u.UniqueStrings([]string{"foo", "bar", "foo", "baz", "foo", "bar", "foobar", "baz", "foobaz"}))
// Output: [foo bar baz foobar foobaz]
}
func ExampleUniqueInts() {
fmt.Println(u.UniqueInts([]int{13, 51, 36, 69, 92, 92, 42, 21, 36, 13, 51}))
// Output: [13 51 36 69 92 42 21]
}
func ExampleUniqueInterfaces() {
fmt.Println(u.UniqueInterfaces([]interface{}{13, "foo", "bar", 42, 13, 43, "baz"}))
// Output: [13 foo bar 42 43 baz]
}
func BenchmarkUniqueStrings(b *testing.B) {
cases := []struct {
Name string
Data []string
}{
{"slice1", []string{"foofoo", "barbar", "foo", "bazbaz", "foo", "bar", "foobar", "baz", "foobaz"}},
{"slice2", bigSliceOfString()},
}
for _, bc := range cases {
b.Run(bc.Name, func(b *testing.B) {
b.ResetTimer()
for i := 0; i < b.N; i++ {
u.UniqueStrings(bc.Data)
}
})
b.Run(bc.Name+"-parallel", func(b *testing.B) {
b.ResetTimer()
b.RunParallel(func(pb *testing.PB) {
for pb.Next() {
u.UniqueStrings(bc.Data)
}
})
})
}
}
func BenchmarkUniqueInts(b *testing.B) {
cases := []struct {
Name string
Data []int
}{
{"slice1", []int{4, 5, 2, 6, 7, 7, 2, 4, 2, 1, 1, 2, 3, 4}},
{"slice2", bigSliceOfInt()},
}
for _, bc := range cases {
b.Run(bc.Name, func(b *testing.B) {
b.ResetTimer()
for i := 0; i < b.N; i++ {
u.UniqueInts(bc.Data)
}
})
b.Run(bc.Name+"-parallel", func(b *testing.B) {
b.ResetTimer()
b.RunParallel(func(pb *testing.PB) {
for pb.Next() {
u.UniqueInts(bc.Data)
}
})
})
}
}
func BenchmarkUniqueInterfaces(b *testing.B) {
cases := []struct {
Name string
Data []interface{}
}{
{"slice1", []interface{}{1, 2, 2, 1, 3, 4, "foo", "bar", "foo", "foo", "barfoo"}},
{"slice2", bigSliceOfInterface()},
}
for _, bc := range cases {
b.Run(bc.Name, func(b *testing.B) {
b.ResetTimer()
for i := 0; i < b.N; i++ {
u.UniqueInterfaces(bc.Data)
}
})
b.Run(bc.Name+"-parallel", func(b *testing.B) {
b.ResetTimer()
b.RunParallel(func(pb *testing.PB) {
for pb.Next() {
u.UniqueInterfaces(bc.Data)
}
})
})
}
}
func bigSliceOfInt() []int {
var ns []int
rand.Seed(42)
for i := 0; i < 1000; i++ {
nb := rand.Intn(500)
ns = append(ns, nb)
}
return ns
}
func bigSliceOfString() []string {
var ss []string
rand.Seed(42)
for i := 0; i < 1000; i++ {
rn := rand.Intn(500)
ss = append(ss, strconv.Itoa(rn))
}
return ss
}
func bigSliceOfInterface() []interface{} {
var is []interface{}
rand.Seed(42)
for i := 0; i < 1000; i++ {
nb := rand.Intn(500)
is = append(is, nb)
}
for i := 0; i < 1000; i++ {
rn := rand.Intn(500)
is = append(is, strconv.Itoa(rn))
}
return is
}