Update tests for paginate functions

This commit is contained in:
ionutboangiu
2022-01-07 15:40:56 +02:00
committed by Dan Christian Bogos
parent dd21ff3ea8
commit 8f15d4ae5f

View File

@@ -625,61 +625,74 @@ func TestAPITPDataPaginate(t *testing.T) {
in := []string{"FLTR_1", "FLTR_2", "FLTR_3", "FLTR_4", "FLTR_5", "FLTR_6", "FLTR_7",
"FLTR_8", "FLTR_9", "FLTR_10", "FLTR_11", "FLTR_12", "FLTR_13", "FLTR_14",
"FLTR_15", "FLTR_16", "FLTR_17", "FLTR_18", "FLTR_19", "FLTR_20"}
args := &ArgsItemIDs{
Tenant: "cgrates.org",
APIOpts: map[string]interface{}{
PageLimitOpt: 2,
PageOffsetOpt: 6,
PageMaxItemsOpt: 9,
},
}
exp := []string{"FLTR_7", "FLTR_8"}
if rcv, err := Paginate(in, args.APIOpts); err != nil {
if rcv, err := Paginate(in, 2, 6, 9); err != nil {
t.Error(err)
} else if !reflect.DeepEqual(rcv, exp) {
t.Errorf("expected: <%+v>, \nreceived: <%+v>", exp, rcv)
}
args.APIOpts[PageLimitOpt] = 0
args.APIOpts[PageOffsetOpt] = 18
args.APIOpts[PageMaxItemsOpt] = 50
exp = []string{"FLTR_19", "FLTR_20"}
if rcv, err := Paginate(in, args.APIOpts); err != nil {
if rcv, err := Paginate(in, 0, 18, 50); err != nil {
t.Error(err)
} else if !reflect.DeepEqual(rcv, exp) {
t.Errorf("expected: <%+v>, \nreceived: <%+v>", exp, rcv)
}
args.APIOpts[PageOffsetOpt] = 0
if rcv, err := Paginate(in, args.APIOpts); err != nil {
if rcv, err := Paginate(in, 0, 0, 50); err != nil {
t.Error(err)
} else if !reflect.DeepEqual(rcv, in) {
t.Errorf("expected: <%+v>, \nreceived: <%+v>", in, rcv)
}
args.APIOpts[PageLimitOpt] = 25
args.APIOpts[PageOffsetOpt] = 18
if rcv, err := Paginate(in, args.APIOpts); err != nil {
experr := `SERVER_ERROR: maximum number of items exceeded`
if _, err := Paginate(in, 0, 0, 19); err == nil || err.Error() != experr {
t.Error(err)
}
if rcv, err := Paginate(in, 25, 18, 50); err != nil {
t.Error(err)
} else if !reflect.DeepEqual(rcv, exp) {
t.Errorf("expected: <%+v>, \nreceived: <%+v>", exp, rcv)
}
args.APIOpts[PageLimitOpt] = 2
args.APIOpts[PageOffsetOpt] = 22
var expOut []string
if rcv, err := Paginate(in, args.APIOpts); err != nil {
if rcv, err := Paginate(in, 2, 22, 50); err != nil {
t.Error(err)
} else if !reflect.DeepEqual(rcv, expOut) {
t.Errorf("expected: <%+v>, \nreceived: <%+v>", expOut, rcv)
}
args.APIOpts[PageLimitOpt] = 2
args.APIOpts[PageOffsetOpt] = 4
args.APIOpts[PageMaxItemsOpt] = 5
experr := `SERVER_ERROR: maximum number of items exceeded`
if _, err := Paginate(in, args.APIOpts); err == nil || err.Error() != experr {
if _, err := Paginate(in, 2, 4, 5); err == nil || err.Error() != experr {
t.Errorf("expected: <%+v>, \nreceived: <%+v>", experr, err)
}
if _, err := Paginate(in, 0, 18, 19); err == nil || err.Error() != experr {
t.Errorf("expected: <%+v>, \nreceived: <%+v>", experr, err)
}
}
func TestAPITPDataGetPaginateOpts(t *testing.T) {
opts := map[string]interface{}{
PageLimitOpt: 1.3,
PageOffsetOpt: 4,
PageMaxItemsOpt: "5",
}
if limit, offset, maxItems, err := GetPaginateOpts(opts); err != nil {
t.Error(err)
} else if limit != 1 {
t.Errorf("expected: <%+v>, \nreceived: <%+v>", 1, limit)
} else if offset != 4 {
t.Errorf("expected: <%+v>, \nreceived: <%+v>", 4, offset)
} else if maxItems != 5 {
t.Errorf("expected: <%+v>, \nreceived: <%+v>", 5, maxItems)
}
opts[PageMaxItemsOpt] = false
experr := `cannot convert field<bool>: false to int`
if _, _, _, err := GetPaginateOpts(opts); err == nil || err.Error() != experr {
t.Errorf("expected: <%+v>, \nreceived: <%+v>", experr, err)
}
}