ledisdb/ledis/t_list_test.go

182 lines
3.2 KiB
Go

package ledis
import (
"fmt"
"sync"
"testing"
"time"
)
func TestListCodec(t *testing.T) {
db := getTestDB()
key := []byte("key")
ek := db.lEncodeMetaKey(key)
if k, err := db.lDecodeMetaKey(ek); err != nil {
t.Fatal(err)
} else if string(k) != "key" {
t.Fatal(string(k))
}
ek = db.lEncodeListKey(key, 1024)
if k, seq, err := db.lDecodeListKey(ek); err != nil {
t.Fatal(err)
} else if string(k) != "key" {
t.Fatal(string(k))
} else if seq != 1024 {
t.Fatal(seq)
}
}
func TestDBList(t *testing.T) {
db := getTestDB()
key := []byte("testdb_list_a")
if n, err := db.RPush(key, []byte("1"), []byte("2"), []byte("3")); err != nil {
t.Fatal(err)
} else if n != 3 {
t.Fatal(n)
}
if ay, err := db.LRange(key, 0, -1); err != nil {
t.Fatal(err)
} else if len(ay) != 3 {
t.Fatal(len(ay))
} else {
for i := range ay {
if ay[i][0] != '1'+byte(i) {
t.Fatal(string(ay[i]))
}
}
}
if k, err := db.RPop(key); err != nil {
t.Fatal(err)
} else if string(k) != "3" {
t.Fatal(string(k))
}
if k, err := db.LPop(key); err != nil {
t.Fatal(err)
} else if string(k) != "1" {
t.Fatal(string(k))
}
if llen, err := db.LLen(key); err != nil {
t.Fatal(err)
} else if llen != 1 {
t.Fatal(llen)
}
if num, err := db.LClear(key); err != nil {
t.Fatal(err)
} else if num != 1 {
t.Fatal(num)
}
if llen, _ := db.LLen(key); llen != 0 {
t.Fatal(llen)
}
}
func TestListPersist(t *testing.T) {
db := getTestDB()
key := []byte("persist")
db.LPush(key, []byte("a"))
if n, err := db.LPersist(key); err != nil {
t.Fatal(err)
} else if n != 0 {
t.Fatal(n)
}
if _, err := db.LExpire(key, 10); err != nil {
t.Fatal(err)
}
if n, err := db.LPersist(key); err != nil {
t.Fatal(err)
} else if n != 1 {
t.Fatal(n)
}
}
func TestLBlock(t *testing.T) {
db := getTestDB()
key1 := []byte("test_lblock_key1")
key2 := []byte("test_lblock_key2")
var wg sync.WaitGroup
wg.Add(2)
f := func(i int) {
defer wg.Done()
ay, err := db.BLPop([][]byte{key1, key2}, 0)
if err != nil {
t.Fatal(err)
} else if len(ay) != 2 {
t.Fatal(len(ay))
}
}
go f(1)
go f(2)
time.Sleep(100 * time.Millisecond)
db.LPush(key1, []byte("value"))
db.LPush(key2, []byte("value"))
wg.Wait()
}
func TestLFlush(t *testing.T) {
db := getTestDB()
db.FlushAll()
for i := 0; i < 2000; i++ {
key := fmt.Sprintf("%d", i)
if _, err := db.LPush([]byte(key), []byte("v")); err != nil {
t.Fatal(err.Error())
}
}
if v, err := db.LScan(nil, 3000, true, ""); err != nil {
t.Fatal(err.Error())
} else if len(v) != 2000 {
t.Fatal("invalid value ", len(v))
}
if n, err := db.lFlush(); err != nil {
t.Fatal(err.Error())
} else if n != 2000 {
t.Fatal("invalid value ", n)
}
if v, err := db.LScan(nil, 3000, true, ""); err != nil {
t.Fatal(err.Error())
} else if len(v) != 0 {
t.Fatal("invalid value length ", len(v))
}
}
func TestXLExists(t *testing.T) {
db := getTestDB()
key := []byte("xlexists_test")
if n, err := db.XLExists(key); err != nil {
t.Fatal(err.Error())
} else if n != 0 {
t.Fatal("invalid value ", n)
}
db.LPush(key, []byte("hello"), []byte("world"))
if n, err := db.XLExists(key); err != nil {
t.Fatal(err.Error())
} else if n != 1 {
t.Fatal("invalid value ", n)
}
}