ledisdb/ledis/t_hash_test.go

125 lines
2.4 KiB
Go
Raw Normal View History

2014-05-16 06:36:18 +04:00
package ledis
import (
"testing"
)
2014-05-20 04:41:24 +04:00
func TestHashCodec(t *testing.T) {
db := getTestDB()
key := []byte("key")
field := []byte("field")
ek := db.hEncodeSizeKey(key)
if k, err := db.hDecodeSizeKey(ek); err != nil {
t.Fatal(err)
} else if string(k) != "key" {
t.Fatal(string(k))
}
ek = db.hEncodeHashKey(key, field)
if k, f, err := db.hDecodeHashKey(ek); err != nil {
t.Fatal(err)
} else if string(k) != "key" {
t.Fatal(string(k))
} else if string(f) != "field" {
t.Fatal(string(f))
}
}
2014-05-16 06:36:18 +04:00
func TestDBHash(t *testing.T) {
db := getTestDB()
key := []byte("testdb_hash_a")
2014-06-19 13:19:40 +04:00
if n, err := db.HSet(key, []byte("a"), []byte("hello world 1")); err != nil {
2014-05-16 06:36:18 +04:00
t.Fatal(err)
} else if n != 1 {
t.Fatal(n)
}
2014-06-19 13:19:40 +04:00
if n, err := db.HSet(key, []byte("b"), []byte("hello world 2")); err != nil {
t.Fatal(err)
} else if n != 1 {
t.Fatal(n)
}
ay, _ := db.HMget(key, []byte("a"), []byte("b"))
if v1 := ay[0]; string(v1) != "hello world 1" {
2014-06-19 13:19:40 +04:00
t.Fatal(string(v1))
}
if v2 := ay[1]; string(v2) != "hello world 2" {
2014-06-19 13:19:40 +04:00
t.Fatal(string(v2))
}
2014-05-16 06:36:18 +04:00
}
2014-05-26 05:21:17 +04:00
func TestDBHScan(t *testing.T) {
db := getTestDB()
db.hFlush()
2014-05-26 05:21:17 +04:00
2014-08-14 07:23:40 +04:00
k1 := []byte("k1")
db.HSet(k1, []byte("1"), []byte{})
2014-05-26 05:21:17 +04:00
2014-08-14 07:23:40 +04:00
k2 := []byte("k2")
db.HSet(k2, []byte("2"), []byte{})
k3 := []byte("k3")
db.HSet(k3, []byte("3"), []byte{})
if v, err := db.HScan(nil, 1, true); err != nil {
2014-05-26 05:21:17 +04:00
t.Fatal(err)
} else if len(v) != 1 {
2014-08-14 07:23:40 +04:00
t.Fatal("invalid length ", len(v))
} else if string(v[0]) != "k1" {
t.Fatal("invalid value ", string(v[0]))
2014-05-26 05:21:17 +04:00
}
2014-08-14 07:23:40 +04:00
if v, err := db.HScan(k1, 2, true); err != nil {
2014-05-26 05:21:17 +04:00
t.Fatal(err)
} else if len(v) != 2 {
2014-08-14 07:23:40 +04:00
t.Fatal("invalid length ", len(v))
} else if string(v[0]) != "k1" {
t.Fatal("invalid value ", string(v[0]))
} else if string(v[1]) != "k2" {
t.Fatal("invalid value ", string(v[1]))
2014-05-26 05:21:17 +04:00
}
2014-08-14 07:23:40 +04:00
if v, err := db.HScan(k1, 2, false); err != nil {
2014-05-26 05:21:17 +04:00
t.Fatal(err)
2014-08-14 07:23:40 +04:00
} else if len(v) != 2 {
t.Fatal("invalid length ", len(v))
} else if string(v[0]) != "k2" {
t.Fatal("invalid value ", string(v[0]))
} else if string(v[1]) != "k3" {
t.Fatal("invalid value ", string(v[1]))
2014-05-26 05:21:17 +04:00
}
2014-08-14 07:23:40 +04:00
2014-06-23 07:12:20 +04:00
}
func TestHashPersist(t *testing.T) {
db := getTestDB()
key := []byte("persist")
db.HSet(key, []byte("field"), []byte{})
if n, err := db.HPersist(key); err != nil {
t.Fatal(err)
} else if n != 0 {
t.Fatal(n)
}
2014-05-26 05:21:17 +04:00
2014-06-23 07:12:20 +04:00
if _, err := db.HExpire(key, 10); err != nil {
t.Fatal(err)
}
if n, err := db.HPersist(key); err != nil {
t.Fatal(err)
} else if n != 1 {
t.Fatal(n)
}
2014-05-26 05:21:17 +04:00
}