-
Notifications
You must be signed in to change notification settings - Fork 225
/
Copy pathexcept_test.go
31 lines (25 loc) · 1005 Bytes
/
except_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
package linq
import "testing"
func TestExcept(t *testing.T) {
input1 := []int{1, 2, 3, 4, 5, 1, 2, 5}
input2 := []int{1, 2}
want := []interface{}{3, 4, 5, 5}
if q := From(input1).Except(From(input2)); !validateQuery(q, want) {
t.Errorf("From(%v).Except(%v)=%v expected %v", input1, input2, toSlice(q), want)
}
}
func TestExceptBy(t *testing.T) {
input1 := []int{1, 2, 3, 4, 5, 1, 2, 5}
input2 := []int{1}
want := []interface{}{2, 4, 2}
if q := From(input1).ExceptBy(From(input2), func(i interface{}) interface{} {
return i.(int) % 2
}); !validateQuery(q, want) {
t.Errorf("From(%v).ExceptBy(%v)=%v expected %v", input1, input2, toSlice(q), want)
}
}
func TestExceptByT_PanicWhenSelectorFnIsInvalid(t *testing.T) {
mustPanicWithError(t, "ExceptByT: parameter [selectorFn] has a invalid function signature. Expected: 'func(T)T', actual: 'func(int,int)int'", func() {
From([]int{1, 1, 1, 2, 1, 2, 3, 4, 2}).ExceptByT(From([]int{1}), func(x, item int) int { return item + 2 })
})
}