-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathuniq_test.go
76 lines (51 loc) · 1.88 KB
/
uniq_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
package ranges
import "testing"
func TestUniq(t *testing.T) {
t.Parallel()
result := Slice(Uniq(Only(4, 1, 2, 2, 3, 4, 4, 5), Eq[int]))
assertEqual(t, result, []int{4, 1, 2, 3, 4, 5})
}
func TestUniqF(t *testing.T) {
t.Parallel()
result := SliceF(UniqF(Only(4, 1, 2, 2, 3, 4, 4, 5), Eq[int]))
assertEqual(t, result, []int{4, 1, 2, 3, 4, 5})
assertHasSaveableFront(t, UniqF(Only(4, 1), Eq[int]), 4)
}
func TestUniqS(t *testing.T) {
t.Parallel()
result := SliceB(UniqS([]int{4, 1, 2, 2, 3, 4, 4, 5}, Eq[int]))
assertEqual(t, result, []int{4, 1, 2, 3, 4, 5})
}
func TestUniqComparable(t *testing.T) {
t.Parallel()
result := Slice(UniqComparable(Only(4, 1, 2, 2, 3, 4, 4, 5)))
assertEqual(t, result, []int{4, 1, 2, 3, 4, 5})
}
func TestUniqComparableF(t *testing.T) {
t.Parallel()
result := SliceF(UniqComparableF(Only(4, 1, 2, 2, 3, 4, 4, 5)))
assertEqual(t, result, []int{4, 1, 2, 3, 4, 5})
assertHasSaveableFront(t, UniqComparableF(Only(4, 1)), 4)
}
func TestUniqComparableB(t *testing.T) {
t.Parallel()
result := SliceB(UniqComparableB(Only(4, 1, 2, 2, 3, 4, 4, 5)))
assertEqual(t, result, []int{4, 1, 2, 3, 4, 5})
result2 := SliceB(Retro(UniqComparableB(Only(4, 1, 2, 2, 3, 4, 4, 5))))
assertEqual(t, result2, []int{5, 4, 3, 2, 1, 4})
assertHasSaveableFront(t, UniqComparableB(Only(4, 1)), 4)
assertHasSaveableBack(t, UniqComparableB(Only(4, 1)), 1)
}
func TestUniqComparableS(t *testing.T) {
t.Parallel()
result := SliceB(UniqComparableS([]int{4, 1, 2, 2, 3, 4, 4, 5}))
assertEqual(t, result, []int{4, 1, 2, 3, 4, 5})
}
// Check that we use cb(front, Front()) and cb(Back(), back) for iterations.
func TestUniqBConsistentOrdering(t *testing.T) {
t.Parallel()
result := SliceB(UniqB(Only(1, 2, 3, 4, 5, 6, 7, 8), Le[int]))
assertEqual(t, result, []int{1})
result2 := SliceB(Retro(UniqB(Only(1, 2, 3, 4, 5, 6, 7, 8), Le[int])))
assertEqual(t, result2, []int{8})
}