-
Notifications
You must be signed in to change notification settings - Fork 4
/
mapper_test.go
101 lines (78 loc) · 2.39 KB
/
mapper_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
package goterator_test
import (
"strings"
"testing"
"github.com/stretchr/testify/assert"
"github.com/yaa110/goterator"
"github.com/yaa110/goterator/generator"
)
func TestMap(t *testing.T) {
assert := assert.New(t)
elements := []interface{}{0, 1, 2, 3, 4, 5}
generator := generator.NewSlice(elements)
doubled := goterator.New(generator).Map(func(e interface{}) interface{} {
return e.(int) * 2
}).Collect()
assert.Equal([]interface{}{0, 2, 4, 6, 8, 10}, doubled)
}
func TestFilter(t *testing.T) {
assert := assert.New(t)
elements := []interface{}{0, 1, 2, 3, 4, 5}
generator := generator.NewSlice(elements)
odds := goterator.New(generator).Filter(func(e interface{}) bool {
return e.(int)%2 != 0
}).Collect()
assert.Equal([]interface{}{1, 3, 5}, odds)
}
func TestTake(t *testing.T) {
assert := assert.New(t)
elements := []interface{}{0, 1, 2, 3, 4, 5}
generator := generator.NewSlice(elements)
odds := goterator.New(generator).Take(3).Collect()
assert.Equal([]interface{}{0, 1, 2}, odds)
}
func TestSkip(t *testing.T) {
assert := assert.New(t)
elements := []interface{}{0, 1, 2, 3, 4, 5}
generator := generator.NewSlice(elements)
odds := goterator.New(generator).Skip(3).Collect()
assert.Equal([]interface{}{3, 4, 5}, odds)
}
func TestSkipWhile(t *testing.T) {
assert := assert.New(t)
elements := []interface{}{0, 1, 2, 3, 2, 5}
generator := generator.NewSlice(elements)
values := goterator.New(generator).SkipWhile(func(e interface{}) bool {
return e.(int) < 3
}).Collect()
assert.Equal([]interface{}{3, 2, 5}, values)
}
func TestTakeWhile(t *testing.T) {
assert := assert.New(t)
elements := []interface{}{0, 1, 2, 3, 2, 5}
generator := generator.NewSlice(elements)
values := goterator.New(generator).TakeWhile(func(e interface{}) bool {
return e.(int) < 3
}).Collect()
assert.Equal([]interface{}{0, 1, 2}, values)
}
func TestChain(t *testing.T) {
assert := assert.New(t)
elements := []interface{}{"test1", "word", "TeSt2", "WorD", "TEST3", "WORD", "Test4", "Word"}
generator := generator.NewSlice(elements)
values := goterator.New(generator).
Map(func(e interface{}) interface{} {
return strings.ToLower(e.(string))
}).
Filter(func(s interface{}) bool {
return s.(string) != "word"
}).
Take(3).
Map(func(e interface{}) interface{} {
return strings.ToUpper(e.(string))
}).
Skip(1).
Take(1).
Collect()
assert.Equal([]interface{}{"TEST2"}, values)
}