forked from mirror/ledisdb
134 lines
2.5 KiB
Go
134 lines
2.5 KiB
Go
package ledis
|
|
|
|
import (
|
|
"fmt"
|
|
"testing"
|
|
)
|
|
|
|
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))
|
|
}
|
|
}
|
|
|
|
func TestDBHash(t *testing.T) {
|
|
db := getTestDB()
|
|
|
|
key := []byte("testdb_hash_a")
|
|
|
|
if n, err := db.HSet(key, []byte("a"), []byte("hello world 1")); err != nil {
|
|
t.Fatal(err)
|
|
} else if n != 1 {
|
|
t.Fatal(n)
|
|
}
|
|
|
|
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" {
|
|
t.Fatal(string(v1))
|
|
}
|
|
|
|
if v2 := ay[1]; string(v2) != "hello world 2" {
|
|
t.Fatal(string(v2))
|
|
}
|
|
|
|
}
|
|
|
|
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)
|
|
}
|
|
|
|
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)
|
|
}
|
|
}
|
|
|
|
func TestHFlush(t *testing.T) {
|
|
db := getTestDB()
|
|
db.FlushAll()
|
|
|
|
for i := 0; i < 2000; i++ {
|
|
key := fmt.Sprintf("%d", i)
|
|
if _, err := db.HSet([]byte(key), []byte("f"), []byte("v")); err != nil {
|
|
t.Fatal(err.Error())
|
|
}
|
|
}
|
|
|
|
if v, err := db.HScan(nil, 3000, true); err != nil {
|
|
t.Fatal(err.Error())
|
|
} else if len(v) != 2000 {
|
|
t.Fatal("invalid value ", len(v))
|
|
}
|
|
|
|
for i := 0; i < 2000; i++ {
|
|
key := fmt.Sprintf("%d", i)
|
|
if v, err := db.HGet([]byte(key), []byte("f")); err != nil {
|
|
t.Fatal(err.Error())
|
|
} else if string(v) != "v" {
|
|
t.Fatal("invalid value ", v)
|
|
}
|
|
}
|
|
|
|
if n, err := db.hFlush(); err != nil {
|
|
t.Fatal(err.Error())
|
|
} else if n != 2000 {
|
|
t.Fatal("invalid value ", n)
|
|
}
|
|
|
|
if v, err := db.HScan(nil, 3000, true); err != nil {
|
|
t.Fatal(err.Error())
|
|
} else if len(v) != 0 {
|
|
t.Fatal("invalid value length ", len(v))
|
|
}
|
|
|
|
for i := 0; i < 2000; i++ {
|
|
|
|
key := []byte(fmt.Sprintf("%d", i))
|
|
|
|
if v, err := db.HGet(key, []byte("f")); err != nil {
|
|
t.Fatal(err.Error())
|
|
} else if v != nil {
|
|
|
|
t.Fatal("invalid value ", v)
|
|
}
|
|
}
|
|
|
|
}
|