Files
cgrates/utils/reflect_test.go
2025-10-13 09:57:41 +02:00

1783 lines
49 KiB
Go

/*
Real-time Online/Offline Charging System (OCS) for Telecom & ISP environments
Copyright (C) ITsysCOM GmbH
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see <https://www.gnu.org/licenses/>
*/
package utils
import (
"net"
"reflect"
"strings"
"testing"
"time"
"github.com/ericlagergren/decimal"
)
func TestGreaterThan(t *testing.T) {
if gte, err := GreaterThan(1, 1.2, false); err != nil {
t.Error(err)
} else if gte {
t.Error("should be not greater than")
}
if _, err := GreaterThan(struct{}{},
map[string]any{"a": "a"}, false); err == nil ||
!strings.HasPrefix(err.Error(), "incomparable") {
t.Error(err)
}
if gte, err := GreaterThan(1.2, 1.2, true); err != nil {
t.Error(err)
} else if !gte {
t.Error("should be equal")
}
if gte, err := GreaterThan(1.3, 1.2, false); err != nil {
t.Error(err)
} else if !gte {
t.Error("should be greater than")
}
if gte, err := GreaterThan(1.3, int(1), false); err != nil {
t.Error(err)
} else if !gte {
t.Error("should be greater than")
}
if gte, err := GreaterThan(1.2, 1.3, false); err != nil {
t.Error(err)
} else if gte {
t.Error("should be greater than")
}
if gte, err := GreaterThan(2, 1, false); err != nil {
t.Error(err)
} else if !gte {
t.Error("should be greater than")
}
if gte, err := GreaterThan(2, float64(1.5), false); err != nil {
t.Error(err)
} else if !gte {
t.Error("should be greater than")
}
if gte, err := GreaterThan(2*time.Second,
time.Second, false); err != nil {
t.Error(err)
} else if !gte {
t.Error("should be greater than")
}
if gte, err := GreaterThan(2*time.Second,
20, false); err != nil {
t.Error(err)
} else if !gte {
t.Error("should be greater than")
}
if gte, err := GreaterThan(2*time.Second,
float64(time.Second), false); err != nil {
t.Error(err)
} else if !gte {
t.Error("should be greater than")
}
if gte, err := GreaterThan(time.Second,
2*time.Second, false); err != nil {
t.Error(err)
} else if gte {
t.Error("should be less than")
}
if gte, err := GreaterThan(2*time.Second,
time.Second, false); err != nil {
t.Error(err)
} else if !gte {
t.Error("should be greater than")
}
now := time.Now()
if gte, err := GreaterThan(now.Add(time.Second), now, false); err != nil {
t.Error(err)
} else if !gte {
t.Error("should be greater than")
}
if gte, err := GreaterThan(now, now, true); err != nil {
t.Error(err)
} else if !gte {
t.Error("should be equal")
}
}
func TestStringToInterface(t *testing.T) {
if res := StringToInterface("1"); res != int64(1) {
t.Error("not parsing int")
}
if res := StringToInterface(""); res != "" {
t.Error("not parsing string")
}
if res := StringToInterface("true"); res != true {
t.Error("not parsing bool")
}
if res := StringToInterface("1.2"); res != 1.2 {
t.Error("not parsing float64")
}
if res := StringToInterface("1.2"); res != 1.2 {
t.Error("not parsing float64")
}
if res := StringToInterface("45s"); res != 45*time.Second {
t.Error("not parsing time.Duration")
}
res := StringToInterface("+24h")
resTime := res.(time.Time)
now := time.Now()
if resTime.Hour() != now.Hour() && resTime.Minute() != now.Minute() {
t.Error("not parsing time.Time")
}
}
func TestIfaceAsString(t *testing.T) {
val := any("string1")
if rply := IfaceAsString(val); rply != "string1" {
t.Errorf("Expected string1 ,received %+v", rply)
}
val = any(123)
if rply := IfaceAsString(val); rply != "123" {
t.Errorf("Expected 123 ,received %+v", rply)
}
val = any([]byte("byte_val"))
if rply := IfaceAsString(val); rply != "byte_val" {
t.Errorf("Expected byte_val ,received %+v", rply)
}
val = any(true)
if rply := IfaceAsString(val); rply != "true" {
t.Errorf("Expected true ,received %+v", rply)
}
if rply := IfaceAsString(time.Second); rply != "1s" {
t.Errorf("Expected 1s ,received %+v", rply)
}
if rply := IfaceAsString(nil); rply != "" {
t.Errorf("Expected ,received %+v", rply)
}
val = any(net.ParseIP("127.0.0.1"))
if rply := IfaceAsString(val); rply != "127.0.0.1" {
t.Errorf("Expected ,received %+v", rply)
}
val = any(10.23)
if rply := IfaceAsString(val); rply != "10.23" {
t.Errorf("Expected ,received %+v", rply)
}
val = any(time.Date(2009, 11, 10, 23, 0, 0, 0, time.UTC))
if rply := IfaceAsString(val); rply != "2009-11-10T23:00:00Z" {
t.Errorf("Expected ,received %+v", rply)
}
}
func TestIfaceAsTime(t *testing.T) {
timeDate := time.Date(2009, 11, 10, 23, 0, 0, 0, time.UTC)
val := any("2009-11-10T23:00:00Z")
if itmConvert, err := IfaceAsTime(val, "UTC"); err != nil {
t.Error(err)
} else if itmConvert != timeDate {
t.Errorf("received: %+v", itmConvert)
}
val = any(timeDate)
if itmConvert, err := IfaceAsTime(val, "UTC"); err != nil {
t.Error(err)
} else if itmConvert != timeDate {
t.Errorf("received: %+v", itmConvert)
}
val = any("This is not a time")
if _, err := IfaceAsTime(val, "UTC"); err == nil {
t.Error("There should be error")
}
}
func TestIfaceAsDuration(t *testing.T) {
eItm := time.Second
if itmConvert, err := IfaceAsDuration(any(time.Second)); err != nil {
t.Error(err)
} else if eItm != itmConvert {
t.Errorf("received: %+v", itmConvert)
}
if itmConvert, err := IfaceAsDuration(any(float64(1000000000.0))); err != nil {
t.Error(err)
} else if eItm != itmConvert {
t.Errorf("received: %+v", itmConvert)
}
if itmConvert, err := IfaceAsDuration(any(int64(1000000000))); err != nil {
t.Error(err)
} else if eItm != itmConvert {
t.Errorf("received: %+v", itmConvert)
}
if itmConvert, err := IfaceAsDuration(any(int(1000000000))); err != nil {
t.Error(err)
} else if eItm != itmConvert {
t.Errorf("received: %+v", itmConvert)
}
if itmConvert, err := IfaceAsDuration(any(string("1s"))); err != nil {
t.Error(err)
} else if eItm != itmConvert {
t.Errorf("received: %+v", itmConvert)
}
if _, err := IfaceAsDuration(any(string("s1s"))); err == nil {
t.Error("empty error")
}
}
func TestIfaceAsFloat64(t *testing.T) {
eFloat := 6.0
val := any(6.0)
if itmConvert, err := IfaceAsFloat64(val); err != nil {
t.Error(err)
} else if itmConvert != eFloat {
t.Errorf("received: %+v", itmConvert)
}
val = any(6)
if itmConvert, err := IfaceAsFloat64(val); err != nil {
t.Error(err)
} else if itmConvert != eFloat {
t.Errorf("received: %+v", itmConvert)
}
val = any("6")
if itmConvert, err := IfaceAsFloat64(val); err != nil {
t.Error(err)
} else if itmConvert != eFloat {
t.Errorf("received: %+v", itmConvert)
}
val = any(int64(6))
if itmConvert, err := IfaceAsFloat64(val); err != nil {
t.Error(err)
} else if itmConvert != eFloat {
t.Errorf("received: %+v", itmConvert)
}
val = any("This is not a float")
if _, err := IfaceAsFloat64(val); err == nil {
t.Error("expecting error")
}
}
func TestIfaceAsInt64(t *testing.T) {
eInt := int64(3)
val := any(3)
if itmConvert, err := IfaceAsInt64(val); err != nil {
t.Error(err)
} else if itmConvert != eInt {
t.Errorf("received: %+v", itmConvert)
}
val = any(3)
if itmConvert, err := IfaceAsInt64(val); err != nil {
t.Error(err)
} else if itmConvert != eInt {
t.Errorf("received: %+v", itmConvert)
}
val = any("3")
if itmConvert, err := IfaceAsInt64(val); err != nil {
t.Error(err)
} else if itmConvert != eInt {
t.Errorf("received: %+v", itmConvert)
}
val = any(int64(3))
if itmConvert, err := IfaceAsInt64(val); err != nil {
t.Error(err)
} else if itmConvert != eInt {
t.Errorf("received: %+v", itmConvert)
}
val = any("This is not an integer")
if _, err := IfaceAsInt64(val); err == nil {
t.Error("expecting error")
}
}
func TestIfaceAsTInt64(t *testing.T) {
eInt := int64(3)
val := any(3)
if itmConvert, err := IfaceAsTInt64(val); err != nil {
t.Error(err)
} else if itmConvert != eInt {
t.Errorf("received: %+v", itmConvert)
}
val = any(3)
if itmConvert, err := IfaceAsTInt64(val); err != nil {
t.Error(err)
} else if itmConvert != eInt {
t.Errorf("received: %+v", itmConvert)
}
val = any("3")
if itmConvert, err := IfaceAsTInt64(val); err != nil {
t.Error(err)
} else if itmConvert != eInt {
t.Errorf("received: %+v", itmConvert)
}
val = any(int64(3))
if itmConvert, err := IfaceAsTInt64(val); err != nil {
t.Error(err)
} else if itmConvert != eInt {
t.Errorf("received: %+v", itmConvert)
}
val = any(int32(3))
if itmConvert, err := IfaceAsTInt64(val); err != nil {
t.Error(err)
} else if itmConvert != eInt {
t.Errorf("received: %+v", itmConvert)
}
val = any(float32(3.14))
if itmConvert, err := IfaceAsTInt64(val); err != nil {
t.Error(err)
} else if itmConvert != eInt {
t.Errorf("received: %+v", itmConvert)
}
val = any(float64(3.14))
if itmConvert, err := IfaceAsTInt64(val); err != nil {
t.Error(err)
} else if itmConvert != eInt {
t.Errorf("received: %+v", itmConvert)
}
val = any("This is not an integer")
if _, err := IfaceAsTInt64(val); err == nil {
t.Error("expecting error")
}
}
func TestIfaceAsBool(t *testing.T) {
val := any(true)
if itmConvert, err := IfaceAsBool(val); err != nil {
t.Error(err)
} else if !itmConvert {
t.Errorf("received: %+v", itmConvert)
}
val = any("true")
if itmConvert, err := IfaceAsBool(val); err != nil {
t.Error(err)
} else if !itmConvert {
t.Errorf("received: %+v", itmConvert)
}
val = any(0)
if itmConvert, err := IfaceAsBool(val); err != nil {
t.Error(err)
} else if itmConvert {
t.Errorf("received: %+v", itmConvert)
}
val = any(int32(2))
if itmConvert, err := IfaceAsBool(val); err != nil {
t.Error(err)
} else if !itmConvert {
t.Errorf("received: %+v", itmConvert)
}
val = any(1)
if itmConvert, err := IfaceAsBool(val); err != nil {
t.Error(err)
} else if !itmConvert {
t.Errorf("received: %+v", itmConvert)
}
val = any(uint32(2))
if itmConvert, err := IfaceAsBool(val); err != nil {
t.Error(err)
} else if !itmConvert {
t.Errorf("received: %+v", itmConvert)
}
val = any(uint64(2))
if itmConvert, err := IfaceAsBool(val); err != nil {
t.Error(err)
} else if !itmConvert {
t.Errorf("received: %+v", itmConvert)
}
val = any(0.0)
if itmConvert, err := IfaceAsBool(val); err != nil {
t.Error(err)
} else if itmConvert {
t.Errorf("received: %+v", itmConvert)
}
val = any(1.0)
if itmConvert, err := IfaceAsBool(val); err != nil {
t.Error(err)
} else if !itmConvert {
t.Errorf("received: %+v", itmConvert)
}
val = any("This is not a bool")
if _, err := IfaceAsBool(val); err == nil {
t.Error("expecting error")
}
val = any("")
if itmConvert, err := IfaceAsBool(val); err != nil {
t.Error(err)
} else if itmConvert {
t.Errorf("received: %+v", itmConvert)
}
}
func TestSum(t *testing.T) {
if _, err := Sum(1); err == nil || err != ErrNotEnoughParameters {
t.Error(err)
}
if _, err := Sum(1, 1.2, false); err == nil || err.Error() != "cannot convert field: 1.2 to int" {
t.Error(err)
}
if sum, err := Sum(1.2, 1.2, 1.2, 1.2); err != nil {
t.Error(err)
} else if sum != 4.8 {
t.Errorf("Expecting: 4.8, received: %+v", sum)
}
if sum, err := Sum(2, 4, 6, 8); err != nil {
t.Error(err)
} else if sum != int64(20) {
t.Errorf("Expecting: 20, received: %+v", sum)
}
if sum, err := Sum(0.5, 1.23, 1.456, 2.234, 11.2, 0.45); err != nil {
t.Error(err)
} else if sum != 17.069999999999997 {
t.Errorf("Expecting: 17.069999999999997, received: %+v", sum)
}
if sum, err := Sum(2*time.Second, time.Second, 2*time.Second,
5*time.Second, 4*time.Millisecond); err != nil {
t.Error(err)
} else if sum != 10*time.Second+4*time.Millisecond {
t.Errorf("Expecting: 10.004s, received: %+v", sum)
}
if sum, err := Sum(2*time.Second,
10*time.Millisecond); err != nil {
t.Error(err)
} else if sum != 2*time.Second+10*time.Millisecond {
t.Errorf("Expecting: 2s10ms, received: %+v", sum)
}
}
func TestGetUniformType(t *testing.T) {
var arg, expected any
arg = time.Second
expected = float64(time.Second)
if rply, err := GetUniformType(arg); err != nil {
t.Error(err)
} else if !reflect.DeepEqual(rply, expected) {
t.Errorf("Expected: %v of type %T, received: %v of type %T", expected, expected, rply, rply)
}
arg = uint(10)
expected = float64(10)
if rply, err := GetUniformType(arg); err != nil {
t.Error(err)
} else if !reflect.DeepEqual(rply, expected) {
t.Errorf("Expected: %v of type %T, received: %v of type %T", expected, expected, rply, rply)
}
arg = int64(10)
if rply, err := GetUniformType(arg); err != nil {
t.Error(err)
} else if !reflect.DeepEqual(rply, expected) {
t.Errorf("Expected: %v of type %T, received: %v of type %T", expected, expected, rply, rply)
}
arg = time.Now()
expected = arg
if rply, err := GetUniformType(arg); err != nil {
t.Error(err)
} else if !reflect.DeepEqual(rply, expected) {
t.Errorf("Expected: %v of type %T, received: %v of type %T", expected, expected, rply, rply)
}
arg = struct{ b int }{b: 10}
expected = arg
if rply, err := GetUniformType(arg); err != nil {
t.Error(err)
} else if !reflect.DeepEqual(rply, expected) {
t.Errorf("Expected: %v of type %T, received: %v of type %T", expected, expected, rply, rply)
}
arg = time.Now()
if _, err := GetUniformType(&arg); err == nil || err.Error() != "incomparable" {
t.Errorf("Exppected \"incomparable\" error received:%v ", err)
}
arg = uint(10)
if _, err := GetUniformType(&arg); err == nil || err.Error() != "incomparable" {
t.Errorf("Exppected \"incomparable\" error received:%v ", err)
}
arg = true
if _, err := GetUniformType(arg); err == nil || err.Error() != "incomparable" {
t.Errorf("Exppected \"incomparable\" error received:%v ", err)
}
arg = "String"
if _, err := GetUniformType(arg); err == nil || err.Error() != "incomparable" {
t.Errorf("Exppected \"incomparable\" error received:%v ", err)
}
}
func TestDifference(t *testing.T) {
if _, err := Difference("", 10); err == nil || err != ErrNotEnoughParameters {
t.Error(err)
}
if _, err := Difference("", 10, 1.2, false); err == nil || err.Error() != "cannot convert field: 1.2 to int" {
t.Error(err)
}
if diff, err := Difference("", 12, 1, 2, 3); err != nil {
t.Error(err)
} else if diff != int64(6) {
t.Errorf("Expecting: 6, received: %+v", diff)
}
if diff, err := Difference("", 8.0, 4.0, 2.0, -1.0); err != nil {
t.Error(err)
} else if diff != 3.0 {
t.Errorf("Expecting: 3.0, received: %+v", diff)
}
if diff, err := Difference("", 8.0, 4, 2.0, -1.0); err != nil {
t.Error(err)
} else if diff != 3.0 {
t.Errorf("Expecting: 3.0, received: %+v", diff)
}
if diff, err := Difference("", 10*time.Second, time.Second, 2*time.Second,
4*time.Millisecond); err != nil {
t.Error(err)
} else if diff != 6*time.Second+996*time.Millisecond {
t.Errorf("Expecting: 6.996ms, received: %+v", diff)
}
if diff, err := Difference("", 2*time.Second,
10*time.Millisecond); err != nil {
t.Error(err)
} else if diff != time.Second+990*time.Millisecond {
t.Errorf("Expecting: 1.99s, received: %+v", diff)
}
if diff, err := Difference("", time.Date(2009, 11, 10, 23, 0, 0, 0, time.UTC),
10*time.Second); err != nil {
t.Error(err)
} else if diff != time.Date(2009, 11, 10, 22, 59, 50, 0, time.UTC) {
t.Errorf("Expecting: %+v, received: %+v", time.Date(2009, 11, 10, 22, 59, 50, 0, time.UTC), diff)
}
if diff, err := Difference("", time.Date(2009, 11, 10, 23, 0, 0, 0, time.UTC),
10*time.Second, 10000000000); err != nil {
t.Error(err)
} else if diff != time.Date(2009, 11, 10, 22, 59, 40, 0, time.UTC) {
t.Errorf("Expecting: %+v, received: %+v", time.Date(2009, 11, 10, 22, 59, 40, 0, time.UTC), diff)
}
}
func TestDifferenceTime(t *testing.T) {
if diff, err := Difference("", time.Date(2009, 11, 10, 23, 10, 0, 0, time.UTC),
time.Date(2009, 11, 10, 23, 13, 0, 0, time.UTC), 10*time.Second); err != nil {
t.Error(err)
} else if diff != -3*time.Minute+0*time.Second {
t.Errorf("Expected %v but received %v %T", "-3m0s", diff, diff)
}
}
func TestMultiply(t *testing.T) {
if _, err := Multiply(10); err == nil || err != ErrNotEnoughParameters {
t.Error(err)
}
if _, err := Multiply(10, 1.2, false); err == nil || err.Error() != "cannot convert field: 1.2 to int" {
t.Error(err)
}
if diff, err := Multiply(12, 1, 2, 3); err != nil {
t.Error(err)
} else if diff != int64(72) {
t.Errorf("Expecting: 72, received: %+v", diff)
}
if diff, err := Multiply(8.0, 4.0, 2.0, 1.0); err != nil {
t.Error(err)
} else if diff != 64.0 {
t.Errorf("Expecting: 64.0, received: %+v", diff)
}
if diff, err := Multiply(8.0, 4, 6.0, 1.0); err != nil {
t.Error(err)
} else if diff != 192.0 {
t.Errorf("Expecting: 192.0, received: %+v", diff)
}
}
func TestDivide(t *testing.T) {
if _, err := Divide(10); err == nil || err != ErrNotEnoughParameters {
t.Error(err)
}
if _, err := Divide(10, 1.2, false); err == nil || err.Error() != "cannot convert field: 1.2 to int" {
t.Error(err)
}
if diff, err := Divide(12, 1, 2, 3); err != nil {
t.Error(err)
} else if diff != int64(2) {
t.Errorf("Expecting: 2, received: %+v", diff)
}
if diff, err := Divide(8.0, 4.0, 2.0, 1.0); err != nil {
t.Error(err)
} else if diff != 1.0 {
t.Errorf("Expecting: 1.0, received: %+v", diff)
}
if diff, err := Divide(8.0, 4, 6.0, 1.0); err != nil {
t.Error(err)
} else if diff != 0.3333333333333333 {
t.Errorf("Expecting: 0.3333333333333333, received: %+v", diff)
}
}
func TestEqualTo(t *testing.T) {
if gte, err := EqualTo(1, 1.2); err != nil {
t.Error(err)
} else if gte {
t.Error("should be not greater than")
}
if _, err := EqualTo(struct{}{},
map[string]any{"a": "a"}); err == nil ||
!strings.HasPrefix(err.Error(), "incomparable") {
t.Error(err)
}
if gte, err := EqualTo(1.2, 1.2); err != nil {
t.Error(err)
} else if !gte {
t.Error("should be equal")
}
if gte, err := EqualTo(1.3, 1.2); err != nil {
t.Error(err)
} else if gte {
t.Error("should not be equal")
}
if gte, err := EqualTo(1.3, int(1)); err != nil {
t.Error(err)
} else if gte {
t.Error("should not be equal")
}
if gte, err := EqualTo(1.2, 1.3); err != nil {
t.Error(err)
} else if gte {
t.Error("should be equal")
}
if gte, err := EqualTo(2.0, int64(2)); err != nil {
t.Error(err)
} else if !gte {
t.Error("should be equal")
}
if gte, err := EqualTo(2*time.Second,
2*time.Second); err != nil {
t.Error(err)
} else if !gte {
t.Error("should be equal")
}
now := time.Now()
if gte, err := EqualTo(now.Add(time.Second), now); err != nil {
t.Error(err)
} else if gte {
t.Error("should not be equal")
}
if gte, err := EqualTo(now, now); err != nil {
t.Error(err)
} else if !gte {
t.Error("should be equal")
}
}
type TestA struct {
StrField string
}
type TestASlice []*TestA
func (*TestA) TestFunc() string {
return "This is a test function on a structure"
}
func (*TestA) TestFuncWithParam(param string) string {
return "Invalid"
}
func (*TestA) TestFuncWithError() (string, error) {
return "TestFuncWithError", nil
}
func (*TestA) TestFuncWithError2() (string, error) {
return "TestFuncWithError2", ErrPartiallyExecuted
}
func TestReflectFieldAsStringError(t *testing.T) {
var test bool
_, err := IfaceAsTime(test, "")
if err == nil || err.Error() != "cannot convert field: false to time.Time" {
t.Errorf("Expecting <cannot convert field: false to time.Time> ,received: <%+v>", err)
}
}
func TestIfaceAsDurationDefaultError(t *testing.T) {
var test bool
_, err := IfaceAsDuration(test)
if err == nil || err.Error() != "cannot convert field: false to time.Duration" {
t.Errorf("Expecting <cannot convert field: false to time.Duration> ,received: <%+v>", err)
}
}
func TestIfaceAsDurationCaseUInt(t *testing.T) {
var test uint = 127
response, _ := IfaceAsDuration(test)
if !reflect.DeepEqual(response.String(), "127ns") {
t.Errorf("Expected <127ns> ,received: <%+v>", response)
}
}
func TestIfaceAsDurationCaseInt8(t *testing.T) {
var test int8 = 127
response, _ := IfaceAsDuration(test)
if !reflect.DeepEqual(response.String(), "127ns") {
t.Errorf("Expected <127ns> ,received: <%+v>", response)
}
}
func TestIfaceAsDurationCaseNegInt8(t *testing.T) {
var test int8 = -127
response, _ := IfaceAsDuration(test)
if !reflect.DeepEqual(response.String(), "-127ns") {
t.Errorf("Expected <-127ns> ,received: <%+v>", response)
}
}
func TestIfaceAsDurationCaseUInt8(t *testing.T) {
var test uint8 = 127
response, _ := IfaceAsDuration(test)
if !reflect.DeepEqual(response.String(), "127ns") {
t.Errorf("Expected <127ns> ,received: <%+v>", response)
}
}
func TestIfaceAsDurationCaseInt16(t *testing.T) {
var test int16 = 32767
response, _ := IfaceAsDuration(test)
if !reflect.DeepEqual(response.String(), "32.767µs") {
t.Errorf("Expected <32.767µs> ,received: <%+v>", response)
}
}
func TestIfaceAsDurationCaseNegInt16(t *testing.T) {
var test int16 = -32767
response, _ := IfaceAsDuration(test)
if !reflect.DeepEqual(response.String(), "-32.767µs") {
t.Errorf("Expected <-32.767µs> ,received: <%+v>", response)
}
}
func TestIfaceAsDurationCaseUInt16(t *testing.T) {
var test uint16 = 32767
response, _ := IfaceAsDuration(test)
if !reflect.DeepEqual(response.String(), "32.767µs") {
t.Errorf("Expected <32.767µs> ,received: <%+v>", response)
}
}
func TestIfaceAsDurationCaseInt32(t *testing.T) {
var test int32 = 2147483647
response, _ := IfaceAsDuration(test)
if !reflect.DeepEqual(response.String(), "2.147483647s") {
t.Errorf("Expected <2.147483647s> ,received: <%+v>", response)
}
}
func TestIfaceAsDurationCaseNegInt32(t *testing.T) {
var test int32 = -2147483647
response, _ := IfaceAsDuration(test)
if !reflect.DeepEqual(response.String(), "-2.147483647s") {
t.Errorf("Expected <-2.147483647s> ,received: <%+v>", response)
}
}
func TestIfaceAsDurationCaseUInt32(t *testing.T) {
var test uint32 = 2147483647
response, _ := IfaceAsDuration(test)
if !reflect.DeepEqual(response.String(), "2.147483647s") {
t.Errorf("Expected <2.147483647s> ,received: <%+v>", response)
}
}
func TestIfaceAsDurationCaseInt64(t *testing.T) {
var test int64 = 9223372036854775807
response, _ := IfaceAsDuration(test)
if !reflect.DeepEqual(response.String(), "2562047h47m16.854775807s") {
t.Errorf("Expected <2562047h47m16.854775807s> ,received: <%+v>", response)
}
}
func TestIfaceAsDurationCaseNegInt64(t *testing.T) {
var test int64 = -9223372036854775807
response, _ := IfaceAsDuration(test)
if !reflect.DeepEqual(response.String(), "-2562047h47m16.854775807s") {
t.Errorf("Expected <-2562047h47m16.854775807s> ,received: <%+v>", response)
}
}
func TestIfaceAsDurationCaseUInt64(t *testing.T) {
var test uint64 = 9223372036854775807
response, _ := IfaceAsDuration(test)
if !reflect.DeepEqual(response.String(), "2562047h47m16.854775807s") {
t.Errorf("Expected <2562047h47m16.854775807s> ,received: <%+v>", response)
}
}
func TestIfaceAsDurationCaseFloat32(t *testing.T) {
var test float32 = 9.5555555
response, _ := IfaceAsDuration(test)
if !reflect.DeepEqual(response.String(), "9ns") {
t.Errorf("Expected <9ns> ,received: <%+v>", response)
}
}
func TestIfaceAsInt6432to64(t *testing.T) {
var test int32 = 2147483647
var expected int64 = 2147483647
response, _ := IfaceAsInt64(test)
if !reflect.DeepEqual(response, expected) {
t.Errorf("Expected <%+v> ,received: <%+v>", expected, response)
}
}
func TestIfaceAsInt64Default(t *testing.T) {
var test bool = true
_, err := IfaceAsInt64(test)
if err == nil || err.Error() != "cannot convert field: true to int" {
t.Errorf("Expecting <cannot convert field: true to int> ,received: <%+v>", err)
}
}
func TestIfaceAsInt64Nanosecs(t *testing.T) {
var test time.Duration = 2147483647
response, _ := IfaceAsInt64(test)
if !reflect.DeepEqual(response, test.Nanoseconds()) {
t.Errorf("Expected <%+v> ,received: <%+v>", test.Nanoseconds(), response)
}
}
func TestIfaceAsTInt64Default(t *testing.T) {
var test bool = true
_, err := IfaceAsTInt64(test)
if err == nil || err.Error() != "cannot convert field<bool>: true to int" {
t.Errorf("Expecting <cannot convert field<bool>: true to int> ,received: <%+v>", err)
}
}
func TestIfaceAsTIntDefault(t *testing.T) {
if _, err := IfaceAsInt(true); err == nil || err.Error() != "cannot convert field<bool>: true to int" {
t.Errorf("Expecting <cannot convert field<bool>: true to int> ,received: <%+v>", err)
}
var test time.Duration = 2147483647
response, _ := IfaceAsInt(test)
if !reflect.DeepEqual(response, int(test.Nanoseconds())) {
t.Errorf("Expected <%+v> ,received: <%+v>", test.Nanoseconds(), response)
}
}
func TestIfaceAsTInt64Nanosecs(t *testing.T) {
var test time.Duration = 2147483647
response, _ := IfaceAsTInt64(test)
if !reflect.DeepEqual(response, test.Nanoseconds()) {
t.Errorf("Expected <%+v> ,received: <%+v>", test.Nanoseconds(), response)
}
}
func TestIfaceAsBoolInt64(t *testing.T) {
var test int64 = 2147483647
response, _ := IfaceAsBool(test)
if !reflect.DeepEqual(response, true) {
t.Errorf("Expected <%+v> ,received: <%+v>", true, response)
}
}
func TestIfaceAsBoolDefault(t *testing.T) {
var test struct{}
_, err := IfaceAsBool(test)
if err == nil || err.Error() != "cannot convert field: {} to bool" {
t.Errorf("Expecting <cannot convert field: {} to bool> ,received: <%+v>", err)
}
}
func TestIfaceAsStringInt32(t *testing.T) {
var test int32 = 2147483647
expected := "2147483647"
response := IfaceAsString(test)
if !reflect.DeepEqual(response, expected) {
t.Errorf("Expected <%+v> ,received: <%+v>", expected, response)
}
}
func TestIfaceAsStringInt32Neg(t *testing.T) {
var test int32 = -2147483647
expected := "-2147483647"
response := IfaceAsString(test)
if !reflect.DeepEqual(response, expected) {
t.Errorf("Expected <%+v> ,received: <%+v>", expected, response)
}
}
func TestIfaceAsStringInt64Neg(t *testing.T) {
var test int64 = -9223372036854775807
expected := "-9223372036854775807"
response := IfaceAsString(test)
if !reflect.DeepEqual(response, expected) {
t.Errorf("Expected <%+v> ,received: <%+v>", expected, response)
}
}
func TestIfaceAsStringUInt32(t *testing.T) {
var test uint32 = 2147483647
expected := "2147483647"
response := IfaceAsString(test)
if !reflect.DeepEqual(response, expected) {
t.Errorf("Expected <%+v> ,received: <%+v>", expected, response)
}
}
func TestIfaceAsStringUInt64(t *testing.T) {
var test uint64 = 9223372036854775807
expected := "9223372036854775807"
response := IfaceAsString(test)
if !reflect.DeepEqual(response, expected) {
t.Errorf("Expected <%+v> ,received: <%+v>", expected, response)
}
}
func TestIfaceAsStringFloat32(t *testing.T) {
var test float32 = 2.5
expected := "2.5"
response := IfaceAsString(test)
if !reflect.DeepEqual(response, expected) {
t.Errorf("Expected <%+v> ,received: <%+v>", expected, response)
}
}
func TestIfaceAsStringFloat32Neg(t *testing.T) {
var test float32 = -2.5
expected := "-2.5"
response := IfaceAsString(test)
if !reflect.DeepEqual(response, expected) {
t.Errorf("Expected <%+v> ,received: <%+v>", expected, response)
}
}
func TestGetBasicTypeUint(t *testing.T) {
var test any = uint8(123)
valItm := reflect.ValueOf(test)
response := GetBasicType(test)
if !reflect.DeepEqual(valItm.Uint(), response) {
t.Errorf("Expected <%+v> ,received: <%+v>", valItm.Uint(), response)
}
}
func TestGreaterThanUint64(t *testing.T) {
var firstUint64 uint64
var secondUint64 uint64
firstUint64 = 1
secondUint64 = 2
if gte, err := GreaterThan(firstUint64, secondUint64, false); err != nil {
t.Error(err)
} else if gte {
t.Error("should be not greater than")
}
}
func TestGreaterThanUint64Equal(t *testing.T) {
var firstUint64 uint64
var secondUint64 uint64
firstUint64 = 2
secondUint64 = 2
if gte, err := GreaterThan(firstUint64, secondUint64, true); err != nil {
t.Error(err)
} else if !gte {
t.Error("should be equal")
}
}
func TestGreaterThanDefaultError(t *testing.T) {
var firstUint64 bool
var secondUint64 bool
firstUint64 = true
secondUint64 = false
_, err := GreaterThan(firstUint64, secondUint64, true)
if err == nil || err.Error() != "unsupported comparison type: bool, kind: bool" {
t.Errorf("Expected <unsupported comparison type: bool, kind: bool> ,received: <%+v>", err)
}
}
func TestEqualToUint64(t *testing.T) {
var firstUint64 uint64
var secondUint64 uint64
firstUint64 = 2
secondUint64 = 2
if gte, err := EqualTo(firstUint64, secondUint64); err != nil {
t.Error(err)
} else if !gte {
t.Error("should be equal")
}
}
func TestEqualToString(t *testing.T) {
var firstUint64 string
var secondUint64 string
firstUint64 = "2"
secondUint64 = "2"
if gte, err := EqualTo(firstUint64, secondUint64); err != nil {
t.Error(err)
} else if !gte {
t.Error("should be equal")
}
}
func TestEqualToError(t *testing.T) {
var firstUint64 bool
var secondUint64 bool
firstUint64 = true
secondUint64 = true
_, err := EqualTo(firstUint64, secondUint64)
if err == nil || err.Error() != "unsupported comparison type: bool, kind: bool" {
t.Errorf("Expected <unsupported comparison type: bool, kind: bool> ,received: <%+v>", err)
}
}
func TestIfaceAsStringDefault(t *testing.T) {
var test int8 = 2
response := IfaceAsString(test)
if !reflect.DeepEqual(response, "2") {
t.Errorf("Expected <2> ,received: <%+v>", response)
}
}
func TestReflectSumTimeDurationError(t *testing.T) {
var time1 time.Duration
var time2 bool
time1 = 2
time2 = true
_, err := Sum(time1, time2)
if err == nil || err.Error() != "cannot convert field: true to time.Duration" {
t.Errorf("Expected <cannot convert field: true to time.Duration> ,received: <%+v>", err)
}
}
func TestReflectSumInt64(t *testing.T) {
var testInt64 int64
var test2Int64 int64
var expected int64
testInt64 = 2
test2Int64 = 3
expected = 5
sum, _ := Sum(testInt64, test2Int64)
if !reflect.DeepEqual(sum, expected) {
t.Errorf("Expected <%+v> ,received: <%+v>", expected, sum)
}
}
func TestReflectSumFloat64Error(t *testing.T) {
var testFloat64 float64
var test2Float64 bool
testFloat64 = 2.56
test2Float64 = true
_, err := Sum(testFloat64, test2Float64)
if err == nil || err.Error() != "cannot convert field: true to float64" {
t.Errorf("Expected <cannot convert field: true to float64> ,received: <%+v>", err)
}
}
func TestReflectSumInt64Error(t *testing.T) {
var testVar int64
var test2Var bool
testVar = 25354
test2Var = true
_, err := Sum(testVar, test2Var)
if err == nil || err.Error() != "cannot convert field: true to int" {
t.Errorf("Expected <cannot convert field: true to int> ,received: <%+v>", err)
}
}
func TestReflectDifferenceTimeDurationError(t *testing.T) {
var testVar time.Duration
var test2Var bool
testVar = 25354
test2Var = true
_, err := Difference("", testVar, test2Var)
if err == nil || err.Error() != "cannot convert field: true to time.Duration" {
t.Errorf("Expected <cannot convert field: true to time.Duration> ,received: <%+v>", err)
}
}
func TestReflectDifferenceFloat64Error(t *testing.T) {
var testVar float64
var test2Var bool
testVar = 2.5
test2Var = true
_, err := Difference("", testVar, test2Var)
if err == nil || err.Error() != "cannot convert field: true to float64" {
t.Errorf("Expected <cannot convert field: true to float64> ,received: <%+v>", err)
}
}
func TestReflectDifferenceInt64Error(t *testing.T) {
var testVar int64
var test2Var int64
var expected int64
testVar = 6
test2Var = 5
expected = 1
dif, _ := Difference("", testVar, test2Var)
if !reflect.DeepEqual(dif, expected) {
t.Errorf("Expected <%+v> ,received: <%+v>", expected, dif)
}
}
func TestReflectDifferenceDefault(t *testing.T) {
var testVar bool
var test2Var bool
testVar = true
test2Var = true
_, err := Difference("", testVar, test2Var)
if err == nil || err.Error() != "unsupported type" {
t.Errorf("Expected <unsupported type> ,received: <%+v>", err)
}
}
func TestReflectMultiplyDefault(t *testing.T) {
var testVar bool
var test2Var bool
testVar = true
test2Var = true
_, err := Multiply(testVar, test2Var)
if err == nil || err.Error() != "unsupported type" {
t.Errorf("Expected <unsupported type> ,received: <%+v>", err)
}
}
func TestReflectMultiplyFloat64Error(t *testing.T) {
var testVar float64
var test2Var bool
testVar = 2.5
test2Var = true
_, err := Multiply(testVar, test2Var)
if err == nil || err.Error() != "cannot convert field: true to float64" {
t.Errorf("Expected <cannot convert field: true to float64> ,received: <%+v>", err)
}
}
func TestReflectMultiplyInt64(t *testing.T) {
var testInt64 int64
var test2Int64 int64
var expected int64
testInt64 = 2
test2Int64 = 3
expected = 6
mul, _ := Multiply(testInt64, test2Int64)
if !reflect.DeepEqual(mul, expected) {
t.Errorf("Expected <%+v> ,received: <%+v>", expected, mul)
}
}
func TestReflectDivideInt64(t *testing.T) {
var testInt64 int64
var test2Int64 int64
var expected int64
testInt64 = 4
test2Int64 = 2
expected = 2
div, _ := Divide(testInt64, test2Int64)
if !reflect.DeepEqual(div, expected) {
t.Errorf("Expected <%+v> ,received: <%+v>", expected, div)
}
}
func TestReflectDivideDefault(t *testing.T) {
var testVar bool
var test2Var bool
testVar = true
test2Var = true
_, err := Divide(testVar, test2Var)
if err == nil || err.Error() != "unsupported type" {
t.Errorf("Expected <unsupported type> ,received: <%+v>", err)
}
}
func TestReflectDivideFloat64Error(t *testing.T) {
var testVar float64
var test2Var bool
testVar = 2.5
test2Var = true
_, err := Divide(testVar, test2Var)
if err == nil || err.Error() != "cannot convert field: true to float64" {
t.Errorf("Expected <cannot convert field: true to float64> ,received: <%+v>", err)
}
}
func TestSumTimeTimeError(t *testing.T) {
day1 := time.Now()
day2 := "testValue"
_, err := Sum(day1, day2)
if err == nil || err.Error() != "time: invalid duration \"testValue\"" {
t.Errorf("Expected <time: invalid duration testValue> ,received: <%+v>", err)
}
}
func TestSumTimeTime(t *testing.T) {
day1 := time.Now()
day2 := time.Hour
expected := day1.Add(day2)
sum, _ := Sum(day1, day2)
if !reflect.DeepEqual(sum, expected) {
t.Errorf("Expected <%+v> ,received: <%+v>", expected, sum)
}
}
func TestDifferenceTimeTimeError(t *testing.T) {
_, err := Difference("", time.Now(), "cat")
if err == nil || err.Error() != "time: invalid duration \"cat\"" {
t.Errorf("Expected <time: invalid duration \"cat\"> ,received: <%+v>", err)
}
}
func TestDifferenceInt64Error(t *testing.T) {
_, err := Difference("", int64(2), "cat")
if err == nil || err.Error() != "strconv.ParseInt: parsing \"cat\": invalid syntax" {
t.Errorf("Expected <strconv.ParseInt: parsing \"cat\": invalid syntax> ,received: <%+v>", err)
}
}
func TestDivideInt64Error(t *testing.T) {
_, err := Divide(int64(2), "cat")
if err == nil || err.Error() != "strconv.ParseInt: parsing \"cat\": invalid syntax" {
t.Errorf("Expected <strconv.ParseInt: parsing \"cat\": invalid syntax> ,received: <%+v>", err)
}
}
func TestMultiplyInt64Error(t *testing.T) {
_, err := Multiply(int64(2), "cat")
if err == nil || err.Error() != "strconv.ParseInt: parsing \"cat\": invalid syntax" {
t.Errorf("Expected <strconv.ParseInt: parsing \"cat\": invalid syntax> ,received: <%+v>", err)
}
}
func TestIfaceAsBig(t *testing.T) {
timeDur := time.Duration(1)
rcv, _ := IfaceAsBig(timeDur)
if !reflect.DeepEqual(rcv, decimal.WithContext(DecimalContext).SetUint64(1)) {
t.Errorf("Expected %v but received %v", 1, rcv)
}
testInt := 2
rcv, _ = IfaceAsBig(testInt)
if !reflect.DeepEqual(rcv, decimal.WithContext(DecimalContext).SetUint64(2)) {
t.Errorf("Expected %v but received %v", 2, rcv)
}
testInt8 := int8(3)
rcv, _ = IfaceAsBig(testInt8)
if !reflect.DeepEqual(rcv, decimal.WithContext(DecimalContext).SetUint64(3)) {
t.Errorf("Expected %v but received %v", 3, rcv)
}
testInt16 := int16(4)
rcv, _ = IfaceAsBig(testInt16)
if !reflect.DeepEqual(rcv, decimal.WithContext(DecimalContext).SetUint64(4)) {
t.Errorf("Expected %v but received %v", 4, rcv)
}
testInt32 := int32(5)
rcv, _ = IfaceAsBig(testInt32)
if !reflect.DeepEqual(rcv, decimal.WithContext(DecimalContext).SetUint64(5)) {
t.Errorf("Expected %v but received %v", 5, rcv)
}
testInt64 := int64(6)
rcv, _ = IfaceAsBig(testInt64)
if !reflect.DeepEqual(rcv, decimal.WithContext(DecimalContext).SetUint64(6)) {
t.Errorf("Expected %v but received %v", 6, rcv)
}
uTestInt := uint(2)
rcv, _ = IfaceAsBig(uTestInt)
if !reflect.DeepEqual(rcv, decimal.WithContext(DecimalContext).SetUint64(2)) {
t.Errorf("Expected %v but received %v", 2, rcv)
}
uTestInt8 := uint8(3)
rcv, _ = IfaceAsBig(uTestInt8)
if !reflect.DeepEqual(rcv, decimal.WithContext(DecimalContext).SetUint64(3)) {
t.Errorf("Expected %v but received %v", 3, rcv)
}
uTestInt16 := uint16(4)
rcv, _ = IfaceAsBig(uTestInt16)
if !reflect.DeepEqual(rcv, decimal.WithContext(DecimalContext).SetUint64(4)) {
t.Errorf("Expected %v but received %v", 4, rcv)
}
uTestInt32 := uint32(5)
rcv, _ = IfaceAsBig(uTestInt32)
if !reflect.DeepEqual(rcv, decimal.WithContext(DecimalContext).SetUint64(5)) {
t.Errorf("Expected %v but received %v", 5, rcv)
}
uTestInt64 := uint64(6)
rcv, _ = IfaceAsBig(uTestInt64)
if !reflect.DeepEqual(rcv, decimal.WithContext(DecimalContext).SetUint64(6)) {
t.Errorf("Expected %v but received %v", 6, rcv)
}
testFloat64 := float64(12.2)
rcv, _ = IfaceAsBig(testFloat64)
if !reflect.DeepEqual(rcv, decimal.WithContext(DecimalContext).SetFloat64(12.2)) {
t.Errorf("Expected %v but received %v", 12.2, rcv)
}
testFloat32 := float32(12)
rcv, _ = IfaceAsBig(testFloat32)
if !reflect.DeepEqual(rcv, decimal.WithContext(DecimalContext).SetFloat64(float64(12))) {
t.Errorf("Expected %v but received %v", decimal.WithContext(DecimalContext).SetFloat64(float64(12)), rcv)
}
timeSuffix := "not_valid_timems"
_, err := IfaceAsBig(timeSuffix)
errExpect := `time: invalid duration "not_valid_timems"`
if err == nil || err.Error() != errExpect {
t.Errorf("Expected %v but received %v", errExpect, err)
}
num := "123"
rcv, err = IfaceAsBig(num)
if err != nil {
t.Error(err)
}
if !reflect.DeepEqual(rcv, decimal.WithContext(DecimalContext).SetUint64(123)) {
t.Errorf("Expected %v but received %v", decimal.WithContext(DecimalContext).SetUint64(123), rcv)
}
decBig := decimal.WithContext(DecimalContext).SetUint64(21)
rcv, _ = IfaceAsBig(decBig)
if !reflect.DeepEqual(rcv, decimal.WithContext(DecimalContext).SetUint64(21)) {
t.Errorf("Expected %v but received %v", decimal.WithContext(DecimalContext).SetUint64(21), rcv)
}
dec := NewDecimal(10, 0)
rcv, _ = IfaceAsBig(dec)
if !reflect.DeepEqual(rcv, decimal.WithContext(DecimalContext).SetUint64(10)) {
t.Errorf("Expected %v but received %v", decimal.WithContext(DecimalContext).SetUint64(10), rcv)
}
def := []string{"test"}
_, err = IfaceAsBig(def)
if err == nil || err.Error() != "cannot convert field: []string to decimal.Big" {
t.Error(err)
}
}
func TestReflectFieldMethodInterfaceStruct(t *testing.T) {
//Make obj a struct
type Obj struct {
Field1 string
Field2 string
}
obj := Obj{
Field1: "field1_string",
}
rcv, err := ReflectFieldMethodInterface(obj, "Field1")
if err != nil {
t.Error(err)
}
if rcv != "field1_string" {
t.Errorf("Expected %v but received %v", "field_string1", rcv)
}
}
func TestReflectFieldMethodInterfaceMap(t *testing.T) {
//Make obj a map[string]string
type Obj map[string]string
obj := &Obj{
"MapField1": "map_field_1",
}
rcv, err := ReflectFieldMethodInterface(obj, "MapField1")
if err != nil {
t.Error(err)
}
if rcv != "map_field_1" {
t.Errorf("Expected %v but received %v", "map_field_1", rcv)
}
}
func TestReflectFieldMethodInterfaceSlice(t *testing.T) {
obj := []string{"sliceField1"}
rcv, err := ReflectFieldMethodInterface(obj, "0")
if err != nil {
t.Error(err)
}
if rcv != "sliceField1" {
t.Errorf("Expected %v but received %v", "sliceField1", rcv)
}
_, err = ReflectFieldMethodInterface(obj, "invalid_index")
if err == nil || err.Error() != `strconv.Atoi: parsing "invalid_index": invalid syntax` {
t.Errorf("Expected %v but received %v", `strconv.Atoi: parsing "invalid_index": invalid syntax`, err)
}
_, err = ReflectFieldMethodInterface(obj, "2")
if err == nil || err.Error() != "index out of range" {
t.Errorf("Expected %v but received %v", "index out of range", err)
}
}
func TestReflectFieldMethodInterfaceDefault(t *testing.T) {
invalidKind := 2
_, err := ReflectFieldMethodInterface(invalidKind, "2")
if err == nil || err.Error() != "unsupported field kind: int" {
t.Errorf("Expected %v but received %v", "unsupported field kind: int", err)
}
}
func TestReflectFieldMethodInterfaceInvalidField(t *testing.T) {
type Obj map[string][]string
obj := &Obj{
"MapField1": []string{""},
}
_, err := ReflectFieldMethodInterface(obj, "NotExistingField")
if err == nil || err != ErrNotFound {
t.Errorf("Expected %v but received %v", ErrNotFound, err)
}
}
type Object struct{}
func (obj *Object) TestFunc1() string {
return "test"
}
func (obj *Object) TestFunc2() (string, string, error) {
return "test1", "test2", nil
}
func (obj *Object) TestFunc3(str string) {}
func (obj *Object) TestFunc4() (string, error) {
return "test1", nil
}
func (obj *Object) TestFunc5() (error, string) {
return nil, "test1"
}
func (obj *Object) TestFunc6() (string, error) {
return "test1", ErrNotFound
}
func TestReflectFieldMethodInterfaceInvalidFieldMethod1(t *testing.T) {
myObj := new(Object)
rcv, err := ReflectFieldMethodInterface(myObj, "TestFunc1")
if err != nil {
t.Error(err)
}
exp := "test"
if rcv != exp {
t.Errorf("Expected %v but received %v", exp, rcv)
}
}
func TestReflectFieldMethodInterfaceInvalidFieldMethod2(t *testing.T) {
myObj := new(Object)
_, err := ReflectFieldMethodInterface(myObj, "TestFunc2")
exp := "invalid function called"
if err == nil || err.Error() != exp {
t.Errorf("Expected %v but received %v", exp, err)
}
}
func TestReflectFieldMethodInterfaceInvalidFieldMethod3(t *testing.T) {
myObj := new(Object)
_, err := ReflectFieldMethodInterface(myObj, "TestFunc3")
exp := "invalid function called"
if err == nil || err.Error() != exp {
t.Errorf("Expected %v but received %v", exp, err)
}
}
func TestReflectFieldMethodInterfaceInvalidFieldMethod4(t *testing.T) {
myObj := new(Object)
rcv, err := ReflectFieldMethodInterface(myObj, "TestFunc4")
if err != nil {
t.Error(err)
}
exp := "test1"
if rcv != exp {
t.Errorf("Expected %v but received %v", exp, rcv)
}
}
func TestReflectFieldMethodInterfaceInvalidFieldMethod5(t *testing.T) {
myObj := new(Object)
_, err := ReflectFieldMethodInterface(myObj, "TestFunc5")
exp := "invalid function called"
if err == nil || err.Error() != exp {
t.Errorf("Expected %v but received %v", exp, err)
}
}
func TestReflectFieldMethodInterfaceInvalidFieldMethod6(t *testing.T) {
myObj := new(Object)
_, err := ReflectFieldMethodInterface(myObj, "TestFunc6")
exp := ErrNotFound
if err == nil || err != exp {
t.Errorf("Expected %v but received %v", exp, err)
}
}
func TestIfaceAsStringSliceString(t *testing.T) {
//case of []string
fld := []string{"string_ex"}
rcv, err := IfaceAsStringSlice(fld)
if err != nil {
t.Error(err)
}
exp := []string{"string_ex"}
if !reflect.DeepEqual(rcv, exp) {
t.Errorf("Expected %v \n but received \n %v", exp, rcv)
}
}
func TestIfaceAsStringSliceInt(t *testing.T) {
//case of []int
fld := []int{1, 2, 3}
rcv, err := IfaceAsStringSlice(fld)
if err != nil {
t.Error(err)
}
exp := []string{"1", "2", "3"}
if !reflect.DeepEqual(rcv, exp) {
t.Errorf("Expected %v \n but received \n %v", exp, rcv)
}
}
func TestIfaceAsStringSliceInt32(t *testing.T) {
//case of []int32
fld := []int32{1, 2, 3}
rcv, err := IfaceAsStringSlice(fld)
if err != nil {
t.Error(err)
}
exp := []string{"1", "2", "3"}
if !reflect.DeepEqual(rcv, exp) {
t.Errorf("Expected %v \n but received \n %v", exp, rcv)
}
}
func TestIfaceAsStringSliceInt64(t *testing.T) {
//case of []int64
fld := []int64{1, 2, 3}
rcv, err := IfaceAsStringSlice(fld)
if err != nil {
t.Error(err)
}
exp := []string{"1", "2", "3"}
if !reflect.DeepEqual(rcv, exp) {
t.Errorf("Expected %v \n but received \n %v", exp, rcv)
}
}
func TestIfaceAsStringSliceUInt32(t *testing.T) {
//case of []uint32
fld := []uint32{1, 2, 3}
rcv, err := IfaceAsStringSlice(fld)
if err != nil {
t.Error(err)
}
exp := []string{"1", "2", "3"}
if !reflect.DeepEqual(rcv, exp) {
t.Errorf("Expected %v \n but received \n %v", exp, rcv)
}
}
func TestIfaceAsStringSliceUInt64(t *testing.T) {
//case of []uint64
fld := []uint64{1, 2, 3}
rcv, err := IfaceAsStringSlice(fld)
if err != nil {
t.Error(err)
}
exp := []string{"1", "2", "3"}
if !reflect.DeepEqual(rcv, exp) {
t.Errorf("Expected %v \n but received \n %v", exp, rcv)
}
}
func TestIfaceAsStringSliceBool(t *testing.T) {
//case of []bool
fld := []bool{true, false, false}
rcv, err := IfaceAsStringSlice(fld)
if err != nil {
t.Error(err)
}
exp := []string{"true", "false", "false"}
if !reflect.DeepEqual(rcv, exp) {
t.Errorf("Expected %v \n but received \n %v", exp, rcv)
}
}
func TestIfaceAsStringSliceFloat32(t *testing.T) {
//case of []float32
fld := []float32{1.2, 2.8, 3.1}
rcv, err := IfaceAsStringSlice(fld)
if err != nil {
t.Error(err)
}
exp := []string{"1.2000000476837158", "2.799999952316284", "3.0999999046325684"}
if !reflect.DeepEqual(rcv, exp) {
t.Errorf("Expected %v \n but received \n %v", exp, rcv)
}
}
func TestIfaceAsStringSliceFloat64(t *testing.T) {
//case of []float64
fld := []float64{1.2, 2.8, 3.1}
rcv, err := IfaceAsStringSlice(fld)
if err != nil {
t.Error(err)
}
exp := []string{"1.2", "2.8", "3.1"}
if !reflect.DeepEqual(rcv, exp) {
t.Errorf("Expected %v \n but received \n %v", exp, rcv)
}
}
func TestIfaceAsStringSliceInterface(t *testing.T) {
//case of []interface
fld := []any{1.2, "string", false}
rcv, err := IfaceAsStringSlice(fld)
if err != nil {
t.Error(err)
}
exp := []string{"1.2", "string", "false"}
if !reflect.DeepEqual(rcv, exp) {
t.Errorf("Expected %v \n but received \n %v", exp, rcv)
}
}
func TestIfaceAsStringSliceStringNonSlice(t *testing.T) {
//case of string
fld := "very;long;string"
rcv, err := IfaceAsStringSlice(fld)
if err != nil {
t.Error(err)
}
exp := []string{"very", "long", "string"}
if !reflect.DeepEqual(rcv, exp) {
t.Errorf("Expected %v \n but received \n %v", exp, rcv)
}
}
func TestIfaceAsStringSliceDefault(t *testing.T) {
//case of default
fld := time.Second * 2
exp := "cannot convert field: 2s to []string"
_, err := IfaceAsStringSlice(fld)
if err.Error() != exp {
t.Errorf("Expected error")
}
}
func TestOptAsBool(t *testing.T) {
opts := map[string]any{
"field1": 2,
}
rcv := OptAsBool(opts, "field1")
if !rcv {
t.Error("Output should've been true")
}
rcv = OptAsBool(opts, "field2")
if rcv {
t.Error("Output should've been false")
}
}
func TestOptAsBoolOrDef(t *testing.T) {
opts := map[string]any{
"field1": 2,
}
rcv := OptAsBoolOrDef(opts, "field1", false)
if !rcv {
t.Error("Output should've been true")
}
rcv = OptAsBoolOrDef(opts, "field2", false)
if rcv {
t.Error("Output should've been false")
}
}
func TestOptAsStringSlice(t *testing.T) {
opts := map[string]any{
"field1": []string{"val1", "val2"},
}
rcv, err := OptAsStringSlice(opts, "field1")
if err != nil {
t.Error(err)
}
exp := []string{"val1", "val2"}
if !reflect.DeepEqual(rcv, exp) {
t.Errorf("Expected %v \n but received \n %v", exp, rcv)
}
_, err = OptAsStringSlice(opts, "field2")
if err != nil {
t.Error(err)
}
opts["field1"] = time.Second * 2
_, err = OptAsStringSlice(opts, "field1")
errExp := "error for option <field1>: cannot convert field: 2s to []string"
if err == nil || err.Error() != errExp {
t.Errorf("Expected %v \n but received \n %v", errExp, err)
}
}
func TestStringAsBig(t *testing.T) {
itm := "2ns"
v, err := StringAsBig(itm)
if err != nil {
t.Error(err)
}
if exp := decimal.New(2, 0); exp.Cmp(v) != 0 {
t.Errorf("Expected %v \n but received \n %v", exp, v)
}
itm = ""
if v, err := StringAsBig(itm); err != nil {
t.Error(err)
} else if exp := decimal.New(0, 0); exp.Cmp(v) != 0 {
t.Errorf("Expected %v \n but received \n %v", exp, v)
}
itm = "2"
if v, err := StringAsBig(itm); err != nil {
t.Error(err)
} else if exp := decimal.New(2, 0); exp.Cmp(v) != 0 {
t.Errorf("Expected %v \n but received \n %v", exp, v)
}
}
func TestIfaceAsTInt(t *testing.T) {
var testInt32 int32 = 132
var testInt64 int64 = 164
var testFloat32 float32 = 15.32
var expInt32 int32 = 132
var expInt64 int64 = 164
var expFloat32 float32 = 15.32
if rcv, err := IfaceAsInt(testInt32); err != nil {
t.Error(err)
} else if rcv != int(expInt32) {
t.Errorf("Expected <%+v>, received <%+v>", expInt32, rcv)
}
if rcv, err := IfaceAsInt(testInt64); err != nil {
t.Error(err)
} else if rcv != int(expInt64) {
t.Errorf("Expected <%+v>, received <%+v>", expInt32, rcv)
}
if rcv, err := IfaceAsInt(testFloat32); err != nil {
t.Error(err)
} else if rcv != int(expFloat32) {
t.Errorf("Expected <%+v>, received <%+v>", expInt32, rcv)
}
}