1
0
mirror of https://github.com/gogf/gf.git synced 2025-04-05 11:18:50 +08:00
gf/util/gconv/gconv_z_unit_uint_test.go

293 lines
7.5 KiB
Go

// Copyright GoFrame Author(https://goframe.org). All Rights Reserved.
//
// This Source Code Form is subject to the terms of the MIT License.
// If a copy of the MIT was not distributed with this file,
// You can obtain one at https://github.com/gogf/gf.
package gconv_test
import (
"reflect"
"testing"
"github.com/gogf/gf/v2/container/gvar"
"github.com/gogf/gf/v2/test/gtest"
"github.com/gogf/gf/v2/util/gconv"
)
var (
uintTestValue = uint(123)
uint8TestValue = uint8(123)
uint16TestValue = uint16(123)
uint32TestValue = uint32(123)
uint64TestValue = uint64(123)
)
var uintTests = []struct {
value interface{}
expect uint
expect8 uint8
expect16 uint16
expect32 uint32
expect64 uint64
}{
{true, 1, 1, 1, 1, 1},
{false, 0, 0, 0, 0, 0},
{int(0), 0, 0, 0, 0, 0},
{int(123), 123, 123, 123, 123, 123},
{int8(123), 123, 123, 123, 123, 123},
{int16(123), 123, 123, 123, 123, 123},
{int32(123), 123, 123, 123, 123, 123},
{int64(123), 123, 123, 123, 123, 123},
{uint(0), 0, 0, 0, 0, 0},
{uint(123), 123, 123, 123, 123, 123},
{uint8(123), 123, 123, 123, 123, 123},
{uint16(123), 123, 123, 123, 123, 123},
{uint32(123), 123, 123, 123, 123, 123},
{uint64(123), 123, 123, 123, 123, 123},
{uintptr(0), 0, 0, 0, 0, 0},
{uintptr(123), 123, 123, 123, 123, 123},
{rune(0), 0, 0, 0, 0, 0},
{rune(49), 49, 49, 49, 49, 49},
{float32(123), 123, 123, 123, 123, 123},
{float64(123.456), 123, 123, 123, 123, 123},
{[]byte(""), 0, 0, 0, 0, 0},
{"", 0, 0, 0, 0, 0},
{"0", 0, 0, 0, 0, 0},
{"1", 1, 1, 1, 1, 1},
{"+1", 1, 1, 1, 1, 1},
{"0xA", 10, 10, 10, 10, 10},
{"0XA", 10, 10, 10, 10, 10},
{"123.456", 123, 123, 123, 123, 123},
{"true", 0, 0, 0, 0, 0},
{"false", 0, 0, 0, 0, 0},
{"on", 0, 0, 0, 0, 0},
{"off", 0, 0, 0, 0, 0},
{"NaN", 0, 0, 0, 0, 0},
{complex(1, 2), 0, 0, 0, 0, 0},
{complex(123.456, 789.123), 0, 0, 0, 0, 0},
{[3]int{1, 2, 3}, 0, 0, 0, 0, 0},
{[]int{1, 2, 3}, 0, 0, 0, 0, 0},
{map[int]int{1: 1}, 0, 0, 0, 0, 0},
{map[string]string{"Earth": "珠穆朗玛峰"}, 0, 0, 0, 0, 0},
{struct{}{}, 0, 0, 0, 0, 0},
{nil, 0, 0, 0, 0, 0},
{(*uint)(nil), 0, 0, 0, 0, 0},
{(*uint8)(nil), 0, 0, 0, 0, 0},
{(*uint16)(nil), 0, 0, 0, 0, 0},
{(*uint32)(nil), 0, 0, 0, 0, 0},
{(*uint64)(nil), 0, 0, 0, 0, 0},
{gvar.New(123), 123, 123, 123, 123, 123},
{gvar.New(123.456), 123, 123, 123, 123, 123},
{&uintTestValue, 123, 123, 123, 123, 123},
{&uint8TestValue, 123, 123, 123, 123, 123},
{&uint16TestValue, 123, 123, 123, 123, 123},
{&uint32TestValue, 123, 123, 123, 123, 123},
{&uint64TestValue, 123, 123, 123, 123, 123},
{(myUint)(uintTestValue), 123, 123, 123, 123, 123},
{(myUint8)(uint8TestValue), 123, 123, 123, 123, 123},
{(myUint16)(uint16TestValue), 123, 123, 123, 123, 123},
{(myUint32)(uint32TestValue), 123, 123, 123, 123, 123},
{(myUint64)(uint64TestValue), 123, 123, 123, 123, 123},
{(*myUint)(&uintTestValue), 123, 123, 123, 123, 123},
{(*myUint8)(&uint8TestValue), 123, 123, 123, 123, 123},
{(*myUint16)(&uint16TestValue), 123, 123, 123, 123, 123},
{(*myUint32)(&uint32TestValue), 123, 123, 123, 123, 123},
{(*myUint64)(&uint64TestValue), 123, 123, 123, 123, 123},
{(*myUint)(nil), 0, 0, 0, 0, 0},
{(*myUint8)(nil), 0, 0, 0, 0, 0},
{(*myUint16)(nil), 0, 0, 0, 0, 0},
{(*myUint32)(nil), 0, 0, 0, 0, 0},
{(*myUint64)(nil), 0, 0, 0, 0, 0},
}
func TestUint(t *testing.T) {
gtest.C(t, func(t *gtest.T) {
for _, v := range uintTests {
//t.Logf(`%+v`, v)
t.AssertEQ(gconv.Uint(v.value), v.expect)
}
})
}
func TestUint8(t *testing.T) {
gtest.C(t, func(t *gtest.T) {
for _, test := range uintTests {
t.AssertEQ(gconv.Uint8(test.value), test.expect8)
}
})
}
func TestUint16(t *testing.T) {
gtest.C(t, func(t *gtest.T) {
for _, test := range uintTests {
t.AssertEQ(gconv.Uint16(test.value), test.expect16)
}
})
}
func TestUint32(t *testing.T) {
gtest.C(t, func(t *gtest.T) {
for _, test := range uintTests {
t.AssertEQ(gconv.Uint32(test.value), test.expect32)
}
})
}
func TestUint64(t *testing.T) {
gtest.C(t, func(t *gtest.T) {
for _, test := range uintTests {
t.AssertEQ(gconv.Uint64(test.value), test.expect64)
}
})
}
func TestUints(t *testing.T) {
gtest.C(t, func(t *gtest.T) {
for _, test := range uintTests {
if test.value == nil {
t.AssertNil(gconv.Uints(test.value))
continue
}
var (
sliceType = reflect.SliceOf(reflect.TypeOf(test.value))
uints = reflect.MakeSlice(sliceType, 0, 0)
expects = []uint{
test.expect, test.expect,
}
)
uints = reflect.Append(uints, reflect.ValueOf(test.value))
uints = reflect.Append(uints, reflect.ValueOf(test.value))
t.AssertEQ(gconv.Uints(uints.Interface()), expects)
t.AssertEQ(gconv.SliceUint(uints.Interface()), expects)
}
})
// Test for special types.
gtest.C(t, func(t *gtest.T) {
// string
t.AssertEQ(gconv.Uints(""), []uint{})
t.AssertEQ(gconv.Uints("123"), []uint{123})
// []int8 json
t.AssertEQ(gconv.Uints([]uint8(`{"Name":"Earth"}`)),
[]uint{123, 34, 78, 97, 109, 101, 34, 58, 34, 69, 97, 114, 116, 104, 34, 125})
// []interface
t.AssertEQ(gconv.Uints([]interface{}{1, 2, 3}), []uint{1, 2, 3})
// gvar.Var
t.AssertEQ(gconv.Uints(
gvar.New([]uint{1, 2, 3}),
), []uint{1, 2, 3})
// array
t.AssertEQ(gconv.Uints("[1, 2]"), []uint{1, 2})
})
}
func TestUint32s(t *testing.T) {
gtest.C(t, func(t *gtest.T) {
for _, test := range uintTests {
if test.value == nil {
t.AssertNil(gconv.Uint32s(test.value))
continue
}
var (
sliceType = reflect.SliceOf(reflect.TypeOf(test.value))
uint32s = reflect.MakeSlice(sliceType, 0, 0)
expects = []uint32{
test.expect32, test.expect32,
}
)
uint32s = reflect.Append(uint32s, reflect.ValueOf(test.value))
uint32s = reflect.Append(uint32s, reflect.ValueOf(test.value))
t.AssertEQ(gconv.Uint32s(uint32s.Interface()), expects)
t.AssertEQ(gconv.SliceUint32(uint32s.Interface()), expects)
}
})
// Test for special types.
gtest.C(t, func(t *gtest.T) {
// string
t.AssertEQ(gconv.Uint32s(""), []uint32{})
t.AssertEQ(gconv.Uint32s("123"), []uint32{123})
// []int8 json
t.AssertEQ(gconv.Uint32s([]uint8(`{"Name":"Earth"}"`)),
[]uint32{123, 34, 78, 97, 109, 101, 34, 58, 34, 69, 97, 114, 116, 104, 34, 125, 34})
// []interface
t.AssertEQ(gconv.Uint32s([]interface{}{1, 2, 3}), []uint32{1, 2, 3})
// gvar.Var
t.AssertEQ(gconv.Uint32s(
gvar.New([]uint32{1, 2, 3}),
), []uint32{1, 2, 3})
})
}
func TestUint64s(t *testing.T) {
gtest.C(t, func(t *gtest.T) {
for _, test := range uintTests {
if test.value == nil {
t.AssertNil(gconv.Uint64s(test.value))
continue
}
var (
sliceType = reflect.SliceOf(reflect.TypeOf(test.value))
uint64s = reflect.MakeSlice(sliceType, 0, 0)
expects = []uint64{
test.expect64, test.expect64,
}
)
uint64s = reflect.Append(uint64s, reflect.ValueOf(test.value))
uint64s = reflect.Append(uint64s, reflect.ValueOf(test.value))
t.AssertEQ(gconv.Uint64s(uint64s.Interface()), expects)
t.AssertEQ(gconv.SliceUint64(uint64s.Interface()), expects)
}
})
// Test for special types.
gtest.C(t, func(t *gtest.T) {
// string
t.AssertEQ(gconv.Uint64s(""), []uint64{})
t.AssertEQ(gconv.Uint64s("123"), []uint64{123})
// []int8 json
t.AssertEQ(gconv.Uint64s([]uint8(`{"Name":"Earth"}"`)),
[]uint64{123, 34, 78, 97, 109, 101, 34, 58, 34, 69, 97, 114, 116, 104, 34, 125, 34})
// []interface
t.AssertEQ(gconv.Uint64s([]interface{}{1, 2, 3}), []uint64{1, 2, 3})
// gvar.Var
t.AssertEQ(gconv.Uint64s(
gvar.New([]uint64{1, 2, 3}),
), []uint64{1, 2, 3})
})
}