-
Notifications
You must be signed in to change notification settings - Fork 51
/
Copy pathtransform_test.go
115 lines (99 loc) · 2.56 KB
/
transform_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
package stl4go
import (
"strconv"
"testing"
)
var (
emptyInts = []int{}
)
func Test_Copy(t *testing.T) {
a := []int{1, 2, 3, 4}
b := Copy(a)
expectTrue(t, Equal(a, b))
}
func Test_Transform(t *testing.T) {
a := Range(0, 100)
Transform(a, func(v int) int { return v * v })
for i, v := range a {
expectEq(t, v, i*i)
}
}
func Test_TransformTo(t *testing.T) {
a := Range(0, 100)
b := make([]string, len(a))
TransformTo(a, func(v int) string { return strconv.Itoa(v) }, b)
for i, v := range a {
expectEq(t, b[i], strconv.Itoa(v))
}
expectPanic(t, func() {
c := make([]string, len(a)-1)
TransformTo(a, func(v int) string { return strconv.Itoa(v) }, c)
})
}
func Test_TransformCopy(t *testing.T) {
a := Range(0, 100)
b := TransformCopy(a, func(v int) string { return strconv.Itoa(v) })
for i, v := range b {
expectEq(t, v, strconv.Itoa(i))
}
}
func Test_Unique(t *testing.T) {
expectTrue(t, Equal(Unique(emptyInts), emptyInts))
a := []int{1, 2, 2, 3, 2, 4}
b := []int{1, 2, 3, 2, 4}
expectTrue(t, Equal(Unique(a), b))
expectTrue(t, Equal(Unique(a[:len(b)]), b))
}
func Test_UniqueCopy(t *testing.T) {
expectTrue(t, Equal(UniqueCopy(emptyInts), emptyInts))
a := []int{1, 2, 2, 3, 2, 4}
a1 := append([]int{}, a...)
b := []int{1, 2, 3, 2, 4}
expectTrue(t, Equal(UniqueCopy(a), b))
expectTrue(t, Equal(a, a1))
}
func Test_Remove(t *testing.T) {
a := []int{1, 2, 2, 3, 2, 4}
b := Remove(a, 2)
expectTrue(t, Equal([]int{1, 3, 4}, b))
expectTrue(t, Equal([]int{1, 3, 4}, a[:len(b)]))
}
func Test_RemoveCopy(t *testing.T) {
a := []int{1, 2, 2, 3, 2, 4}
a1 := []int{1, 2, 2, 3, 2, 4}
b := RemoveCopy(a, 2)
expectTrue(t, Equal([]int{1, 3, 4}, b))
expectTrue(t, Equal(a1, a))
}
func Test_RemoveIf(t *testing.T) {
a := []int{1, 2, 2, 3, 2, 4}
b := RemoveIf(a, func(v int) bool { return v == 2 })
expectTrue(t, Equal([]int{1, 3, 4}, b))
expectTrue(t, Equal([]int{1, 3, 4}, a[:len(b)]))
}
func Test_RemoveIfCopy(t *testing.T) {
a := []int{1, 2, 2, 3, 2, 4}
a1 := []int{1, 2, 2, 3, 2, 4}
b := RemoveIfCopy(a, func(v int) bool { return v == 2 })
expectTrue(t, Equal([]int{1, 3, 4}, b))
expectTrue(t, Equal(a1, a))
}
func Test_Shuffle(t *testing.T) {
a := []int{1, 2, 3, 4, 5, 6}
Shuffle(a)
}
func Test_Reverse(t *testing.T) {
a := []int{1, 2, 3, 4}
Reverse(a)
expectTrue(t, Equal(a, []int{4, 3, 2, 1}))
}
func Test_Reverse_Odd(t *testing.T) {
a := []int{1, 2, 3, 4, 5}
Reverse(a)
expectTrue(t, Equal(a, []int{5, 4, 3, 2, 1}))
}
func Test_ReverseCopy(t *testing.T) {
a := []int{1, 2, 3, 4, 5}
b := ReverseCopy(a)
expectTrue(t, Equal(b, []int{5, 4, 3, 2, 1}))
}