mirror of
https://gitee.com/johng/gf.git
synced 2024-12-03 04:37:49 +08:00
376 lines
7.4 KiB
Go
376 lines
7.4 KiB
Go
// Copyright 2019 gf Author(https://github.com/gogf/gf). 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 gredis_test
|
|
|
|
import (
|
|
"github.com/gogf/gf/container/gvar"
|
|
"github.com/gogf/gf/frame/g"
|
|
"github.com/gogf/gf/util/guid"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/gogf/gf/os/gtime"
|
|
"github.com/gogf/gf/util/gconv"
|
|
|
|
"github.com/gogf/gf/database/gredis"
|
|
"github.com/gogf/gf/test/gtest"
|
|
)
|
|
|
|
var (
|
|
config = gredis.Config{
|
|
Host: "127.0.0.1",
|
|
Port: 6379,
|
|
Db: 1,
|
|
}
|
|
)
|
|
|
|
func Test_NewClose(t *testing.T) {
|
|
gtest.C(t, func(t *gtest.T) {
|
|
redis := gredis.New(config)
|
|
t.AssertNE(redis, nil)
|
|
err := redis.Close()
|
|
t.Assert(err, nil)
|
|
})
|
|
}
|
|
|
|
func Test_Do(t *testing.T) {
|
|
gtest.C(t, func(t *gtest.T) {
|
|
redis := gredis.New(config)
|
|
defer redis.Close()
|
|
_, err := redis.Do("SET", "k", "v")
|
|
t.Assert(err, nil)
|
|
|
|
r, err := redis.Do("GET", "k")
|
|
t.Assert(err, nil)
|
|
t.Assert(r, []byte("v"))
|
|
|
|
_, err = redis.Do("DEL", "k")
|
|
t.Assert(err, nil)
|
|
r, err = redis.Do("GET", "k")
|
|
t.Assert(err, nil)
|
|
t.Assert(r, nil)
|
|
})
|
|
}
|
|
|
|
func Test_Stats(t *testing.T) {
|
|
gtest.C(t, func(t *gtest.T) {
|
|
redis := gredis.New(config)
|
|
defer redis.Close()
|
|
redis.SetMaxIdle(2)
|
|
redis.SetMaxActive(100)
|
|
redis.SetIdleTimeout(500 * time.Millisecond)
|
|
redis.SetMaxConnLifetime(500 * time.Millisecond)
|
|
|
|
array := make([]*gredis.Conn, 0)
|
|
for i := 0; i < 10; i++ {
|
|
array = append(array, redis.Conn())
|
|
}
|
|
stats := redis.Stats()
|
|
t.Assert(stats.ActiveCount, 10)
|
|
t.Assert(stats.IdleCount, 0)
|
|
for i := 0; i < 10; i++ {
|
|
array[i].Close()
|
|
}
|
|
stats = redis.Stats()
|
|
t.Assert(stats.ActiveCount, 2)
|
|
t.Assert(stats.IdleCount, 2)
|
|
//time.Sleep(3000*time.Millisecond)
|
|
//stats = redis.Stats()
|
|
//fmt.Println(stats)
|
|
//t.Assert(stats.ActiveCount, 0)
|
|
//t.Assert(stats.IdleCount, 0)
|
|
})
|
|
}
|
|
|
|
func Test_Conn(t *testing.T) {
|
|
gtest.C(t, func(t *gtest.T) {
|
|
redis := gredis.New(config)
|
|
defer redis.Close()
|
|
conn := redis.Conn()
|
|
defer conn.Close()
|
|
|
|
key := gconv.String(gtime.TimestampNano())
|
|
value := []byte("v")
|
|
r, err := conn.Do("SET", key, value)
|
|
t.Assert(err, nil)
|
|
|
|
r, err = conn.Do("GET", key)
|
|
t.Assert(err, nil)
|
|
t.Assert(r, value)
|
|
|
|
_, err = conn.Do("DEL", key)
|
|
t.Assert(err, nil)
|
|
r, err = conn.Do("GET", key)
|
|
t.Assert(err, nil)
|
|
t.Assert(r, nil)
|
|
})
|
|
}
|
|
|
|
func Test_Instance(t *testing.T) {
|
|
gtest.C(t, func(t *gtest.T) {
|
|
group := "my-test"
|
|
gredis.SetConfig(config, group)
|
|
defer gredis.RemoveConfig(group)
|
|
redis := gredis.Instance(group)
|
|
defer redis.Close()
|
|
|
|
conn := redis.Conn()
|
|
defer conn.Close()
|
|
|
|
_, err := conn.Do("SET", "k", "v")
|
|
t.Assert(err, nil)
|
|
|
|
r, err := conn.Do("GET", "k")
|
|
t.Assert(err, nil)
|
|
t.Assert(r, []byte("v"))
|
|
|
|
_, err = conn.Do("DEL", "k")
|
|
t.Assert(err, nil)
|
|
r, err = conn.Do("GET", "k")
|
|
t.Assert(err, nil)
|
|
t.Assert(r, nil)
|
|
})
|
|
}
|
|
|
|
func Test_Error(t *testing.T) {
|
|
gtest.C(t, func(t *gtest.T) {
|
|
config1 := gredis.Config{
|
|
Host: "127.0.0.2",
|
|
Port: 6379,
|
|
Db: 1,
|
|
ConnectTimeout: time.Second,
|
|
}
|
|
redis := gredis.New(config1)
|
|
_, err := redis.Do("info")
|
|
t.AssertNE(err, nil)
|
|
|
|
config1 = gredis.Config{
|
|
Host: "127.0.0.1",
|
|
Port: 6379,
|
|
Db: 1,
|
|
Pass: "666666",
|
|
}
|
|
redis = gredis.New(config1)
|
|
_, err = redis.Do("info")
|
|
t.AssertNE(err, nil)
|
|
|
|
config1 = gredis.Config{
|
|
Host: "127.0.0.1",
|
|
Port: 6379,
|
|
Db: 100,
|
|
}
|
|
redis = gredis.New(config1)
|
|
_, err = redis.Do("info")
|
|
t.AssertNE(err, nil)
|
|
|
|
redis = gredis.Instance("gf")
|
|
t.Assert(redis == nil, true)
|
|
gredis.ClearConfig()
|
|
|
|
redis = gredis.New(config)
|
|
defer redis.Close()
|
|
_, err = redis.DoVar("SET", "k", "v")
|
|
t.Assert(err, nil)
|
|
|
|
v, err := redis.DoVar("GET", "k")
|
|
t.Assert(err, nil)
|
|
t.Assert(v.String(), "v")
|
|
|
|
conn := redis.Conn()
|
|
defer conn.Close()
|
|
_, err = conn.DoVar("SET", "k", "v")
|
|
t.Assert(err, nil)
|
|
|
|
_, err = conn.DoVar("Subscribe", "gf")
|
|
t.Assert(err, nil)
|
|
|
|
_, err = redis.DoVar("PUBLISH", "gf", "test")
|
|
t.Assert(err, nil)
|
|
|
|
v, _ = conn.ReceiveVar()
|
|
t.Assert(len(v.Strings()), 3)
|
|
t.Assert(v.Strings()[2], "test")
|
|
|
|
time.Sleep(time.Second)
|
|
})
|
|
}
|
|
|
|
func Test_Bool(t *testing.T) {
|
|
gtest.C(t, func(t *gtest.T) {
|
|
redis := gredis.New(config)
|
|
defer func() {
|
|
redis.Do("DEL", "key-true")
|
|
redis.Do("DEL", "key-false")
|
|
}()
|
|
|
|
_, err := redis.Do("SET", "key-true", true)
|
|
t.Assert(err, nil)
|
|
|
|
_, err = redis.Do("SET", "key-false", false)
|
|
t.Assert(err, nil)
|
|
|
|
r, err := redis.DoVar("GET", "key-true")
|
|
t.Assert(err, nil)
|
|
t.Assert(r.Bool(), true)
|
|
|
|
r, err = redis.DoVar("GET", "key-false")
|
|
t.Assert(err, nil)
|
|
t.Assert(r.Bool(), false)
|
|
})
|
|
}
|
|
|
|
func Test_Int(t *testing.T) {
|
|
gtest.C(t, func(t *gtest.T) {
|
|
redis := gredis.New(config)
|
|
key := guid.S()
|
|
defer redis.Do("DEL", key)
|
|
|
|
_, err := redis.Do("SET", key, 1)
|
|
t.Assert(err, nil)
|
|
|
|
r, err := redis.DoVar("GET", key)
|
|
t.Assert(err, nil)
|
|
t.Assert(r.Int(), 1)
|
|
})
|
|
}
|
|
|
|
func Test_HSet(t *testing.T) {
|
|
gtest.C(t, func(t *gtest.T) {
|
|
redis := gredis.New(config)
|
|
key := guid.S()
|
|
defer redis.Do("DEL", key)
|
|
|
|
_, err := redis.Do("HSET", key, "name", "john")
|
|
t.Assert(err, nil)
|
|
|
|
r, err := redis.DoVar("HGETALL", key)
|
|
t.Assert(err, nil)
|
|
t.Assert(r.Strings(), g.ArrayStr{"name", "john"})
|
|
})
|
|
}
|
|
|
|
func Test_HGetAll1(t *testing.T) {
|
|
gtest.C(t, func(t *gtest.T) {
|
|
var err error
|
|
redis := gredis.New(config)
|
|
key := guid.S()
|
|
defer redis.Do("DEL", key)
|
|
|
|
_, err = redis.Do("HSET", key, "id", 100)
|
|
t.Assert(err, nil)
|
|
_, err = redis.Do("HSET", key, "name", "john")
|
|
t.Assert(err, nil)
|
|
|
|
r, err := redis.DoVar("HGETALL", key)
|
|
t.Assert(err, nil)
|
|
t.Assert(r.Map(), g.MapStrAny{
|
|
"id": 100,
|
|
"name": "john",
|
|
})
|
|
})
|
|
}
|
|
|
|
func Test_HGetAll2(t *testing.T) {
|
|
gtest.C(t, func(t *gtest.T) {
|
|
var (
|
|
err error
|
|
key = guid.S()
|
|
redis = gredis.New(config)
|
|
)
|
|
defer redis.Do("DEL", key)
|
|
|
|
_, err = redis.Do("HSET", key, "id", 100)
|
|
t.Assert(err, nil)
|
|
_, err = redis.Do("HSET", key, "name", "john")
|
|
t.Assert(err, nil)
|
|
|
|
result, err := redis.DoVar("HGETALL", key)
|
|
t.Assert(err, nil)
|
|
|
|
t.Assert(gconv.Uint(result.MapStrVar()["id"]), 100)
|
|
t.Assert(result.MapStrVar()["id"].Uint(), 100)
|
|
})
|
|
}
|
|
|
|
func Test_Auto_Marshal(t *testing.T) {
|
|
var (
|
|
err error
|
|
redis = gredis.New(config)
|
|
key = guid.S()
|
|
)
|
|
defer redis.Do("DEL", key)
|
|
|
|
type User struct {
|
|
Id int
|
|
Name string
|
|
}
|
|
|
|
gtest.C(t, func(t *gtest.T) {
|
|
user := &User{
|
|
Id: 10000,
|
|
Name: "john",
|
|
}
|
|
|
|
_, err = redis.Do("SET", key, user)
|
|
t.Assert(err, nil)
|
|
|
|
r, err := redis.DoVar("GET", key)
|
|
t.Assert(err, nil)
|
|
t.Assert(r.Map(), g.MapStrAny{
|
|
"Id": user.Id,
|
|
"Name": user.Name,
|
|
})
|
|
|
|
var user2 *User
|
|
t.Assert(r.Struct(&user2), nil)
|
|
t.Assert(user2.Id, user.Id)
|
|
t.Assert(user2.Name, user.Name)
|
|
})
|
|
}
|
|
|
|
func Test_Auto_MarshalSlice(t *testing.T) {
|
|
var (
|
|
err error
|
|
redis = gredis.New(config)
|
|
key = guid.S()
|
|
)
|
|
defer redis.Do("DEL", key)
|
|
|
|
type User struct {
|
|
Id int
|
|
Name string
|
|
}
|
|
|
|
gtest.C(t, func(t *gtest.T) {
|
|
var (
|
|
result *gvar.Var
|
|
key = "user-slice"
|
|
users1 = []User{
|
|
{
|
|
Id: 1,
|
|
Name: "john1",
|
|
},
|
|
{
|
|
Id: 2,
|
|
Name: "john2",
|
|
},
|
|
}
|
|
)
|
|
|
|
_, err = redis.Do("SET", key, users1)
|
|
t.Assert(err, nil)
|
|
|
|
result, err = redis.DoVar("GET", key)
|
|
t.Assert(err, nil)
|
|
|
|
var users2 []User
|
|
err = result.Structs(&users2)
|
|
t.Assert(err, nil)
|
|
t.Assert(users2, users1)
|
|
})
|
|
}
|