wp-go/stream/simpleStream_test.go

338 lines
6.4 KiB
Go
Raw Normal View History

package stream
import (
"fmt"
"github/fthvgb1/wp-go/helper"
"reflect"
"testing"
)
var s = NewSimpleSliceStream(helper.RangeSlice(1, 10, 1))
func TestSimpleSliceStream_Filter(t *testing.T) {
type args[T int] struct {
fn func(T) bool
}
type testCase[T int] struct {
name string
r SimpleSliceStream[T]
args args[T]
want SimpleSliceStream[T]
}
tests := []testCase[int]{
{
name: "t1",
r: s,
args: args[int]{
func(t int) (r bool) {
if t > 5 {
r = true
}
return
},
},
want: SimpleSliceStream[int]{helper.RangeSlice(6, 10, 1)},
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := tt.r.Filter(tt.args.fn); !reflect.DeepEqual(got, tt.want) {
t.Errorf("Filter() = %v, want %v", got, tt.want)
}
})
}
}
func TestSimpleSliceStream_ForEach(t *testing.T) {
type args[T int] struct {
fn func(T)
}
type testCase[T int] struct {
name string
r SimpleSliceStream[T]
args args[T]
}
tests := []testCase[int]{
{
name: "t1",
r: s,
args: args[int]{
func(t int) {
fmt.Println(t)
},
},
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
tt.r.ForEach(tt.args.fn)
})
}
}
func TestSimpleSliceStream_Limit(t *testing.T) {
type args struct {
limit int
offset int
}
type testCase[T int] struct {
name string
r SimpleSliceStream[T]
args args
want SimpleSliceStream[T]
}
tests := []testCase[int]{
{
name: "t1",
r: s,
args: args{
limit: 3,
offset: 5,
},
want: SimpleSliceStream[int]{helper.RangeSlice(6, 8, 1)},
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := tt.r.Limit(tt.args.limit, tt.args.offset); !reflect.DeepEqual(got, tt.want) {
t.Errorf("Limit() = %v, want %v", got, tt.want)
}
})
}
}
func TestSimpleSliceStream_Map(t *testing.T) {
type args[T int] struct {
fn func(T) T
}
type testCase[T int] struct {
name string
r SimpleSliceStream[T]
args args[T]
want SimpleSliceStream[T]
}
tests := []testCase[int]{
{
name: "t1",
r: s,
args: args[int]{
func(t int) (r int) {
return t * 2
},
},
want: SimpleSliceStream[int]{helper.RangeSlice(2, 20, 2)},
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := tt.r.Map(tt.args.fn); !reflect.DeepEqual(got, tt.want) {
t.Errorf("Map() = %v, want %v", got, tt.want)
}
})
}
}
func TestSimpleSliceStream_Result(t *testing.T) {
type testCase[T int] struct {
name string
r SimpleSliceStream[T]
want []T
}
tests := []testCase[int]{
{
name: "t1",
r: s,
want: helper.RangeSlice(1, 10, 1),
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := tt.r.Result(); !reflect.DeepEqual(got, tt.want) {
t.Errorf("Result() = %v, want %v", got, tt.want)
}
})
}
}
func TestSimpleSliceStream_Sort(t *testing.T) {
type args[T int] struct {
fn func(i, j T) bool
}
type testCase[T int] struct {
name string
r SimpleSliceStream[T]
args args[T]
want SimpleSliceStream[T]
}
tests := []testCase[int]{
{
name: "t1",
r: s,
args: args[int]{
fn: func(i, j int) bool {
return i > j
},
},
want: SimpleSliceStream[int]{helper.RangeSlice(10, 1, -1)},
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := tt.r.Sort(tt.args.fn); !reflect.DeepEqual(got, tt.want) {
t.Errorf("Sort() = %v, want %v", got, tt.want)
}
})
}
}
func TestSimpleSliceStream_parallelForEach(t *testing.T) {
type args[T int] struct {
fn func(T)
c int
}
type testCase[T int] struct {
name string
r SimpleSliceStream[T]
args args[T]
}
tests := []testCase[int]{
{
name: "t1",
r: s,
args: args[int]{
fn: func(t int) {
fmt.Println(t)
},
c: 3,
},
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
tt.r.ParallelForEach(tt.args.fn, tt.args.c)
})
}
}
func TestSimpleSliceStream_ParallelFilter(t *testing.T) {
type args[T int] struct {
fn func(T) bool
c int
}
type testCase[T int] struct {
name string
r SimpleSliceStream[T]
args args[T]
want SimpleSliceStream[T]
}
tests := []testCase[int]{
{
name: "t1",
r: s,
args: args[int]{
fn: func(t int) bool {
return t > 3
},
c: 6,
},
want: SimpleSliceStream[int]{helper.RangeSlice(4, 10, 1)},
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := tt.r.ParallelFilter(tt.args.fn, tt.args.c).Sort(func(i, j int) bool {
return i < j
}); !reflect.DeepEqual(got, tt.want) {
t.Errorf("ParallelFilter() = %v, want %v", got, tt.want)
}
})
}
}
func TestSimpleSliceStream_ParallelMap(t *testing.T) {
type args[T int] struct {
fn func(T) T
c int
}
type testCase[T int] struct {
name string
r SimpleSliceStream[T]
args args[T]
want SimpleSliceStream[T]
}
tests := []testCase[int]{
{
name: "t1",
r: s,
args: args[int]{
fn: func(t int) int {
return t * 2
},
c: 6,
},
want: SimpleSliceStream[int]{helper.RangeSlice(2, 20, 2)},
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := tt.r.ParallelMap(tt.args.fn, tt.args.c).Sort(func(i, j int) bool {
return i < j
}); !reflect.DeepEqual(got, tt.want) {
t.Errorf("ParallelMap() = %v, want %v", got, tt.want)
}
})
}
}
func TestReduce(t *testing.T) {
type args[S, T int] struct {
s SimpleSliceStream[S]
fn func(S, T) T
}
type testCase[S, T int] struct {
name string
args args[S, T]
wantR T
}
tests := []testCase[int, int]{
{
name: "t1",
args: args[int, int]{
s, func(i, r int) int {
return i + r
},
},
wantR: helper.Sum(s.Result()...),
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if gotR := Reduce(tt.args.s, tt.args.fn); !reflect.DeepEqual(gotR, tt.wantR) {
t.Errorf("Reduce() = %v, want %v", gotR, tt.wantR)
}
})
}
}
func TestSimpleSliceStream_Reverse(t *testing.T) {
type testCase[T int] struct {
name string
r SimpleSliceStream[T]
want SimpleSliceStream[T]
}
tests := []testCase[int]{
{
name: "t1",
r: s,
want: SimpleSliceStream[int]{helper.RangeSlice(10, 1, -1)},
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := tt.r.Reverse(); !reflect.DeepEqual(got, tt.want) {
t.Errorf("Reverse() = %v, want %v", got, tt.want)
}
})
}
}