mirror of
https://github.com/gogf/gf.git
synced 2025-04-05 11:18:50 +08:00
improve unit testing cases
This commit is contained in:
parent
f18e6f078c
commit
e57942b374
@ -49,84 +49,89 @@ var testData = map[string]interface{}{
|
||||
var testBitData = []int{0, 99, 122, 129, 222, 999, 22322}
|
||||
|
||||
func Test_EncodeAndDecode(t *testing.T) {
|
||||
for k, v := range testData {
|
||||
ve := gbinary.Encode(v)
|
||||
ve1 := gbinary.EncodeByLength(len(ve), v)
|
||||
gtest.C(t, func(t *gtest.T) {
|
||||
for k, v := range testData {
|
||||
ve := gbinary.Encode(v)
|
||||
ve1 := gbinary.EncodeByLength(len(ve), v)
|
||||
|
||||
//t.Logf("%s:%v, encoded:%v\n", k, v, ve)
|
||||
switch v.(type) {
|
||||
case int:
|
||||
t.Assert(gbinary.DecodeToInt(ve), v)
|
||||
t.Assert(gbinary.DecodeToInt(ve1), v)
|
||||
case int8:
|
||||
t.Assert(gbinary.DecodeToInt8(ve), v)
|
||||
t.Assert(gbinary.DecodeToInt8(ve1), v)
|
||||
case int16:
|
||||
t.Assert(gbinary.DecodeToInt16(ve), v)
|
||||
t.Assert(gbinary.DecodeToInt16(ve1), v)
|
||||
case int32:
|
||||
t.Assert(gbinary.DecodeToInt32(ve), v)
|
||||
t.Assert(gbinary.DecodeToInt32(ve1), v)
|
||||
case int64:
|
||||
t.Assert(gbinary.DecodeToInt64(ve), v)
|
||||
t.Assert(gbinary.DecodeToInt64(ve1), v)
|
||||
case uint:
|
||||
t.Assert(gbinary.DecodeToUint(ve), v)
|
||||
t.Assert(gbinary.DecodeToUint(ve1), v)
|
||||
case uint8:
|
||||
t.Assert(gbinary.DecodeToUint8(ve), v)
|
||||
t.Assert(gbinary.DecodeToUint8(ve1), v)
|
||||
case uint16:
|
||||
t.Assert(gbinary.DecodeToUint16(ve1), v)
|
||||
t.Assert(gbinary.DecodeToUint16(ve), v)
|
||||
case uint32:
|
||||
t.Assert(gbinary.DecodeToUint32(ve1), v)
|
||||
t.Assert(gbinary.DecodeToUint32(ve), v)
|
||||
case uint64:
|
||||
t.Assert(gbinary.DecodeToUint64(ve), v)
|
||||
t.Assert(gbinary.DecodeToUint64(ve1), v)
|
||||
case bool:
|
||||
t.Assert(gbinary.DecodeToBool(ve), v)
|
||||
t.Assert(gbinary.DecodeToBool(ve1), v)
|
||||
case string:
|
||||
t.Assert(gbinary.DecodeToString(ve), v)
|
||||
t.Assert(gbinary.DecodeToString(ve1), v)
|
||||
case float32:
|
||||
t.Assert(gbinary.DecodeToFloat32(ve), v)
|
||||
t.Assert(gbinary.DecodeToFloat32(ve1), v)
|
||||
case float64:
|
||||
t.Assert(gbinary.DecodeToFloat64(ve), v)
|
||||
t.Assert(gbinary.DecodeToFloat64(ve1), v)
|
||||
default:
|
||||
if v == nil {
|
||||
continue
|
||||
//t.Logf("%s:%v, encoded:%v\n", k, v, ve)
|
||||
switch v.(type) {
|
||||
case int:
|
||||
t.Assert(gbinary.DecodeToInt(ve), v)
|
||||
t.Assert(gbinary.DecodeToInt(ve1), v)
|
||||
case int8:
|
||||
t.Assert(gbinary.DecodeToInt8(ve), v)
|
||||
t.Assert(gbinary.DecodeToInt8(ve1), v)
|
||||
case int16:
|
||||
t.Assert(gbinary.DecodeToInt16(ve), v)
|
||||
t.Assert(gbinary.DecodeToInt16(ve1), v)
|
||||
case int32:
|
||||
t.Assert(gbinary.DecodeToInt32(ve), v)
|
||||
t.Assert(gbinary.DecodeToInt32(ve1), v)
|
||||
case int64:
|
||||
t.Assert(gbinary.DecodeToInt64(ve), v)
|
||||
t.Assert(gbinary.DecodeToInt64(ve1), v)
|
||||
case uint:
|
||||
t.Assert(gbinary.DecodeToUint(ve), v)
|
||||
t.Assert(gbinary.DecodeToUint(ve1), v)
|
||||
case uint8:
|
||||
t.Assert(gbinary.DecodeToUint8(ve), v)
|
||||
t.Assert(gbinary.DecodeToUint8(ve1), v)
|
||||
case uint16:
|
||||
t.Assert(gbinary.DecodeToUint16(ve1), v)
|
||||
t.Assert(gbinary.DecodeToUint16(ve), v)
|
||||
case uint32:
|
||||
t.Assert(gbinary.DecodeToUint32(ve1), v)
|
||||
t.Assert(gbinary.DecodeToUint32(ve), v)
|
||||
case uint64:
|
||||
t.Assert(gbinary.DecodeToUint64(ve), v)
|
||||
t.Assert(gbinary.DecodeToUint64(ve1), v)
|
||||
case bool:
|
||||
t.Assert(gbinary.DecodeToBool(ve), v)
|
||||
t.Assert(gbinary.DecodeToBool(ve1), v)
|
||||
case string:
|
||||
t.Assert(gbinary.DecodeToString(ve), v)
|
||||
t.Assert(gbinary.DecodeToString(ve1), v)
|
||||
case float32:
|
||||
t.Assert(gbinary.DecodeToFloat32(ve), v)
|
||||
t.Assert(gbinary.DecodeToFloat32(ve1), v)
|
||||
case float64:
|
||||
t.Assert(gbinary.DecodeToFloat64(ve), v)
|
||||
t.Assert(gbinary.DecodeToFloat64(ve1), v)
|
||||
default:
|
||||
if v == nil {
|
||||
continue
|
||||
}
|
||||
res := make([]byte, len(ve))
|
||||
err := gbinary.Decode(ve, res)
|
||||
if err != nil {
|
||||
t.Errorf("test data: %s, %v, error:%v", k, v, err)
|
||||
}
|
||||
t.Assert(res, v)
|
||||
}
|
||||
res := make([]byte, len(ve))
|
||||
err := gbinary.Decode(ve, res)
|
||||
if err != nil {
|
||||
t.Errorf("test data: %s, %v, error:%v", k, v, err)
|
||||
}
|
||||
t.Assert(res, v)
|
||||
}
|
||||
}
|
||||
})
|
||||
}
|
||||
|
||||
func Test_EncodeStruct(t *testing.T) {
|
||||
user := User{"wenzi1", 999, "www.baidu.com"}
|
||||
ve := gbinary.Encode(user)
|
||||
s := gbinary.DecodeToString(ve)
|
||||
t.Assert(string(s), s)
|
||||
gtest.C(t, func(t *gtest.T) {
|
||||
user := User{"wenzi1", 999, "www.baidu.com"}
|
||||
ve := gbinary.Encode(user)
|
||||
s := gbinary.DecodeToString(ve)
|
||||
t.Assert(s, s)
|
||||
})
|
||||
}
|
||||
|
||||
func Test_Bits(t *testing.T) {
|
||||
for i := range testBitData {
|
||||
bits := make([]gbinary.Bit, 0)
|
||||
res := gbinary.EncodeBits(bits, testBitData[i], 64)
|
||||
gtest.C(t, func(t *gtest.T) {
|
||||
for i := range testBitData {
|
||||
bits := make([]gbinary.Bit, 0)
|
||||
res := gbinary.EncodeBits(bits, testBitData[i], 64)
|
||||
|
||||
t.Assert(gbinary.DecodeBits(res), testBitData[i])
|
||||
t.Assert(gbinary.DecodeBitsToUint(res), uint(testBitData[i]))
|
||||
|
||||
t.Assert(gbinary.DecodeBytesToBits(gbinary.EncodeBitsToBytes(res)), res)
|
||||
}
|
||||
t.Assert(gbinary.DecodeBits(res), testBitData[i])
|
||||
t.Assert(gbinary.DecodeBitsToUint(res), uint(testBitData[i]))
|
||||
|
||||
t.Assert(gbinary.DecodeBytesToBits(gbinary.EncodeBitsToBytes(res)), res)
|
||||
}
|
||||
})
|
||||
}
|
||||
|
@ -8,7 +8,6 @@ package gjson_test
|
||||
|
||||
import (
|
||||
"github.com/gogf/gf/encoding/gjson"
|
||||
"github.com/gogf/gf/frame/g"
|
||||
"github.com/gogf/gf/test/gtest"
|
||||
"testing"
|
||||
)
|
||||
@ -91,7 +90,6 @@ func Test_ToStruct1(t *testing.T) {
|
||||
t.Assert(err, nil)
|
||||
err = j.ToStruct(data)
|
||||
t.Assert(err, nil)
|
||||
g.Dump(data)
|
||||
})
|
||||
}
|
||||
|
||||
|
@ -18,8 +18,9 @@ import (
|
||||
)
|
||||
|
||||
func Test_Database(t *testing.T) {
|
||||
databaseContent := gfile.GetContents(gfile.Join(gdebug.TestDataPath(), "database", "config.toml"))
|
||||
|
||||
databaseContent := gfile.GetContents(
|
||||
gfile.Join(gdebug.TestDataPath(), "database", "config.toml"),
|
||||
)
|
||||
gtest.C(t, func(t *gtest.T) {
|
||||
var err error
|
||||
dirPath := gfile.Join(gfile.TempDir(), gtime.TimestampNanoStr())
|
||||
@ -33,14 +34,12 @@ func Test_Database(t *testing.T) {
|
||||
|
||||
err = gins.Config().AddPath(dirPath)
|
||||
t.Assert(err, nil)
|
||||
})
|
||||
|
||||
defer gins.Config().Clear()
|
||||
defer gins.Config().Clear()
|
||||
|
||||
// for gfsnotify callbacks to refresh cache of config file
|
||||
time.Sleep(500 * time.Millisecond)
|
||||
// for gfsnotify callbacks to refresh cache of config file
|
||||
time.Sleep(500 * time.Millisecond)
|
||||
|
||||
gtest.C(t, func(t *gtest.T) {
|
||||
//fmt.Println("gins Test_Database", Config().Get("test"))
|
||||
|
||||
dbDefault := gins.Database()
|
||||
|
@ -18,7 +18,9 @@ import (
|
||||
)
|
||||
|
||||
func Test_Redis(t *testing.T) {
|
||||
redisContent := gfile.GetContents(gfile.Join(gdebug.TestDataPath(), "redis", "config.toml"))
|
||||
redisContent := gfile.GetContents(
|
||||
gfile.Join(gdebug.TestDataPath(), "redis", "config.toml"),
|
||||
)
|
||||
|
||||
gtest.C(t, func(t *gtest.T) {
|
||||
var err error
|
||||
@ -33,14 +35,12 @@ func Test_Redis(t *testing.T) {
|
||||
|
||||
err = gins.Config().AddPath(dirPath)
|
||||
t.Assert(err, nil)
|
||||
})
|
||||
|
||||
defer gins.Config().Clear()
|
||||
defer gins.Config().Clear()
|
||||
|
||||
// for gfsnotify callbacks to refresh cache of config file
|
||||
time.Sleep(500 * time.Millisecond)
|
||||
// for gfsnotify callbacks to refresh cache of config file
|
||||
time.Sleep(500 * time.Millisecond)
|
||||
|
||||
gtest.C(t, func(t *gtest.T) {
|
||||
//fmt.Println("gins Test_Redis", Config().Get("test"))
|
||||
|
||||
redisDefault := gins.Redis()
|
||||
|
2
os/gres/testdata/data/data.go
vendored
2
os/gres/testdata/data/data.go
vendored
File diff suppressed because one or more lines are too long
2
os/gres/testdata/testdata.go
vendored
2
os/gres/testdata/testdata.go
vendored
File diff suppressed because one or more lines are too long
Loading…
x
Reference in New Issue
Block a user